visual_script_builtin_funcs.cpp 44 KB

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