visual_script_builtin_funcs.cpp 37 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318
  1. /*************************************************************************/
  2. /* visual_script_builtin_funcs.cpp */
  3. /*************************************************************************/
  4. /* This file is part of: */
  5. /* GODOT ENGINE */
  6. /* https://godotengine.org */
  7. /*************************************************************************/
  8. /* Copyright (c) 2007-2017 Juan Linietsky, Ariel Manzur. */
  9. /* Copyright (c) 2014-2017 Godot Engine contributors (cf. AUTHORS.md) */
  10. /* */
  11. /* Permission is hereby granted, free of charge, to any person obtaining */
  12. /* a copy of this software and associated documentation files (the */
  13. /* "Software"), to deal in the Software without restriction, including */
  14. /* without limitation the rights to use, copy, modify, merge, publish, */
  15. /* distribute, sublicense, and/or sell copies of the Software, and to */
  16. /* permit persons to whom the Software is furnished to do so, subject to */
  17. /* the following conditions: */
  18. /* */
  19. /* The above copyright notice and this permission notice shall be */
  20. /* included in all copies or substantial portions of the Software. */
  21. /* */
  22. /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
  23. /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
  24. /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
  25. /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
  26. /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
  27. /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
  28. /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
  29. /*************************************************************************/
  30. #include "visual_script_builtin_funcs.h"
  31. #include "class_db.h"
  32. #include "func_ref.h"
  33. #include "io/marshalls.h"
  34. #include "math_funcs.h"
  35. #include "os/os.h"
  36. #include "reference.h"
  37. #include "variant_parser.h"
  38. const char *VisualScriptBuiltinFunc::func_name[VisualScriptBuiltinFunc::FUNC_MAX] = {
  39. "sin",
  40. "cos",
  41. "tan",
  42. "sinh",
  43. "cosh",
  44. "tanh",
  45. "asin",
  46. "acos",
  47. "atan",
  48. "atan2",
  49. "sqrt",
  50. "fmod",
  51. "fposmod",
  52. "floor",
  53. "ceil",
  54. "round",
  55. "abs",
  56. "sign",
  57. "pow",
  58. "log",
  59. "exp",
  60. "is_nan",
  61. "is_inf",
  62. "ease",
  63. "decimals",
  64. "stepify",
  65. "lerp",
  66. "dectime",
  67. "randomize",
  68. "randi",
  69. "randf",
  70. "rand_range",
  71. "seed",
  72. "rand_seed",
  73. "deg2rad",
  74. "rad2deg",
  75. "linear2db",
  76. "db2linear",
  77. "max",
  78. "min",
  79. "clamp",
  80. "nearest_po2",
  81. "weakref",
  82. "funcref",
  83. "convert",
  84. "typeof",
  85. "type_exists",
  86. "char",
  87. "str",
  88. "print",
  89. "printerr",
  90. "printraw",
  91. "var2str",
  92. "str2var",
  93. "var2bytes",
  94. "bytes2var",
  95. "color_named",
  96. };
  97. VisualScriptBuiltinFunc::BuiltinFunc VisualScriptBuiltinFunc::find_function(const String &p_string) {
  98. for (int i = 0; i < FUNC_MAX; i++) {
  99. if (p_string == func_name[i])
  100. return BuiltinFunc(i);
  101. }
  102. return FUNC_MAX;
  103. }
  104. String VisualScriptBuiltinFunc::get_func_name(BuiltinFunc p_func) {
  105. ERR_FAIL_INDEX_V(p_func, FUNC_MAX, String());
  106. return func_name[p_func];
  107. }
  108. int VisualScriptBuiltinFunc::get_output_sequence_port_count() const {
  109. return has_input_sequence_port() ? 1 : 0;
  110. }
  111. bool VisualScriptBuiltinFunc::has_input_sequence_port() const {
  112. switch (func) {
  113. case MATH_RANDOMIZE:
  114. case TEXT_PRINT:
  115. case TEXT_PRINTERR:
  116. case TEXT_PRINTRAW:
  117. return true;
  118. default:
  119. return false;
  120. }
  121. }
  122. int VisualScriptBuiltinFunc::get_func_argument_count(BuiltinFunc p_func) {
  123. switch (p_func) {
  124. case MATH_RANDOMIZE:
  125. case MATH_RAND:
  126. case MATH_RANDF:
  127. return 0;
  128. case MATH_SIN:
  129. case MATH_COS:
  130. case MATH_TAN:
  131. case MATH_SINH:
  132. case MATH_COSH:
  133. case MATH_TANH:
  134. case MATH_ASIN:
  135. case MATH_ACOS:
  136. case MATH_ATAN:
  137. case MATH_SQRT:
  138. case MATH_FLOOR:
  139. case MATH_CEIL:
  140. case MATH_ROUND:
  141. case MATH_ABS:
  142. case MATH_SIGN:
  143. case MATH_LOG:
  144. case MATH_EXP:
  145. case MATH_ISNAN:
  146. case MATH_ISINF:
  147. case MATH_DECIMALS:
  148. case MATH_SEED:
  149. case MATH_RANDSEED:
  150. case MATH_DEG2RAD:
  151. case MATH_RAD2DEG:
  152. case MATH_LINEAR2DB:
  153. case MATH_DB2LINEAR:
  154. case LOGIC_NEAREST_PO2:
  155. case OBJ_WEAKREF:
  156. case TYPE_OF:
  157. case TEXT_CHAR:
  158. case TEXT_STR:
  159. case TEXT_PRINT:
  160. case TEXT_PRINTERR:
  161. case TEXT_PRINTRAW:
  162. case VAR_TO_STR:
  163. case STR_TO_VAR:
  164. case VAR_TO_BYTES:
  165. case BYTES_TO_VAR:
  166. case TYPE_EXISTS:
  167. return 1;
  168. case MATH_ATAN2:
  169. case MATH_FMOD:
  170. case MATH_FPOSMOD:
  171. case MATH_POW:
  172. case MATH_EASE:
  173. case MATH_STEPIFY:
  174. case MATH_RANDOM:
  175. case LOGIC_MAX:
  176. case LOGIC_MIN:
  177. case FUNC_FUNCREF:
  178. case TYPE_CONVERT:
  179. case COLORN:
  180. return 2;
  181. case MATH_LERP:
  182. case MATH_DECTIME:
  183. case LOGIC_CLAMP:
  184. return 3;
  185. case FUNC_MAX: {
  186. }
  187. }
  188. return 0;
  189. }
  190. int VisualScriptBuiltinFunc::get_input_value_port_count() const {
  191. return get_func_argument_count(func);
  192. }
  193. int VisualScriptBuiltinFunc::get_output_value_port_count() const {
  194. switch (func) {
  195. case MATH_RANDOMIZE:
  196. case TEXT_PRINT:
  197. case TEXT_PRINTERR:
  198. case TEXT_PRINTRAW:
  199. case MATH_SEED:
  200. return 0;
  201. case MATH_RANDSEED:
  202. return 2;
  203. default:
  204. return 1;
  205. }
  206. return 1;
  207. }
  208. String VisualScriptBuiltinFunc::get_output_sequence_port_text(int p_port) const {
  209. return String();
  210. }
  211. PropertyInfo VisualScriptBuiltinFunc::get_input_value_port_info(int p_idx) const {
  212. switch (func) {
  213. case MATH_SIN:
  214. case MATH_COS:
  215. case MATH_TAN:
  216. case MATH_SINH:
  217. case MATH_COSH:
  218. case MATH_TANH:
  219. case MATH_ASIN:
  220. case MATH_ACOS:
  221. case MATH_ATAN:
  222. case MATH_ATAN2:
  223. case MATH_SQRT: {
  224. return PropertyInfo(Variant::REAL, "num");
  225. } break;
  226. case MATH_FMOD:
  227. case MATH_FPOSMOD: {
  228. if (p_idx == 0)
  229. return PropertyInfo(Variant::REAL, "x");
  230. else
  231. return PropertyInfo(Variant::REAL, "y");
  232. } break;
  233. case MATH_FLOOR:
  234. case MATH_CEIL:
  235. case MATH_ROUND:
  236. case MATH_ABS:
  237. case MATH_SIGN: {
  238. return PropertyInfo(Variant::REAL, "num");
  239. } break;
  240. case MATH_POW: {
  241. if (p_idx == 0)
  242. return PropertyInfo(Variant::REAL, "x");
  243. else
  244. return PropertyInfo(Variant::REAL, "y");
  245. } break;
  246. case MATH_LOG:
  247. case MATH_EXP:
  248. case MATH_ISNAN:
  249. case MATH_ISINF: {
  250. return PropertyInfo(Variant::REAL, "num");
  251. } break;
  252. case MATH_EASE: {
  253. if (p_idx == 0)
  254. return PropertyInfo(Variant::REAL, "s");
  255. else
  256. return PropertyInfo(Variant::REAL, "curve");
  257. } break;
  258. case MATH_DECIMALS: {
  259. return PropertyInfo(Variant::REAL, "step");
  260. } break;
  261. case MATH_STEPIFY: {
  262. if (p_idx == 0)
  263. return PropertyInfo(Variant::REAL, "s");
  264. else
  265. return PropertyInfo(Variant::REAL, "steps");
  266. } break;
  267. case MATH_LERP: {
  268. if (p_idx == 0)
  269. return PropertyInfo(Variant::REAL, "from");
  270. else if (p_idx == 1)
  271. return PropertyInfo(Variant::REAL, "to");
  272. else
  273. return PropertyInfo(Variant::REAL, "weight");
  274. } break;
  275. case MATH_DECTIME: {
  276. if (p_idx == 0)
  277. return PropertyInfo(Variant::REAL, "value");
  278. else if (p_idx == 1)
  279. return PropertyInfo(Variant::REAL, "amount");
  280. else
  281. return PropertyInfo(Variant::REAL, "step");
  282. } break;
  283. case MATH_RANDOMIZE: {
  284. } break;
  285. case MATH_RAND: {
  286. } break;
  287. case MATH_RANDF: {
  288. } break;
  289. case MATH_RANDOM: {
  290. if (p_idx == 0)
  291. return PropertyInfo(Variant::REAL, "from");
  292. else
  293. return PropertyInfo(Variant::REAL, "to");
  294. } break;
  295. case MATH_SEED: {
  296. return PropertyInfo(Variant::INT, "seed");
  297. } break;
  298. case MATH_RANDSEED: {
  299. return PropertyInfo(Variant::INT, "seed");
  300. } break;
  301. case MATH_DEG2RAD: {
  302. return PropertyInfo(Variant::REAL, "deg");
  303. } break;
  304. case MATH_RAD2DEG: {
  305. return PropertyInfo(Variant::REAL, "rad");
  306. } break;
  307. case MATH_LINEAR2DB: {
  308. return PropertyInfo(Variant::REAL, "nrg");
  309. } break;
  310. case MATH_DB2LINEAR: {
  311. return PropertyInfo(Variant::REAL, "db");
  312. } break;
  313. case LOGIC_MAX: {
  314. if (p_idx == 0)
  315. return PropertyInfo(Variant::REAL, "a");
  316. else
  317. return PropertyInfo(Variant::REAL, "b");
  318. } break;
  319. case LOGIC_MIN: {
  320. if (p_idx == 0)
  321. return PropertyInfo(Variant::REAL, "a");
  322. else
  323. return PropertyInfo(Variant::REAL, "b");
  324. } break;
  325. case LOGIC_CLAMP: {
  326. if (p_idx == 0)
  327. return PropertyInfo(Variant::REAL, "a");
  328. else if (p_idx == 0) // FIXME: is it ok to test p_idx == 0 twice?
  329. return PropertyInfo(Variant::REAL, "min");
  330. else
  331. return PropertyInfo(Variant::REAL, "max");
  332. } break;
  333. case LOGIC_NEAREST_PO2: {
  334. return PropertyInfo(Variant::INT, "num");
  335. } break;
  336. case OBJ_WEAKREF: {
  337. return PropertyInfo(Variant::OBJECT, "source");
  338. } break;
  339. case FUNC_FUNCREF: {
  340. if (p_idx == 0)
  341. return PropertyInfo(Variant::OBJECT, "instance");
  342. else
  343. return PropertyInfo(Variant::STRING, "funcname");
  344. } break;
  345. case TYPE_CONVERT: {
  346. if (p_idx == 0)
  347. return PropertyInfo(Variant::NIL, "what");
  348. else
  349. return PropertyInfo(Variant::STRING, "type");
  350. } break;
  351. case TYPE_OF: {
  352. return PropertyInfo(Variant::NIL, "what");
  353. } break;
  354. case TYPE_EXISTS: {
  355. return PropertyInfo(Variant::STRING, "type");
  356. } break;
  357. case TEXT_CHAR: {
  358. return PropertyInfo(Variant::INT, "ascii");
  359. } break;
  360. case TEXT_STR: {
  361. return PropertyInfo(Variant::NIL, "value");
  362. } break;
  363. case TEXT_PRINT: {
  364. return PropertyInfo(Variant::NIL, "value");
  365. } break;
  366. case TEXT_PRINTERR: {
  367. return PropertyInfo(Variant::NIL, "value");
  368. } break;
  369. case TEXT_PRINTRAW: {
  370. return PropertyInfo(Variant::NIL, "value");
  371. } break;
  372. case VAR_TO_STR: {
  373. return PropertyInfo(Variant::NIL, "var");
  374. } break;
  375. case STR_TO_VAR: {
  376. return PropertyInfo(Variant::STRING, "string");
  377. } break;
  378. case VAR_TO_BYTES: {
  379. return PropertyInfo(Variant::NIL, "var");
  380. } break;
  381. case BYTES_TO_VAR: {
  382. return PropertyInfo(Variant::POOL_BYTE_ARRAY, "bytes");
  383. } break;
  384. case COLORN: {
  385. if (p_idx == 0)
  386. return PropertyInfo(Variant::STRING, "name");
  387. else
  388. return PropertyInfo(Variant::REAL, "alpha");
  389. } break;
  390. case FUNC_MAX: {
  391. }
  392. }
  393. return PropertyInfo();
  394. }
  395. PropertyInfo VisualScriptBuiltinFunc::get_output_value_port_info(int p_idx) const {
  396. Variant::Type t = Variant::NIL;
  397. switch (func) {
  398. case MATH_SIN:
  399. case MATH_COS:
  400. case MATH_TAN:
  401. case MATH_SINH:
  402. case MATH_COSH:
  403. case MATH_TANH:
  404. case MATH_ASIN:
  405. case MATH_ACOS:
  406. case MATH_ATAN:
  407. case MATH_ATAN2:
  408. case MATH_SQRT:
  409. case MATH_FMOD:
  410. case MATH_FPOSMOD:
  411. case MATH_FLOOR:
  412. case MATH_CEIL: {
  413. t = Variant::REAL;
  414. } break;
  415. case MATH_ROUND: {
  416. t = Variant::INT;
  417. } break;
  418. case MATH_ABS: {
  419. t = Variant::NIL;
  420. } break;
  421. case MATH_SIGN: {
  422. t = Variant::NIL;
  423. } break;
  424. case MATH_POW:
  425. case MATH_LOG:
  426. case MATH_EXP: {
  427. t = Variant::REAL;
  428. } break;
  429. case MATH_ISNAN:
  430. case MATH_ISINF: {
  431. t = Variant::BOOL;
  432. } break;
  433. case MATH_EASE: {
  434. t = Variant::REAL;
  435. } break;
  436. case MATH_DECIMALS: {
  437. t = Variant::INT;
  438. } break;
  439. case MATH_STEPIFY:
  440. case MATH_LERP:
  441. case MATH_DECTIME: {
  442. t = Variant::REAL;
  443. } break;
  444. case MATH_RANDOMIZE: {
  445. } break;
  446. case MATH_RAND: {
  447. t = Variant::INT;
  448. } break;
  449. case MATH_RANDF:
  450. case MATH_RANDOM: {
  451. t = Variant::REAL;
  452. } break;
  453. case MATH_SEED: {
  454. } break;
  455. case MATH_RANDSEED: {
  456. if (p_idx == 0)
  457. return PropertyInfo(Variant::INT, "rnd");
  458. else
  459. return PropertyInfo(Variant::INT, "seed");
  460. } break;
  461. case MATH_DEG2RAD:
  462. case MATH_RAD2DEG:
  463. case MATH_LINEAR2DB:
  464. case MATH_DB2LINEAR: {
  465. t = Variant::REAL;
  466. } break;
  467. case LOGIC_MAX:
  468. case LOGIC_MIN:
  469. case LOGIC_CLAMP: {
  470. } break;
  471. case LOGIC_NEAREST_PO2: {
  472. t = Variant::NIL;
  473. } break;
  474. case OBJ_WEAKREF: {
  475. t = Variant::OBJECT;
  476. } break;
  477. case FUNC_FUNCREF: {
  478. t = Variant::OBJECT;
  479. } break;
  480. case TYPE_CONVERT: {
  481. } break;
  482. case TYPE_OF: {
  483. t = Variant::INT;
  484. } break;
  485. case TYPE_EXISTS: {
  486. t = Variant::BOOL;
  487. } break;
  488. case TEXT_CHAR:
  489. case TEXT_STR: {
  490. t = Variant::STRING;
  491. } break;
  492. case TEXT_PRINT: {
  493. } break;
  494. case TEXT_PRINTERR: {
  495. } break;
  496. case TEXT_PRINTRAW: {
  497. } break;
  498. case VAR_TO_STR: {
  499. t = Variant::STRING;
  500. } break;
  501. case STR_TO_VAR: {
  502. } break;
  503. case VAR_TO_BYTES: {
  504. t = Variant::POOL_BYTE_ARRAY;
  505. } break;
  506. case BYTES_TO_VAR: {
  507. } break;
  508. case COLORN: {
  509. t = Variant::COLOR;
  510. } break;
  511. case FUNC_MAX: {
  512. }
  513. }
  514. return PropertyInfo(t, "");
  515. }
  516. String VisualScriptBuiltinFunc::get_caption() const {
  517. return "BuiltinFunc";
  518. }
  519. String VisualScriptBuiltinFunc::get_text() const {
  520. return func_name[func];
  521. }
  522. void VisualScriptBuiltinFunc::set_func(BuiltinFunc p_which) {
  523. ERR_FAIL_INDEX(p_which, FUNC_MAX);
  524. func = p_which;
  525. _change_notify();
  526. ports_changed_notify();
  527. }
  528. VisualScriptBuiltinFunc::BuiltinFunc VisualScriptBuiltinFunc::get_func() {
  529. return func;
  530. }
  531. #define VALIDATE_ARG_NUM(m_arg) \
  532. if (!p_inputs[m_arg]->is_num()) { \
  533. r_error.error = Variant::CallError::CALL_ERROR_INVALID_ARGUMENT; \
  534. r_error.argument = m_arg; \
  535. r_error.expected = Variant::REAL; \
  536. return; \
  537. }
  538. void VisualScriptBuiltinFunc::exec_func(BuiltinFunc p_func, const Variant **p_inputs, Variant *r_return, Variant::CallError &r_error, String &r_error_str) {
  539. switch (p_func) {
  540. case VisualScriptBuiltinFunc::MATH_SIN: {
  541. VALIDATE_ARG_NUM(0);
  542. *r_return = Math::sin((double)*p_inputs[0]);
  543. } break;
  544. case VisualScriptBuiltinFunc::MATH_COS: {
  545. VALIDATE_ARG_NUM(0);
  546. *r_return = Math::cos((double)*p_inputs[0]);
  547. } break;
  548. case VisualScriptBuiltinFunc::MATH_TAN: {
  549. VALIDATE_ARG_NUM(0);
  550. *r_return = Math::tan((double)*p_inputs[0]);
  551. } break;
  552. case VisualScriptBuiltinFunc::MATH_SINH: {
  553. VALIDATE_ARG_NUM(0);
  554. *r_return = Math::sinh((double)*p_inputs[0]);
  555. } break;
  556. case VisualScriptBuiltinFunc::MATH_COSH: {
  557. VALIDATE_ARG_NUM(0);
  558. *r_return = Math::cosh((double)*p_inputs[0]);
  559. } break;
  560. case VisualScriptBuiltinFunc::MATH_TANH: {
  561. VALIDATE_ARG_NUM(0);
  562. *r_return = Math::tanh((double)*p_inputs[0]);
  563. } break;
  564. case VisualScriptBuiltinFunc::MATH_ASIN: {
  565. VALIDATE_ARG_NUM(0);
  566. *r_return = Math::asin((double)*p_inputs[0]);
  567. } break;
  568. case VisualScriptBuiltinFunc::MATH_ACOS: {
  569. VALIDATE_ARG_NUM(0);
  570. *r_return = Math::acos((double)*p_inputs[0]);
  571. } break;
  572. case VisualScriptBuiltinFunc::MATH_ATAN: {
  573. VALIDATE_ARG_NUM(0);
  574. *r_return = Math::atan((double)*p_inputs[0]);
  575. } break;
  576. case VisualScriptBuiltinFunc::MATH_ATAN2: {
  577. VALIDATE_ARG_NUM(0);
  578. VALIDATE_ARG_NUM(1);
  579. *r_return = Math::atan2((double)*p_inputs[0], (double)*p_inputs[1]);
  580. } break;
  581. case VisualScriptBuiltinFunc::MATH_SQRT: {
  582. VALIDATE_ARG_NUM(0);
  583. *r_return = Math::sqrt((double)*p_inputs[0]);
  584. } break;
  585. case VisualScriptBuiltinFunc::MATH_FMOD: {
  586. VALIDATE_ARG_NUM(0);
  587. VALIDATE_ARG_NUM(1);
  588. *r_return = Math::fmod((double)*p_inputs[0], (double)*p_inputs[1]);
  589. } break;
  590. case VisualScriptBuiltinFunc::MATH_FPOSMOD: {
  591. VALIDATE_ARG_NUM(0);
  592. VALIDATE_ARG_NUM(1);
  593. *r_return = Math::fposmod((double)*p_inputs[0], (double)*p_inputs[1]);
  594. } break;
  595. case VisualScriptBuiltinFunc::MATH_FLOOR: {
  596. VALIDATE_ARG_NUM(0);
  597. *r_return = Math::floor((double)*p_inputs[0]);
  598. } break;
  599. case VisualScriptBuiltinFunc::MATH_CEIL: {
  600. VALIDATE_ARG_NUM(0);
  601. *r_return = Math::ceil((double)*p_inputs[0]);
  602. } break;
  603. case VisualScriptBuiltinFunc::MATH_ROUND: {
  604. VALIDATE_ARG_NUM(0);
  605. *r_return = Math::round((double)*p_inputs[0]);
  606. } break;
  607. case VisualScriptBuiltinFunc::MATH_ABS: {
  608. if (p_inputs[0]->get_type() == Variant::INT) {
  609. int64_t i = *p_inputs[0];
  610. *r_return = ABS(i);
  611. } else if (p_inputs[0]->get_type() == Variant::REAL) {
  612. real_t r = *p_inputs[0];
  613. *r_return = Math::abs(r);
  614. } else {
  615. r_error.error = Variant::CallError::CALL_ERROR_INVALID_ARGUMENT;
  616. r_error.argument = 0;
  617. r_error.expected = Variant::REAL;
  618. }
  619. } break;
  620. case VisualScriptBuiltinFunc::MATH_SIGN: {
  621. if (p_inputs[0]->get_type() == Variant::INT) {
  622. int64_t i = *p_inputs[0];
  623. *r_return = i < 0 ? -1 : (i > 0 ? +1 : 0);
  624. } else if (p_inputs[0]->get_type() == Variant::REAL) {
  625. real_t r = *p_inputs[0];
  626. *r_return = r < 0.0 ? -1.0 : (r > 0.0 ? +1.0 : 0.0);
  627. } else {
  628. r_error.error = Variant::CallError::CALL_ERROR_INVALID_ARGUMENT;
  629. r_error.argument = 0;
  630. r_error.expected = Variant::REAL;
  631. }
  632. } break;
  633. case VisualScriptBuiltinFunc::MATH_POW: {
  634. VALIDATE_ARG_NUM(0);
  635. VALIDATE_ARG_NUM(1);
  636. *r_return = Math::pow((double)*p_inputs[0], (double)*p_inputs[1]);
  637. } break;
  638. case VisualScriptBuiltinFunc::MATH_LOG: {
  639. VALIDATE_ARG_NUM(0);
  640. *r_return = Math::log((double)*p_inputs[0]);
  641. } break;
  642. case VisualScriptBuiltinFunc::MATH_EXP: {
  643. VALIDATE_ARG_NUM(0);
  644. *r_return = Math::exp((double)*p_inputs[0]);
  645. } break;
  646. case VisualScriptBuiltinFunc::MATH_ISNAN: {
  647. VALIDATE_ARG_NUM(0);
  648. *r_return = Math::is_nan((double)*p_inputs[0]);
  649. } break;
  650. case VisualScriptBuiltinFunc::MATH_ISINF: {
  651. VALIDATE_ARG_NUM(0);
  652. *r_return = Math::is_inf((double)*p_inputs[0]);
  653. } break;
  654. case VisualScriptBuiltinFunc::MATH_EASE: {
  655. VALIDATE_ARG_NUM(0);
  656. VALIDATE_ARG_NUM(1);
  657. *r_return = Math::ease((double)*p_inputs[0], (double)*p_inputs[1]);
  658. } break;
  659. case VisualScriptBuiltinFunc::MATH_DECIMALS: {
  660. VALIDATE_ARG_NUM(0);
  661. *r_return = Math::step_decimals((double)*p_inputs[0]);
  662. } break;
  663. case VisualScriptBuiltinFunc::MATH_STEPIFY: {
  664. VALIDATE_ARG_NUM(0);
  665. VALIDATE_ARG_NUM(1);
  666. *r_return = Math::stepify((double)*p_inputs[0], (double)*p_inputs[1]);
  667. } break;
  668. case VisualScriptBuiltinFunc::MATH_LERP: {
  669. VALIDATE_ARG_NUM(0);
  670. VALIDATE_ARG_NUM(1);
  671. VALIDATE_ARG_NUM(2);
  672. *r_return = Math::lerp((double)*p_inputs[0], (double)*p_inputs[1], (double)*p_inputs[2]);
  673. } break;
  674. case VisualScriptBuiltinFunc::MATH_DECTIME: {
  675. VALIDATE_ARG_NUM(0);
  676. VALIDATE_ARG_NUM(1);
  677. VALIDATE_ARG_NUM(2);
  678. *r_return = Math::dectime((double)*p_inputs[0], (double)*p_inputs[1], (double)*p_inputs[2]);
  679. } break;
  680. case VisualScriptBuiltinFunc::MATH_RANDOMIZE: {
  681. Math::randomize();
  682. } break;
  683. case VisualScriptBuiltinFunc::MATH_RAND: {
  684. *r_return = Math::rand();
  685. } break;
  686. case VisualScriptBuiltinFunc::MATH_RANDF: {
  687. *r_return = Math::randf();
  688. } break;
  689. case VisualScriptBuiltinFunc::MATH_RANDOM: {
  690. VALIDATE_ARG_NUM(0);
  691. VALIDATE_ARG_NUM(1);
  692. *r_return = Math::random((double)*p_inputs[0], (double)*p_inputs[1]);
  693. } break;
  694. case VisualScriptBuiltinFunc::MATH_SEED: {
  695. VALIDATE_ARG_NUM(0);
  696. uint64_t seed = *p_inputs[0];
  697. Math::seed(seed);
  698. } break;
  699. case VisualScriptBuiltinFunc::MATH_RANDSEED: {
  700. VALIDATE_ARG_NUM(0);
  701. uint64_t seed = *p_inputs[0];
  702. int ret = Math::rand_from_seed(&seed);
  703. Array reta;
  704. reta.push_back(ret);
  705. reta.push_back(seed);
  706. *r_return = reta;
  707. } break;
  708. case VisualScriptBuiltinFunc::MATH_DEG2RAD: {
  709. VALIDATE_ARG_NUM(0);
  710. *r_return = Math::deg2rad((double)*p_inputs[0]);
  711. } break;
  712. case VisualScriptBuiltinFunc::MATH_RAD2DEG: {
  713. VALIDATE_ARG_NUM(0);
  714. *r_return = Math::rad2deg((double)*p_inputs[0]);
  715. } break;
  716. case VisualScriptBuiltinFunc::MATH_LINEAR2DB: {
  717. VALIDATE_ARG_NUM(0);
  718. *r_return = Math::linear2db((double)*p_inputs[0]);
  719. } break;
  720. case VisualScriptBuiltinFunc::MATH_DB2LINEAR: {
  721. VALIDATE_ARG_NUM(0);
  722. *r_return = Math::db2linear((double)*p_inputs[0]);
  723. } break;
  724. case VisualScriptBuiltinFunc::LOGIC_MAX: {
  725. if (p_inputs[0]->get_type() == Variant::INT && p_inputs[1]->get_type() == Variant::INT) {
  726. int64_t a = *p_inputs[0];
  727. int64_t b = *p_inputs[1];
  728. *r_return = MAX(a, b);
  729. } else {
  730. VALIDATE_ARG_NUM(0);
  731. VALIDATE_ARG_NUM(1);
  732. real_t a = *p_inputs[0];
  733. real_t b = *p_inputs[1];
  734. *r_return = MAX(a, b);
  735. }
  736. } break;
  737. case VisualScriptBuiltinFunc::LOGIC_MIN: {
  738. if (p_inputs[0]->get_type() == Variant::INT && p_inputs[1]->get_type() == Variant::INT) {
  739. int64_t a = *p_inputs[0];
  740. int64_t b = *p_inputs[1];
  741. *r_return = MIN(a, b);
  742. } else {
  743. VALIDATE_ARG_NUM(0);
  744. VALIDATE_ARG_NUM(1);
  745. real_t a = *p_inputs[0];
  746. real_t b = *p_inputs[1];
  747. *r_return = MIN(a, b);
  748. }
  749. } break;
  750. case VisualScriptBuiltinFunc::LOGIC_CLAMP: {
  751. if (p_inputs[0]->get_type() == Variant::INT && p_inputs[1]->get_type() == Variant::INT && p_inputs[2]->get_type() == Variant::INT) {
  752. int64_t a = *p_inputs[0];
  753. int64_t b = *p_inputs[1];
  754. int64_t c = *p_inputs[2];
  755. *r_return = CLAMP(a, b, c);
  756. } else {
  757. VALIDATE_ARG_NUM(0);
  758. VALIDATE_ARG_NUM(1);
  759. VALIDATE_ARG_NUM(2);
  760. real_t a = *p_inputs[0];
  761. real_t b = *p_inputs[1];
  762. real_t c = *p_inputs[2];
  763. *r_return = CLAMP(a, b, c);
  764. }
  765. } break;
  766. case VisualScriptBuiltinFunc::LOGIC_NEAREST_PO2: {
  767. VALIDATE_ARG_NUM(0);
  768. int64_t num = *p_inputs[0];
  769. *r_return = next_power_of_2(num);
  770. } break;
  771. case VisualScriptBuiltinFunc::OBJ_WEAKREF: {
  772. if (p_inputs[0]->get_type() != Variant::OBJECT) {
  773. r_error.error = Variant::CallError::CALL_ERROR_INVALID_ARGUMENT;
  774. r_error.argument = 0;
  775. r_error.expected = Variant::OBJECT;
  776. return;
  777. }
  778. if (p_inputs[0]->is_ref()) {
  779. REF r = *p_inputs[0];
  780. if (!r.is_valid()) {
  781. return;
  782. }
  783. Ref<WeakRef> wref = memnew(WeakRef);
  784. wref->set_ref(r);
  785. *r_return = wref;
  786. } else {
  787. Object *obj = *p_inputs[0];
  788. if (!obj) {
  789. return;
  790. }
  791. Ref<WeakRef> wref = memnew(WeakRef);
  792. wref->set_obj(obj);
  793. *r_return = wref;
  794. }
  795. } break;
  796. case VisualScriptBuiltinFunc::FUNC_FUNCREF: {
  797. if (p_inputs[0]->get_type() != Variant::OBJECT) {
  798. r_error.error = Variant::CallError::CALL_ERROR_INVALID_ARGUMENT;
  799. r_error.argument = 0;
  800. r_error.expected = Variant::OBJECT;
  801. return;
  802. }
  803. if (p_inputs[1]->get_type() != Variant::STRING && p_inputs[1]->get_type() != Variant::NODE_PATH) {
  804. r_error.error = Variant::CallError::CALL_ERROR_INVALID_ARGUMENT;
  805. r_error.argument = 1;
  806. r_error.expected = Variant::STRING;
  807. return;
  808. }
  809. Ref<FuncRef> fr = memnew(FuncRef);
  810. fr->set_instance(*p_inputs[0]);
  811. fr->set_function(*p_inputs[1]);
  812. *r_return = fr;
  813. } break;
  814. case VisualScriptBuiltinFunc::TYPE_CONVERT: {
  815. VALIDATE_ARG_NUM(1);
  816. int type = *p_inputs[1];
  817. if (type < 0 || type >= Variant::VARIANT_MAX) {
  818. r_error_str = RTR("Invalid type argument to convert(), use TYPE_* constants.");
  819. r_error.error = Variant::CallError::CALL_ERROR_INVALID_ARGUMENT;
  820. r_error.argument = 0;
  821. r_error.expected = Variant::INT;
  822. return;
  823. } else {
  824. *r_return = Variant::construct(Variant::Type(type), p_inputs, 1, r_error);
  825. }
  826. } break;
  827. case VisualScriptBuiltinFunc::TYPE_OF: {
  828. *r_return = p_inputs[0]->get_type();
  829. } break;
  830. case VisualScriptBuiltinFunc::TYPE_EXISTS: {
  831. *r_return = ClassDB::class_exists(*p_inputs[0]);
  832. } break;
  833. case VisualScriptBuiltinFunc::TEXT_CHAR: {
  834. CharType result[2] = { *p_inputs[0], 0 };
  835. *r_return = String(result);
  836. } break;
  837. case VisualScriptBuiltinFunc::TEXT_STR: {
  838. String str = *p_inputs[0];
  839. *r_return = str;
  840. } break;
  841. case VisualScriptBuiltinFunc::TEXT_PRINT: {
  842. String str = *p_inputs[0];
  843. print_line(str);
  844. } break;
  845. case VisualScriptBuiltinFunc::TEXT_PRINTERR: {
  846. String str = *p_inputs[0];
  847. //str+="\n";
  848. OS::get_singleton()->printerr("%s\n", str.utf8().get_data());
  849. } break;
  850. case VisualScriptBuiltinFunc::TEXT_PRINTRAW: {
  851. String str = *p_inputs[0];
  852. //str+="\n";
  853. OS::get_singleton()->print("%s", str.utf8().get_data());
  854. } break;
  855. case VisualScriptBuiltinFunc::VAR_TO_STR: {
  856. String vars;
  857. VariantWriter::write_to_string(*p_inputs[0], vars);
  858. *r_return = vars;
  859. } break;
  860. case VisualScriptBuiltinFunc::STR_TO_VAR: {
  861. if (p_inputs[0]->get_type() != Variant::STRING) {
  862. r_error.error = Variant::CallError::CALL_ERROR_INVALID_ARGUMENT;
  863. r_error.argument = 0;
  864. r_error.expected = Variant::STRING;
  865. return;
  866. }
  867. VariantParser::StreamString ss;
  868. ss.s = *p_inputs[0];
  869. String errs;
  870. int line;
  871. Error err = VariantParser::parse(&ss, *r_return, errs, line);
  872. if (err != OK) {
  873. r_error.error = Variant::CallError::CALL_ERROR_INVALID_ARGUMENT;
  874. r_error.argument = 0;
  875. r_error.expected = Variant::STRING;
  876. *r_return = "Parse error at line " + itos(line) + ": " + errs;
  877. return;
  878. }
  879. } break;
  880. case VisualScriptBuiltinFunc::VAR_TO_BYTES: {
  881. PoolByteArray barr;
  882. int len;
  883. Error err = encode_variant(*p_inputs[0], NULL, len);
  884. if (err) {
  885. r_error.error = Variant::CallError::CALL_ERROR_INVALID_ARGUMENT;
  886. r_error.argument = 0;
  887. r_error.expected = Variant::NIL;
  888. r_error_str = "Unexpected error encoding variable to bytes, likely unserializable type found (Object or RID).";
  889. return;
  890. }
  891. barr.resize(len);
  892. {
  893. PoolByteArray::Write w = barr.write();
  894. encode_variant(*p_inputs[0], w.ptr(), len);
  895. }
  896. *r_return = barr;
  897. } break;
  898. case VisualScriptBuiltinFunc::BYTES_TO_VAR: {
  899. if (p_inputs[0]->get_type() != Variant::POOL_BYTE_ARRAY) {
  900. r_error.error = Variant::CallError::CALL_ERROR_INVALID_ARGUMENT;
  901. r_error.argument = 0;
  902. r_error.expected = Variant::POOL_BYTE_ARRAY;
  903. return;
  904. }
  905. PoolByteArray varr = *p_inputs[0];
  906. Variant ret;
  907. {
  908. PoolByteArray::Read r = varr.read();
  909. Error err = decode_variant(ret, r.ptr(), varr.size(), NULL);
  910. if (err != OK) {
  911. r_error_str = RTR("Not enough bytes for decoding bytes, or invalid format.");
  912. r_error.error = Variant::CallError::CALL_ERROR_INVALID_ARGUMENT;
  913. r_error.argument = 0;
  914. r_error.expected = Variant::POOL_BYTE_ARRAY;
  915. return;
  916. }
  917. }
  918. *r_return = ret;
  919. } break;
  920. case VisualScriptBuiltinFunc::COLORN: {
  921. VALIDATE_ARG_NUM(1);
  922. Color color = Color::named(*p_inputs[0]);
  923. color.a = *p_inputs[1];
  924. *r_return = String(color);
  925. } break;
  926. default: {}
  927. }
  928. }
  929. class VisualScriptNodeInstanceBuiltinFunc : public VisualScriptNodeInstance {
  930. public:
  931. VisualScriptBuiltinFunc *node;
  932. VisualScriptInstance *instance;
  933. VisualScriptBuiltinFunc::BuiltinFunc func;
  934. //virtual int get_working_memory_size() const { return 0; }
  935. //virtual bool is_output_port_unsequenced(int p_idx) const { return false; }
  936. //virtual bool get_output_port_unsequenced(int p_idx,Variant* r_value,Variant* p_working_mem,String &r_error) const { return true; }
  937. virtual int step(const Variant **p_inputs, Variant **p_outputs, StartMode p_start_mode, Variant *p_working_mem, Variant::CallError &r_error, String &r_error_str) {
  938. VisualScriptBuiltinFunc::exec_func(func, p_inputs, p_outputs[0], r_error, r_error_str);
  939. return 0;
  940. }
  941. };
  942. VisualScriptNodeInstance *VisualScriptBuiltinFunc::instance(VisualScriptInstance *p_instance) {
  943. VisualScriptNodeInstanceBuiltinFunc *instance = memnew(VisualScriptNodeInstanceBuiltinFunc);
  944. instance->node = this;
  945. instance->instance = p_instance;
  946. instance->func = func;
  947. return instance;
  948. }
  949. void VisualScriptBuiltinFunc::_bind_methods() {
  950. ClassDB::bind_method(D_METHOD("set_func", "which"), &VisualScriptBuiltinFunc::set_func);
  951. ClassDB::bind_method(D_METHOD("get_func"), &VisualScriptBuiltinFunc::get_func);
  952. String cc;
  953. for (int i = 0; i < FUNC_MAX; i++) {
  954. if (i > 0)
  955. cc += ",";
  956. cc += func_name[i];
  957. }
  958. ADD_PROPERTY(PropertyInfo(Variant::INT, "function", PROPERTY_HINT_ENUM, cc), "set_func", "get_func");
  959. BIND_ENUM_CONSTANT(MATH_SIN);
  960. BIND_ENUM_CONSTANT(MATH_COS);
  961. BIND_ENUM_CONSTANT(MATH_TAN);
  962. BIND_ENUM_CONSTANT(MATH_SINH);
  963. BIND_ENUM_CONSTANT(MATH_COSH);
  964. BIND_ENUM_CONSTANT(MATH_TANH);
  965. BIND_ENUM_CONSTANT(MATH_ASIN);
  966. BIND_ENUM_CONSTANT(MATH_ACOS);
  967. BIND_ENUM_CONSTANT(MATH_ATAN);
  968. BIND_ENUM_CONSTANT(MATH_ATAN2);
  969. BIND_ENUM_CONSTANT(MATH_SQRT);
  970. BIND_ENUM_CONSTANT(MATH_FMOD);
  971. BIND_ENUM_CONSTANT(MATH_FPOSMOD);
  972. BIND_ENUM_CONSTANT(MATH_FLOOR);
  973. BIND_ENUM_CONSTANT(MATH_CEIL);
  974. BIND_ENUM_CONSTANT(MATH_ROUND);
  975. BIND_ENUM_CONSTANT(MATH_ABS);
  976. BIND_ENUM_CONSTANT(MATH_SIGN);
  977. BIND_ENUM_CONSTANT(MATH_POW);
  978. BIND_ENUM_CONSTANT(MATH_LOG);
  979. BIND_ENUM_CONSTANT(MATH_EXP);
  980. BIND_ENUM_CONSTANT(MATH_ISNAN);
  981. BIND_ENUM_CONSTANT(MATH_ISINF);
  982. BIND_ENUM_CONSTANT(MATH_EASE);
  983. BIND_ENUM_CONSTANT(MATH_DECIMALS);
  984. BIND_ENUM_CONSTANT(MATH_STEPIFY);
  985. BIND_ENUM_CONSTANT(MATH_LERP);
  986. BIND_ENUM_CONSTANT(MATH_DECTIME);
  987. BIND_ENUM_CONSTANT(MATH_RANDOMIZE);
  988. BIND_ENUM_CONSTANT(MATH_RAND);
  989. BIND_ENUM_CONSTANT(MATH_RANDF);
  990. BIND_ENUM_CONSTANT(MATH_RANDOM);
  991. BIND_ENUM_CONSTANT(MATH_SEED);
  992. BIND_ENUM_CONSTANT(MATH_RANDSEED);
  993. BIND_ENUM_CONSTANT(MATH_DEG2RAD);
  994. BIND_ENUM_CONSTANT(MATH_RAD2DEG);
  995. BIND_ENUM_CONSTANT(MATH_LINEAR2DB);
  996. BIND_ENUM_CONSTANT(MATH_DB2LINEAR);
  997. BIND_ENUM_CONSTANT(LOGIC_MAX);
  998. BIND_ENUM_CONSTANT(LOGIC_MIN);
  999. BIND_ENUM_CONSTANT(LOGIC_CLAMP);
  1000. BIND_ENUM_CONSTANT(LOGIC_NEAREST_PO2);
  1001. BIND_ENUM_CONSTANT(OBJ_WEAKREF);
  1002. BIND_ENUM_CONSTANT(FUNC_FUNCREF);
  1003. BIND_ENUM_CONSTANT(TYPE_CONVERT);
  1004. BIND_ENUM_CONSTANT(TYPE_OF);
  1005. BIND_ENUM_CONSTANT(TYPE_EXISTS);
  1006. BIND_ENUM_CONSTANT(TEXT_CHAR);
  1007. BIND_ENUM_CONSTANT(TEXT_STR);
  1008. BIND_ENUM_CONSTANT(TEXT_PRINT);
  1009. BIND_ENUM_CONSTANT(TEXT_PRINTERR);
  1010. BIND_ENUM_CONSTANT(TEXT_PRINTRAW);
  1011. BIND_ENUM_CONSTANT(VAR_TO_STR);
  1012. BIND_ENUM_CONSTANT(STR_TO_VAR);
  1013. BIND_ENUM_CONSTANT(VAR_TO_BYTES);
  1014. BIND_ENUM_CONSTANT(BYTES_TO_VAR);
  1015. BIND_ENUM_CONSTANT(COLORN);
  1016. BIND_ENUM_CONSTANT(FUNC_MAX);
  1017. }
  1018. VisualScriptBuiltinFunc::VisualScriptBuiltinFunc() {
  1019. func = MATH_SIN;
  1020. }
  1021. template <VisualScriptBuiltinFunc::BuiltinFunc func>
  1022. static Ref<VisualScriptNode> create_builtin_func_node(const String &p_name) {
  1023. Ref<VisualScriptBuiltinFunc> node;
  1024. node.instance();
  1025. node->set_func(func);
  1026. return node;
  1027. }
  1028. void register_visual_script_builtin_func_node() {
  1029. VisualScriptLanguage::singleton->add_register_func("functions/built_in/sin", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_SIN>);
  1030. VisualScriptLanguage::singleton->add_register_func("functions/built_in/cos", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_COS>);
  1031. VisualScriptLanguage::singleton->add_register_func("functions/built_in/tan", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_TAN>);
  1032. VisualScriptLanguage::singleton->add_register_func("functions/built_in/sinh", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_SINH>);
  1033. VisualScriptLanguage::singleton->add_register_func("functions/built_in/cosh", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_COSH>);
  1034. VisualScriptLanguage::singleton->add_register_func("functions/built_in/tanh", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_TANH>);
  1035. VisualScriptLanguage::singleton->add_register_func("functions/built_in/asin", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_ASIN>);
  1036. VisualScriptLanguage::singleton->add_register_func("functions/built_in/acos", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_ACOS>);
  1037. VisualScriptLanguage::singleton->add_register_func("functions/built_in/atan", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_ATAN>);
  1038. VisualScriptLanguage::singleton->add_register_func("functions/built_in/atan2", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_ATAN2>);
  1039. VisualScriptLanguage::singleton->add_register_func("functions/built_in/sqrt", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_SQRT>);
  1040. VisualScriptLanguage::singleton->add_register_func("functions/built_in/fmod", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_FMOD>);
  1041. VisualScriptLanguage::singleton->add_register_func("functions/built_in/fposmod", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_FPOSMOD>);
  1042. VisualScriptLanguage::singleton->add_register_func("functions/built_in/floor", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_FLOOR>);
  1043. VisualScriptLanguage::singleton->add_register_func("functions/built_in/ceil", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_CEIL>);
  1044. VisualScriptLanguage::singleton->add_register_func("functions/built_in/round", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_ROUND>);
  1045. VisualScriptLanguage::singleton->add_register_func("functions/built_in/abs", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_ABS>);
  1046. VisualScriptLanguage::singleton->add_register_func("functions/built_in/sign", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_SIGN>);
  1047. VisualScriptLanguage::singleton->add_register_func("functions/built_in/pow", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_POW>);
  1048. VisualScriptLanguage::singleton->add_register_func("functions/built_in/log", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_LOG>);
  1049. VisualScriptLanguage::singleton->add_register_func("functions/built_in/exp", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_EXP>);
  1050. VisualScriptLanguage::singleton->add_register_func("functions/built_in/isnan", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_ISNAN>);
  1051. VisualScriptLanguage::singleton->add_register_func("functions/built_in/isinf", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_ISINF>);
  1052. VisualScriptLanguage::singleton->add_register_func("functions/built_in/ease", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_EASE>);
  1053. VisualScriptLanguage::singleton->add_register_func("functions/built_in/decimals", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_DECIMALS>);
  1054. VisualScriptLanguage::singleton->add_register_func("functions/built_in/stepify", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_STEPIFY>);
  1055. VisualScriptLanguage::singleton->add_register_func("functions/built_in/lerp", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_LERP>);
  1056. VisualScriptLanguage::singleton->add_register_func("functions/built_in/dectime", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_DECTIME>);
  1057. VisualScriptLanguage::singleton->add_register_func("functions/built_in/randomize", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_RANDOMIZE>);
  1058. VisualScriptLanguage::singleton->add_register_func("functions/built_in/rand", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_RAND>);
  1059. VisualScriptLanguage::singleton->add_register_func("functions/built_in/randf", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_RANDF>);
  1060. VisualScriptLanguage::singleton->add_register_func("functions/built_in/random", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_RANDOM>);
  1061. VisualScriptLanguage::singleton->add_register_func("functions/built_in/seed", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_SEED>);
  1062. VisualScriptLanguage::singleton->add_register_func("functions/built_in/randseed", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_RANDSEED>);
  1063. VisualScriptLanguage::singleton->add_register_func("functions/built_in/deg2rad", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_DEG2RAD>);
  1064. VisualScriptLanguage::singleton->add_register_func("functions/built_in/rad2deg", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_RAD2DEG>);
  1065. VisualScriptLanguage::singleton->add_register_func("functions/built_in/linear2db", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_LINEAR2DB>);
  1066. VisualScriptLanguage::singleton->add_register_func("functions/built_in/db2linear", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_DB2LINEAR>);
  1067. VisualScriptLanguage::singleton->add_register_func("functions/built_in/max", create_builtin_func_node<VisualScriptBuiltinFunc::LOGIC_MAX>);
  1068. VisualScriptLanguage::singleton->add_register_func("functions/built_in/min", create_builtin_func_node<VisualScriptBuiltinFunc::LOGIC_MIN>);
  1069. VisualScriptLanguage::singleton->add_register_func("functions/built_in/clamp", create_builtin_func_node<VisualScriptBuiltinFunc::LOGIC_CLAMP>);
  1070. VisualScriptLanguage::singleton->add_register_func("functions/built_in/nearest_po2", create_builtin_func_node<VisualScriptBuiltinFunc::LOGIC_NEAREST_PO2>);
  1071. VisualScriptLanguage::singleton->add_register_func("functions/built_in/weakref", create_builtin_func_node<VisualScriptBuiltinFunc::OBJ_WEAKREF>);
  1072. VisualScriptLanguage::singleton->add_register_func("functions/built_in/funcref", create_builtin_func_node<VisualScriptBuiltinFunc::FUNC_FUNCREF>);
  1073. VisualScriptLanguage::singleton->add_register_func("functions/built_in/convert", create_builtin_func_node<VisualScriptBuiltinFunc::TYPE_CONVERT>);
  1074. VisualScriptLanguage::singleton->add_register_func("functions/built_in/typeof", create_builtin_func_node<VisualScriptBuiltinFunc::TYPE_OF>);
  1075. VisualScriptLanguage::singleton->add_register_func("functions/built_in/type_exists", create_builtin_func_node<VisualScriptBuiltinFunc::TYPE_EXISTS>);
  1076. VisualScriptLanguage::singleton->add_register_func("functions/built_in/char", create_builtin_func_node<VisualScriptBuiltinFunc::TEXT_CHAR>);
  1077. VisualScriptLanguage::singleton->add_register_func("functions/built_in/str", create_builtin_func_node<VisualScriptBuiltinFunc::TEXT_STR>);
  1078. VisualScriptLanguage::singleton->add_register_func("functions/built_in/print", create_builtin_func_node<VisualScriptBuiltinFunc::TEXT_PRINT>);
  1079. VisualScriptLanguage::singleton->add_register_func("functions/built_in/printerr", create_builtin_func_node<VisualScriptBuiltinFunc::TEXT_PRINTERR>);
  1080. VisualScriptLanguage::singleton->add_register_func("functions/built_in/printraw", create_builtin_func_node<VisualScriptBuiltinFunc::TEXT_PRINTRAW>);
  1081. VisualScriptLanguage::singleton->add_register_func("functions/built_in/var2str", create_builtin_func_node<VisualScriptBuiltinFunc::VAR_TO_STR>);
  1082. VisualScriptLanguage::singleton->add_register_func("functions/built_in/str2var", create_builtin_func_node<VisualScriptBuiltinFunc::STR_TO_VAR>);
  1083. VisualScriptLanguage::singleton->add_register_func("functions/built_in/var2bytes", create_builtin_func_node<VisualScriptBuiltinFunc::VAR_TO_BYTES>);
  1084. VisualScriptLanguage::singleton->add_register_func("functions/built_in/bytes2var", create_builtin_func_node<VisualScriptBuiltinFunc::BYTES_TO_VAR>);
  1085. VisualScriptLanguage::singleton->add_register_func("functions/built_in/color_named", create_builtin_func_node<VisualScriptBuiltinFunc::COLORN>);
  1086. }