OSXScriptLauncher.cxx 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. /* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
  2. file Copyright.txt or https://cmake.org/licensing for details. */
  3. #include "cmsys/FStream.hxx"
  4. #include "cmsys/Process.h"
  5. #include "cmsys/SystemTools.hxx"
  6. #include <iostream>
  7. #include <stddef.h>
  8. #include <string>
  9. #include <vector>
  10. #include <CoreFoundation/CoreFoundation.h>
  11. // For the PATH_MAX constant
  12. #include <sys/syslimits.h>
  13. #define DebugError(x) \
  14. ofs << x << std::endl; \
  15. std::cout << x << std::endl
  16. int main(int argc, char* argv[])
  17. {
  18. // if ( cmsys::SystemTools::FileExists(
  19. cmsys::ofstream ofs("/tmp/output.txt");
  20. CFStringRef fileName;
  21. CFBundleRef appBundle;
  22. CFURLRef scriptFileURL;
  23. UInt8* path;
  24. // get CF URL for script
  25. if (!(appBundle = CFBundleGetMainBundle())) {
  26. DebugError("Cannot get main bundle");
  27. return 1;
  28. }
  29. fileName = CFSTR("RuntimeScript");
  30. if (!(scriptFileURL =
  31. CFBundleCopyResourceURL(appBundle, fileName, nullptr, nullptr))) {
  32. DebugError("CFBundleCopyResourceURL failed");
  33. return 1;
  34. }
  35. // create path string
  36. if (!(path = new UInt8[PATH_MAX])) {
  37. return 1;
  38. }
  39. // get the file system path of the url as a cstring
  40. // in an encoding suitable for posix apis
  41. if (!CFURLGetFileSystemRepresentation(scriptFileURL, true, path, PATH_MAX)) {
  42. DebugError("CFURLGetFileSystemRepresentation failed");
  43. return 1;
  44. }
  45. // dispose of the CF variable
  46. CFRelease(scriptFileURL);
  47. std::string fullScriptPath = reinterpret_cast<char*>(path);
  48. delete[] path;
  49. if (!cmsys::SystemTools::FileExists(fullScriptPath.c_str())) {
  50. return 1;
  51. }
  52. std::string scriptDirectory =
  53. cmsys::SystemTools::GetFilenamePath(fullScriptPath);
  54. ofs << fullScriptPath << std::endl;
  55. std::vector<const char*> args;
  56. args.push_back(fullScriptPath.c_str());
  57. int cc;
  58. for (cc = 1; cc < argc; ++cc) {
  59. args.push_back(argv[cc]);
  60. }
  61. args.push_back(nullptr);
  62. cmsysProcess* cp = cmsysProcess_New();
  63. cmsysProcess_SetCommand(cp, args.data());
  64. cmsysProcess_SetWorkingDirectory(cp, scriptDirectory.c_str());
  65. cmsysProcess_SetOption(cp, cmsysProcess_Option_HideWindow, 1);
  66. cmsysProcess_SetTimeout(cp, 0);
  67. cmsysProcess_Execute(cp);
  68. std::vector<char> tempOutput;
  69. char* data;
  70. int length;
  71. while (cmsysProcess_WaitForData(cp, &data, &length, nullptr)) {
  72. // Translate NULL characters in the output into valid text.
  73. for (int i = 0; i < length; ++i) {
  74. if (data[i] == '\0') {
  75. data[i] = ' ';
  76. }
  77. }
  78. std::cout.write(data, length);
  79. }
  80. cmsysProcess_WaitForExit(cp, nullptr);
  81. bool result = true;
  82. if (cmsysProcess_GetState(cp) == cmsysProcess_State_Exited) {
  83. if (cmsysProcess_GetExitValue(cp) != 0) {
  84. result = false;
  85. }
  86. } else if (cmsysProcess_GetState(cp) == cmsysProcess_State_Exception) {
  87. const char* exception_str = cmsysProcess_GetExceptionString(cp);
  88. std::cerr << exception_str << std::endl;
  89. result = false;
  90. } else if (cmsysProcess_GetState(cp) == cmsysProcess_State_Error) {
  91. const char* error_str = cmsysProcess_GetErrorString(cp);
  92. std::cerr << error_str << std::endl;
  93. result = false;
  94. } else if (cmsysProcess_GetState(cp) == cmsysProcess_State_Expired) {
  95. const char* error_str = "Process terminated due to timeout\n";
  96. std::cerr << error_str << std::endl;
  97. result = false;
  98. }
  99. cmsysProcess_Delete(cp);
  100. return 0;
  101. }