source: josm/trunk/src/org/openstreetmap/josm/command/conflict/DeletedStateConflictResolveCommand.java@ 7509

Last change on this file since 7509 was 7509, checked in by stoecker, 10 years ago

remove tabs

  • Property svn:eol-style set to native
File size: 2.9 KB
Line 
1// License: GPL. For details, see LICENSE file.
2package org.openstreetmap.josm.command.conflict;
3
4import static org.openstreetmap.josm.tools.I18n.tr;
5
6import java.util.Collection;
7import java.util.Set;
8
9import javax.swing.Icon;
10
11import org.openstreetmap.josm.data.conflict.Conflict;
12import org.openstreetmap.josm.data.osm.OsmPrimitive;
13import org.openstreetmap.josm.gui.conflict.pair.MergeDecisionType;
14import org.openstreetmap.josm.tools.ImageProvider;
15
16/**
17 * Represents the resolution of a conflict between the deleted flag of two {@link OsmPrimitive}s.
18 * @since 1654
19 */
20public class DeletedStateConflictResolveCommand extends ConflictResolveCommand {
21
22 /** the conflict to resolve */
23 private Conflict<? extends OsmPrimitive> conflict;
24
25 /** the merge decision */
26 private final MergeDecisionType decision;
27
28 /**
29 * Constructs a new {@code DeletedStateConflictResolveCommand}.
30 *
31 * @param conflict the conflict data set
32 * @param decision the merge decision
33 */
34 public DeletedStateConflictResolveCommand(Conflict<? extends OsmPrimitive> conflict, MergeDecisionType decision) {
35 this.conflict = conflict;
36 this.decision = decision;
37 }
38
39 @Override
40 public String getDescriptionText() {
41 return tr("Resolve conflicts in deleted state in {0}", conflict.getMy().getId());
42 }
43
44 @Override
45 public Icon getDescriptionIcon() {
46 return ImageProvider.get("data", "object");
47 }
48
49 @Override
50 public boolean executeCommand() {
51 // remember the current state of modified primitives, i.e. of OSM primitive 'my'
52 super.executeCommand();
53
54 if (decision.equals(MergeDecisionType.KEEP_MINE)) {
55 if (conflict.getMy().isDeleted() || conflict.isMyDeleted()) {
56 // because my was involved in a conflict it my still be referred
57 // to from a way or a relation. Fix this now.
58 deleteMy();
59 }
60 } else if (decision.equals(MergeDecisionType.KEEP_THEIR)) {
61 if (conflict.getTheir().isDeleted()) {
62 deleteMy();
63 } else {
64 conflict.getMy().setDeleted(false);
65 }
66 } else
67 // should not happen
68 throw new IllegalStateException(tr("Cannot resolve undecided conflict."));
69
70 rememberConflict(conflict);
71 return true;
72 }
73
74 private void deleteMy() {
75 Set<OsmPrimitive> referrers = getLayer().data.unlinkReferencesToPrimitive(conflict.getMy());
76 for (OsmPrimitive p : referrers) {
77 if (!p.isNew() && !p.isDeleted()) {
78 p.setModified(true);
79 }
80 }
81 conflict.getMy().setDeleted(true);
82 }
83
84 @Override
85 public void fillModifiedData(Collection<OsmPrimitive> modified, Collection<OsmPrimitive> deleted,
86 Collection<OsmPrimitive> added) {
87 modified.add(conflict.getMy());
88 modified.addAll(conflict.getMy().getReferrers());
89 }
90}
Note: See TracBrowser for help on using the repository browser.