From f5ea667f34087b8a96a197f83026e8d8c780d72f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20T=C5=AFma?= Date: Sun, 27 Jun 2021 16:00:08 +0200 Subject: [PATCH] Improved error handling --- src/map/prjfile.cpp | 20 +++++++++++++------- src/map/prjfile.h | 3 ++- 2 files changed, 15 insertions(+), 8 deletions(-) diff --git a/src/map/prjfile.cpp b/src/map/prjfile.cpp index d256b985..7e10a129 100644 --- a/src/map/prjfile.cpp +++ b/src/map/prjfile.cpp @@ -118,7 +118,7 @@ void PRJFile::error(CTX &ctx) if (ctx.token == ERROR) return; - _errorString = "parse error"; + _errorString = QString("parse error on line: %1").arg(ctx.line); ctx.token = ERROR; } @@ -142,9 +142,11 @@ void PRJFile::nextToken(CTX &ctx) switch (state) { case 0: - if (isspace(c)) + if (isspace(c)) { + if (c == '\n') + ctx.line++; break; - if (c == '[') { + } if (c == '[') { ctx.token = LBRK; return; } @@ -522,7 +524,6 @@ void PRJFile::projectedCS(CTX &ctx, PCS *pcs) int epsg = -1; GCS gcs; LinearUnits lu; - CoordinateSystem cs(CoordinateSystem::XY); Projection::Method method; Projection::Setup setup; @@ -539,7 +540,9 @@ void PRJFile::projectedCS(CTX &ctx, PCS *pcs) optProjectedCS(ctx, &epsg); compare(ctx, RBRK); - *pcs = (epsg > 0) ? PCS::pcs(epsg) : PCS(gcs, method, setup, lu, cs); + *pcs = (epsg > 0) + ? PCS::pcs(epsg) + : PCS(gcs, method, setup, lu, CoordinateSystem()); } void PRJFile::axisType(CTX &ctx) @@ -772,6 +775,9 @@ PRJFile::PRJFile(const QString &fileName) nextToken(ctx); CS(ctx); - if (ctx.token != ERROR && !_projection.isValid()) - _errorString = "invalid/incomplete projection"; + if (ctx.token == EOI) { + if (!_projection.isValid()) + _errorString = "unknown/incomplete projection"; + } else + _projection = Projection(); } diff --git a/src/map/prjfile.h b/src/map/prjfile.h index 3118eaaa..4a117783 100644 --- a/src/map/prjfile.h +++ b/src/map/prjfile.h @@ -36,12 +36,13 @@ private: }; struct CTX { - CTX(const QString &fileName) : file(fileName), token(START) {} + CTX(const QString &fileName) : file(fileName), token(START), line(1) {} QFile file; Token token; QString string; double number; + int line; }; Token keyword(CTX &ctx);