visual_script_builtin_funcs.cpp 45 KB

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