Commit 6581a46c authored by sumpfralle's avatar sumpfralle

fixed various small problems of the filename/URI handling


git-svn-id: https://pycam.svn.sourceforge.net/svnroot/pycam/trunk@1026 bbaffbd6-741e-11dd-a85d-61de82d9cad9
parent f411d3a4
...@@ -100,10 +100,10 @@ def show_gui(inputfile=None, task_settings_file=None): ...@@ -100,10 +100,10 @@ def show_gui(inputfile=None, task_settings_file=None):
gui = gui_class() gui = gui_class()
# load the given model or the default # load the given model or the default
if inputfile is None: if not inputfile:
default_model = get_default_model() default_model = get_default_model()
if isinstance(default_model, basestring): if isinstance(default_model, (basestring, pycam.Utils.URIHandler)):
gui.load_model_file(filename=default_model) gui.load_model_file(filename=default_model, store_filename=False)
else: else:
gui.load_model(default_model) gui.load_model(default_model)
else: else:
...@@ -113,6 +113,9 @@ def show_gui(inputfile=None, task_settings_file=None): ...@@ -113,6 +113,9 @@ def show_gui(inputfile=None, task_settings_file=None):
if not task_settings_file is None: if not task_settings_file is None:
gui.open_task_settings_file(task_settings_file) gui.open_task_settings_file(task_settings_file)
# tell the GUI to empty the "undo" queue
gui.finish_startup()
# open the GUI # open the GUI
gui.mainloop() gui.mainloop()
# no error -> return no error code # no error -> return no error code
...@@ -134,14 +137,16 @@ def get_default_model(): ...@@ -134,14 +137,16 @@ def get_default_model():
return pycam.Importers.TestModel.get_test_model() return pycam.Importers.TestModel.get_test_model()
def load_model_file(filename, program_locations, unit=None): def load_model_file(filename, program_locations, unit=None):
filename = os.path.expanduser(filename) uri = pycam.Utils.URIHandler(filename)
if not os.path.isfile(filename): if uri.is_local():
log.warn("The input file ('%s') was not found!" % filename) uri = pycam.Utils.URIHandler(os.path.expanduser(str(filename)))
if not uri.exists():
log.warn("The input file ('%s') was not found!" % uri)
return None return None
importer = pycam.Importers.detect_file_type(filename)[1] importer = pycam.Importers.detect_file_type(uri)[1]
model = importer(filename, program_locations=program_locations, unit=unit) model = importer(uri, program_locations=program_locations, unit=unit)
if model is None: if model is None:
log.warn("Failed to load the model file (%s)." % filename) log.warn("Failed to load the model file (%s)." % uri)
return None return None
else: else:
return model return model
...@@ -167,7 +172,7 @@ def execute(parser, opts, args, pycam): ...@@ -167,7 +172,7 @@ def execute(parser, opts, args, pycam):
pycam.Utils.setproctitle("pycam") pycam.Utils.setproctitle("pycam")
if len(args) > 0: if len(args) > 0:
inputfile = os.path.expanduser(args[0]) inputfile = pycam.Utils.URIHandler(args[0])
else: else:
inputfile = None inputfile = None
......
...@@ -1052,6 +1052,11 @@ caused by careless DXF/SVG exporting programs.</property> ...@@ -1052,6 +1052,11 @@ caused by careless DXF/SVG exporting programs.</property>
<property name="position">0</property> <property name="position">0</property>
</packing> </packing>
</child> </child>
<child>
<object class="GtkVButtonBox" id="vbuttonbox6">
<property name="visible">True</property>
<property name="orientation">vertical</property>
<property name="layout_style">end</property>
<child> <child>
<object class="GtkLinkButton" id="ModelTransformationsHelp"> <object class="GtkLinkButton" id="ModelTransformationsHelp">
<property name="label">gtk-help</property> <property name="label">gtk-help</property>
...@@ -1065,6 +1070,11 @@ caused by careless DXF/SVG exporting programs.</property> ...@@ -1065,6 +1070,11 @@ caused by careless DXF/SVG exporting programs.</property>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>
<property name="fill">False</property> <property name="fill">False</property>
<property name="position">0</property>
</packing>
</child>
</object>
<packing>
<property name="position">1</property> <property name="position">1</property>
</packing> </packing>
</child> </child>
...@@ -3252,19 +3262,28 @@ Usually you will want to use the cutter radius here to cut around the outline.</ ...@@ -3252,19 +3262,28 @@ Usually you will want to use the cutter radius here to cut around the outline.</
<property name="position">0</property> <property name="position">0</property>
</packing> </packing>
</child> </child>
<child>
<object class="GtkVButtonBox" id="vbuttonbox7">
<property name="visible">True</property>
<property name="orientation">vertical</property>
<property name="layout_style">end</property>
<child> <child>
<object class="GtkLinkButton" id="BoundsHelp"> <object class="GtkLinkButton" id="BoundsHelp">
<property name="label">gtk-help</property> <property name="label">gtk-help</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="can_focus">True</property> <property name="can_focus">True</property>
<property name="receives_default">True</property> <property name="receives_default">True</property>
<property name="has_tooltip">True</property>
<property name="relief">none</property> <property name="relief">none</property>
<property name="use_stock">True</property> <property name="use_stock">True</property>
<property name="uri">http://sourceforge.net/apps/mediawiki/pycam/index.php?title=BoundsSettings</property> <property name="uri">http://sourceforge.net/apps/mediawiki/pycam/index.php?title=BoundsSettings</property>
</object> </object>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>
<property name="position">0</property>
</packing>
</child>
</object>
<packing>
<property name="position">1</property> <property name="position">1</property>
</packing> </packing>
</child> </child>
......
...@@ -1289,7 +1289,7 @@ class ProjectGui: ...@@ -1289,7 +1289,7 @@ class ProjectGui:
""" """
uri = pycam.Utils.URIHandler(filename) uri = pycam.Utils.URIHandler(filename)
self.last_model_uri = uri self.last_model_uri = uri
if self.last_model_uri: if not self.last_model_uri:
self.window.set_title("PyCAM") self.window.set_title("PyCAM")
else: else:
short_name = os.path.basename(uri.get_path()) short_name = os.path.basename(uri.get_path())
...@@ -2017,7 +2017,7 @@ class ProjectGui: ...@@ -2017,7 +2017,7 @@ class ProjectGui:
def export_from_font_dialog(self, widget=None): def export_from_font_dialog(self, widget=None):
text_model = self.get_font_dialog_text_rendered() text_model = self.get_font_dialog_text_rendered()
if text_model and (not text_model.maxx is None): if text_model and (not text_model.maxx is None):
self.save_model(model=text_model) self.save_model(model=text_model, store_filename=False)
def copy_font_dialog_to_clipboard(self, widget=None): def copy_font_dialog_to_clipboard(self, widget=None):
text_model = self.get_font_dialog_text_rendered() text_model = self.get_font_dialog_text_rendered()
...@@ -2713,7 +2713,8 @@ class ProjectGui: ...@@ -2713,7 +2713,8 @@ class ProjectGui:
return filename return filename
@gui_activity_guard @gui_activity_guard
def save_model(self, widget=None, filename=None, model=None): def save_model(self, widget=None, filename=None, model=None,
store_filename=True):
if model is None: if model is None:
model = self.model model = self.model
if not model.is_export_supported(): if not model.is_export_supported():
...@@ -2723,7 +2724,8 @@ class ProjectGui: ...@@ -2723,7 +2724,8 @@ class ProjectGui:
# get the filename # get the filename
if callable(filename): if callable(filename):
filename = filename() filename = filename()
if not isinstance(filename, basestring): uri = None
if not isinstance(filename, (basestring, pycam.Utils.URIHandler)):
# we open a dialog # we open a dialog
# determine the file type # determine the file type
# TODO: this needs to be decided by the exporter code # TODO: this needs to be decided by the exporter code
...@@ -2740,12 +2742,20 @@ class ProjectGui: ...@@ -2740,12 +2742,20 @@ class ProjectGui:
mode_load=False, type_filter=type_filter, mode_load=False, type_filter=type_filter,
filename_templates=(self.last_model_uri,)) filename_templates=(self.last_model_uri,))
if filename: if filename:
uri = pycam.Utils.URIHandler(filename)
if uri.is_local() and store_filename:
self.set_model_filename(filename) self.set_model_filename(filename)
else:
uri = pycam.Utils.URIHandler(filename)
# no filename given -> exit # no filename given -> exit
if not filename: if not uri:
return return
if not uri.is_local():
log.error("Unable to write file to a non-local " + \
"destination: %s" % uri)
else:
try: try:
file_in = open(filename, "w") file_in = open(uri.get_local_path(), "w")
model.export(comment=self.get_meta_data(), model.export(comment=self.get_meta_data(),
unit=self.settings.get("unit")).write(file_in) unit=self.settings.get("unit")).write(file_in)
file_in.close() file_in.close()
...@@ -2754,6 +2764,7 @@ class ProjectGui: ...@@ -2754,6 +2764,7 @@ class ProjectGui:
else: else:
log.info("Successfully stored the current model as '%s'." % \ log.info("Successfully stored the current model as '%s'." % \
str(filename)) str(filename))
self.update_save_actions()
self.add_to_recent_file_list(filename) self.add_to_recent_file_list(filename)
@gui_activity_guard @gui_activity_guard
...@@ -3049,7 +3060,7 @@ class ProjectGui: ...@@ -3049,7 +3060,7 @@ class ProjectGui:
@gui_activity_guard @gui_activity_guard
@progress_activity_guard @progress_activity_guard
def load_model_file(self, widget=None, filename=None): def load_model_file(self, widget=None, filename=None, store_filename=True):
if callable(filename): if callable(filename):
filename = filename() filename = filename()
if not filename: if not filename:
...@@ -3066,6 +3077,7 @@ class ProjectGui: ...@@ -3066,6 +3077,7 @@ class ProjectGui:
unit=self.settings.get("unit"), unit=self.settings.get("unit"),
fonts_cache=self._fonts_cache, fonts_cache=self._fonts_cache,
callback=self.update_progress_bar)): callback=self.update_progress_bar)):
if store_filename:
self.set_model_filename(filename) self.set_model_filename(filename)
self.add_to_recent_file_list(filename) self.add_to_recent_file_list(filename)
return True return True
...@@ -3095,6 +3107,14 @@ class ProjectGui: ...@@ -3095,6 +3107,14 @@ class ProjectGui:
else: else:
self.add_to_recent_file_list(filename) self.add_to_recent_file_list(filename)
def finish_startup(self):
""" This function is called by the pycam script after everything is
set up properly.
"""
# empty the "undo" states (accumulated by loading the defualt model)
while self._undo_states:
self._undo_states.pop(0)
def open_task_settings_file(self, filename): def open_task_settings_file(self, filename):
""" This function is used by the commandline handler """ """ This function is used by the commandline handler """
self.last_task_settings_uri = pycam.Utils.URIHandler(filename) self.last_task_settings_uri = pycam.Utils.URIHandler(filename)
...@@ -3610,7 +3630,7 @@ class ProjectGui: ...@@ -3610,7 +3630,7 @@ class ProjectGui:
def save_task_settings_file(self, widget=None, filename=None): def save_task_settings_file(self, widget=None, filename=None):
if callable(filename): if callable(filename):
filename = filename() filename = filename()
if not isinstance(filename, basestring): if not isinstance(filename, (basestring, pycam.Utils.URIHandler)):
# we open a dialog # we open a dialog
filename = self.get_filename_via_dialog("Save settings to ...", filename = self.get_filename_via_dialog("Save settings to ...",
mode_load=False, type_filter=FILTER_CONFIG, mode_load=False, type_filter=FILTER_CONFIG,
...@@ -3626,7 +3646,9 @@ class ProjectGui: ...@@ -3626,7 +3646,9 @@ class ProjectGui:
self.process_list, self.bounds_list, self.task_list): self.process_list, self.bounds_list, self.task_list):
log.error("Failed to save settings file") log.error("Failed to save settings file")
else: else:
log.info("Task settings written to %s" % filename)
self.add_to_recent_file_list(filename) self.add_to_recent_file_list(filename)
self.update_save_actions()
def toggle_progress_bar(self, status): def toggle_progress_bar(self, status):
# always hide the progress button - it will be enabled later # always hide the progress button - it will be enabled later
...@@ -4049,8 +4071,10 @@ class ProjectGui: ...@@ -4049,8 +4071,10 @@ class ProjectGui:
valid_templates = [] valid_templates = []
if filename_templates: if filename_templates:
for template in filename_templates: for template in filename_templates:
if hasattr(template, "get_local_path"): if not template:
valid_templates.append(template.get_local_path()) continue
elif hasattr(template, "get_path"):
valid_templates.append(template.get_path())
else: else:
valid_templates.append(template) valid_templates.append(template)
if valid_templates: if valid_templates:
......
...@@ -854,7 +854,6 @@ def import_model(filename, color_as_height=False, fonts_cache=None, ...@@ -854,7 +854,6 @@ def import_model(filename, color_as_height=False, fonts_cache=None,
try: try:
infile = pycam.Utils.URIHandler(filename).open() infile = pycam.Utils.URIHandler(filename).open()
except IOError, err_msg: except IOError, err_msg:
print pycam.Utils.URIHandler(filename)
log.error("DXFImporter: Failed to read file (%s): %s" \ log.error("DXFImporter: Failed to read file (%s): %s" \
% (filename, err_msg)) % (filename, err_msg))
return None return None
......
...@@ -24,6 +24,7 @@ along with PyCAM. If not, see <http://www.gnu.org/licenses/>. ...@@ -24,6 +24,7 @@ along with PyCAM. If not, see <http://www.gnu.org/licenses/>.
__all__ = ["STLImporter", "DXFImporter", "SVGImporter", "TestModel"] __all__ = ["STLImporter", "DXFImporter", "SVGImporter", "TestModel"]
import pycam.Utils.log import pycam.Utils.log
import pycam.Utils
import pycam.Importers.DXFImporter import pycam.Importers.DXFImporter
import pycam.Importers.STLImporter import pycam.Importers.STLImporter
import pycam.Importers.SVGImporter import pycam.Importers.SVGImporter
...@@ -35,6 +36,9 @@ log = pycam.Utils.log.get_logger() ...@@ -35,6 +36,9 @@ log = pycam.Utils.log.get_logger()
def detect_file_type(filename, quiet=False): def detect_file_type(filename, quiet=False):
# also accept URI input
uri = pycam.Utils.URIHandler(filename)
filename = uri.get_path()
failure = (None, None) failure = (None, None)
# check all listed importers # check all listed importers
# TODO: this should be done by evaluating the header of the file # TODO: this should be done by evaluating the header of the file
......
...@@ -76,6 +76,8 @@ class URIHandler(object): ...@@ -76,6 +76,8 @@ class URIHandler(object):
def set_location(self, location): def set_location(self, location):
if isinstance(location, URIHandler): if isinstance(location, URIHandler):
self._uri = location._uri self._uri = location._uri
elif not location:
self._uri = urlparse.urlparse(self.DEFAULT_PREFIX)
elif (get_platform() == PLATFORM_WINDOWS) and (location[1:3] == ":\\"): elif (get_platform() == PLATFORM_WINDOWS) and (location[1:3] == ":\\"):
self._uri = urlparse.urlparse(self.DEFAULT_PREFIX + location) self._uri = urlparse.urlparse(self.DEFAULT_PREFIX + location)
else: else:
...@@ -91,7 +93,6 @@ class URIHandler(object): ...@@ -91,7 +93,6 @@ class URIHandler(object):
def get_local_path(self): def get_local_path(self):
if self.is_local(): if self.is_local():
print "LOCAL:", self._uri.path
return self._uri.path return self._uri.path
else: else:
return None return None
...@@ -184,7 +185,6 @@ def get_all_ips(): ...@@ -184,7 +185,6 @@ def get_all_ips():
return cmp(ip1, ip2) return cmp(ip1, ip2)
# non-local IPs first # non-local IPs first
filtered_result.sort(cmp=sort_ip_by_relevance) filtered_result.sort(cmp=sort_ip_by_relevance)
print filtered_result
return filtered_result return filtered_result
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment