Changeset 21539 in osm for applications/editors/josm
- Timestamp:
- 2010-06-01T09:11:37+02:00 (15 years ago)
- Location:
- applications/editors/josm/plugins/validator
- Files:
-
- 1 added
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
applications/editors/josm/plugins/validator/build.xml
r20799 r21539 27 27 --> 28 28 <property name="commit.message" value="don't break relations, when fixing duplicate ways" /> 29 <property name="plugin.main.version" value="3 118" />29 <property name="plugin.main.version" value="3289" /> 30 30 31 31 -
applications/editors/josm/plugins/validator/src/org/openstreetmap/josm/plugins/validator/OSMValidatorPlugin.java
r20828 r21539 44 44 import org.openstreetmap.josm.plugins.validator.tests.NodesWithSameName; 45 45 import org.openstreetmap.josm.plugins.validator.tests.OverlappingWays; 46 import org.openstreetmap.josm.plugins.validator.tests.RelationChecker; 46 47 import org.openstreetmap.josm.plugins.validator.tests.SelfIntersectingWay; 47 48 import org.openstreetmap.josm.plugins.validator.tests.SimilarNamedWays; … … 83 84 */ 84 85 @SuppressWarnings("unchecked") 85 public static Class<Test>[] allAvailableTests = new Class[] { DuplicateNode.class, // ID 1 .. 99 86 public static Class<Test>[] allAvailableTests = new Class[] { 87 DuplicateNode.class, // ID 1 .. 99 86 88 OverlappingWays.class, // ID 101 .. 199 87 89 UntaggedNode.class, // ID 201 .. 299 … … 100 102 NameMismatch.class, // ID 1501 .. 1599 101 103 MultipolygonTest.class, // ID 1601 .. 1699 104 RelationChecker.class, // ID 1701 .. 1799 102 105 }; 103 106 -
applications/editors/josm/plugins/validator/src/org/openstreetmap/josm/plugins/validator/ValidateAction.java
r20828 r21539 106 106 107 107 class ValidationTask extends PleaseWaitRunnable { 108 private Collection<Test> tests;109 private Collection<OsmPrimitive> validatedPrimitmives;110 private Collection<OsmPrimitive> formerValidatedPrimitives;111 private boolean canceled;108 private Collection<Test> tests; 109 private Collection<OsmPrimitive> validatedPrimitmives; 110 private Collection<OsmPrimitive> formerValidatedPrimitives; 111 private boolean canceled; 112 112 private List<TestError> errors; 113 113 … … 118 118 * @param formerValidatedPrimitives the last collection of primitives being validates. May be null. 119 119 */ 120 public ValidationTask(Collection<Test> tests, Collection<OsmPrimitive> validatedPrimitives, Collection<OsmPrimitive> formerValidatedPrimitives) {121 super(tr("Validating"), false /*don't ignore exceptions */);122 this.validatedPrimitmives = validatedPrimitives;123 this.formerValidatedPrimitives = formerValidatedPrimitives;124 this.tests = tests;125 }120 public ValidationTask(Collection<Test> tests, Collection<OsmPrimitive> validatedPrimitives, Collection<OsmPrimitive> formerValidatedPrimitives) { 121 super(tr("Validating"), false /*don't ignore exceptions */); 122 this.validatedPrimitmives = validatedPrimitives; 123 this.formerValidatedPrimitives = formerValidatedPrimitives; 124 this.tests = tests; 125 } 126 126 127 @Override128 protected void cancel() {129 this.canceled = true;130 }127 @Override 128 protected void cancel() { 129 this.canceled = true; 130 } 131 131 132 @Override133 protected void finish() {134 if (canceled) return;132 @Override 133 protected void finish() { 134 if (canceled) return; 135 135 136 // update GUI on Swing EDT137 //138 Runnable r = new Runnable() {139 public void run() {140 plugin.validationDialog.tree.setErrors(errors);141 plugin.validationDialog.setVisible(true);142 Main.main.getCurrentDataSet().fireSelectionChanged();143 }144 };145 if (SwingUtilities.isEventDispatchThread()) {146 r.run();147 } else {148 SwingUtilities.invokeLater(r);149 }150 }136 // update GUI on Swing EDT 137 // 138 Runnable r = new Runnable() { 139 public void run() { 140 plugin.validationDialog.tree.setErrors(errors); 141 plugin.validationDialog.setVisible(true); 142 Main.main.getCurrentDataSet().fireSelectionChanged(); 143 } 144 }; 145 if (SwingUtilities.isEventDispatchThread()) { 146 r.run(); 147 } else { 148 SwingUtilities.invokeLater(r); 149 } 150 } 151 151 152 @Override153 protected void realRun() throws SAXException, IOException,154 OsmTransferException {155 if (tests == null || tests.isEmpty()) return;156 errors = new ArrayList<TestError>(200);157 getProgressMonitor().setTicksCount(tests.size() * validatedPrimitmives.size());158 int testCounter = 0;159 for (Test test : tests) {160 if (canceled) return;161 testCounter++;162 getProgressMonitor().setCustomText(tr("Test {0}/{1}: Starting {2}", testCounter, tests.size(),test.name));163 test.setPartialSelection(formerValidatedPrimitives != null);164 test.startTest(getProgressMonitor().createSubTaskMonitor(validatedPrimitmives.size(), false));165 test.visit(validatedPrimitmives);166 test.endTest();167 errors.addAll(test.getErrors());168 }169 tests = null;170 if (Main.pref.getBoolean(PreferenceEditor.PREF_USE_IGNORE, true)) {171 getProgressMonitor().subTask(tr("Updating ignored errors ..."));172 for (TestError error : errors) {173 if (canceled) return;174 List<String> s = new ArrayList<String>();175 s.add(error.getIgnoreState());176 s.add(error.getIgnoreGroup());177 s.add(error.getIgnoreSubGroup());178 for (String state : s) {179 if (state != null && plugin.ignoredErrors.contains(state)) {180 error.setIgnored(true);181 }182 }183 }184 }185 }152 @Override 153 protected void realRun() throws SAXException, IOException, 154 OsmTransferException { 155 if (tests == null || tests.isEmpty()) return; 156 errors = new ArrayList<TestError>(200); 157 getProgressMonitor().setTicksCount(tests.size() * validatedPrimitmives.size()); 158 int testCounter = 0; 159 for (Test test : tests) { 160 if (canceled) return; 161 testCounter++; 162 getProgressMonitor().setCustomText(tr("Test {0}/{1}: Starting {2}", testCounter, tests.size(),test.name)); 163 test.setPartialSelection(formerValidatedPrimitives != null); 164 test.startTest(getProgressMonitor().createSubTaskMonitor(validatedPrimitmives.size(), false)); 165 test.visit(validatedPrimitmives); 166 test.endTest(); 167 errors.addAll(test.getErrors()); 168 } 169 tests = null; 170 if (Main.pref.getBoolean(PreferenceEditor.PREF_USE_IGNORE, true)) { 171 getProgressMonitor().subTask(tr("Updating ignored errors ...")); 172 for (TestError error : errors) { 173 if (canceled) return; 174 List<String> s = new ArrayList<String>(); 175 s.add(error.getIgnoreState()); 176 s.add(error.getIgnoreGroup()); 177 s.add(error.getIgnoreSubGroup()); 178 for (String state : s) { 179 if (state != null && plugin.ignoredErrors.contains(state)) { 180 error.setIgnored(true); 181 } 182 } 183 } 184 } 185 } 186 186 } 187 187 }
Note:
See TracChangeset
for help on using the changeset viewer.
