cmCPluginAPI.cxx 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457
  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::CacheEntryType::BOOL);
  61. break;
  62. case CM_CACHE_PATH:
  63. mf->AddCacheDefinition(name,value,doc,
  64. cmCacheManager::CacheEntryType::PATH);
  65. break;
  66. case CM_CACHE_FILEPATH:
  67. mf->AddCacheDefinition(name,value,doc,
  68. cmCacheManager::CacheEntryType::FILEPATH);
  69. break;
  70. case CM_CACHE_STRING:
  71. mf->AddCacheDefinition(name,value,doc,
  72. cmCacheManager::CacheEntryType::STRING);
  73. break;
  74. case CM_CACHE_INTERNAL:
  75. mf->AddCacheDefinition(name,value,doc,
  76. cmCacheManager::CacheEntryType::INTERNAL);
  77. break;
  78. case CM_CACHE_STATIC:
  79. mf->AddCacheDefinition(name,value,doc,
  80. cmCacheManager::CacheEntryType::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,
  215. cmTarget::LinkLibraryType::GENERAL);
  216. break;
  217. case CM_LIBRARY_DEBUG:
  218. mf->AddLinkLibraryForTarget(tgt,value,
  219. cmTarget::LinkLibraryType::DEBUG);
  220. break;
  221. case CM_LIBRARY_OPTIMIZED:
  222. mf->AddLinkLibraryForTarget(tgt,value,
  223. cmTarget::LinkLibraryType::OPTIMIZED);
  224. break;
  225. }
  226. }
  227. void cmAddLibrary(void *arg, const char *libname, int shared,
  228. int numSrcs, const char **srcs)
  229. {
  230. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  231. std::vector<std::string> srcs2;
  232. int i;
  233. for (i = 0; i < numSrcs; ++i)
  234. {
  235. srcs2.push_back(srcs[i]);
  236. }
  237. mf->AddLibrary(libname, (shared ? true : false), srcs2);
  238. }
  239. char *cmExpandVariablesInString(void *arg, const char *source,
  240. int escapeQuotes, int atOnly)
  241. {
  242. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  243. std::string result =
  244. mf->ExpandVariablesInString(std::string(source),
  245. (escapeQuotes ? true : false),
  246. (atOnly ? true : false));
  247. char *res = static_cast<char *>(malloc(result.size() + 1));
  248. if (result.size())
  249. {
  250. strcpy(res,result.c_str());
  251. }
  252. res[result.size()] = '\0';
  253. return res;
  254. }
  255. void cmExecuteCommand(void *arg, const char *name,
  256. int numArgs, const char **args)
  257. {
  258. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  259. std::vector<std::string> args2;
  260. int i;
  261. for (i = 0; i < numArgs; ++i)
  262. {
  263. args2.push_back(args[i]);
  264. }
  265. mf->ExecuteCommand(std::string(name), args2);
  266. }
  267. void cmExpandSourceListArguments(void *arg,
  268. int numArgs,
  269. const char **args,
  270. int *resArgc,
  271. char ***resArgv,
  272. unsigned int startArgumentIndex)
  273. {
  274. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  275. std::vector<std::string> result;
  276. std::vector<std::string> args2;
  277. int i;
  278. for (i = 0; i < numArgs; ++i)
  279. {
  280. args2.push_back(args[i]);
  281. }
  282. mf->ExpandSourceListArguments(args2, result, startArgumentIndex);
  283. int resargc = result.size();
  284. char **resargv = NULL;
  285. if (resargc)
  286. {
  287. resargv = (char **)malloc(resargc*sizeof(char *));
  288. }
  289. for (i = 0; i < resargc; ++i)
  290. {
  291. resargv[i] = strdup(result[i].c_str());
  292. }
  293. *resArgc = resargc;
  294. *resArgv = resargv;
  295. }
  296. void cmFreeArguments(int argc, char **argv)
  297. {
  298. int i;
  299. for (i = 0; i < argc; ++i)
  300. {
  301. free(argv[i]);
  302. }
  303. if (argv)
  304. {
  305. free(argv);
  306. }
  307. }
  308. int cmGetTotalArgumentSize(int argc, char **argv)
  309. {
  310. int i;
  311. int result = 0;
  312. for (i = 0; i < argc; ++i)
  313. {
  314. if (argv[i])
  315. {
  316. result = result + strlen(argv[i]);
  317. }
  318. }
  319. return result;
  320. }
  321. void *cmGetSource(void *arg, const char *name)
  322. {
  323. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  324. return (void *)mf->GetSource(name);
  325. }
  326. void * cmAddSource(void *arg, void *arg2)
  327. {
  328. cmMakefile *mf = static_cast<cmMakefile *>(arg);
  329. cmSourceFile *sf = static_cast<cmSourceFile *>(arg2);
  330. return (void *)mf->AddSource(*sf);
  331. }
  332. void * cmCreateSourceFile()
  333. {
  334. return (void *)(new cmSourceFile);
  335. }
  336. const char *cmSourceFileGetSourceName(void *arg)
  337. {
  338. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  339. return sf->GetSourceName().c_str();
  340. }
  341. const char *cmSourceFileGetProperty(void *arg,const char *prop)
  342. {
  343. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  344. return sf->GetProperty(prop);
  345. }
  346. int cmSourceFileGetPropertyAsBool(void *arg,const char *prop)
  347. {
  348. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  349. return (sf->GetPropertyAsBool(prop) ? 1: 0);
  350. }
  351. void cmSourceFileSetProperty(void *arg,const char *prop, const char *val)
  352. {
  353. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  354. sf->SetProperty(prop,val);
  355. }
  356. void cmSourceFileAddDepend(void *arg, const char *depend)
  357. {
  358. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  359. sf->GetDepends().push_back(depend);
  360. }
  361. void cmSourceFileSetName(void *arg, const char* name, const char* dir,
  362. int numSourceExtensions,
  363. const char **sourceExtensions,
  364. int numHeaderExtensions,
  365. const char **headerExtensions)
  366. {
  367. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  368. std::vector<std::string> srcs;
  369. std::vector<std::string> hdrs;
  370. int i;
  371. for (i = 0; i < numSourceExtensions; ++i)
  372. {
  373. srcs.push_back(sourceExtensions[i]);
  374. }
  375. for (i = 0; i < numHeaderExtensions; ++i)
  376. {
  377. hdrs.push_back(headerExtensions[i]);
  378. }
  379. sf->SetName(name,dir, srcs, hdrs);
  380. }
  381. void cmSourceFileSetName2(void *arg, const char* name, const char* dir,
  382. const char *ext, int headerFileOnly)
  383. {
  384. cmSourceFile *sf = static_cast<cmSourceFile *>(arg);
  385. sf->SetName(name,dir,ext,(headerFileOnly ? true : false));
  386. }
  387. char *cmGetFilenameWithoutExtension(const char *name)
  388. {
  389. std::string sres = cmSystemTools::GetFilenameWithoutExtension(name);
  390. char *result = (char *)malloc(sres.size()+1);
  391. strcpy(result,sres.c_str());
  392. return result;
  393. }
  394. char *cmCapitalized(const char *name)
  395. {
  396. std::string sres = cmSystemTools::Capitalized(name);
  397. char *result = (char *)malloc(sres.size()+1);
  398. strcpy(result,sres.c_str());
  399. return result;
  400. }
  401. void cmCopyFileIfDifferent(const char *name1, const char *name2)
  402. {
  403. cmSystemTools::CopyFileIfDifferent(name1,name2);
  404. }
  405. void cmRemoveFile(const char *name)
  406. {
  407. cmSystemTools::RemoveFile(name);
  408. }