Skip to content

Commit

Permalink
Merge branch 'code_smells'
Browse files Browse the repository at this point in the history
  • Loading branch information
simonpoole committed Dec 4, 2024
2 parents 8c6b256 + 7e95bae commit 71c1120
Showing 1 changed file with 113 additions and 110 deletions.
223 changes: 113 additions & 110 deletions src/main/java/de/blau/android/Logic.java
Original file line number Diff line number Diff line change
Expand Up @@ -2218,7 +2218,7 @@ public synchronized List<Result> performExtractSegment(@Nullable FragmentActivit
* @param results a list of Result
*/
private void checkForArea(@Nullable FragmentActivity activity, @NonNull Way way, @NonNull List<Result> results) {
if (way.hasTag(Tags.KEY_AREA, Tags.VALUE_YES) || ( activity != null && App.getAreaTags(activity).isImpliedArea(way.getTags()))) {
if (way.hasTag(Tags.KEY_AREA, Tags.VALUE_YES) || (activity != null && App.getAreaTags(activity).isImpliedArea(way.getTags()))) {
results.get(0).addIssue(SplitIssue.SPLIT_AREA);
}
}
Expand Down Expand Up @@ -3860,18 +3860,16 @@ protected AsyncResult doInBackground(Boolean arg) {
osmParser.clearBoundingBoxes(); // this removes the default bounding box
try (final InputStream in = new BufferedInputStream(is)) {
osmParser.start(in);
StorageDelegator sd = getDelegator();
sd.reset(false);
sd.setCurrentStorage(osmParser.getStorage()); // this sets dirty flag
sd.fixupApiStorage();
if (!add && sd.getBoundingBoxes().isEmpty()) {
// ensure a valid bounding box
sd.addBoundingBox(sd.getCurrentStorage().calcBoundingBoxFromData());
}
if (map != null) {
viewBox.fitToBoundingBox(map, sd.getLastBox()); // set to current or previous
}
}
StorageDelegator sd = getDelegator();
sd.reset(false);
sd.setCurrentStorage(osmParser.getStorage()); // this sets dirty flag
sd.fixupApiStorage();
if (!add && sd.getBoundingBoxes().isEmpty()) {
// ensure a valid bounding box
sd.addBoundingBox(sd.getCurrentStorage().calcBoundingBoxFromData());
}
fitToBoundingBox(sd);
} catch (SAXException e) {
Log.e(DEBUG_TAG, "Problem parsing ", e);
Exception ce = e.getException();
Expand All @@ -3893,6 +3891,17 @@ protected AsyncResult doInBackground(Boolean arg) {
}.execute(add);
}

/**
* Set the current ViewBox to the last BoundingBox held by the StorageDelegator
*
* @param sd the StorageDelegator
*/
private void fitToBoundingBox(StorageDelegator sd) {
if (map != null) {
viewBox.fitToBoundingBox(map, sd.getLastBox()); // set to current or previous
}
}

/**
* Write data to a file in (J)OSM compatible format, if fileName contains directories these are created, otherwise
* it is stored in the standard public dir
Expand All @@ -3902,10 +3911,9 @@ protected AsyncResult doInBackground(Boolean arg) {
* @param postSaveHandler if not null executes code after saving
*/
public void writeOsmFile(@NonNull final FragmentActivity activity, @NonNull final String fileName, @Nullable final PostAsyncActionHandler postSaveHandler) {
try {
File outfile = FileUtil.openFileForWriting(activity, fileName);
Log.d(DEBUG_TAG, "Saving to " + outfile.getPath());
writeOsmFile(activity, new FileOutputStream(outfile), postSaveHandler);
try (OutputStream os = new FileOutputStream(FileUtil.openFileForWriting(activity, fileName))) {
Log.d(DEBUG_TAG, "Saving to " + fileName);
writeOsmFile(activity, os, postSaveHandler);
} catch (IOException e) {
if (!activity.isFinishing()) {
ErrorAlert.showDialog(activity, ErrorCodes.FILE_WRITE_FAILED);
Expand All @@ -3924,8 +3932,8 @@ public void writeOsmFile(@NonNull final FragmentActivity activity, @NonNull fina
* @param postSaveHandler if not null executes code after saving
*/
public void writeOsmFile(@NonNull final FragmentActivity activity, @NonNull final Uri uri, @Nullable final PostAsyncActionHandler postSaveHandler) {
try {
writeOsmFile(activity, activity.getContentResolver().openOutputStream(uri, FileUtil.TRUNCATE_WRITE_MODE), postSaveHandler);
try (OutputStream os = activity.getContentResolver().openOutputStream(uri, FileUtil.TRUNCATE_WRITE_MODE)) {
writeOsmFile(activity, os, postSaveHandler);
} catch (IOException e) {
if (!activity.isFinishing()) {
ErrorAlert.showDialog(activity, ErrorCodes.FILE_WRITE_FAILED);
Expand Down Expand Up @@ -3961,8 +3969,6 @@ protected Integer doInBackground(Void arg) {
} catch (IllegalArgumentException | IllegalStateException | XmlPullParserException | IOException e) {
result = ErrorCodes.FILE_WRITE_FAILED;
Log.e(DEBUG_TAG, "Problem writing", e);
} finally {
SavingHelper.close(fout);
}
return result;
}
Expand Down Expand Up @@ -4007,8 +4013,11 @@ protected void onPostExecute(Integer result) {
* @throws FileNotFoundException when the selected file could not be found
*/
public void readPbfFile(@NonNull final FragmentActivity activity, @NonNull Uri uri, boolean add) throws FileNotFoundException {
final InputStream is = activity.getContentResolver().openInputStream(uri);
readPbfFile(activity, is, add, null);
try (final InputStream is = activity.getContentResolver().openInputStream(uri)) {
readPbfFile(activity, is, add, null);
} catch (IOException e) {
Log.e(DEBUG_TAG, "Problem closing PBF " + e.getMessage());
}
}

/**
Expand All @@ -4029,19 +4038,13 @@ protected AsyncResult doInBackground(Boolean arg) {
synchronized (Logic.this) {
try {
Storage storage = new Storage();
try {
BlockReaderAdapter opp = new OsmPbfParser(storage);
new BlockInputStream(is, opp).process();
StorageDelegator sd = getDelegator();
sd.reset(false);
sd.setCurrentStorage(storage); // this sets dirty flag
sd.fixupApiStorage();
if (map != null) {
viewBox.fitToBoundingBox(map, sd.getLastBox()); // set to current or previous
}
} finally {
SavingHelper.close(is);
}
BlockReaderAdapter opp = new OsmPbfParser(storage);
new BlockInputStream(is, opp).process();
StorageDelegator sd = getDelegator();
sd.reset(false);
sd.setCurrentStorage(storage); // this sets dirty flag
sd.fixupApiStorage();
fitToBoundingBox(sd);
} catch (StorageException sex) {
Log.e(DEBUG_TAG, "Problem reading PBF " + sex.getMessage());
return new AsyncResult(ErrorCodes.OUT_OF_MEMORY, sex.getMessage());
Expand Down Expand Up @@ -4084,9 +4087,7 @@ protected AsyncResult doInBackground(Boolean arg) {
removeCheckpoint((FragmentActivity) context, R.string.undo_action_apply_osc, true);
return new AsyncResult(ErrorCodes.APPLYING_OSC_FAILED);
}
if (map != null) {
viewBox.fitToBoundingBox(map, sd.getLastBox()); // set to current or previous
}
fitToBoundingBox(sd);
// support for OSMAND extension
List<Note> notes = oscParser.getNotes();
if (!notes.isEmpty()) {
Expand Down Expand Up @@ -4251,18 +4252,7 @@ protected void onPostExecute(Integer result) {
}
Log.d(DEBUG_TAG, "loadfromFile: File read correctly");
if (mainMap != null) {
try {
viewBox.setRatio(mainMap, (float) mainMap.getWidth() / (float) mainMap.getHeight());
} catch (Exception e) {
// invalid dimensions or similar error
viewBox.setBorders(mainMap, new BoundingBox(-GeoMath.MAX_LON, -GeoMath.MAX_COMPAT_LAT, GeoMath.MAX_LON, GeoMath.MAX_COMPAT_LAT));
}
mainMap.getDataStyle().updateStrokes(STROKE_FACTOR / viewBox.getWidth()); // safety measure if not
// done in
// loadEiditngState
synchronized (Logic.this) {
loadEditingState((Main) activity, true);
}
setupMapAndViewBox(activity, mainMap);
} else {
Log.e(DEBUG_TAG, "loadFromFile map is null");
}
Expand Down Expand Up @@ -4417,14 +4407,7 @@ public void syncLoadFromFile(@NonNull FragmentActivity activity) {
if (result != READ_FAILED) {
Log.d(DEBUG_TAG, "syncLoadfromFile: File read correctly");
if (hasMap) {
try {
viewBox.setRatio(mainMap, (float) mainMap.getWidth() / (float) mainMap.getHeight());
} catch (Exception e) {
// invalid dimensions or similar error
viewBox.setBorders(mainMap, new BoundingBox(-180.0, -GeoMath.MAX_COMPAT_LAT, 180.0, GeoMath.MAX_COMPAT_LAT));
}
mainMap.getDataStyle().updateStrokes(STROKE_FACTOR / viewBox.getWidth());
loadEditingState((Main) activity, true);
setupMapAndViewBox(activity, mainMap);
invalidateMap();
}
activity.invalidateOptionsMenu();
Expand All @@ -4434,6 +4417,25 @@ public void syncLoadFromFile(@NonNull FragmentActivity activity) {
}
}

/**
* Setup ViewBox and Map post loading data
*
* @param activity the current Activity
* @param mainMap the Map instance
*/
private void setupMapAndViewBox(@NonNull FragmentActivity activity, @NonNull Map mainMap) {
try {
viewBox.setRatio(mainMap, (float) mainMap.getWidth() / (float) mainMap.getHeight());
} catch (Exception e) {
// invalid dimensions or similar error
viewBox.setBorders(mainMap, new BoundingBox(-GeoMath.MAX_LON, -GeoMath.MAX_COMPAT_LAT, GeoMath.MAX_LON, GeoMath.MAX_COMPAT_LAT));
}
mainMap.getDataStyle().updateStrokes(STROKE_FACTOR / viewBox.getWidth());
synchronized (Logic.this) {
loadEditingState((Main) activity, true);
}
}

/**
* Uploads to the server in the background.
*
Expand Down Expand Up @@ -4526,60 +4528,61 @@ protected void onPostExecute(UploadResult result) {
postUploadHandler.onSuccess();
}
}
if (!activity.isFinishing()) {
switch (error) {
case ErrorCodes.UPLOAD_CONFLICT:
Conflict conflict = ApiResponse.parseConflictResponse(result.getHttpError(), result.getMessage());
if (conflict instanceof ApiResponse.ClosedChangesetConflict) {
// this can really only happen if the changeset is closed between when we check for an
// open one and we starting the upload
ScreenMessage.toastTopWarning(activity, R.string.upload_conflict_message_changeset_closed);
this.execute(); // restart new changeset will be opened automatically
return;
} else if (conflict instanceof ApiResponse.BoundingBoxTooLargeError) {
if (!closeOpenChangeset) {
// we've potentially already uploaded something, so don't reuse this changeset
server.resetChangeset();
}
ErrorAlert.showDialog(activity, ErrorCodes.UPLOAD_BOUNDING_BOX_TOO_LARGE, result.getMessage());
} else if (conflict instanceof ApiResponse.ChangesetLocked) {
ErrorAlert.showDialog(activity, ErrorCodes.UPLOAD_PROBLEM, result.getMessage());
} else {
UploadConflict.showDialog(activity, conflict, elements);
if (activity.isFinishing()) {
return;
}
switch (error) {
case ErrorCodes.UPLOAD_CONFLICT:
Conflict conflict = ApiResponse.parseConflictResponse(result.getHttpError(), result.getMessage());
if (conflict instanceof ApiResponse.ClosedChangesetConflict) {
// this can really only happen if the changeset is closed between when we check for an
// open one and we starting the upload
ScreenMessage.toastTopWarning(activity, R.string.upload_conflict_message_changeset_closed);
this.execute(); // restart new changeset will be opened automatically
return;
} else if (conflict instanceof ApiResponse.BoundingBoxTooLargeError) {
if (!closeOpenChangeset) {
// we've potentially already uploaded something, so don't reuse this changeset
server.resetChangeset();
}
break;
case ErrorCodes.INVALID_LOGIN:
InvalidLogin.showDialog(activity);
break;
case ErrorCodes.FORBIDDEN:
ForbiddenLogin.showDialog(activity, result.getMessage());
break;
case ErrorCodes.BAD_REQUEST:
case ErrorCodes.NOT_FOUND:
case ErrorCodes.UNKNOWN_ERROR:
case ErrorCodes.UPLOAD_PROBLEM:
case ErrorCodes.UPLOAD_LIMIT_EXCEEDED:
ErrorAlert.showDialog(activity, error, result.getMessage());
break;
case ErrorCodes.ALREADY_DELETED:
conflict = ApiResponse.parseConflictResponse(result.getHttpError(), result.getMessage());
if (conflict instanceof ApiResponse.AlreadyDeletedConflict) {
final OsmElement deletedElement = delegator.getOsmElement(conflict.getElementType(), conflict.getElementId());
delegator.removeFromUpload(deletedElement, OsmElement.STATE_DELETED);
if (elements != null) {
elements.remove(deletedElement);
}
ScreenMessage.toastTopWarning(activity,
activity.getString(R.string.upload_conflict_message_already_deleted, deletedElement.getDescription(true)));
this.execute(); // restart
return;
} // NOSONAR fall through
default:
ErrorAlert.showDialog(activity, error);
}
if (postUploadHandler != null) {
postUploadHandler.onError(null);
ErrorAlert.showDialog(activity, ErrorCodes.UPLOAD_BOUNDING_BOX_TOO_LARGE, result.getMessage());
} else if (conflict instanceof ApiResponse.ChangesetLocked) {
ErrorAlert.showDialog(activity, ErrorCodes.UPLOAD_PROBLEM, result.getMessage());
} else {
UploadConflict.showDialog(activity, conflict, elements);
}
break;
case ErrorCodes.INVALID_LOGIN:
InvalidLogin.showDialog(activity);
break;
case ErrorCodes.FORBIDDEN:
ForbiddenLogin.showDialog(activity, result.getMessage());
break;
case ErrorCodes.BAD_REQUEST:
case ErrorCodes.NOT_FOUND:
case ErrorCodes.UNKNOWN_ERROR:
case ErrorCodes.UPLOAD_PROBLEM:
case ErrorCodes.UPLOAD_LIMIT_EXCEEDED:
ErrorAlert.showDialog(activity, error, result.getMessage());
break;
case ErrorCodes.ALREADY_DELETED:
conflict = ApiResponse.parseConflictResponse(result.getHttpError(), result.getMessage());
if (conflict instanceof ApiResponse.AlreadyDeletedConflict) {
final OsmElement deletedElement = delegator.getOsmElement(conflict.getElementType(), conflict.getElementId());
delegator.removeFromUpload(deletedElement, OsmElement.STATE_DELETED);
if (elements != null) {
elements.remove(deletedElement);
}
ScreenMessage.toastTopWarning(activity,
activity.getString(R.string.upload_conflict_message_already_deleted, deletedElement.getDescription(true)));
this.execute(); // restart
return;
} // NOSONAR fall through
default:
ErrorAlert.showDialog(activity, error);
}
if (postUploadHandler != null) {
postUploadHandler.onError(null);
}
} catch (Exception ex) {
Log.e(DEBUG_TAG, "Unexpected exception in upload " + ex.getMessage());
Expand Down

0 comments on commit 71c1120

Please sign in to comment.