]> gitweb.fperrin.net Git - GpsPrune.git/blobdiff - tim/prune/function/gpsies/GpsiesXmlHandler.java
Version 19, May 2018
[GpsPrune.git] / tim / prune / function / gpsies / GpsiesXmlHandler.java
index e63916029450a4ae0f5c3159cc65e26405e127a5..c549c59c1a7a59d2f57a05e46067af0e1af6d19d 100644 (file)
@@ -6,21 +6,16 @@ import org.xml.sax.Attributes;
 import org.xml.sax.SAXException;
 import org.xml.sax.helpers.DefaultHandler;
 
+import tim.prune.function.search.SearchResult;
+
 /**
  * XML handler for dealing with XML returned from gpsies.com
  */
 public class GpsiesXmlHandler extends DefaultHandler
 {
-       private boolean _inTracks = false;
-       private boolean _inTrack = false;
-       private boolean _inTrackName = false;
-       private boolean _inDescription = false;
-       private boolean _inFileId = false;
-       private boolean _inTrackLength = false;
-       private boolean _inLink = false;
        private String _value = null;
-       private ArrayList<GpsiesTrack> _trackList = null;
-       private GpsiesTrack _track = null;
+       private ArrayList<SearchResult> _trackList = null;
+       private SearchResult _track = null;
 
 
        /**
@@ -30,18 +25,12 @@ public class GpsiesXmlHandler extends DefaultHandler
                Attributes inAttributes) throws SAXException
        {
                if (inTagName.equals("tracks")) {
-                       _inTracks = true;
-                       _trackList = new ArrayList<GpsiesTrack>();
+                       _trackList = new ArrayList<SearchResult>();
                }
-               else if (_inTracks && inTagName.equals("track")) {
-                       _inTrack = true;
-                       _track = new GpsiesTrack();
+               else if (inTagName.equals("track")) {
+                       _track = new SearchResult();
                }
-               else if (_inTrack && inTagName.equals("title")) {_inTrackName = true;}
-               else if (_inTrack && inTagName.equals("description")) {_inDescription = true;}
-               else if (_inTrack && inTagName.equals("fileId")) {_inFileId = true;}
-               else if (_inTrack && inTagName.equals("trackLengthM")) {_inTrackLength = true;}
-               else if (_inTrack && inTagName.equals("downloadLink")) {_inLink = true;}
+               _value = null;
                super.startElement(inUri, inLocalName, inTagName, inAttributes);
        }
 
@@ -51,33 +40,26 @@ public class GpsiesXmlHandler extends DefaultHandler
        public void endElement(String inUri, String inLocalName, String inTagName)
        throws SAXException
        {
-               if (inTagName.equals("tracks")) {_inTracks = false;}
-               else if (_inTrack && inTagName.equals("track")) {
+               if (inTagName.equals("track")) {
                        _trackList.add(_track);
-                       _inTrack = false;
                }
-               else if (_inTrackName && inTagName.equals("title")) {
+               else if (inTagName.equals("title")) {
                        _track.setTrackName(_value);
-                       _inTrackName = false;
                }
-               else if (_inDescription && inTagName.equals("description")) {
+               else if (inTagName.equals("description")) {
                        _track.setDescription(_value);
-                       _inDescription = false;
                }
-               else if (_inFileId && inTagName.equals("fileId")) {
-                       _track.setFileId(_value);
-                       _inFileId = false;
+               else if (inTagName.equals("fileId")) {
+                       _track.setWebUrl("https://gpsies.com/map.do?fileId=" + _value);
                }
-               else if (_inTrackLength && inTagName.equals("trackLengthM")) {
+               else if (inTagName.equals("trackLengthM")) {
                        try {
                                _track.setLength(Double.parseDouble(_value));
                        }
                        catch (NumberFormatException nfe) {}
-                       _inTrackLength = false;
                }
-               else if (_inLink && inTagName.equals("downloadLink")) {
+               else if (inTagName.equals("downloadLink")) {
                        _track.setDownloadLink(_value);
-                       _inLink = false;
                }
                super.endElement(inUri, inLocalName, inTagName);
        }
@@ -88,16 +70,15 @@ public class GpsiesXmlHandler extends DefaultHandler
        public void characters(char[] inCh, int inStart, int inLength)
        throws SAXException
        {
-               _value = new String(inCh, inStart, inLength);
-               // System.out.println("Value: '" + value + "'");
-               // TODO: Note, this doesn't cope well with split characters for really long descriptions etc
+               String value = new String(inCh, inStart, inLength);
+               _value = (_value==null?value:_value+value);
                super.characters(inCh, inStart, inLength);
        }
 
        /**
         * @return the list of tracks
         */
-       public ArrayList<GpsiesTrack> getTrackList()
+       public ArrayList<SearchResult> getTrackList()
        {
                return _trackList;
        }