esdlcmd_common.cpp 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. /*##############################################################################
  2. HPCC SYSTEMS software Copyright (C) 2013 HPCC Systems®.
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. http://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. ############################################################################## */
  13. #include <stdio.h>
  14. #include "jlog.hpp"
  15. #include "jfile.hpp"
  16. #include "jargv.hpp"
  17. #include "junicode.hpp"
  18. #include "esdlcmdutils.hpp"
  19. #include "esdlcmd_common.hpp"
  20. void outputMultiExceptions(const IMultiException &me)
  21. {
  22. fprintf(stderr, "\nException(s):\n");
  23. aindex_t count = me.ordinality();
  24. for (aindex_t i=0; i<count; i++)
  25. {
  26. IException& e = me.item(i);
  27. StringBuffer msg;
  28. fprintf(stderr, "%d: %s\n", e.errorCode(), e.errorMessage(msg).str());
  29. }
  30. fprintf(stderr, "\n");
  31. }
  32. static inline void appendFileName(StringBuffer &path, const char *filename)
  33. {
  34. if (!filename)
  35. return;
  36. while (*filename==PATHSEPCHAR)
  37. filename++;
  38. if (!*filename)
  39. return;
  40. if (path.length() && path.charAt(path.length()-1) != PATHSEPCHAR)
  41. path.append(PATHSEPCHAR);
  42. path.append(filename);
  43. }
  44. void saveAsFile(const char * filepath, const char *filename, const char *text, const char *ext)
  45. {
  46. StringBuffer path(filepath);
  47. appendFileName(path, filename);
  48. if(ext && *ext)
  49. path.append(ext);
  50. Owned<IFile> file = createIFile(path.str());
  51. Owned<IFileIO> io = file->open(IFOcreate);
  52. DBGLOG("Writing to file %s", file->queryFilename());
  53. if (io.get())
  54. io->write(0, strlen(text), text);
  55. else
  56. DBGLOG("File %s can't be created", file->queryFilename());
  57. }
  58. //=========================================================================================
  59. #define PE_OFFSET_LOCATION_IN_DOS_SECTION 0x3C
  60. esdlCmdOptionMatchIndicator EsdlCmdCommon::matchCommandLineOption(ArgvIterator &iter, bool finalAttempt)
  61. {
  62. bool boolValue;
  63. if (iter.matchFlag(boolValue, ESDLOPT_HELP))
  64. {
  65. usage();
  66. return EsdlCmdOptionCompletion;
  67. }
  68. if (iter.matchFlag(boolValue, ESDLOPT_VERSION))
  69. {
  70. fprintf(stdout, "%s\n", hpccBuildInfo.buildTag);
  71. return EsdlCmdOptionCompletion;
  72. }
  73. if (iter.matchFlag(optVerbose, ESDL_OPTION_VERBOSE) || iter.matchFlag(optVerbose, ESDL_OPT_VERBOSE))
  74. {
  75. return EsdlCmdOptionMatch;
  76. }
  77. StringAttr traceCategories;
  78. if (iter.matchOption(traceCategories, ESDL_OPTION_TRACE_CATEGORY) || iter.matchOption(traceCategories, ESDL_OPT_TRACE_CATEGORY))
  79. {
  80. parseTraceFlags(traceCategories);
  81. return EsdlCmdOptionMatch;
  82. }
  83. StringAttr tempArg;
  84. if (iter.matchOption(tempArg, "-brk"))
  85. {
  86. #if defined(_WIN32) && defined(_DEBUG)
  87. unsigned id = atoi(tempArg.str());
  88. if (id == 0)
  89. DebugBreak();
  90. else
  91. _CrtSetBreakAlloc(id);
  92. #endif
  93. return EsdlCmdOptionMatch;
  94. }
  95. if (finalAttempt)
  96. {
  97. fprintf(stderr, "\n%s option not recognized\n", iter.query());
  98. usage();
  99. }
  100. return EsdlCmdOptionNoMatch;
  101. }
  102. void EsdlCmdCommon::parseTraceFlags(const char* traceCategories)
  103. {
  104. m_optTraceFlagsGiven = true;
  105. if (!isEmptyString(traceCategories))
  106. {
  107. using Category = std::pair<const char*, IEsdlDefReporter::Flags>;
  108. using CategoryMap = std::list<Category>;
  109. static const CategoryMap definedCategories({
  110. { ESDL_TRACE_CATEGORY_DEVELOPER, IEsdlDefReporter::ReportDeveloperAudience },
  111. { ESDL_TRACE_CATEGORY_OPERATOR, IEsdlDefReporter::ReportOperatorAudience },
  112. { ESDL_TRACE_CATEGORY_USER, IEsdlDefReporter::ReportUserAudience },
  113. { ESDL_TRACE_CATEGORY_ERROR, IEsdlDefReporter::ReportErrorClass },
  114. { ESDL_TRACE_CATEGORY_WARNING, IEsdlDefReporter::ReportWarningClass },
  115. { ESDL_TRACE_CATEGORY_PROGRESS, IEsdlDefReporter::ReportProgressClass },
  116. { ESDL_TRACE_CATEGORY_INFO, IEsdlDefReporter::ReportInfoClass },
  117. { ESDL_TRACE_CATEGORY_IERROR, IEsdlDefReporter::ReportIError },
  118. { ESDL_TRACE_CATEGORY_OERROR, IEsdlDefReporter::ReportOError },
  119. { ESDL_TRACE_CATEGORY_UERROR, IEsdlDefReporter::ReportUError },
  120. { ESDL_TRACE_CATEGORY_IWARNING, IEsdlDefReporter::ReportIWarning },
  121. { ESDL_TRACE_CATEGORY_OWARNING, IEsdlDefReporter::ReportOWarning },
  122. { ESDL_TRACE_CATEGORY_UWARNING, IEsdlDefReporter::ReportUWarning },
  123. { ESDL_TRACE_CATEGORY_DPROGRESS, IEsdlDefReporter::ReportDProgress },
  124. { ESDL_TRACE_CATEGORY_OPROGRESS, IEsdlDefReporter::ReportOProgress },
  125. { ESDL_TRACE_CATEGORY_UPROGRESS, IEsdlDefReporter::ReportUProgress },
  126. { ESDL_TRACE_CATEGORY_DINFO, IEsdlDefReporter::ReportDInfo },
  127. { ESDL_TRACE_CATEGORY_OINFO, IEsdlDefReporter::ReportOInfo },
  128. { ESDL_TRACE_CATEGORY_UINFO, IEsdlDefReporter::ReportUInfo },
  129. });
  130. StringArray categories;
  131. categories.appendList(traceCategories, ",");
  132. for (aindex_t idx = 0; idx < categories.ordinality(); idx++) // not using ForEachItemIn because ordinality may change
  133. {
  134. const char* category = categories.item(idx);
  135. CategoryMap::const_iterator it = std::find_if(definedCategories.begin(), definedCategories.end(), [category](const Category& entry) {
  136. return strieq(category, entry.first);
  137. });
  138. if (it != definedCategories.end())
  139. {
  140. m_actualTraceFlags |= it->second;
  141. }
  142. }
  143. }
  144. }
  145. bool EsdlCmdCommon::finalizeOptions(IProperties *globals)
  146. {
  147. if (!optVerbose)
  148. {
  149. Owned<ILogMsgFilter> filter = getCategoryLogMsgFilter(MSGAUD_user, MSGCLS_error);
  150. queryLogMsgManager()->changeMonitorFilter(queryStderrLogMsgHandler(), filter);
  151. }
  152. return true;
  153. }
  154. bool EsdlConvertCmd::parseCommandLineOptions(ArgvIterator &iter)
  155. {
  156. if (iter.done())
  157. {
  158. usage();
  159. return false;
  160. }
  161. for (; !iter.done(); iter.next())
  162. {
  163. if (parseCommandLineOption(iter))
  164. continue;
  165. if (matchCommandLineOption(iter, true)!=EsdlCmdOptionMatch)
  166. return false;
  167. }
  168. return true;
  169. }
  170. bool EsdlConvertCmd::parseCommandLineOption(ArgvIterator &iter)
  171. {
  172. if (iter.matchOption(optSource, ESDL_CONVERT_SOURCE))
  173. return true;
  174. if (iter.matchOption(optOutDirPath, ESDL_CONVERT_OUTDIR))
  175. return true;
  176. StringAttr oneOption;
  177. if (iter.matchOption(oneOption, ESDLOPT_INCLUDE_PATH) || iter.matchOption(oneOption, ESDLOPT_INCLUDE_PATH_S))
  178. {
  179. if(optIncludePath.length() > 0)
  180. optIncludePath.append(ENVSEPSTR);
  181. optIncludePath.append(oneOption.get());
  182. return true;
  183. }
  184. return false;
  185. }
  186. esdlCmdOptionMatchIndicator EsdlConvertCmd::matchCommandLineOption(ArgvIterator &iter, bool finalAttempt)
  187. {
  188. if (iter.matchOption(optSource, ESDL_CONVERT_SOURCE))
  189. return EsdlCmdOptionMatch;
  190. if (iter.matchOption(optOutDirPath, ESDL_CONVERT_OUTDIR))
  191. return EsdlCmdOptionMatch;
  192. return EsdlCmdCommon::matchCommandLineOption(iter, true);
  193. }
  194. bool EsdlConvertCmd::finalizeOptions(IProperties *globals)
  195. {
  196. extractEsdlCmdOption(optIncludePath, globals, ESDLOPT_INCLUDE_PATH_ENV, ESDLOPT_INCLUDE_PATH_INI, NULL, NULL);
  197. if (optSource.isEmpty())
  198. {
  199. fprintf(stderr, "\nError: Source esdl parameter required\n");
  200. return false;
  201. }
  202. if (optOutDirPath.isEmpty())
  203. {
  204. fprintf(stderr, "\nError: Target output directory path parameter required\n");
  205. return false;
  206. }
  207. return EsdlCmdCommon::finalizeOptions(globals);
  208. }