cmCPluginAPI.cxx 12 KB

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