/[thuban]/branches/WIP-pyshapelib-bramz/Thuban/Model/load.py
ViewVC logotype

Diff of /branches/WIP-pyshapelib-bramz/Thuban/Model/load.py

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1970 by bh, Mon Nov 24 18:36:00 2003 UTC revision 2449 by frank, Mon Dec 13 13:37:40 2004 UTC
# Line 1  Line 1 
1  # Copyright (C) 2001, 2002, 2003 by Intevation GmbH  # Copyright (C) 2001, 2002, 2003, 2004 by Intevation GmbH
2  # Authors:  # Authors:
3  # Jan-Oliver Wagner <[email protected]>  # Jan-Oliver Wagner <[email protected]>
4  # Bernhard Herzog <[email protected]>  # Bernhard Herzog <[email protected]>
5  # Jonathan Coles <[email protected]>  # Jonathan Coles <[email protected]>
6    # Frank Koormann <[email protected]>
7  #  #
8  # This program is free software under the GPL (>=v2)  # This program is free software under the GPL (>=v2)
9  # Read the file COPYING coming with GRASS for details.  # Read the file COPYING coming with GRASS for details.
# Line 100  class AttrDesc: Line 101  class AttrDesc:
101    
102  class SessionLoader(XMLReader):  class SessionLoader(XMLReader):
103    
104      def __init__(self, db_connection_callback = None):      def __init__(self, db_connection_callback = None,
105                           shapefile_callback = None):
106          """Inititialize the Sax handler."""          """Inititialize the Sax handler."""
107          XMLReader.__init__(self)          XMLReader.__init__(self)
108    
109          self.db_connection_callback = db_connection_callback          self.db_connection_callback = db_connection_callback
110            self.shapefile_callback = shapefile_callback
111          self.theSession = None          self.theSession = None
112          self.aMap = None          self.aMap = None
113          self.aLayer = None          self.aLayer = None
# Line 143  class SessionLoader(XMLReader): Line 145  class SessionLoader(XMLReader):
145          for xmlns in ("http://thuban.intevation.org/dtds/thuban-0.8.dtd",          for xmlns in ("http://thuban.intevation.org/dtds/thuban-0.8.dtd",
146                        "http://thuban.intevation.org/dtds/thuban-0.9-dev.dtd",                        "http://thuban.intevation.org/dtds/thuban-0.9-dev.dtd",
147                        "http://thuban.intevation.org/dtds/thuban-0.9.dtd",                        "http://thuban.intevation.org/dtds/thuban-0.9.dtd",
148                        "http://thuban.intevation.org/dtds/thuban-1.0-dev.dtd"):                        "http://thuban.intevation.org/dtds/thuban-1.0-dev.dtd",
149                          "http://thuban.intevation.org/dtds/thuban-1.0rc1.dtd",
150                          "http://thuban.intevation.org/dtds/thuban-1.0.0.dtd",
151                          "http://thuban.intevation.org/dtds/thuban-1.1-dev.dtd"):
152              for key, value in dispatchers.items():              for key, value in dispatchers.items():
153                  dispatchers[(xmlns, key)] = value                  dispatchers[(xmlns, key)] = value
154    
# Line 255  class SessionLoader(XMLReader): Line 260  class SessionLoader(XMLReader):
260              normalized[d.name] = value              normalized[d.name] = value
261          return normalized          return normalized
262    
263        def open_shapefile(self, filename):
264            """Open shapefile, with alternative path handling.
265            
266               If a shapefile cannot be opened and an IOError is raised, check for
267               an alternative. This alternative can be specified interactively by
268               the user or taken from a list of (potential) locations, depending on
269               the callback implementation.
270                
271               The alternative is rechecked. If taken from a list the user
272               has to confirm the alternative.
273            """
274    
275            # Flag if the alternative path was specified interactively / from list.
276            from_list = 0
277            while 1:
278                try:
279                    store = self.theSession.OpenShapefile(filename)
280                    if from_list:
281                        # A valid path has been guessed from a list
282                        # Let the user confirm - or select an alternative.
283                        filename, from_list = self.shapefile_callback(
284                                                filename, "check")
285                        if filename is None:
286                            # Selection cancelled
287                            raise LoadCancelled
288                        elif store.FileName() == filename:
289                            # Proposed file has been accepted
290                            break
291                        else:
292                            # the filename has been changed, try the new file
293                            pass
294                    else:
295                        break
296                except IOError:
297                    if self.shapefile_callback is not None:
298                        filename, from_list = self.shapefile_callback(
299                                                filename,
300                                                mode = "search",
301                                                second_try = from_list)
302                        if filename is None:
303                            raise LoadCancelled
304                        print filename
305                    else:
306                        raise
307            return store
308    
309      def start_dbconnection(self, name, qname, attrs):      def start_dbconnection(self, name, qname, attrs):
310          attrs = self.check_attrs(name, attrs,          attrs = self.check_attrs(name, attrs,
311                                   [AttrDesc("id", True),                                   [AttrDesc("id", True),
# Line 298  class SessionLoader(XMLReader): Line 349  class SessionLoader(XMLReader):
349                                    AttrDesc("dbconn", True,                                    AttrDesc("dbconn", True,
350                                             conversion = "idref"),                                             conversion = "idref"),
351                                    AttrDesc("tablename", True,                                    AttrDesc("tablename", True,
352                                               conversion = "ascii"),
353                                      # id_column and geometry_column were
354                                      # newly introduced with thuban-1.1.dtd
355                                      # where they're required.  Since we
356                                      # support the older formats too we
357                                      # have them optional here.
358                                      AttrDesc("id_column", False, "gid",
359                                               conversion = "ascii"),
360                                      AttrDesc("geometry_column", False,
361                                             conversion = "ascii")])                                             conversion = "ascii")])
362          ID = attrs["id"]          # The default value of geometry_column to use when instantiating
363          db = attrs["dbconn"]          # the db shapestore is None which we currently can't easily use
364          tablename = attrs["tablename"]          # in check_attrs
365          self.idmap[ID] = self.theSession.OpenDBShapeStore(db, tablename)          geometry_column = attrs["geometry_column"]
366            if not geometry_column:
367                geometry_column = None
368            dbopen = self.theSession.OpenDBShapeStore
369            self.idmap[attrs["id"]] = dbopen(attrs["dbconn"], attrs["tablename"],
370                                             id_column = attrs["id_column"],
371                                             geometry_column=geometry_column)
372    
373      def start_fileshapesource(self, name, qname, attrs):      def start_fileshapesource(self, name, qname, attrs):
374          attrs = self.check_attrs(name, attrs,          attrs = self.check_attrs(name, attrs,
# Line 315  class SessionLoader(XMLReader): Line 381  class SessionLoader(XMLReader):
381          filetype = attrs["filetype"]          filetype = attrs["filetype"]
382          if filetype != "shapefile":          if filetype != "shapefile":
383              raise LoadError("shapesource filetype %r not supported" % filetype)              raise LoadError("shapesource filetype %r not supported" % filetype)
384          self.idmap[ID] = self.theSession.OpenShapefile(filename)          self.idmap[ID] = self.open_shapefile(filename)
385    
386      def start_derivedshapesource(self, name, qname, attrs):      def start_derivedshapesource(self, name, qname, attrs):
387          attrs = self.check_attrs(name, attrs,          attrs = self.check_attrs(name, attrs,
# Line 426  class SessionLoader(XMLReader): Line 492  class SessionLoader(XMLReader):
492          if attrs.has_key((None, "shapestore")):          if attrs.has_key((None, "shapestore")):
493              store = self.idmap[attrs[(None, "shapestore")]]              store = self.idmap[attrs[(None, "shapestore")]]
494          else:          else:
495              store = self.theSession.OpenShapefile(filename)              store = self.open_shapefile(filename)
496    
497          self.aLayer = layer_class(title, store,          self.aLayer = layer_class(title, store,
498                                    fill = fill, stroke = stroke,                                    fill = fill, stroke = stroke,
499                                    lineWidth = stroke_width,                                    lineWidth = stroke_width,
# Line 536  class SessionLoader(XMLReader): Line 603  class SessionLoader(XMLReader):
603              parse_color(attrs.get((None, 'stroke'), "None")))              parse_color(attrs.get((None, 'stroke'), "None")))
604          self.cl_prop.SetLineWidth(          self.cl_prop.SetLineWidth(
605              int(attrs.get((None, 'stroke_width'), "0")))              int(attrs.get((None, 'stroke_width'), "0")))
606            self.cl_prop.SetSize(int(attrs.get((None, 'size'), "5")))
607          self.cl_prop.SetFill(parse_color(attrs.get((None, 'fill'), "None")))          self.cl_prop.SetFill(parse_color(attrs.get((None, 'fill'), "None")))
608    
609      def end_cldata(self, name, qname):      def end_cldata(self, name, qname):
# Line 545  class SessionLoader(XMLReader): Line 613  class SessionLoader(XMLReader):
613          self.aLayer = self.aMap.LabelLayer()          self.aLayer = self.aMap.LabelLayer()
614    
615      def start_label(self, name, qname, attrs):      def start_label(self, name, qname, attrs):
616          x = float(attrs[(None, 'x')])          attrs = self.check_attrs(name, attrs,
617          y = float(attrs[(None, 'y')])                                   [AttrDesc("x", True, conversion = float),
618          text = self.encode(attrs[(None, 'text')])                                    AttrDesc("y", True, conversion = float),
619          halign = attrs[(None, 'halign')]                                    AttrDesc("text", True),
620          valign = attrs[(None, 'valign')]                                    AttrDesc("halign", True,
621                                               conversion = "ascii"),
622                                      AttrDesc("valign", True,
623                                               conversion = "ascii")])
624            x = attrs['x']
625            y = attrs['y']
626            text = attrs['text']
627            halign = attrs['halign']
628            valign = attrs['valign']
629            if halign not in ("left", "center", "right"):
630                raise LoadError("Unsupported halign value %r" % halign)
631            if valign not in ("top", "center", "bottom"):
632                raise LoadError("Unsupported valign value %r" % valign)
633          self.aLayer.AddLabel(x, y, text, halign = halign, valign = valign)          self.aLayer.AddLabel(x, y, text, halign = halign, valign = valign)
634    
635      def characters(self, chars):      def characters(self, chars):
636          pass          pass
637    
638    
639  def load_session(filename, db_connection_callback = None):  def load_session(filename, db_connection_callback = None,
640                               shapefile_callback = None):
641      """Load a Thuban session from the file object file      """Load a Thuban session from the file object file
642    
643      The db_connection_callback, if given should be a callable object      The db_connection_callback, if given should be a callable object
# Line 569  def load_session(filename, db_connection Line 650  def load_session(filename, db_connection
650      corrected and perhaps additional parameters like a password or None      corrected and perhaps additional parameters like a password or None
651      to indicate that the user cancelled.      to indicate that the user cancelled.
652      """      """
653      handler = SessionLoader(db_connection_callback)      handler = SessionLoader(db_connection_callback, shapefile_callback)
654      handler.read(filename)      handler.read(filename)
655    
656      session = handler.theSession      session = handler.theSession

Legend:
Removed from v.1970  
changed lines
  Added in v.2449

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26