Ignore:
Timestamp:
2007-08-11T21:19:21+02:00 (17 years ago)
Author:
frsantos
Message:

Allow "by user" and "before upload" validations be enabled separately
Preferences prefix moved from "tests" to "validator".

Location:
applications/editors/josm/plugins/validator/src/org/openstreetmap/josm/plugins/validator
Files:
6 edited

Legend:

Unmodified
Added
Removed
  • applications/editors/josm/plugins/validator/src/org/openstreetmap/josm/plugins/validator/OSMValidatorPlugin.java

    r4086 r4087  
    6565        public OSMValidatorPlugin()
    6666        {
    67         initializeTests( getTests(true) );
     67                PreferenceEditor.importOldPreferences();
     68        initializeTests( getTests(true, true) );
    6869        }
    6970       
     
    124125         * Gets a collection with the available tests
    125126         *
    126          * @param onlyActive if true, gets only active tests
     127         * @param enabled if false, don't get enabled tests
     128         * @param enabledBeforeUpload if false, don't get tests enabled before upload
    127129         * @return A collection with the available tests
    128130         */
    129         public static Collection<Test> getTests(boolean onlyActive)
     131        public static Collection<Test> getTests(boolean enabled, boolean enabledBeforeUpload)
    130132        {
    131133                Map<String, Test> enabledTests = new LinkedHashMap<String, Test>();
    132134                for(Class<Test> testClass : getAllAvailableTests() )
    133135                {
    134                         Test test;
    135136                        try {
    136                                 test = testClass.newInstance();
     137                                Test test = testClass.newInstance();
     138                                enabledTests.put(testClass.getSimpleName(), test);
    137139                        }
    138140                        catch( Exception e)
     
    141143                                continue;
    142144                        }
    143                         test.enabled = true;
    144            
    145             String simpleName = testClass.getSimpleName();
    146             test.testBeforeUpload = Main.pref.getBoolean( "tests." + simpleName + ".checkBeforeUpload", true);           
    147                         enabledTests.put(simpleName, test);
    148145                }
    149146
    150147                Pattern regexp = Pattern.compile("(\\w+)=(true|false),?");
    151                 Matcher m = regexp.matcher(Main.pref.get("tests"));
     148                Matcher m = regexp.matcher(Main.pref.get(PreferenceEditor.PREF_TESTS));
    152149                int pos = 0;
    153150                while( m.find(pos) )
     
    157154                        if( test != null )
    158155                        {
    159                                 test.enabled = Boolean.valueOf(m.group(2)).booleanValue();
    160                                 if( onlyActive && !test.enabled)
     156                                test.enabled = Boolean.valueOf(m.group(2));
     157                        }
     158                        pos = m.end();
     159                }
     160
     161                m = regexp.matcher(Main.pref.get( PreferenceEditor.PREF_TESTS_BEFORE_UPLOAD ));
     162                pos = 0;
     163                while( m.find(pos) )
     164                {
     165                        String testName = m.group(1);
     166                        Test test = enabledTests.get(testName);
     167                        if( test != null )
     168                        {
     169                                test.testBeforeUpload = Boolean.valueOf(m.group(2));
     170                                if( !enabled && test.enabled || !enabledBeforeUpload && test.testBeforeUpload)
    161171                                        enabledTests.remove(test.getClass().getSimpleName() );
    162172                        }
    163173                        pos = m.end();
    164174                }
     175               
    165176                return enabledTests.values();
    166177        }
  • applications/editors/josm/plugins/validator/src/org/openstreetmap/josm/plugins/validator/PreferenceEditor.java

    r2792 r4087  
    44
    55import java.awt.GridBagLayout;
    6 import java.awt.event.ActionEvent;
    7 import java.awt.event.ActionListener;
    86import java.util.Collection;
     7import java.util.Map;
     8import java.util.regex.Pattern;
    99
    1010import javax.swing.*;
     
    2424public class PreferenceEditor implements PreferenceSetting
    2525{
     26        /** The preferences prefix */
     27        public static final String PREFIX = "validator";
     28       
     29        /** The preferences key for enabled tests */
     30        public static final String PREF_TESTS = PREFIX + ".tests";
     31
     32        /** The preferences key for enabled tests before upload*/
     33        public static final String PREF_TESTS_BEFORE_UPLOAD = PREFIX + ".testsBeforeUpload";
     34
    2635        /** The list of all tests */
    2736        private Collection<Test> allTests;
     
    3544        testPanel.add( new JLabel("On upload"), GBC.eop() );
    3645       
    37                 allTests = OSMValidatorPlugin.getTests(false);
    38                 for(final Test test: allTests)
     46                allTests = OSMValidatorPlugin.getTests(true, true);
     47                for(Test test: allTests)
    3948                {
    40                         final JCheckBox testCheck = new JCheckBox(test.name, test.enabled);
    41                         testCheck.setToolTipText(test.description);
    42                         testPanel.add(testCheck, GBC.std().insets(20,0,0,0));
    43 
    44             testCheck.addActionListener(new ActionListener(){
    45                 public void actionPerformed(ActionEvent e) {
    46                     boolean selected = testCheck.isSelected();
    47                     test.enabled = selected;
    48                     test.setGuiEnabled(selected );
    49                 }
    50             });
    51            
    5249            test.addGui(testPanel);
    53             test.setGuiEnabled(test.enabled);
     50            test.setGuiEnabled(test.enabled || test.testBeforeUpload);
    5451                }
    5552               
     
    6865        public void ok()
    6966        {
    70                 String tests = "";
     67                StringBuilder tests = new StringBuilder();
     68                StringBuilder testsBeforeUpload = new StringBuilder();
    7169               
    7270                for (Test test : allTests)
    7371                {
    74                         boolean enabled = test.enabled;
     72                        test.ok();
    7573                        String name = test.getClass().getSimpleName();
    76                         tests += name + "=" + enabled + ",";
    77                        
    78                         if (enabled)
    79                         {
    80                                 test.ok();
    81                         }
     74                        tests.append( ',' ).append( name ).append( '=' ).append( test.enabled );
     75                        testsBeforeUpload.append( ',' ).append( name ).append( '=' ).append( test.testBeforeUpload );
    8276                }
    8377               
    84                 if (tests.endsWith(","))
    85                         tests = tests.substring(0, tests.length() - 1);
     78                if (tests.length() > 0 ) tests = tests.deleteCharAt(0);
     79                if (testsBeforeUpload.length() > 0 ) testsBeforeUpload = testsBeforeUpload.deleteCharAt(0);
    8680               
    8781                OSMValidatorPlugin.getPlugin().initializeTests( allTests );
    8882               
    89                 Main.pref.put("tests", tests);
     83                Main.pref.put( PREF_TESTS, tests.toString());
     84                Main.pref.put( PREF_TESTS_BEFORE_UPLOAD, testsBeforeUpload.toString());
     85        }
     86       
     87        /**
     88         * Import old stored preferences
     89         */
     90        public static void importOldPreferences()
     91        {
     92                if( !Main.pref.hasKey("tests") || !Pattern.matches("(\\w+=(true|false),?)*", Main.pref.get("tests")) )
     93                        return;
     94               
     95                String enabledTests = Main.pref.get("tests");
     96                Main.pref.put(PREF_TESTS, enabledTests);
     97                Main.pref.put("tests", null );
     98               
     99                StringBuilder testsBeforeUpload = new StringBuilder();
     100                Map<String, String> oldPrefs = Main.pref.getAllPrefix("tests");
     101                for( Map.Entry<String, String> pref : oldPrefs.entrySet() )
     102                {
     103                        String key = pref.getKey();
     104                        String value = pref.getValue();
     105                        if( key.endsWith(".checkBeforeUpload") )
     106                        {
     107                                String testName = key.substring(6, key.length() - 18);
     108                                testsBeforeUpload.append( ',' ).append( testName ).append( '=' ).append( value );
     109                        }
     110                        else
     111                                Main.pref.put( PREFIX + key.substring(5), value );
     112                        Main.pref.put(key, null );
     113                }
     114               
     115                if (testsBeforeUpload.length() > 0 ) testsBeforeUpload = testsBeforeUpload.deleteCharAt(0);
     116                Main.pref.put( PREF_TESTS_BEFORE_UPLOAD, testsBeforeUpload.toString());
    90117        }
    91118
  • applications/editors/josm/plugins/validator/src/org/openstreetmap/josm/plugins/validator/Test.java

    r2792 r4087  
    11package org.openstreetmap.josm.plugins.validator;
    22
    3 import java.util.*;
     3import java.awt.event.ActionEvent;
     4import java.awt.event.ActionListener;
     5import java.util.ArrayList;
     6import java.util.Collection;
     7import java.util.List;
    48
    59import javax.swing.JCheckBox;
    610import javax.swing.JPanel;
    711
    8 import org.openstreetmap.josm.Main;
    912import org.openstreetmap.josm.command.Command;
    1013import org.openstreetmap.josm.data.osm.*;
     
    2932        protected String description;
    3033       
    31     /** Whether this test is enabled. Used by peferences */
    32     protected boolean enabled;
     34    /** Whether this test is enabled. Enabled by default */
     35    protected boolean enabled = true;
     36
     37    /** The preferences check for validation */
     38    protected JCheckBox checkEnabled;
    3339
    3440    /** The preferences check for validation on upload */
    3541    protected JCheckBox checkBeforeUpload;
    3642   
    37     /** Whether this test must check before upload. Used by peferences */
    38     protected boolean testBeforeUpload;
     43    /** Whether this test must check before upload. Enabled by default */
     44    protected boolean testBeforeUpload = true;
    3945
    4046    /** Whether this test is performing just before an upload */
     
    134140        public void addGui(@SuppressWarnings("unused") JPanel testPanel)
    135141        {
     142                checkEnabled = new JCheckBox(name, enabled);
     143                checkEnabled.setToolTipText(description);
     144        checkEnabled.addActionListener(new ActionListener(){
     145            public void actionPerformed(ActionEvent e) {
     146                setGuiEnabled(checkEnabled.isSelected() || checkBeforeUpload.isSelected() );
     147            }
     148        });
     149                testPanel.add(checkEnabled, GBC.std().insets(20,0,0,0));
     150               
    136151        checkBeforeUpload = new JCheckBox();
    137152        checkBeforeUpload.setSelected(testBeforeUpload);
     153        checkBeforeUpload.addActionListener(new ActionListener(){
     154            public void actionPerformed(ActionEvent e) {
     155                setGuiEnabled(checkEnabled.isSelected() || checkBeforeUpload.isSelected() );
     156            }
     157        });
    138158        testPanel.add(checkBeforeUpload, GBC.eop().insets(20,0,0,0));
    139159        }
     
    145165    public void setGuiEnabled(boolean enabled)
    146166    {
    147         checkBeforeUpload.setEnabled(enabled);
    148167    }   
    149168
     
    153172        public void ok()
    154173        {
    155         String simpleName = getClass().getSimpleName();
    156         Main.pref.put("tests." + simpleName + ".checkBeforeUpload", checkBeforeUpload.isSelected() );
     174                enabled = checkEnabled.isSelected();
     175                testBeforeUpload = checkBeforeUpload.isSelected();
    157176        }
    158177       
  • applications/editors/josm/plugins/validator/src/org/openstreetmap/josm/plugins/validator/ValidateAction.java

    r4023 r4087  
    5858            return;
    5959       
    60                 Collection<Test> tests = OSMValidatorPlugin.getTests(true);
     60                Collection<Test> tests = OSMValidatorPlugin.getTests(true, false);
    6161                if( tests.isEmpty() )
    6262                        return;
  • applications/editors/josm/plugins/validator/src/org/openstreetmap/josm/plugins/validator/ValidateUploadHook.java

    r3037 r4087  
    3232    public boolean checkUpload(Collection<OsmPrimitive> add, Collection<OsmPrimitive> update, Collection<OsmPrimitive> delete)
    3333    {
    34         Collection<Test> tests = OSMValidatorPlugin.getTests(true);
     34        Collection<Test> tests = OSMValidatorPlugin.getTests(false, true);
    3535        if( tests.isEmpty() )
    3636            return true;
  • applications/editors/josm/plugins/validator/src/org/openstreetmap/josm/plugins/validator/tests/SpellCheck.java

    r4025 r4087  
    4141        /** The spell check preset values */
    4242        protected static Bag<String, String> spellCheckValueData;
    43        
     43
     44        /** The preferences prefix */
     45        protected static final String PREFIX = PreferenceEditor.PREFIX + "." + SpellCheck.class.getSimpleName();
     46   
    4447    /** Preference name for checking values */
    45     public static final String PREF_CHECK_VALUES = "tests." + SpellCheck.class.getSimpleName() + ".checkValues";
     48    public static final String PREF_CHECK_VALUES                                = PREFIX + ".checkValues";
    4649    /** Preference name for checking values */
    47     public static final String PREF_CHECK_KEYS = "tests." + SpellCheck.class.getSimpleName() + ".checkKeys";
     50    public static final String PREF_CHECK_KEYS                                  = PREFIX + ".checkKeys";
    4851    /** Preference name for checking FIXMES */
    49     public static final String PREF_CHECK_FIXMES = "tests." + SpellCheck.class.getSimpleName() + ".checkFixmes";
     52    public static final String PREF_CHECK_FIXMES                                = PREFIX + ".checkFixmes";
    5053    /** Preference name for sources */
    51     public static final String PREF_SOURCES = "tests." + SpellCheck.class.getSimpleName() + ".sources";
    52     /** Preference name for global upload check */
    53     public static final String PREF_CHECK_BEFORE_UPLOAD = "tests." + SpellCheck.class.getSimpleName() + ".checkBeforeUpload";
     54    public static final String PREF_SOURCES                                     = PREFIX + ".sources";
    5455    /** Preference name for keys upload check */
    55     public static final String PREF_CHECK_KEYS_BEFORE_UPLOAD = "tests." + SpellCheck.class.getSimpleName() + ".checkKeysBeforeUpload";
     56    public static final String PREF_CHECK_KEYS_BEFORE_UPLOAD    = PREFIX + ".checkKeysBeforeUpload";
    5657    /** Preference name for values upload check */
    57     public static final String PREF_CHECK_VALUES_BEFORE_UPLOAD = "tests." + SpellCheck.class.getSimpleName() + ".checkValuesBeforeUpload";
     58    public static final String PREF_CHECK_VALUES_BEFORE_UPLOAD  = PREFIX + ".checkValuesBeforeUpload";
    5859    /** Preference name for fixmes upload check */
    59     public static final String PREF_CHECK_FIXMES_BEFORE_UPLOAD = "tests." + SpellCheck.class.getSimpleName() + ".checkFixmesBeforeUpload";
     60    public static final String PREF_CHECK_FIXMES_BEFORE_UPLOAD  = PREFIX + ".checkFixmesBeforeUpload";
    6061       
    6162    /** Whether to check keys */
     
    364365        public void addGui(JPanel testPanel)
    365366        {
    366         testPanel.add( new JLabel(), GBC.eol());
     367                testPanel.add( new JLabel(name), GBC.eol().insets(35,0,0,0) );
    367368       
    368369        boolean checkKeys = Main.pref.getBoolean(PREF_CHECK_KEYS, true);
     
    433434        buttonPanel.add(deleteSrcButton, GBC.std().insets(0,5,0,0));
    434435       
    435         prefCheckKeys.addActionListener(new ActionListener(){
    436             public void actionPerformed(ActionEvent e) {
    437                 boolean selected = prefCheckKeys.isSelected();
    438                 spellcheckSources.setEnabled( selected );
    439                 addSrcButton.setEnabled(selected);
    440                 editSrcButton.setEnabled(selected);
    441                 deleteSrcButton.setEnabled(selected);
    442             }
    443         });
     436        ActionListener disableCheckKeysActionListener = new ActionListener(){
     437                            public void actionPerformed(ActionEvent e) {
     438                                boolean selected = prefCheckKeys.isSelected() || prefCheckKeysBeforeUpload.isSelected();
     439                                spellcheckSources.setEnabled( selected );
     440                                addSrcButton.setEnabled(selected);
     441                                editSrcButton.setEnabled(selected);
     442                                deleteSrcButton.setEnabled(selected);
     443                            }
     444                        };
     445                prefCheckKeys.addActionListener(disableCheckKeysActionListener);
     446                prefCheckKeysBeforeUpload.addActionListener(disableCheckKeysActionListener);
    444447       
    445448        spellcheckSources.setEnabled( checkKeys );
     
    465468        }
    466469
    467     public void setGuiEnabled(boolean enabled)
    468     {
    469         prefCheckKeys.setEnabled(enabled);
    470         prefCheckKeysBeforeUpload.setEnabled(enabled);
    471         spellcheckSources.setEnabled( enabled );
    472         addSrcButton.setEnabled(enabled);
    473         editSrcButton.setEnabled(enabled);
    474         deleteSrcButton.setEnabled(enabled);
    475         prefCheckValues.setEnabled(enabled);
    476         prefCheckValuesBeforeUpload.setEnabled(enabled);
    477         prefCheckFixmes.setEnabled(enabled);
    478         prefCheckFixmesBeforeUpload.setEnabled(enabled);
    479     }
    480    
    481470        @Override
    482471        public void ok()
    483472        {
     473                enabled = prefCheckKeys.isSelected() || prefCheckValues.isSelected() || prefCheckFixmes.isSelected();
     474        testBeforeUpload = prefCheckKeysBeforeUpload.isSelected() || prefCheckValuesBeforeUpload.isSelected() || prefCheckFixmesBeforeUpload.isSelected();
     475               
    484476        Main.pref.put(PREF_CHECK_VALUES, prefCheckValues.isSelected());
    485477        Main.pref.put(PREF_CHECK_KEYS, prefCheckKeys.isSelected());
     
    488480        Main.pref.put(PREF_CHECK_KEYS_BEFORE_UPLOAD, prefCheckKeysBeforeUpload.isSelected());
    489481        Main.pref.put(PREF_CHECK_FIXMES_BEFORE_UPLOAD, prefCheckFixmesBeforeUpload.isSelected());           
    490         Main.pref.put(PREF_CHECK_BEFORE_UPLOAD, prefCheckKeysBeforeUpload.isSelected() || prefCheckValuesBeforeUpload.isSelected() || prefCheckFixmesBeforeUpload.isSelected());
    491482        String sources = "";
    492483        if( spellcheckSources.getModel().getSize() > 0 )
Note: See TracChangeset for help on using the changeset viewer.