visual_script_builtin_funcs.cpp 40 KB

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