diff clients/editor/scripts/gui/filemanager.py @ 282:0adf9423062e

* Buttons and functions for importing objects in the editor * Fixed an index overflow bug in FileBrowser which could occur when selectDirs was enabled * Removed unused import functions from MapView
author cheesesucker@33b003aa-7bff-0310-803a-e67f0ece8222
date Wed, 17 Jun 2009 01:34:59 +0000
parents 51cc05d862f2
children 54de5aebf732
line wrap: on
line diff
--- a/clients/editor/scripts/gui/filemanager.py	Tue Jun 16 18:57:56 2009 +0000
+++ b/clients/editor/scripts/gui/filemanager.py	Wed Jun 17 01:34:59 2009 +0000
@@ -1,9 +1,10 @@
-import math, fife, pychan, filebrowser
+import os, math, fife, pychan, filebrowser, traceback, sys
 import loaders, savers
 import action
 import scripts.editor
 import pychan.widgets as widgets
-
+from pychan.tools import callbackWithArguments as cbwa
+from scripts.gui.error import ErrorDialog
 from action import Action, ActionGroup
 from input import InputDialog
 from selection import SelectionDialog, ClickSelectionDialog
@@ -19,6 +20,7 @@
 		self._cameradlg = None
 		
 		self._filebrowser = None
+		self._importbrowser = None
 		self._savebrowser = None
 
 		newAction = Action(u"New map", "gui/icons/new_map.png")
@@ -26,12 +28,16 @@
 		saveAction = Action(u"Save", "gui/icons/save_map.png")
 		saveAsAction = Action(u"Save as", "gui/icons/save_mapas.png")
 		saveAllAction = Action(u"Save all", "gui/icons/save_allmaps.png")
+		importFileAction = Action(u"Import file", "gui/icons/import_file.png")
+		importDirAction = Action(u"Import directory", "gui/icons/import_dir.png")
 		
 		newAction.helptext = u"Create new map"
 		loadAction.helptext = u"Open existing map"
 		saveAction.helptext = u"Save map"
 		saveAsAction.helptext = u"Save map as"
 		saveAllAction.helptext = u"Save all opened maps"
+		importFileAction.helptext = u"Imports an object file"
+		importDirAction.helptext = u"Recursively imports all objects from a directory"
 		
 		action.activated.connect(self.showMapWizard, sender=newAction)
 		action.activated.connect(self.showLoadDialog, sender=loadAction)
@@ -39,6 +45,11 @@
 		action.activated.connect(self.saveAs, sender=saveAsAction)
 		action.activated.connect(self.editor.saveAll, sender=saveAllAction)
 		
+		self._importFileCallback = cbwa(self.showImportDialog, self.importFile, False)
+		self._importDirCallback = cbwa(self.showImportDialog, self.importDir, True)
+		action.activated.connect(self._importFileCallback, sender=importFileAction)
+		action.activated.connect(self._importDirCallback, sender=importDirAction)
+		
 		eventlistener = self.editor.getEventListener()
 		eventlistener.getKeySequenceSignal(fife.Key.N, ["ctrl"]).connect(self.showMapWizard)
 		eventlistener.getKeySequenceSignal(fife.Key.O, ["ctrl"]).connect(self.showLoadDialog)
@@ -51,6 +62,9 @@
 		fileGroup.addAction(saveAction)
 		fileGroup.addAction(saveAsAction)
 		fileGroup.addAction(saveAllAction)
+		fileGroup.addSeparator()
+		fileGroup.addAction(importFileAction)
+		fileGroup.addAction(importDirAction)
 		
 		self.editor.getToolBar().insertAction(fileGroup, 0)
 		self.editor.getToolBar().insertSeparator(None, 1)
@@ -66,6 +80,13 @@
 		if self._savebrowser is None:
 			self._savebrowser = filebrowser.FileBrowser(self.engine, self.saveFile, savefile=True, extensions = loaders.fileExtensions)
 		self._savebrowser.showBrowser()
+		
+	def showImportDialog(self, callback, selectdir):
+		if self._importbrowser is None:
+			self._importbrowser = filebrowser.FileBrowser(self.engine, callback, extensions = loaders.fileExtensions)
+		self._importbrowser.fileSelected = callback
+		self._importbrowser.selectdir = selectdir
+		self._importbrowser.showBrowser()
 
 	def saveFile(self, path, filename):
 		mapview = self.editor.getActiveMapView()
@@ -105,9 +126,9 @@
 		
 	def _newCamera(self, layerId):
 		grid = fife.SquareGrid()
-		layer = self._map.createLayer(str(layerId), grid)
+		self._layer = self._map.createLayer(str(layerId), grid)
 		grid.thisown = 0
-
+		
 		self._cameradlg = CameraEditor(self.engine, self._addMap, self._clean, self._map, self._layer)
 		
 	def _addMap(self):
@@ -135,6 +156,49 @@
 			return
 		
 		mapview.save()
+		
+	def importFile(self, path, filename):
+		file = os.path.normpath(os.path.join(path, filename))
+		# FIXME: This is necassary for the files to be loaded properly.
+		#		 The loader should be fixed to support native (windows)
+		#		 path separators.
+		file = file.replace('\\', '/') 
+		
+		try:
+			if os.path.isfile(file):
+				loaders.loadImportFile(file, self.engine)
+			else:
+				raise file+ " is not a file!"
+		except:
+			traceback.print_exc(sys.exc_info()[1])
+			errormsg = u"Importing file failed:\n"
+			errormsg += u"File: "+unicode(file)+u"\n"
+			errormsg += u"Error: "+unicode(sys.exc_info()[1])
+			ErrorDialog(errormsg)
+			return None
+			
+	def importDir(self, path, filename=""):
+		if os.path.isdir(os.path.join(path, filename)):
+			path = os.path.join(path, filename)
+			path = os.path.normpath(path)
+		
+		# FIXME: This is necassary for the files to be loaded properly.
+		#		 The loader should be fixed to support native (windows)
+		#		 path separators.
+		path = path.replace('\\', '/') 
+		
+		try:
+			if os.path.isdir(path):
+				loaders.loadImportDirRec(path, self.engine)
+			else:
+				raise file+ " is not a directory!"
+		except:
+			traceback.print_exc(sys.exc_info()[1])
+			errormsg = u"Importing directory failed:\n"
+			errormsg += u"File: "+unicode(file)+u"\n"
+			errormsg += u"Error: "+unicode(sys.exc_info()[1])
+			ErrorDialog(errormsg)
+			return None
 
 class CameraEditor(object):
 	"""