visual_script_builtin_funcs.cpp 39 KB

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