visual_script_builtin_funcs.cpp 42 KB

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