diff --git a/CMakeLists.txt b/CMakeLists.txt index 282f08fdf3..4cbb9aebc0 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -4,45 +4,58 @@ cmake_minimum_required(VERSION 2.8.12) set(URANIUM_SCRIPTS_DIR "${CMAKE_SOURCE_DIR}/../uranium/scripts" CACHE DIRECTORY "The location of the scripts directory of the Uranium repository") -# Extract Strings -add_custom_target(extract-messages ${URANIUM_SCRIPTS_DIR}/extract-messages ${CMAKE_SOURCE_DIR} cura) +if(${URANIUM_SCRIPTS_DIR}) + # Extract Strings + add_custom_target(extract-messages ${URANIUM_SCRIPTS_DIR}/extract-messages ${CMAKE_SOURCE_DIR} cura) -# Build Translations -find_package(Gettext) -include(${URANIUM_SCRIPTS_DIR}/ECMPoQmTools.cmake) + # Build Translations + find_package(Gettext) + include(${URANIUM_SCRIPTS_DIR}/ECMPoQmTools.cmake) -if(GETTEXT_FOUND) - # translations target will convert .po files into .mo and .qm as needed. - # The files are checked for a _qt suffix and if it is found, converted to - # qm, otherwise they are converted to .po. - add_custom_target(translations) - # copy-translations can be used to copy the built translation files from the - # build directory to the source resources directory. This is mostly a convenience - # during development, normally you want to simply use the install target to install - # the files along side the rest of the application. - add_custom_target(copy-translations) + if(GETTEXT_FOUND) + # translations target will convert .po files into .mo and .qm as needed. + # The files are checked for a _qt suffix and if it is found, converted to + # qm, otherwise they are converted to .po. + add_custom_target(translations) + # copy-translations can be used to copy the built translation files from the + # build directory to the source resources directory. This is mostly a convenience + # during development, normally you want to simply use the install target to install + # the files along side the rest of the application. + add_custom_target(copy-translations) - #TODO: Properly install the built files. This should be done after we move the applications out of the Uranium repo. - set(languages - en - x-test - ) - foreach(lang ${languages}) - file(GLOB po_files resources/i18n/${lang}/*.po) - foreach(file ${po_files}) - string(REGEX MATCH "qt\\.po$" match "${file}") - if(match) - ecm_process_po_files_as_qm(${lang} PO_FILES ${file}) - else() - string(REGEX REPLACE ".*/(.*).po" "${lang}/\\1.mo" mofile ${file}) - add_custom_command(TARGET translations POST_BUILD COMMAND mkdir ARGS -p ${lang} COMMAND ${GETTEXT_MSGFMT_EXECUTABLE} ARGS ${file} -o ${mofile}) - endif() + #TODO: Properly install the built files. This should be done after we move the applications out of the Uranium repo. + set(languages + en + x-test + ) + foreach(lang ${languages}) + file(GLOB po_files resources/i18n/${lang}/*.po) + foreach(file ${po_files}) + string(REGEX MATCH "qt\\.po$" match "${file}") + if(match) + ecm_process_po_files_as_qm(${lang} PO_FILES ${file}) + else() + string(REGEX REPLACE ".*/(.*).po" "${lang}/\\1.mo" mofile ${file}) + add_custom_command(TARGET translations POST_BUILD COMMAND mkdir ARGS -p ${lang} COMMAND ${GETTEXT_MSGFMT_EXECUTABLE} ARGS ${file} -o ${mofile}) + endif() + endforeach() + + file(GLOB qm_files ${CMAKE_BINARY_DIR}/${lang}/*.qm) + file(GLOB mo_files ${CMAKE_BINARY_DIR}/${lang}/*.mo) + foreach(file ${qm_files} ${mo_files}) + add_custom_command(TARGET copy-translations POST_BUILD COMMAND mkdir ARGS -p ${CMAKE_SOURCE_DIR}/resources/i18n/${lang}/LC_MESSAGES/ COMMAND cp ARGS ${file} ${CMAKE_SOURCE_DIR}/resources/i18n/${lang}/LC_MESSAGES/ COMMENT "Copying ${file}...") + endforeach() endforeach() - - file(GLOB qm_files ${CMAKE_BINARY_DIR}/${lang}/*.qm) - file(GLOB mo_files ${CMAKE_BINARY_DIR}/${lang}/*.mo) - foreach(file ${qm_files} ${mo_files}) - add_custom_command(TARGET copy-translations POST_BUILD COMMAND mkdir ARGS -p ${CMAKE_SOURCE_DIR}/resources/i18n/${lang}/LC_MESSAGES/ COMMAND cp ARGS ${file} ${CMAKE_SOURCE_DIR}/resources/i18n/${lang}/LC_MESSAGES/ COMMENT "Copying ${file}...") - endforeach() - endforeach() + endif() endif() + +include(GNUInstallDirs) +find_package(PythonInterp 3.4.0 REQUIRED) + +set(PYTHON_SITE_PACKAGES_DIR ${CMAKE_INSTALL_LIBDIR}/python${PYTHON_VERSION_MAJOR}.${PYTHON_VERSION_MINOR}/site-packages CACHE PATH "Install location of Python package") +install(DIRECTORY resources DESTINATION ${CMAKE_INSTALL_DATADIR}/cura) +install(DIRECTORY plugins DESTINATION ${CMAKE_INSTALL_LIBDIR}/cura) +file(GLOB cura_SRCS cura/*) +install(FILES ${cura_SRCS} DESTINATION ${PYTHON_SITE_PACKAGES_DIR}/cura) +install(FILES cura_app.py DESTINATION ${CMAKE_INSTALL_BINDIR}) + diff --git a/src/BuildVolume.py b/cura/BuildVolume.py similarity index 100% rename from src/BuildVolume.py rename to cura/BuildVolume.py diff --git a/src/CameraAnimation.py b/cura/CameraAnimation.py similarity index 100% rename from src/CameraAnimation.py rename to cura/CameraAnimation.py diff --git a/src/ConvexHullJob.py b/cura/ConvexHullJob.py similarity index 100% rename from src/ConvexHullJob.py rename to cura/ConvexHullJob.py diff --git a/src/ConvexHullNode.py b/cura/ConvexHullNode.py similarity index 100% rename from src/ConvexHullNode.py rename to cura/ConvexHullNode.py diff --git a/src/CuraApplication.py b/cura/CuraApplication.py similarity index 93% rename from src/CuraApplication.py rename to cura/CuraApplication.py index ddc2f2e404..1b608dd222 100644 --- a/src/CuraApplication.py +++ b/cura/CuraApplication.py @@ -7,6 +7,7 @@ from UM.Scene.Camera import Camera from UM.Scene.Platform import Platform from UM.Math.Vector import Vector from UM.Math.Matrix import Matrix +from UM.Math.Quaternion import Quaternion from UM.Resources import Resources from UM.Scene.ToolHandle import ToolHandle from UM.Scene.Iterator.DepthFirstIterator import DepthFirstIterator @@ -35,6 +36,7 @@ from . import PrintInformation from PyQt5.QtCore import pyqtSlot, QUrl, Qt, pyqtSignal, pyqtProperty from PyQt5.QtGui import QColor +import platform import sys import os.path import numpy @@ -42,10 +44,11 @@ numpy.seterr(all="ignore") class CuraApplication(QtApplication): def __init__(self): + Resources.addResourcePath(os.path.join(QtApplication.getInstallPrefix(), "share", "cura")) if not hasattr(sys, "frozen"): Resources.addResourcePath(os.path.join(os.path.abspath(os.path.dirname(__file__)), "..")) - super().__init__(name = "cura", version = "master") + super().__init__(name = "cura", version = "15.05.90") self.setRequiredPlugins([ "CuraEngineBackend", @@ -72,6 +75,7 @@ class CuraApplication(QtApplication): ## Handle loading of all plugin types (and the backend explicitly) # \sa PluginRegistery def _loadPlugins(self): + self._plugin_registry.addPluginLocation(os.path.join(QtApplication.getInstallPrefix(), "lib", "cura")) if not hasattr(sys, "frozen"): self._plugin_registry.addPluginLocation(os.path.join(os.path.abspath(os.path.dirname(__file__)), "..", "plugins")) @@ -85,6 +89,9 @@ class CuraApplication(QtApplication): self._plugin_registry.loadPlugin("CuraEngineBackend") + def addCommandLineOptions(self, parser): + parser.add_argument("file", nargs="*", help="Files to load after starting the application.") + def run(self): self._i18n_catalog = i18nCatalog("cura"); @@ -153,6 +160,10 @@ class CuraApplication(QtApplication): if self._engine.rootObjects: self.closeSplash() + for file in self.getCommandLineOption("file", []): + job = ReadMeshJob(os.path.abspath(file)) + job.start() + self.exec_() def registerObjects(self, engine): @@ -205,9 +216,7 @@ class CuraApplication(QtApplication): node = self.getController().getScene().findObject(object_id) if node: - transform = node.getLocalTransformation() - transform.setTranslation(Vector(0, 0, 0)) - op = SetTransformOperation(node, transform) + op = SetTransformOperation(node, Vector()) op.push() ## Delete all mesh data on the scene. @@ -240,9 +249,7 @@ class CuraApplication(QtApplication): op = GroupedOperation() for node in nodes: - transform = node.getLocalTransformation() - transform.setTranslation(Vector(0, 0, 0)) - op.addOperation(SetTransformOperation(node, transform)) + op.addOperation(SetTransformOperation(node, Vector())) op.push() @@ -259,8 +266,7 @@ class CuraApplication(QtApplication): op = GroupedOperation() for node in nodes: - transform = Matrix() - op.addOperation(SetTransformOperation(node, transform)) + op.addOperation(SetTransformOperation(node, Vector(), Quaternion(), Vector(1, 1, 1))) op.push() @@ -274,12 +280,18 @@ class CuraApplication(QtApplication): nodes.append(node) - if nodes: - file_name = node.getMeshData().getFileName() + if not nodes: + return - job = ReadMeshJob(file_name) - job.finished.connect(lambda j: node.setMeshData(j.getResult())) - job.start() + for node in nodes: + if not node.getMeshData(): + continue + + file_name = node.getMeshData().getFileName() + if file_name: + job = ReadMeshJob(file_name) + job.finished.connect(lambda j: node.setMeshData(j.getResult())) + job.start() ## Get logging data of the backend engine # \returns \type{string} Logging data diff --git a/src/PlatformPhysics.py b/cura/PlatformPhysics.py similarity index 100% rename from src/PlatformPhysics.py rename to cura/PlatformPhysics.py diff --git a/src/PlatformPhysicsOperation.py b/cura/PlatformPhysicsOperation.py similarity index 100% rename from src/PlatformPhysicsOperation.py rename to cura/PlatformPhysicsOperation.py diff --git a/src/PrintInformation.py b/cura/PrintInformation.py similarity index 100% rename from src/PrintInformation.py rename to cura/PrintInformation.py diff --git a/cura/__init__.py b/cura/__init__.py new file mode 100644 index 0000000000..e69de29bb2 diff --git a/cura.py b/cura_app.py similarity index 60% rename from cura.py rename to cura_app.py index 1d7a515e9b..cfe99284b3 100644 --- a/cura.py +++ b/cura_app.py @@ -3,7 +3,7 @@ # Copyright (c) 2015 Ultimaker B.V. # Cura is released under the terms of the AGPLv3 or higher. -from src.CuraApplication import CuraApplication +import cura.CuraApplication -app = CuraApplication.getInstance() +app = cura.CuraApplication.CuraApplication.getInstance() app.run() diff --git a/plugins/CuraEngineBackend/CuraEngineBackend.py b/plugins/CuraEngineBackend/CuraEngineBackend.py index 9655a4d08e..7c52a3c6cb 100644 --- a/plugins/CuraEngineBackend/CuraEngineBackend.py +++ b/plugins/CuraEngineBackend/CuraEngineBackend.py @@ -26,7 +26,7 @@ class CuraEngineBackend(Backend): super().__init__() # Find out where the engine is located, and how it is called. This depends on how Cura is packaged and which OS we are running on. - default_engine_location = "../PinkUnicornEngine/CuraEngine" + default_engine_location = os.path.join(Application.getInstallPrefix(), "bin", "CuraEngine") if hasattr(sys, "frozen"): default_engine_location = os.path.join(os.path.dirname(os.path.abspath(sys.executable)), "CuraEngine") if sys.platform == "win32": diff --git a/resources/settings/fdmprinter.json b/resources/settings/fdmprinter.json index 16a8cab7f1..657102c5d2 100644 --- a/resources/settings/fdmprinter.json +++ b/resources/settings/fdmprinter.json @@ -912,7 +912,7 @@ "label": "Brim Line Count", "description": "The amount of lines used for a brim: More lines means a larger brim which sticks better, but this also makes your effective print area smaller.", "type": "int", - "default": 1, + "default": 10, "active_if": { "setting": "adhesion_type", "value": "Brim" diff --git a/setup.py b/setup.py index c7804d1534..cfd59c47d2 100644 --- a/setup.py +++ b/setup.py @@ -46,9 +46,9 @@ setup(name="Cura", author_email="d.braam@ultimaker.com", url="http://software.ultimaker.com/", license="GNU AFFERO GENERAL PUBLIC LICENSE (AGPL)", - scripts=["cura.py"], + scripts=["cura_app.py"], #windows=[{"script": "printer.py", "dest_name": "Cura"}], - console=[{"script": "cura.py"}], + console=[{"script": "cura_app.py"}], options={"py2exe": {"skip_archive": False, "includes": includes}}) print("Coping Cura plugins.")