]> gitweb.fperrin.net Git - GpsPrune.git/blobdiff - tim/prune/Config.java
Version 8, September 2009
[GpsPrune.git] / tim / prune / Config.java
index aa36c158930cc07e0d15a21ec98363cc1988030c..befbaccc1b4819216576f8d6a3c653ad7baca9dd 100644 (file)
@@ -9,67 +9,46 @@ import java.util.Properties;
  */
 public abstract class Config
 {
-       /** Working directory for loading and saving */
-       private static File _workingDir = null;
-       /** Default language */
-       private static String _langCode = null;
-       /** GPS device name */
-       private static String _gpsDevice = null;
-       /** GPS format name */
-       private static String _gpsFormat = null;
-       /** Font to use for povray */
-       private static String _povrayFont = null;
-       /** True to use metric units */
-       private static boolean _metricUnits = true;
-       /** Path to gnuplot executable */
-       private static String _gnuplotPath = null;
-       /** Index of selected map tile server */
-       private static int _mapTileServerIndex = -1;
-       /** URL for freeform map tile server */
-       private static String _mapTileServerUrl = null;
        /** File from which Config was loaded */
        private static File _configFile = null;
 
-       // TODO: Need setters for all these parameters if want to make the config saveable
+       /** Hashtable containing all config values */
+       private static Properties _configValues = new Properties();
 
        /** Default config file */
        private static final File DEFAULT_CONFIG_FILE = new File(".pruneconfig");
 
-       /** Key for working directory */
-       private static final String KEY_WORKING_DIR = "prune.directory";
+       /** Key for track directory */
+       public static final String KEY_TRACK_DIR = "prune.trackdirectory";
+       /** Key for photo directory */
+       public static final String KEY_PHOTO_DIR = "prune.photodirectory";
        /** Key for language code */
-       private static final String KEY_LANGUAGE_CODE = "prune.languagecode";
+       public static final String KEY_LANGUAGE_CODE = "prune.languagecode";
        /** Key for GPS device */
-       private static final String KEY_GPS_DEVICE = "prune.gpsdevice";
+       public static final String KEY_GPS_DEVICE = "prune.gpsdevice";
        /** Key for GPS format */
-       private static final String KEY_GPS_FORMAT = "prune.gpsformat";
+       public static final String KEY_GPS_FORMAT = "prune.gpsformat";
        /** Key for Povray font */
-       private static final String KEY_POVRAY_FONT = "prune.povrayfont";
+       public static final String KEY_POVRAY_FONT = "prune.povrayfont";
        /** Key for metric/imperial */
-       private static final String KEY_METRIC_UNITS = "prune.metricunits";
-       /** Key for gpsbabel path */
-       private static final String KEY_GNUPLOTPATH = "prune.gnuplotpath";
+       public static final String KEY_METRIC_UNITS = "prune.metricunits";
        /** Key for map server index */
-       private static final String KEY_MAPSERVERINDEX = "prune.mapserverindex";
+       public static final String KEY_MAPSERVERINDEX = "prune.mapserverindex";
        /** Key for map server url */
-       private static final String KEY_MAPSERVERURL = "prune.mapserverurl";
-
-
-       /**
-        * @return working directory for loading and saving
-        */
-       public static File getWorkingDirectory()
-       {
-               return _workingDir;
-       }
+       public static final String KEY_MAPSERVERURL = "prune.mapserverurl";
+       /** Key for show pace flag */
+       public static final String KEY_SHOW_PACE = "prune.showpace";
+       /** Key for width of thumbnails in kmz */
+       public static final String KEY_KMZ_IMAGE_WIDTH = "prune.kmzimagewidth";
+       /** Key for height of thumbnails in kmz */
+       public static final String KEY_KMZ_IMAGE_HEIGHT = "prune.kmzimageheight";
+       /** Key for gpsbabel path */
+       public static final String KEY_GPSBABEL_PATH = "prune.gpsbabelpath";
+       /** Key for gnuplot path */
+       public static final String KEY_GNUPLOT_PATH = "prune.gnuplotpath";
+       /** Key for exiftool path */
+       public static final String KEY_EXIFTOOL_PATH = "prune.exiftoolpath";
 
-       /**
-        * @param inDirectory working directory to use
-        */
-       public static void setWorkingDirectory(File inDirectory)
-       {
-               _workingDir = inDirectory;
-       }
 
        /**
         * Load the default configuration file
@@ -110,19 +89,8 @@ public abstract class Config
                        }
                        catch (Exception e) {}
                }
-               // Save the properties we know about, ignore the rest
-               _langCode = props.getProperty(KEY_LANGUAGE_CODE);
-               String dir = props.getProperty(KEY_WORKING_DIR);
-               if (dir != null) {setWorkingDirectory(new File(dir));}
-               _gpsDevice = props.getProperty(KEY_GPS_DEVICE);
-               _gpsFormat = props.getProperty(KEY_GPS_FORMAT);
-               _povrayFont = props.getProperty(KEY_POVRAY_FONT);
-               String useMetric = props.getProperty(KEY_METRIC_UNITS);
-               _metricUnits = (useMetric == null || useMetric.equals("") || useMetric.toLowerCase().equals("y"));
-               _gnuplotPath = props.getProperty(KEY_GNUPLOTPATH);
-               if (_gnuplotPath == null || _gnuplotPath.equals("")) {_gnuplotPath = "gnuplot";}
-               _mapTileServerIndex = parseInt(props.getProperty(KEY_MAPSERVERINDEX));
-               _mapTileServerUrl = props.getProperty(KEY_MAPSERVERURL);
+               // Save all properties from file
+               _configValues.putAll(props);
                if (loadFailed) {
                        throw new ConfigException();
                }
@@ -140,6 +108,12 @@ public abstract class Config
                props.put(KEY_GPS_DEVICE, "usb:");
                props.put(KEY_GPS_FORMAT, "garmin");
                props.put(KEY_POVRAY_FONT, "crystal.ttf"); // alternative: DejaVuSans-Bold.ttf
+               props.put(KEY_SHOW_PACE, "0"); // hide by default
+               props.put(KEY_EXIFTOOL_PATH, "exiftool");
+               props.put(KEY_GNUPLOT_PATH, "gnuplot");
+               props.put(KEY_GPSBABEL_PATH, "gpsbabel");
+               props.put(KEY_KMZ_IMAGE_WIDTH, "240");
+               props.put(KEY_KMZ_IMAGE_HEIGHT, "180");
                return props;
        }
 
@@ -157,81 +131,98 @@ public abstract class Config
                return val;
        }
 
-       /** @return language code */
-       public static String getLanguageCode()
-       {
-               return _langCode;
-       }
-
-       /** @return gps device */
-       public static String getGpsDevice()
-       {
-               return _gpsDevice;
-       }
-
-       /** @return gps format */
-       public static String getGpsFormat()
-       {
-               return _gpsFormat;
-       }
-
-       /** @return povray font */
-       public static String getPovrayFont()
-       {
-               return _povrayFont;
-       }
-
-       /** @return true to use metric units */
-       public static boolean getUseMetricUnits()
+       /** @return File from which config was loaded (or null) */
+       public static File getConfigFile()
        {
-               return _metricUnits;
+               return _configFile;
        }
 
-       /** @param inMetric true to use metric units */
-       public static void setUseMetricUnits(boolean inMetric)
+       /**
+        * @return config Properties object to allow all config values to be saved
+        */
+       public static Properties getAllConfig()
        {
-               _metricUnits = inMetric;
+               return _configValues;
        }
 
-       /** @return path to gnuplot */
-       public static String getGnuplotPath()
+       /**
+        * Store the given configuration setting
+        * @param inKey key (from constants)
+        * @param inValue value as string
+        */
+       public static void setConfigString(String inKey, String inValue)
        {
-               return _gnuplotPath;
+               if (inKey != null && !inKey.equals(""))
+               {
+                       _configValues.put(inKey, inValue);
+               }
        }
 
-       /** @param inPath path to Gnuplot */
-       public static void setGnuplotPath(String inPath)
+       /**
+        * Store the given configuration setting
+        * @param inKey key (from constants)
+        * @param inValue value as boolean
+        */
+       public static void setConfigBoolean(String inKey, boolean inValue)
        {
-               _gnuplotPath = inPath;
+               if (inKey != null && !inKey.equals(""))
+               {
+                       _configValues.put(inKey, (inValue?"1":"0"));
+               }
        }
 
-       /** @return index of map server */
-       public static int getMapServerIndex()
+       /**
+        * Store the given configuration setting
+        * @param inKey key (from constants)
+        * @param inValue value as int
+        */
+       public static void setConfigInt(String inKey, int inValue)
        {
-               return _mapTileServerIndex;
+               if (inKey != null && !inKey.equals(""))
+               {
+                       _configValues.put(inKey, "" + inValue);
+               }
        }
 
-       /** @param inIndex selected index */
-       public static void setMapServerIndex(int inIndex)
+       /**
+        * Get the given configuration setting as a String
+        * @param inKey key
+        * @return configuration setting as a String
+        */
+       public static String getConfigString(String inKey)
        {
-               _mapTileServerIndex = inIndex;
+               return _configValues.getProperty(inKey);
        }
 
-       /** @return url of map server */
-       public static String getMapServerUrl()
+       /**
+        * Get the given configuration setting as a boolean
+        * @param inKey key
+        * @return configuration setting as a boolean
+        */
+       public static boolean getConfigBoolean(String inKey)
        {
-               return _mapTileServerUrl;
+               String val = _configValues.getProperty(inKey);
+               return (val == null || val.equals("1"));
        }
 
-       /** @param inUrl url of map server */
-       public static void setMapServerUrl(String inUrl)
+       /**
+        * Get the given configuration setting as an int
+        * @param inKey key
+        * @return configuration setting as an int
+        */
+       public static int getConfigInt(String inKey)
        {
-               _mapTileServerUrl = inUrl;
+               return parseInt(_configValues.getProperty(inKey));
        }
 
-       /** @return File from which config was loaded (or null) */
-       public static File getConfigFile()
+       /**
+        * Check whether the given key corresponds to a boolean property
+        * @param inKey key to check
+        * @return true if corresponding property is boolean
+        */
+       public static boolean isKeyBoolean(String inKey)
        {
-               return _configFile;
+               // Only two boolean keys so far
+               return inKey != null && (inKey.equals(KEY_METRIC_UNITS) || inKey.equals(KEY_SHOW_PACE));
        }
 }