Team Fortress 2 Source Code as on 22/4/2020
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

695 lines
22 KiB

  1. /* -----------------------------------------------------------------------------
  2. * See the LICENSE file for information on copyright, usage and redistribution
  3. * of SWIG, and the README file for authors - http://www.swig.org/release.html.
  4. *
  5. * tclrun.swg
  6. *
  7. * This file contains the runtime support for Tcl modules and includes
  8. * code for managing global variables and pointer type checking.
  9. * ----------------------------------------------------------------------------- */
  10. /* Common SWIG API */
  11. /* for raw pointers */
  12. #define SWIG_ConvertPtr(oc, ptr, ty, flags) SWIG_Tcl_ConvertPtr(interp, oc, ptr, ty, flags)
  13. #define SWIG_NewPointerObj(ptr, type, flags) SWIG_Tcl_NewPointerObj(ptr, type, flags)
  14. /* for raw packed data */
  15. #define SWIG_ConvertPacked(obj, ptr, sz, ty) SWIG_Tcl_ConvertPacked(interp, obj, ptr, sz, ty)
  16. #define SWIG_NewPackedObj(ptr, sz, type) SWIG_Tcl_NewPackedObj(ptr, sz, type)
  17. /* for class or struct pointers */
  18. #define SWIG_ConvertInstance(obj, pptr, type, flags) SWIG_Tcl_ConvertPtr(interp, obj, pptr, type, flags)
  19. #define SWIG_NewInstanceObj(thisvalue, type, flags) SWIG_Tcl_NewInstanceObj(interp, thisvalue, type, flags)
  20. /* for C or C++ function pointers */
  21. #define SWIG_ConvertFunctionPtr(obj, pptr, type) SWIG_Tcl_ConvertPtr(interp, obj, pptr, type, 0)
  22. #define SWIG_NewFunctionPtrObj(ptr, type) SWIG_Tcl_NewPointerObj(ptr, type, 0)
  23. /* for C++ member pointers, ie, member methods */
  24. #define SWIG_ConvertMember(obj, ptr, sz, ty) SWIG_Tcl_ConvertPacked(interp,obj, ptr, sz, ty)
  25. #define SWIG_NewMemberObj(ptr, sz, type) SWIG_Tcl_NewPackedObj(ptr, sz, type)
  26. /* Runtime API */
  27. #define SWIG_GetModule(clientdata) SWIG_Tcl_GetModule((Tcl_Interp *) (clientdata))
  28. #define SWIG_SetModule(clientdata, pointer) SWIG_Tcl_SetModule((Tcl_Interp *) (clientdata), pointer)
  29. /* Error manipulation */
  30. #define SWIG_ErrorType(code) SWIG_Tcl_ErrorType(code)
  31. #define SWIG_Error(code, msg) SWIG_Tcl_SetErrorMsg(interp, SWIG_Tcl_ErrorType(code), msg)
  32. #define SWIG_fail goto fail
  33. /* Tcl-specific SWIG API */
  34. #define SWIG_Acquire(ptr) SWIG_Tcl_Acquire(ptr)
  35. #define SWIG_MethodCommand SWIG_Tcl_MethodCommand
  36. #define SWIG_Disown(ptr) SWIG_Tcl_Disown(ptr)
  37. #define SWIG_ConvertPtrFromString(c, ptr, ty, flags) SWIG_Tcl_ConvertPtrFromString(interp, c, ptr, ty, flags)
  38. #define SWIG_MakePtr(c, ptr, ty, flags) SWIG_Tcl_MakePtr(c, ptr, ty, flags)
  39. #define SWIG_PointerTypeFromString(c) SWIG_Tcl_PointerTypeFromString(c)
  40. #define SWIG_GetArgs SWIG_Tcl_GetArgs
  41. #define SWIG_GetConstantObj(key) SWIG_Tcl_GetConstantObj(key)
  42. #define SWIG_ObjectConstructor SWIG_Tcl_ObjectConstructor
  43. #define SWIG_Thisown(ptr) SWIG_Tcl_Thisown(ptr)
  44. #define SWIG_ObjectDelete SWIG_Tcl_ObjectDelete
  45. #define SWIG_TCL_DECL_ARGS_2(arg1, arg2) (Tcl_Interp *interp SWIGUNUSED, arg1, arg2)
  46. #define SWIG_TCL_CALL_ARGS_2(arg1, arg2) (interp, arg1, arg2)
  47. /* -----------------------------------------------------------------------------
  48. * pointers/data manipulation
  49. * ----------------------------------------------------------------------------- */
  50. /* For backward compatibility only */
  51. #define SWIG_POINTER_EXCEPTION 0
  52. #define SWIG_GetConstant SWIG_GetConstantObj
  53. #define SWIG_Tcl_GetConstant SWIG_Tcl_GetConstantObj
  54. #include "assert.h"
  55. #ifdef __cplusplus
  56. extern "C" {
  57. #if 0
  58. } /* cc-mode */
  59. #endif
  60. #endif
  61. /* Object support */
  62. SWIGRUNTIME Tcl_HashTable*
  63. SWIG_Tcl_ObjectTable(void) {
  64. static Tcl_HashTable swigobjectTable;
  65. static int swigobjectTableinit = 0;
  66. if (!swigobjectTableinit) {
  67. Tcl_InitHashTable(&swigobjectTable, TCL_ONE_WORD_KEYS);
  68. swigobjectTableinit = 1;
  69. }
  70. return &swigobjectTable;
  71. }
  72. /* Acquire ownership of a pointer */
  73. SWIGRUNTIME void
  74. SWIG_Tcl_Acquire(void *ptr) {
  75. int newobj;
  76. Tcl_CreateHashEntry(SWIG_Tcl_ObjectTable(), (char *) ptr, &newobj);
  77. }
  78. SWIGRUNTIME int
  79. SWIG_Tcl_Thisown(void *ptr) {
  80. if (Tcl_FindHashEntry(SWIG_Tcl_ObjectTable(), (char *) ptr)) {
  81. return 1;
  82. }
  83. return 0;
  84. }
  85. /* Disown a pointer. Returns 1 if we owned it to begin with */
  86. SWIGRUNTIME int
  87. SWIG_Tcl_Disown(void *ptr) {
  88. Tcl_HashEntry *entryPtr = Tcl_FindHashEntry(SWIG_Tcl_ObjectTable(), (char *) ptr);
  89. if (entryPtr) {
  90. Tcl_DeleteHashEntry(entryPtr);
  91. return 1;
  92. }
  93. return 0;
  94. }
  95. /* Convert a pointer value */
  96. SWIGRUNTIME int
  97. SWIG_Tcl_ConvertPtrFromString(Tcl_Interp *interp, const char *c, void **ptr, swig_type_info *ty, int flags) {
  98. swig_cast_info *tc;
  99. /* Pointer values must start with leading underscore */
  100. while (*c != '_') {
  101. *ptr = (void *) 0;
  102. if (strcmp(c,"NULL") == 0) return SWIG_OK;
  103. /* Empty string: not a pointer */
  104. if (*c == 0) return SWIG_ERROR;
  105. /* Hmmm. It could be an object name. */
  106. /* Check if this is a command at all. Prevents <c> cget -this */
  107. /* from being called when c is not a command, firing the unknown proc */
  108. if (Tcl_VarEval(interp,"info commands ", c, (char *) NULL) == TCL_OK) {
  109. Tcl_Obj *result = Tcl_GetObjResult(interp);
  110. if (*(Tcl_GetStringFromObj(result, NULL)) == 0) {
  111. /* It's not a command, so it can't be a pointer */
  112. Tcl_ResetResult(interp);
  113. return SWIG_ERROR;
  114. }
  115. } else {
  116. /* This will only fail if the argument is multiple words. */
  117. /* Multiple words are also not commands. */
  118. Tcl_ResetResult(interp);
  119. return SWIG_ERROR;
  120. }
  121. /* Check if this is really a SWIG pointer */
  122. if (Tcl_VarEval(interp,c," cget -this", (char *) NULL) != TCL_OK) {
  123. Tcl_ResetResult(interp);
  124. return SWIG_ERROR;
  125. }
  126. c = Tcl_GetStringFromObj(Tcl_GetObjResult(interp), NULL);
  127. }
  128. c++;
  129. c = SWIG_UnpackData(c,ptr,sizeof(void *));
  130. if (ty) {
  131. tc = c ? SWIG_TypeCheck(c,ty) : 0;
  132. if (!tc) {
  133. return SWIG_ERROR;
  134. }
  135. if (flags & SWIG_POINTER_DISOWN) {
  136. SWIG_Disown((void *) *ptr);
  137. }
  138. {
  139. int newmemory = 0;
  140. *ptr = SWIG_TypeCast(tc,(void *) *ptr,&newmemory);
  141. assert(!newmemory); /* newmemory handling not yet implemented */
  142. }
  143. }
  144. return SWIG_OK;
  145. }
  146. /* Convert a pointer value */
  147. SWIGRUNTIMEINLINE int
  148. SWIG_Tcl_ConvertPtr(Tcl_Interp *interp, Tcl_Obj *oc, void **ptr, swig_type_info *ty, int flags) {
  149. return SWIG_Tcl_ConvertPtrFromString(interp, Tcl_GetStringFromObj(oc,NULL), ptr, ty, flags);
  150. }
  151. /* Convert a pointer value */
  152. SWIGRUNTIME char *
  153. SWIG_Tcl_PointerTypeFromString(char *c) {
  154. char d;
  155. /* Pointer values must start with leading underscore. NULL has no type */
  156. if (*c != '_') {
  157. return 0;
  158. }
  159. c++;
  160. /* Extract hex value from pointer */
  161. while ((d = *c)) {
  162. if (!(((d >= '0') && (d <= '9')) || ((d >= 'a') && (d <= 'f')))) break;
  163. c++;
  164. }
  165. return c;
  166. }
  167. /* Convert a packed value value */
  168. SWIGRUNTIME int
  169. SWIG_Tcl_ConvertPacked(Tcl_Interp *SWIGUNUSEDPARM(interp) , Tcl_Obj *obj, void *ptr, int sz, swig_type_info *ty) {
  170. swig_cast_info *tc;
  171. const char *c;
  172. if (!obj) goto type_error;
  173. c = Tcl_GetStringFromObj(obj,NULL);
  174. /* Pointer values must start with leading underscore */
  175. if (*c != '_') goto type_error;
  176. c++;
  177. c = SWIG_UnpackData(c,ptr,sz);
  178. if (ty) {
  179. tc = SWIG_TypeCheck(c,ty);
  180. if (!tc) goto type_error;
  181. }
  182. return SWIG_OK;
  183. type_error:
  184. return SWIG_ERROR;
  185. }
  186. /* Take a pointer and convert it to a string */
  187. SWIGRUNTIME void
  188. SWIG_Tcl_MakePtr(char *c, void *ptr, swig_type_info *ty, int flags) {
  189. if (ptr) {
  190. *(c++) = '_';
  191. c = SWIG_PackData(c,&ptr,sizeof(void *));
  192. strcpy(c,ty->name);
  193. } else {
  194. strcpy(c,(char *)"NULL");
  195. }
  196. flags = 0;
  197. }
  198. /* Create a new pointer object */
  199. SWIGRUNTIMEINLINE Tcl_Obj *
  200. SWIG_Tcl_NewPointerObj(void *ptr, swig_type_info *type, int flags) {
  201. Tcl_Obj *robj;
  202. char result[SWIG_BUFFER_SIZE];
  203. SWIG_MakePtr(result,ptr,type,flags);
  204. robj = Tcl_NewStringObj(result,-1);
  205. return robj;
  206. }
  207. SWIGRUNTIME Tcl_Obj *
  208. SWIG_Tcl_NewPackedObj(void *ptr, int sz, swig_type_info *type) {
  209. char result[1024];
  210. char *r = result;
  211. if ((2*sz + 1 + strlen(type->name)) > 1000) return 0;
  212. *(r++) = '_';
  213. r = SWIG_PackData(r,ptr,sz);
  214. strcpy(r,type->name);
  215. return Tcl_NewStringObj(result,-1);
  216. }
  217. /* -----------------------------------------------------------------------------*
  218. * Get type list
  219. * -----------------------------------------------------------------------------*/
  220. SWIGRUNTIME swig_module_info *
  221. SWIG_Tcl_GetModule(Tcl_Interp *interp) {
  222. const char *data;
  223. swig_module_info *ret = 0;
  224. /* first check if pointer already created */
  225. data = Tcl_GetVar(interp, (char *)"swig_runtime_data_type_pointer" SWIG_RUNTIME_VERSION SWIG_TYPE_TABLE_NAME, TCL_GLOBAL_ONLY);
  226. if (data) {
  227. SWIG_UnpackData(data, &ret, sizeof(swig_type_info **));
  228. }
  229. return ret;
  230. }
  231. SWIGRUNTIME void
  232. SWIG_Tcl_SetModule(Tcl_Interp *interp, swig_module_info *module) {
  233. char buf[SWIG_BUFFER_SIZE];
  234. char *data;
  235. /* create a new pointer */
  236. data = SWIG_PackData(buf, &module, sizeof(swig_type_info **));
  237. *data = 0;
  238. Tcl_SetVar(interp, (char *)"swig_runtime_data_type_pointer" SWIG_RUNTIME_VERSION SWIG_TYPE_TABLE_NAME, buf, 0);
  239. }
  240. /* -----------------------------------------------------------------------------*
  241. * Object auxiliars
  242. * -----------------------------------------------------------------------------*/
  243. SWIGRUNTIME void
  244. SWIG_Tcl_ObjectDelete(ClientData clientData) {
  245. swig_instance *si = (swig_instance *) clientData;
  246. if ((si) && (si->destroy) && (SWIG_Disown(si->thisvalue))) {
  247. if (si->classptr->destructor) {
  248. (si->classptr->destructor)(si->thisvalue);
  249. }
  250. }
  251. Tcl_DecrRefCount(si->thisptr);
  252. free(si);
  253. }
  254. /* Function to invoke object methods given an instance */
  255. SWIGRUNTIME int
  256. SWIG_Tcl_MethodCommand(ClientData clientData, Tcl_Interp *interp, int objc, Tcl_Obj *CONST _objv[]) {
  257. char *method, *attrname;
  258. swig_instance *inst = (swig_instance *) clientData;
  259. swig_method *meth;
  260. swig_attribute *attr;
  261. Tcl_Obj *oldarg;
  262. Tcl_Obj **objv;
  263. int rcode;
  264. swig_class *cls;
  265. swig_class *cls_stack[64];
  266. int cls_stack_bi[64];
  267. int cls_stack_top = 0;
  268. int numconf = 2;
  269. int bi;
  270. objv = (Tcl_Obj **) _objv;
  271. if (objc < 2) {
  272. Tcl_SetResult(interp, (char *) "wrong # args.", TCL_STATIC);
  273. return TCL_ERROR;
  274. }
  275. method = Tcl_GetStringFromObj(objv[1],NULL);
  276. if (strcmp(method,"-acquire") == 0) {
  277. inst->destroy = 1;
  278. SWIG_Acquire(inst->thisvalue);
  279. return TCL_OK;
  280. }
  281. if (strcmp(method,"-disown") == 0) {
  282. if (inst->destroy) {
  283. SWIG_Disown(inst->thisvalue);
  284. }
  285. inst->destroy = 0;
  286. return TCL_OK;
  287. }
  288. if (strcmp(method,"-delete") == 0) {
  289. Tcl_DeleteCommandFromToken(interp,inst->cmdtok);
  290. return TCL_OK;
  291. }
  292. cls_stack[cls_stack_top] = inst->classptr;
  293. cls_stack_bi[cls_stack_top] = -1;
  294. cls = inst->classptr;
  295. while (1) {
  296. bi = cls_stack_bi[cls_stack_top];
  297. cls = cls_stack[cls_stack_top];
  298. if (bi != -1) {
  299. if (!cls->bases[bi] && cls->base_names[bi]) {
  300. /* lookup and cache the base class */
  301. swig_type_info *info = SWIG_TypeQueryModule(cls->module, cls->module, cls->base_names[bi]);
  302. if (info) cls->bases[bi] = (swig_class *) info->clientdata;
  303. }
  304. cls = cls->bases[bi];
  305. if (cls) {
  306. cls_stack_bi[cls_stack_top]++;
  307. cls_stack_top++;
  308. cls_stack[cls_stack_top] = cls;
  309. cls_stack_bi[cls_stack_top] = -1;
  310. continue;
  311. }
  312. }
  313. if (!cls) {
  314. cls_stack_top--;
  315. if (cls_stack_top < 0) break;
  316. else continue;
  317. }
  318. cls_stack_bi[cls_stack_top]++;
  319. meth = cls->methods;
  320. /* Check for methods */
  321. while (meth && meth->name) {
  322. if (strcmp(meth->name,method) == 0) {
  323. oldarg = objv[1];
  324. objv[1] = inst->thisptr;
  325. Tcl_IncrRefCount(inst->thisptr);
  326. rcode = (*meth->method)(clientData,interp,objc,objv);
  327. objv[1] = oldarg;
  328. Tcl_DecrRefCount(inst->thisptr);
  329. return rcode;
  330. }
  331. meth++;
  332. }
  333. /* Check class methods for a match */
  334. if (strcmp(method,"cget") == 0) {
  335. if (objc < 3) {
  336. Tcl_SetResult(interp, (char *) "wrong # args.", TCL_STATIC);
  337. return TCL_ERROR;
  338. }
  339. attrname = Tcl_GetStringFromObj(objv[2],NULL);
  340. attr = cls->attributes;
  341. while (attr && attr->name) {
  342. if ((strcmp(attr->name, attrname) == 0) && (attr->getmethod)) {
  343. oldarg = objv[1];
  344. objv[1] = inst->thisptr;
  345. Tcl_IncrRefCount(inst->thisptr);
  346. rcode = (*attr->getmethod)(clientData,interp,2, objv);
  347. objv[1] = oldarg;
  348. Tcl_DecrRefCount(inst->thisptr);
  349. return rcode;
  350. }
  351. attr++;
  352. }
  353. if (strcmp(attrname, "-this") == 0) {
  354. Tcl_SetObjResult(interp, Tcl_DuplicateObj(inst->thisptr));
  355. return TCL_OK;
  356. }
  357. if (strcmp(attrname, "-thisown") == 0) {
  358. if (SWIG_Thisown(inst->thisvalue)) {
  359. Tcl_SetResult(interp,(char*)"1",TCL_STATIC);
  360. } else {
  361. Tcl_SetResult(interp,(char*)"0",TCL_STATIC);
  362. }
  363. return TCL_OK;
  364. }
  365. } else if (strcmp(method, "configure") == 0) {
  366. int i;
  367. if (objc < 4) {
  368. Tcl_SetResult(interp, (char *) "wrong # args.", TCL_STATIC);
  369. return TCL_ERROR;
  370. }
  371. i = 2;
  372. while (i < objc) {
  373. attrname = Tcl_GetStringFromObj(objv[i],NULL);
  374. attr = cls->attributes;
  375. while (attr && attr->name) {
  376. if ((strcmp(attr->name, attrname) == 0) && (attr->setmethod)) {
  377. oldarg = objv[i];
  378. objv[i] = inst->thisptr;
  379. Tcl_IncrRefCount(inst->thisptr);
  380. rcode = (*attr->setmethod)(clientData,interp,3, &objv[i-1]);
  381. objv[i] = oldarg;
  382. Tcl_DecrRefCount(inst->thisptr);
  383. if (rcode != TCL_OK) return rcode;
  384. numconf += 2;
  385. }
  386. attr++;
  387. }
  388. i+=2;
  389. }
  390. }
  391. }
  392. if (strcmp(method,"configure") == 0) {
  393. if (numconf >= objc) {
  394. return TCL_OK;
  395. } else {
  396. Tcl_SetResult(interp,(char *) "Invalid attribute name.", TCL_STATIC);
  397. return TCL_ERROR;
  398. }
  399. }
  400. if (strcmp(method,"cget") == 0) {
  401. Tcl_SetResult(interp,(char *) "Invalid attribute name.", TCL_STATIC);
  402. return TCL_ERROR;
  403. }
  404. Tcl_SetResult(interp, (char *) "Invalid method. Must be one of: configure cget -acquire -disown -delete", TCL_STATIC);
  405. cls = inst->classptr;
  406. bi = 0;
  407. while (cls) {
  408. meth = cls->methods;
  409. while (meth && meth->name) {
  410. char *cr = (char *) Tcl_GetStringResult(interp);
  411. size_t meth_len = strlen(meth->name);
  412. char* where = strchr(cr,':');
  413. while(where) {
  414. where = strstr(where, meth->name);
  415. if(where) {
  416. if(where[-1] == ' ' && (where[meth_len] == ' ' || where[meth_len]==0)) {
  417. break;
  418. } else {
  419. where++;
  420. }
  421. }
  422. }
  423. if (!where)
  424. Tcl_AppendElement(interp, (char *) meth->name);
  425. meth++;
  426. }
  427. cls = inst->classptr->bases[bi++];
  428. }
  429. return TCL_ERROR;
  430. }
  431. /* This function takes the current result and turns it into an object command */
  432. SWIGRUNTIME Tcl_Obj *
  433. SWIG_Tcl_NewInstanceObj(Tcl_Interp *interp, void *thisvalue, swig_type_info *type, int flags) {
  434. Tcl_Obj *robj = SWIG_NewPointerObj(thisvalue, type,0);
  435. /* Check to see if this pointer belongs to a class or not */
  436. if ((type->clientdata) && (interp)) {
  437. Tcl_CmdInfo ci;
  438. char *name;
  439. name = Tcl_GetStringFromObj(robj,NULL);
  440. if (!Tcl_GetCommandInfo(interp,name, &ci) || (flags)) {
  441. swig_instance *newinst = (swig_instance *) malloc(sizeof(swig_instance));
  442. newinst->thisptr = Tcl_DuplicateObj(robj);
  443. Tcl_IncrRefCount(newinst->thisptr);
  444. newinst->thisvalue = thisvalue;
  445. newinst->classptr = (swig_class *) type->clientdata;
  446. newinst->destroy = flags;
  447. newinst->cmdtok = Tcl_CreateObjCommand(interp, Tcl_GetStringFromObj(robj,NULL), (swig_wrapper_func) SWIG_MethodCommand, (ClientData) newinst, (swig_delete_func) SWIG_ObjectDelete);
  448. if (flags) {
  449. SWIG_Acquire(thisvalue);
  450. }
  451. }
  452. }
  453. return robj;
  454. }
  455. /* Function to create objects */
  456. SWIGRUNTIME int
  457. SWIG_Tcl_ObjectConstructor(ClientData clientData, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[]) {
  458. Tcl_Obj *newObj = 0;
  459. void *thisvalue = 0;
  460. swig_instance *newinst = 0;
  461. swig_class *classptr = (swig_class *) clientData;
  462. swig_wrapper cons = 0;
  463. char *name = 0;
  464. int firstarg = 0;
  465. int thisarg = 0;
  466. int destroy = 1;
  467. if (!classptr) {
  468. Tcl_SetResult(interp, (char *) "swig: internal runtime error. No class object defined.", TCL_STATIC);
  469. return TCL_ERROR;
  470. }
  471. cons = classptr->constructor;
  472. if (objc > 1) {
  473. char *s = Tcl_GetStringFromObj(objv[1],NULL);
  474. if (strcmp(s,"-this") == 0) {
  475. thisarg = 2;
  476. cons = 0;
  477. } else if (strcmp(s,"-args") == 0) {
  478. firstarg = 1;
  479. } else if (objc == 2) {
  480. firstarg = 1;
  481. name = s;
  482. } else if (objc >= 3) {
  483. char *s1;
  484. name = s;
  485. s1 = Tcl_GetStringFromObj(objv[2],NULL);
  486. if (strcmp(s1,"-this") == 0) {
  487. thisarg = 3;
  488. cons = 0;
  489. } else {
  490. firstarg = 1;
  491. }
  492. }
  493. }
  494. if (cons) {
  495. int result;
  496. result = (*cons)(0, interp, objc-firstarg, &objv[firstarg]);
  497. if (result != TCL_OK) {
  498. return result;
  499. }
  500. newObj = Tcl_DuplicateObj(Tcl_GetObjResult(interp));
  501. if (!name) name = Tcl_GetStringFromObj(newObj,NULL);
  502. } else if (thisarg > 0) {
  503. if (thisarg < objc) {
  504. destroy = 0;
  505. newObj = Tcl_DuplicateObj(objv[thisarg]);
  506. if (!name) name = Tcl_GetStringFromObj(newObj,NULL);
  507. } else {
  508. Tcl_SetResult(interp, (char *) "wrong # args.", TCL_STATIC);
  509. return TCL_ERROR;
  510. }
  511. } else {
  512. Tcl_SetResult(interp, (char *) "No constructor available.", TCL_STATIC);
  513. return TCL_ERROR;
  514. }
  515. if (SWIG_Tcl_ConvertPtr(interp,newObj, (void **) &thisvalue, *(classptr->type), 0) != SWIG_OK) {
  516. Tcl_DecrRefCount(newObj);
  517. return TCL_ERROR;
  518. }
  519. newinst = (swig_instance *) malloc(sizeof(swig_instance));
  520. newinst->thisptr = newObj;
  521. Tcl_IncrRefCount(newObj);
  522. newinst->thisvalue = thisvalue;
  523. newinst->classptr = classptr;
  524. newinst->destroy = destroy;
  525. if (destroy) {
  526. SWIG_Acquire(thisvalue);
  527. }
  528. newinst->cmdtok = Tcl_CreateObjCommand(interp,name, (swig_wrapper) SWIG_MethodCommand, (ClientData) newinst, (swig_delete_func) SWIG_ObjectDelete);
  529. return TCL_OK;
  530. }
  531. /* -----------------------------------------------------------------------------*
  532. * Get arguments
  533. * -----------------------------------------------------------------------------*/
  534. SWIGRUNTIME int
  535. SWIG_Tcl_GetArgs(Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[], const char *fmt, ...) {
  536. int argno = 0, opt = 0;
  537. long tempi;
  538. double tempd;
  539. const char *c;
  540. va_list ap;
  541. void *vptr;
  542. Tcl_Obj *obj = 0;
  543. swig_type_info *ty;
  544. va_start(ap,fmt);
  545. for (c = fmt; (*c && (*c != ':') && (*c != ';')); c++,argno++) {
  546. if (*c == '|') {
  547. opt = 1;
  548. c++;
  549. }
  550. if (argno >= (objc-1)) {
  551. if (!opt) {
  552. Tcl_SetResult(interp, (char *) "Wrong number of arguments ", TCL_STATIC);
  553. goto argerror;
  554. } else {
  555. va_end(ap);
  556. return TCL_OK;
  557. }
  558. }
  559. vptr = va_arg(ap,void *);
  560. if (vptr) {
  561. if (isupper(*c)) {
  562. obj = SWIG_Tcl_GetConstantObj(Tcl_GetStringFromObj(objv[argno+1],0));
  563. if (!obj) obj = objv[argno+1];
  564. } else {
  565. obj = objv[argno+1];
  566. }
  567. switch(*c) {
  568. case 'i': case 'I':
  569. case 'l': case 'L':
  570. case 'h': case 'H':
  571. case 'b': case 'B':
  572. if (Tcl_GetLongFromObj(interp,obj,&tempi) != TCL_OK) goto argerror;
  573. if ((*c == 'i') || (*c == 'I')) *((int *)vptr) = (int)tempi;
  574. else if ((*c == 'l') || (*c == 'L')) *((long *)vptr) = (long)tempi;
  575. else if ((*c == 'h') || (*c == 'H')) *((short*)vptr) = (short)tempi;
  576. else if ((*c == 'b') || (*c == 'B')) *((unsigned char *)vptr) = (unsigned char)tempi;
  577. break;
  578. case 'f': case 'F':
  579. case 'd': case 'D':
  580. if (Tcl_GetDoubleFromObj(interp,obj,&tempd) != TCL_OK) goto argerror;
  581. if ((*c == 'f') || (*c == 'F')) *((float *) vptr) = (float)tempd;
  582. else if ((*c == 'd') || (*c == 'D')) *((double*) vptr) = tempd;
  583. break;
  584. case 's': case 'S':
  585. if (*(c+1) == '#') {
  586. int *vlptr = (int *) va_arg(ap, void *);
  587. *((char **) vptr) = Tcl_GetStringFromObj(obj, vlptr);
  588. c++;
  589. } else {
  590. *((char **)vptr) = Tcl_GetStringFromObj(obj,NULL);
  591. }
  592. break;
  593. case 'c': case 'C':
  594. *((char *)vptr) = *(Tcl_GetStringFromObj(obj,NULL));
  595. break;
  596. case 'p': case 'P':
  597. ty = (swig_type_info *) va_arg(ap, void *);
  598. if (SWIG_Tcl_ConvertPtr(interp, obj, (void **) vptr, ty, 0) != SWIG_OK) goto argerror;
  599. break;
  600. case 'o': case 'O':
  601. *((Tcl_Obj **)vptr) = objv[argno+1];
  602. break;
  603. default:
  604. break;
  605. }
  606. }
  607. }
  608. if ((*c != ';') && ((objc-1) > argno)) {
  609. Tcl_SetResult(interp, (char *) "Wrong # args.", TCL_STATIC);
  610. goto argerror;
  611. }
  612. va_end(ap);
  613. return TCL_OK;
  614. argerror:
  615. {
  616. char temp[32];
  617. sprintf(temp,"%d", argno+1);
  618. c = strchr(fmt,':');
  619. if (!c) c = strchr(fmt,';');
  620. if (!c) c = (char *)"";
  621. Tcl_AppendResult(interp,c," argument ", temp, NULL);
  622. va_end(ap);
  623. return TCL_ERROR;
  624. }
  625. }
  626. #ifdef __cplusplus
  627. #if 0
  628. { /* cc-mode */
  629. #endif
  630. }
  631. #endif