cmCPluginAPI.cxx 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455
  1. /*=========================================================================
  2. Program: Insight Segmentation & Registration Toolkit
  3. Module: $RCSfile$
  4. Language: C++
  5. Date: $Date$
  6. Version: $Revision$
  7. Copyright (c) 2002 Insight Consortium. All rights reserved.
  8. See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details.
  9. This software is distributed WITHOUT ANY WARRANTY; without even
  10. the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
  11. PURPOSE. See the above copyright notices for more information.
  12. =========================================================================*/
  13. /*
  14. this file contains the implementation of the C API to CMake. Generally
  15. these routines just manipulate arguments and then call the associated
  16. methods on the CMake classes. */
  17. #include "cmMakefile.h"
  18. #include "cmCPluginAPI.h"
  19. void *cmGetClientData(void *info)
  20. {
  21. return ((cmLoadedCommandInfo *)info)->ClientData;
  22. }
  23. void cmSetClientData(void *info, void *cd)
  24. {
  25. ((cmLoadedCommandInfo *)info)->ClientData = cd;
  26. }
  27. unsigned int cmGetCacheMajorVersion(void *arg)
  28. {
  29. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  30. return mf->GetCacheMajorVersion();
  31. }
  32. unsigned int cmGetCacheMinorVersion(void *arg)
  33. {
  34. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  35. return mf->GetCacheMinorVersion();
  36. }
  37. unsigned int cmGetMajorVersion(void *)
  38. {
  39. return cmMakefile::GetMajorVersion();
  40. }
  41. unsigned int cmGetMinorVersion(void *)
  42. {
  43. return cmMakefile::GetMinorVersion();
  44. }
  45. void cmAddDefinition(void *arg, const char* name, const char* value)
  46. {
  47. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  48. mf->AddDefinition(name,value);
  49. }
  50. /* Add a definition to this makefile and the global cmake cache. */
  51. void cmAddCacheDefinition(void *arg, const char* name, const char* value,
  52. const char* doc,
  53. int type)
  54. {
  55. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  56. switch (type)
  57. {
  58. case CM_CACHE_BOOL:
  59. mf->AddCacheDefinition(name,value,doc,
  60. cmCacheManager::BOOL);
  61. break;
  62. case CM_CACHE_PATH:
  63. mf->AddCacheDefinition(name,value,doc,
  64. cmCacheManager::PATH);
  65. break;
  66. case CM_CACHE_FILEPATH:
  67. mf->AddCacheDefinition(name,value,doc,
  68. cmCacheManager::FILEPATH);
  69. break;
  70. case CM_CACHE_STRING:
  71. mf->AddCacheDefinition(name,value,doc,
  72. cmCacheManager::STRING);
  73. break;
  74. case CM_CACHE_INTERNAL:
  75. mf->AddCacheDefinition(name,value,doc,
  76. cmCacheManager::INTERNAL);
  77. break;
  78. case CM_CACHE_STATIC:
  79. mf->AddCacheDefinition(name,value,doc,
  80. cmCacheManager::STATIC);
  81. break;
  82. }
  83. }
  84. const char* cmGetProjectName(void *arg)
  85. {
  86. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  87. return mf->GetProjectName();
  88. }
  89. const char* cmGetHomeDirectory(void *arg)
  90. {
  91. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  92. return mf->GetHomeDirectory();
  93. }
  94. const char* cmGetHomeOutputDirectory(void *arg)
  95. {
  96. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  97. return mf->GetHomeOutputDirectory();
  98. }
  99. const char* cmGetStartDirectory(void *arg)
  100. {
  101. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  102. return mf->GetStartDirectory();
  103. }
  104. const char* cmGetStartOutputDirectory(void *arg)
  105. {
  106. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  107. return mf->GetStartOutputDirectory();
  108. }
  109. const char* cmGetCurrentDirectory(void *arg)
  110. {
  111. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  112. return mf->GetCurrentDirectory();
  113. }
  114. const char* cmGetCurrentOutputDirectory(void *arg)
  115. {
  116. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  117. return mf->GetCurrentOutputDirectory();
  118. }
  119. const char* cmGetDefinition(void *arg,const char*def)
  120. {
  121. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  122. return mf->GetDefinition(def);
  123. }
  124. int cmIsOn(void *arg, const char* name)
  125. {
  126. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  127. return static_cast<int>(mf->IsOn(name));
  128. }
  129. /** Check if a command exists. */
  130. int cmCommandExists(void *arg, const char* name)
  131. {
  132. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  133. return static_cast<int>(mf->CommandExists(name));
  134. }
  135. void cmAddDefineFlag(void *arg, const char* definition)
  136. {
  137. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  138. mf->AddDefineFlag(definition);
  139. }
  140. void cmAddLinkDirectoryForTarget(void *arg, const char *tgt, const char* d)
  141. {
  142. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  143. mf->AddLinkDirectoryForTarget(tgt,d);
  144. }
  145. void cmAddExecutable(void *arg, const char *exename,
  146. int numSrcs, const char **srcs, int win32)
  147. {
  148. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  149. std::vector<std::string> srcs2;
  150. int i;
  151. for (i = 0; i < numSrcs; ++i)
  152. {
  153. srcs2.push_back(srcs[i]);
  154. }
  155. mf->AddExecutable(exename, srcs2, (win32 ? true : false));
  156. }
  157. void cmAddUtilityCommand(void *arg, const char* utilityName,
  158. const char* command,
  159. const char* arguments,
  160. int all,
  161. int numDepends,
  162. const char **depends,
  163. int numOutputs,
  164. const char **outputs)
  165. {
  166. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  167. std::vector<std::string> depends2;
  168. int i;
  169. for (i = 0; i < numDepends; ++i)
  170. {
  171. depends2.push_back(depends[i]);
  172. }
  173. std::vector<std::string> outputs2;
  174. for (i = 0; i < numOutputs; ++i)
  175. {
  176. outputs2.push_back(outputs[i]);
  177. }
  178. mf->AddUtilityCommand(utilityName,command,arguments, (all ? true : false),
  179. depends2, outputs2);
  180. }
  181. void cmAddCustomCommand(void *arg, const char* source,
  182. const char* command,
  183. int numArgs, const char **args,
  184. int numDepends, const char **depends,
  185. int numOutputs, const char **outputs,
  186. const char *target)
  187. {
  188. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  189. int i;
  190. std::vector<std::string> args2;
  191. for (i = 0; i < numArgs; ++i)
  192. {
  193. args2.push_back(args[i]);
  194. }
  195. std::vector<std::string> depends2;
  196. for (i = 0; i < numDepends; ++i)
  197. {
  198. depends2.push_back(depends[i]);
  199. }
  200. std::vector<std::string> outputs2;
  201. for (i = 0; i < numOutputs; ++i)
  202. {
  203. outputs2.push_back(outputs[i]);
  204. }
  205. mf->AddCustomCommand(source, command, args2, depends2, outputs2, target);
  206. }
  207. void cmAddLinkLibraryForTarget(void *arg, const char *tgt, const char*value,
  208. int libtype)
  209. {
  210. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  211. switch (libtype)
  212. {
  213. case CM_LIBRARY_GENERAL:
  214. mf->AddLinkLibraryForTarget(tgt,value, cmTarget::GENERAL);
  215. break;
  216. case CM_LIBRARY_DEBUG:
  217. mf->AddLinkLibraryForTarget(tgt,value, cmTarget::DEBUG);
  218. break;
  219. case CM_LIBRARY_OPTIMIZED:
  220. mf->AddLinkLibraryForTarget(tgt,value, cmTarget::OPTIMIZED);
  221. break;
  222. }
  223. }
  224. void cmAddLibrary(void *arg, const char *libname, int shared,
  225. int numSrcs, const char **srcs)
  226. {
  227. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  228. std::vector<std::string> srcs2;
  229. int i;
  230. for (i = 0; i < numSrcs; ++i)
  231. {
  232. srcs2.push_back(srcs[i]);
  233. }
  234. mf->AddLibrary(libname, (shared ? true : false), srcs2);
  235. }
  236. char *cmExpandVariablesInString(void *arg, const char *source,
  237. int escapeQuotes, int atOnly)
  238. {
  239. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  240. std::string barf = source;
  241. std::string result =
  242. mf->ExpandVariablesInString(barf,
  243. (escapeQuotes ? true : false),
  244. (atOnly ? true : false));
  245. char *res = static_cast<char *>(malloc(result.size() + 1));
  246. if (result.size())
  247. {
  248. strcpy(res,result.c_str());
  249. }
  250. res[result.size()] = '\0';
  251. return res;
  252. }
  253. void cmExecuteCommand(void *arg, const char *name,
  254. int numArgs, const char **args)
  255. {
  256. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  257. std::vector<std::string> args2;
  258. int i;
  259. for (i = 0; i < numArgs; ++i)
  260. {
  261. args2.push_back(args[i]);
  262. }
  263. mf->ExecuteCommand(std::string(name), args2);
  264. }
  265. void cmExpandSourceListArguments(void *arg,
  266. int numArgs,
  267. const char **args,
  268. int *resArgc,
  269. char ***resArgv,
  270. unsigned int startArgumentIndex)
  271. {
  272. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  273. std::vector<std::string> result;
  274. std::vector<std::string> args2;
  275. int i;
  276. for (i = 0; i < numArgs; ++i)
  277. {
  278. args2.push_back(args[i]);
  279. }
  280. mf->ExpandSourceListArguments(args2, result, startArgumentIndex);
  281. int resargc = result.size();
  282. char **resargv = NULL;
  283. if (resargc)
  284. {
  285. resargv = (char **)malloc(resargc*sizeof(char *));
  286. }
  287. for (i = 0; i < resargc; ++i)
  288. {
  289. resargv[i] = strdup(result[i].c_str());
  290. }
  291. *resArgc = resargc;
  292. *resArgv = resargv;
  293. }
  294. void cmFreeArguments(int argc, char **argv)
  295. {
  296. int i;
  297. for (i = 0; i < argc; ++i)
  298. {
  299. free(argv[i]);
  300. }
  301. if (argv)
  302. {
  303. free(argv);
  304. }
  305. }
  306. int cmGetTotalArgumentSize(int argc, char **argv)
  307. {
  308. int i;
  309. int result = 0;
  310. for (i = 0; i < argc; ++i)
  311. {
  312. if (argv[i])
  313. {
  314. result = result + strlen(argv[i]);
  315. }
  316. }
  317. return result;
  318. }
  319. void *cmGetSource(void *arg, const char *name)
  320. {
  321. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  322. return (void *)mf->GetSource(name);
  323. }
  324. void * cmAddSource(void *arg, void *arg2)
  325. {
  326. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  327. cmSourceFile *sf = static_cast<cmSourceFile *>(arg2);
  328. return (void *)mf->AddSource(*sf);
  329. }
  330. void * cmCreateSourceFile()
  331. {
  332. return (void *)(new cmSourceFile);
  333. }
  334. const char *cmSourceFileGetSourceName(void *arg)
  335. {
  336. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  337. return sf->GetSourceName().c_str();
  338. }
  339. const char *cmSourceFileGetProperty(void *arg,const char *prop)
  340. {
  341. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  342. return sf->GetProperty(prop);
  343. }
  344. int cmSourceFileGetPropertyAsBool(void *arg,const char *prop)
  345. {
  346. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  347. return (sf->GetPropertyAsBool(prop) ? 1: 0);
  348. }
  349. void cmSourceFileSetProperty(void *arg,const char *prop, const char *val)
  350. {
  351. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  352. sf->SetProperty(prop,val);
  353. }
  354. void cmSourceFileAddDepend(void *arg, const char *depend)
  355. {
  356. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  357. sf->GetDepends().push_back(depend);
  358. }
  359. void cmSourceFileSetName(void *arg, const char* name, const char* dir,
  360. int numSourceExtensions,
  361. const char **sourceExtensions,
  362. int numHeaderExtensions,
  363. const char **headerExtensions)
  364. {
  365. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  366. std::vector<std::string> srcs;
  367. std::vector<std::string> hdrs;
  368. int i;
  369. for (i = 0; i < numSourceExtensions; ++i)
  370. {
  371. srcs.push_back(sourceExtensions[i]);
  372. }
  373. for (i = 0; i < numHeaderExtensions; ++i)
  374. {
  375. hdrs.push_back(headerExtensions[i]);
  376. }
  377. sf->SetName(name,dir, srcs, hdrs);
  378. }
  379. void cmSourceFileSetName2(void *arg, const char* name, const char* dir,
  380. const char *ext, int headerFileOnly)
  381. {
  382. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  383. sf->SetName(name,dir,ext,(headerFileOnly ? true : false));
  384. }
  385. char *cmGetFilenameWithoutExtension(const char *name)
  386. {
  387. std::string sres = cmSystemTools::GetFilenameWithoutExtension(name);
  388. char *result = (char *)malloc(sres.size()+1);
  389. strcpy(result,sres.c_str());
  390. return result;
  391. }
  392. char *cmCapitalized(const char *name)
  393. {
  394. std::string sres = cmSystemTools::Capitalized(name);
  395. char *result = (char *)malloc(sres.size()+1);
  396. strcpy(result,sres.c_str());
  397. return result;
  398. }
  399. void cmCopyFileIfDifferent(const char *name1, const char *name2)
  400. {
  401. cmSystemTools::CopyFileIfDifferent(name1,name2);
  402. }
  403. void cmRemoveFile(const char *name)
  404. {
  405. cmSystemTools::RemoveFile(name);
  406. }