ToolEnvironment.cpp 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. //
  2. // Copyright (c) 2014-2016 THUNDERBEAST GAMES LLC
  3. //
  4. // Permission is hereby granted, free of charge, to any person obtaining a copy
  5. // of this software and associated documentation files (the "Software"), to deal
  6. // in the Software without restriction, including without limitation the rights
  7. // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  8. // copies of the Software, and to permit persons to whom the Software is
  9. // furnished to do so, subject to the following conditions:
  10. //
  11. // The above copyright notice and this permission notice shall be included in
  12. // all copies or substantial portions of the Software.
  13. //
  14. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  19. // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  20. // THE SOFTWARE.
  21. //
  22. // before resource system exists so use rapidjson directly
  23. #include <rapidjson/document.h>
  24. #include <rapidjson/prettywriter.h>
  25. #include <rapidjson/filestream.h>
  26. #include <Atomic/IO/Log.h>
  27. #include <Atomic/IO/FileSystem.h>
  28. #include <Atomic/IO/File.h>
  29. #include "ToolEnvironment.h"
  30. using namespace rapidjson;
  31. namespace ToolCore
  32. {
  33. ToolEnvironment::ToolEnvironment(Context* context) : Object(context),
  34. toolPrefs_(new ToolPrefs(context))
  35. {
  36. }
  37. ToolEnvironment::~ToolEnvironment()
  38. {
  39. }
  40. bool ToolEnvironment::InitFromPackage()
  41. {
  42. toolPrefs_->Load();
  43. FileSystem* fileSystem = GetSubsystem<FileSystem>();
  44. #ifdef ATOMIC_PLATFORM_WINDOWS
  45. editorBinary_ = fileSystem->GetProgramDir() + "AtomicEditor.exe";
  46. String resourcesDir = fileSystem->GetProgramDir() + "Resources/";
  47. #elif ATOMIC_PLATFORM_LINUX
  48. editorBinary_ = fileSystem->GetProgramDir() + "AtomicEditor";
  49. String resourcesDir = fileSystem->GetProgramDir() + "Resources/";
  50. #else
  51. editorBinary_ = fileSystem->GetProgramDir() + "AtomicEditor";
  52. String resourcesDir = GetPath(RemoveTrailingSlash(fileSystem->GetProgramDir())) + "Resources/";
  53. #endif
  54. //TODO: move this to deployment stuff
  55. playerAppFolder_ = resourcesDir + "ToolData/Deployment/MacOS/AtomicPlayer.app/";
  56. playerBinary_ = resourcesDir + "ToolData/Deployment/Windows/x64/AtomicPlayer.exe";
  57. resourceCoreDataDir_ = resourcesDir + "CoreData";
  58. resourcePlayerDataDir_ = resourcesDir + "PlayerData";
  59. toolDataDir_ = resourcesDir + "ToolData/";
  60. // AtomicNET
  61. // atomicNETNuGetBinary_ = ToString("%sBuild/Managed/nuget/nuget.exe", rootSourceDir_.CString());
  62. atomicNETRootDir_ = resourcesDir + "ToolData/AtomicNET/";
  63. atomicNETCoreAssemblyDir_ = atomicNETRootDir_ + "Release/";
  64. #ifdef ATOMIC_PLATFORM_OSX
  65. monoExecutableDir_ = "/Library/Frameworks/Mono.framework/Versions/Current/Commands/";
  66. atomicNETNuGetBinary_ = monoExecutableDir_ + "nuget";
  67. #endif
  68. return true;
  69. }
  70. bool ToolEnvironment::InitFromJSON(bool atomicTool)
  71. {
  72. toolPrefs_->Load();
  73. // make sure config path is initialized
  74. GetDevConfigFilename();
  75. FileSystem* fileSystem = GetSubsystem<FileSystem>();
  76. if (atomicTool || !fileSystem->FileExists(devConfigFilename_))
  77. {
  78. // default to build directories
  79. SetRootSourceDir(ATOMIC_ROOT_SOURCE_DIR);
  80. SetRootBuildDir(ATOMIC_ROOT_BUILD_DIR, true);
  81. return true;
  82. }
  83. File jsonFile(context_, devConfigFilename_);
  84. if (!jsonFile.IsOpen())
  85. return false;
  86. String json;
  87. jsonFile.ReadText(json);
  88. if (!json.Length())
  89. return false;
  90. rapidjson::Document document;
  91. if (document.Parse<0>(json.CString()).HasParseError())
  92. {
  93. return false;
  94. }
  95. const Value::Member* rootSourceDir = document.FindMember("rootSourceDir");
  96. if (rootSourceDir && rootSourceDir->value.IsString())
  97. SetRootSourceDir(rootSourceDir->value.GetString());
  98. else
  99. return false;
  100. const Value::Member* rootBuildDir = document.FindMember("rootBuildDir");
  101. if (rootBuildDir && rootBuildDir->value.IsString())
  102. SetRootBuildDir(rootBuildDir->value.GetString(), true);
  103. else
  104. return false;
  105. return true;
  106. }
  107. const String& ToolEnvironment::GetDevConfigFilename()
  108. {
  109. if (devConfigFilename_.Length())
  110. return devConfigFilename_;
  111. FileSystem* fileSystem = GetSubsystem<FileSystem>();
  112. #ifdef ATOMIC_PLATFORM_OSX
  113. devConfigFilename_ = fileSystem->GetUserDocumentsDir() + ".atomicgameengine/toolEnv.json";
  114. #elif ATOMIC_PLATFORM_WINDOWS
  115. devConfigFilename_ = fileSystem->GetUserDocumentsDir() + "AtomicGameEngine/toolEnv.json";
  116. #else
  117. devConfigFilename_ = fileSystem->GetUserDocumentsDir() + ".atomicgameengine/toolEnv.json";
  118. #endif
  119. return devConfigFilename_;
  120. }
  121. void ToolEnvironment::SetRootSourceDir(const String& sourceDir)
  122. {
  123. rootSourceDir_ = AddTrailingSlash(sourceDir);
  124. resourceCoreDataDir_ = rootSourceDir_ + "Resources/CoreData";
  125. resourcePlayerDataDir_ = rootSourceDir_ + "Resources/PlayerData";
  126. resourceEditorDataDir_ = rootSourceDir_ + "Resources/EditorData";
  127. toolDataDir_ = rootSourceDir_ + "Data/AtomicEditor/";
  128. // AtomicNET
  129. #ifdef ATOMIC_DEBUG
  130. String config = "Debug";
  131. #else
  132. String config = "Release";
  133. #endif
  134. atomicNETRootDir_ = rootSourceDir_ + "Artifacts/AtomicNET/";
  135. atomicNETCoreAssemblyDir_ = rootSourceDir_ + "Artifacts/AtomicNET/" + config + "/";
  136. #if defined ATOMIC_PLATFORM_WINDOWS || defined ATOMIC_PLATFORM_LINUX
  137. atomicNETNuGetBinary_ = ToString("%sBuild/Managed/nuget/nuget.exe", rootSourceDir_.CString());
  138. #endif
  139. #ifdef ATOMIC_PLATFORM_OSX
  140. monoExecutableDir_ = "/Library/Frameworks/Mono.framework/Versions/Current/Commands/";
  141. atomicNETNuGetBinary_ = monoExecutableDir_ + "nuget";
  142. #endif
  143. }
  144. void ToolEnvironment::SetRootBuildDir(const String& buildDir, bool setBinaryPaths)
  145. {
  146. FileSystem* fileSystem = GetSubsystem<FileSystem>();
  147. rootBuildDir_ = AddTrailingSlash(buildDir);
  148. if (setBinaryPaths)
  149. {
  150. #ifdef ATOMIC_PLATFORM_WINDOWS
  151. #ifdef _DEBUG
  152. playerBinary_ = rootBuildDir_ + "Source/AtomicPlayer/Application/Debug/AtomicPlayer.exe";
  153. editorBinary_ = rootBuildDir_ + "Source/AtomicEditor/Debug/AtomicEditor.exe";
  154. #else
  155. playerBinary_ = rootBuildDir_ + "Source/AtomicPlayer/Application/Release/AtomicPlayer.exe";
  156. editorBinary_ = rootBuildDir_ + "Source/AtomicEditor/Release/AtomicEditor.exe";
  157. #endif
  158. // some build tools like ninja don't use Release/Debug folders
  159. if (!fileSystem->FileExists(playerBinary_))
  160. playerBinary_ = rootBuildDir_ + "Source/AtomicPlayer/Application/AtomicPlayer.exe";
  161. if (!fileSystem->FileExists(editorBinary_))
  162. editorBinary_ = rootBuildDir_ + "Source/AtomicEditor/AtomicEditor.exe";
  163. playerAppFolder_ = rootSourceDir_ + "Data/AtomicEditor/Deployment/MacOS/AtomicPlayer.app";
  164. #elif ATOMIC_PLATFORM_OSX
  165. #ifdef ATOMIC_XCODE
  166. playerBinary_ = rootBuildDir_ + "Source/AtomicPlayer/" + CMAKE_INTDIR + "/AtomicPlayer.app/Contents/MacOS/AtomicPlayer";
  167. editorBinary_ = rootBuildDir_ + "Source/AtomicEditor/" + CMAKE_INTDIR + "/AtomicEditor.app/Contents/MacOS/AtomicEditor";
  168. #else
  169. playerBinary_ = rootBuildDir_ + "Source/AtomicPlayer/Application/AtomicPlayer.app/Contents/MacOS/AtomicPlayer";
  170. playerAppFolder_ = rootBuildDir_ + "Source/AtomicPlayer/Application/AtomicPlayer.app/";
  171. editorBinary_ = rootBuildDir_ + "Source/AtomicEditor/AtomicEditor.app/Contents/MacOS/AtomicEditor";
  172. #endif
  173. #else
  174. playerBinary_ = rootBuildDir_ + "Source/AtomicPlayer/Application/AtomicPlayer";
  175. editorBinary_ = rootBuildDir_ + "Source/AtomicEditor/AtomicEditor";
  176. #endif
  177. }
  178. }
  179. String ToolEnvironment::GetIOSDeployBinary()
  180. {
  181. return GetToolDataDir() + "Deployment/IOS/ios-deploy/ios-deploy";
  182. }
  183. void ToolEnvironment::Dump()
  184. {
  185. ATOMIC_LOGINFOF("Root Source Dir: %s", rootSourceDir_.CString());
  186. ATOMIC_LOGINFOF("Root Build Dir: %s", rootBuildDir_.CString());
  187. ATOMIC_LOGINFOF("Core Resource Dir: %s", resourceCoreDataDir_.CString());
  188. ATOMIC_LOGINFOF("Player Resource Dir: %s", resourcePlayerDataDir_.CString());
  189. ATOMIC_LOGINFOF("Editor Resource Dir: %s", resourceEditorDataDir_.CString());
  190. ATOMIC_LOGINFOF("Editor Binary: %s", editorBinary_.CString());
  191. ATOMIC_LOGINFOF("Player Binary: %s", playerBinary_.CString());
  192. ATOMIC_LOGINFOF("Tool Binary: %s", toolBinary_.CString());
  193. ATOMIC_LOGINFOF("Tool Data Dir: %s", toolDataDir_.CString());
  194. ATOMIC_LOGINFOF("Deployment Data Dir: %s", deploymentDataDir_.CString());
  195. ATOMIC_LOGINFOF("Dev Config File: %s", devConfigFilename_.CString());
  196. }
  197. }