| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191 |
- /*
- Copyright (C) 2012 by Ivan Safrin
-
- Permission is hereby granted, free of charge, to any person obtaining a copy
- of this software and associated documentation files (the "Software"), to deal
- in the Software without restriction, including without limitation the rights
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- copies of the Software, and to permit persons to whom the Software is
- furnished to do so, subject to the following conditions:
-
- The above copyright notice and this permission notice shall be included in
- all copies or substantial portions of the Software.
-
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- THE SOFTWARE.
- */
-
- #include "PolycodeToolLauncher.h"
- #if defined(__APPLE__) && defined(__MACH__)
- #include "PolyCocoaCore.h"
- #endif
- GenericRunner::GenericRunner(String app, String file, String inFolder) : Threaded() {
- this->app = app;
- this->file = file;
- this->inFolder = inFolder;
- }
- void GenericRunner::runThread() {
- #if defined(__APPLE__) && defined(__MACH__)
- CocoaCore *cocoaCore = (CocoaCore*) CoreServices::getInstance()->getCore();
- cocoaCore->openFileWithApplication(file, app);
- #else
- String ret = CoreServices::getInstance()->getCore()->executeExternalCommand(app, file, inFolder);
- #endif
- }
- PolycodeRunner::PolycodeRunner(String polyappPath) : Threaded() {
- this->polyappPath = polyappPath;
- }
- void PolycodeRunner::runThread() {
- String polycodeBasePath = CoreServices::getInstance()->getCore()->getDefaultWorkingDirectory();
- #if defined(__APPLE__) && defined(__MACH__)
- String command = "../MacOS/PolycodePlayer";
- String inFolder = polycodeBasePath+"/Standalone/Player/PolycodePlayer.app/Contents/Resources";
- String args = polyappPath;
- #elif defined _WINDOWS
- String command = "\""+polycodeBasePath+"/Standalone/Player/PolycodePlayer.exe\"";
- String args = polyappPath;
- String inFolder = polycodeBasePath+"/Standalone/Player";
- #else
- String command = "./PolycodePlayer";
- String inFolder = polycodeBasePath+"/Standalone/Player";
- String args = polyappPath;
- #endif
- String ret = CoreServices::getInstance()->getCore()->executeExternalCommand(command, args, inFolder);
- CoreServices::getInstance()->getCore()->removeDiskItem(polyappPath);
- }
- PolycodeToolLauncher::PolycodeToolLauncher() {
- }
- PolycodeToolLauncher::~PolycodeToolLauncher() {
- }
- String PolycodeToolLauncher::generateTempPath(PolycodeProject *project) {
- #ifdef _WINDOWS
- wchar_t buf[2048];
- GetTempPath(2048, buf);
- String retString = String(buf)+project->getProjectName();
- printf("TEMP_PATH: %s\n", retString.c_str());
- return retString;
- #else
- return "/tmp/"+project->getProjectName();
- #endif
- }
- void PolycodeToolLauncher::buildProject(PolycodeProject *project, String destinationPath, bool compileScripts) {
- PolycodeConsole::print("Building project: "+project->getProjectName() + "\n");
- project->saveFile();
- String projectBasePath = project->getRootFolder();
- String projectPath = project->getProjectFile();
-
-
- String polycodeBasePath = CoreServices::getInstance()->getCore()->getDefaultWorkingDirectory();
-
- #ifdef _WINDOWS
- String targetFolder = projectBasePath;
- String command = "\""+polycodeBasePath+"/Standalone/Bin/polybuild.exe\"";
- String args = "--config=\""+projectPath+"\" --out=\""+destinationPath+"\" --compileScripts=\""+((compileScripts)?"true":"false")+"\"";
- String ret = CoreServices::getInstance()->getCore()->executeExternalCommand(command, args, targetFolder);
- #else
- String command = polycodeBasePath+"/Standalone/Bin/polybuild";
- String inFolder = projectBasePath;
- String args = "--config=\""+projectPath+"\" --out=\""+destinationPath+"\" --compileScripts=\""+((compileScripts)?"true":"false")+"\"";
- String ret = CoreServices::getInstance()->getCore()->executeExternalCommand(command, args, inFolder);
- // PolycodeConsole::print(ret);
- #endif
- }
- String PolycodeToolLauncher::importAssets(String sourceFile, String inFolder, bool addMeshes, String prefix, bool swapZY, bool generateTangents, bool listOnly, bool writeNormals, bool writeTangents, bool writeColors, bool writeBoneWeights, bool writeUVs, bool writeSecondaryUVs) {
- String ret;
- String polycodeBasePath = CoreServices::getInstance()->getCore()->getDefaultWorkingDirectory();
-
- String args = "\""+sourceFile+"\"";
- if(listOnly) {
- args = "-l "+args;
- }
- if(addMeshes) {
- args = "-a "+args;
- }
- if(swapZY) {
- args = "-s "+args;
- }
- if(generateTangents) {
- args = "-t "+args;
- }
- if(writeNormals) {
- args = "-n "+args;
- }
- if(writeTangents) {
- args = "-g "+args;
- }
- if(writeColors) {
- args = "-c "+args;
- }
- if(writeBoneWeights) {
- args = "-w "+args;
- }
- if(writeUVs) {
- args = "-u "+args;
- }
- if(writeSecondaryUVs) {
- args = "-v "+args;
- }
-
- if(prefix != "") {
- args = "-p "+prefix+" "+args;
- }
-
-
- #ifdef _WINDOWS
- String command = "\""+polycodeBasePath+"/Standalone/Bin/polyimport.exe\"";
- ret = CoreServices::getInstance()->getCore()->executeExternalCommand(command, args, inFolder);
- #else
- String command = polycodeBasePath+"/Standalone/Bin/polyimport";
- ret = CoreServices::getInstance()->getCore()->executeExternalCommand(command, args, inFolder);
- #endif
- return ret;
- }
- void PolycodeToolLauncher::openExternalEditor(String app, String file, String inFolder) {
- GenericRunner *runner = new GenericRunner(app, "\""+file+"\"", inFolder);
- CoreServices::getInstance()->getCore()->createThread(runner);
- }
- void PolycodeToolLauncher::runPolyapp(String polyappPath) {
- PolycodeConsole::clearBacktraces();
-
- #if defined(__APPLE__) && defined(__MACH__)
- CocoaCore *cocoaCore = (CocoaCore*) CoreServices::getInstance()->getCore();
- String polycodeBasePath = CoreServices::getInstance()->getCore()->getDefaultWorkingDirectory();
- String command = polycodeBasePath+"/Standalone/Player/PolycodePlayer.app";
-
- cocoaCore->openFileWithApplication(polyappPath, command);
- #else
- PolycodeRunner *runner = new PolycodeRunner(polyappPath);
- CoreServices::getInstance()->getCore()->createThread(runner);
- #endif
- }
|