Changeset 35409 in osm for applications/editors/josm


Ignore:
Timestamp:
2020-04-04T07:40:00+02:00 (5 years ago)
Author:
gerdp
Message:

see #19028: Plugin reverter uses a more recent API that minimal requested

  • revert temp. changes done in o35407 and increase main version
Location:
applications/editors/josm/plugins/reverter
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • applications/editors/josm/plugins/reverter/build.xml

    r35226 r35409  
    44    <property name="commit.message" value="Reverter: fix deleted/redacted relation members"/>
    55    <!-- enter the *lowest* JOSM version this plugin is currently compatible with -->
    6     <property name="plugin.main.version" value="15520"/>
     6    <property name="plugin.main.version" value="16205"/>
    77
    88    <!-- Configure these properties (replace "..." accordingly).
  • applications/editors/josm/plugins/reverter/src/reverter/DataSetCommandMerger.java

    r35407 r35409  
    5353
    5454    private void addChangeCommandIfNotEquals(OsmPrimitive target, OsmPrimitive newTarget, boolean nominal) {
    55         if (target.isIncomplete() != newTarget.isIncomplete() || target.isDeleted() != newTarget.isDeleted()
    56                 || target.isVisible() != newTarget.isVisible()
    57                 || !getNonDiscardableTags(target).equals(getNonDiscardableTags(newTarget))) {
     55                if (!target.hasEqualSemanticAttributes(newTarget) || target.isDeleted() != newTarget.isDeleted()
     56                                || target.isVisible() != newTarget.isVisible()
     57                                || !getNonDiscardableTags(target).equals(getNonDiscardableTags(newTarget))) {
    5858            cmds.add(new ChangeCommand(target, newTarget));
    5959            if (nominal) {
  • applications/editors/josm/plugins/reverter/src/reverter/RevertChangesetCommand.java

    r35407 r35409  
    1919     * Create the command by specifying the list of commands to execute.
    2020     * @param name The description text
    21      * @param sequenz The sequence that should be executed.
     21     * @param sequenz The sequence that was already executed.
    2222     */
    2323    public RevertChangesetCommand(String name, Collection<Command> sequenz) {
    2424        super(name, sequenz);
    2525        ReverterPlugin.reverterUsed = true;
     26        setSequenceComplete(true);
    2627    }
    2728
     
    3637    }
    3738
     39    @Override
     40    public void undoCommand() {
     41        getAffectedDataSet().update(super::undoCommand);
     42    }
     43
     44    @Override
     45    public boolean executeCommand() {
     46        return getAffectedDataSet().update(super::executeCommand);
     47    }
     48
    3849}
  • applications/editors/josm/plugins/reverter/src/reverter/RevertChangesetTask.java

    r35407 r35409  
    1515
    1616import org.openstreetmap.josm.command.Command;
    17 import org.openstreetmap.josm.command.SequenceCommand;
    1817import org.openstreetmap.josm.command.conflict.ConflictAddCommand;
    1918import org.openstreetmap.josm.data.UndoRedoHandler;
     
    9998                newLayer = false; // reuse layer for subsequent reverts
    10099            } catch (OsmTransferException e) {
    101                 Logging.error(e);
     100                                if (!allcmds.isEmpty()) {
     101                                        GuiHelper.runInEDT(() -> UndoRedoHandler.getInstance().undo(allcmds.size()));
     102                                }
     103                                Logging.error(e);
    102104                throw e;
    103105            } catch (UserCancelException e) {
     106                                if (!allcmds.isEmpty()) {
     107                                        GuiHelper.runInEDT(() -> UndoRedoHandler.getInstance().undo(allcmds.size()));
     108                                }
    104109                Logging.warn("Revert canceled");
    105110                Logging.trace(e);
     
    108113        }
    109114        if (!allcmds.isEmpty()) {
    110             Command cmd = allcmds.size() == 1 ? allcmds.get(0) : new SequenceCommand(tr("Revert changesets"), allcmds);
     115            Command cmd = allcmds.size() == 1 ? allcmds.get(0) : new RevertChangesetCommand(tr("Revert changesets"), allcmds);
    111116            GuiHelper.runInEDT(() -> {
    112                 UndoRedoHandler.getInstance().add(cmd);
     117                UndoRedoHandler.getInstance().add(cmd, false);
    113118                if (numberOfConflicts > 0) {
    114119                    MainApplication.getMap().conflictDialog.warnNumNewConflicts(numberOfConflicts);
     
    169174                numberOfConflicts++;
    170175            }
     176            c.executeCommand();
    171177        }
    172178        final String desc;
Note: See TracChangeset for help on using the changeset viewer.