shader_compiler_gles2.cpp 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930
  1. /*************************************************************************/
  2. /* shader_compiler_gles2.cpp */
  3. /*************************************************************************/
  4. /* This file is part of: */
  5. /* GODOT ENGINE */
  6. /* http://www.godotengine.org */
  7. /*************************************************************************/
  8. /* Copyright (c) 2007-2015 Juan Linietsky, Ariel Manzur. */
  9. /* */
  10. /* Permission is hereby granted, free of charge, to any person obtaining */
  11. /* a copy of this software and associated documentation files (the */
  12. /* "Software"), to deal in the Software without restriction, including */
  13. /* without limitation the rights to use, copy, modify, merge, publish, */
  14. /* distribute, sublicense, and/or sell copies of the Software, and to */
  15. /* permit persons to whom the Software is furnished to do so, subject to */
  16. /* the following conditions: */
  17. /* */
  18. /* The above copyright notice and this permission notice shall be */
  19. /* included in all copies or substantial portions of the Software. */
  20. /* */
  21. /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
  22. /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
  23. /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
  24. /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
  25. /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
  26. /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
  27. /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
  28. /*************************************************************************/
  29. #include "shader_compiler_gles2.h"
  30. #include "print_string.h"
  31. #include "stdio.h"
  32. //#define DEBUG_SHADER_ENABLED
  33. typedef ShaderLanguage SL;
  34. struct CodeGLSL2 {
  35. String code;
  36. };
  37. static String _mktab(int p_level) {
  38. String tb;
  39. for(int i=0;i<p_level;i++) {
  40. tb+="\t";
  41. }
  42. return tb;
  43. }
  44. static String _typestr(SL::DataType p_type) {
  45. switch(p_type) {
  46. case SL::TYPE_VOID: return "void";
  47. case SL::TYPE_BOOL: return "bool";
  48. case SL::TYPE_FLOAT: return "float";
  49. case SL::TYPE_VEC2: return "vec2";
  50. case SL::TYPE_VEC3: return "vec3";
  51. case SL::TYPE_VEC4: return "vec4";
  52. case SL::TYPE_MAT2: return "mat2";
  53. case SL::TYPE_MAT3: return "mat3";
  54. case SL::TYPE_MAT4: return "mat4";
  55. case SL::TYPE_TEXTURE: return "sampler2D";
  56. case SL::TYPE_CUBEMAP: return "samplerCube";
  57. }
  58. return "";
  59. }
  60. static String _mknum(float p_num) {
  61. return String::num_real(p_num);
  62. }
  63. static String _opstr(SL::Operator p_op) {
  64. switch(p_op) {
  65. case SL::OP_ASSIGN: return "=";
  66. case SL::OP_ADD: return "+";
  67. case SL::OP_SUB: return "-";
  68. case SL::OP_MUL: return "*";
  69. case SL::OP_DIV: return "/";
  70. case SL::OP_ASSIGN_ADD: return "+=";
  71. case SL::OP_ASSIGN_SUB: return "-=";
  72. case SL::OP_ASSIGN_MUL: return "*=";
  73. case SL::OP_ASSIGN_DIV: return "/=";
  74. case SL::OP_NEG: return "-";
  75. case SL::OP_NOT: return "!";
  76. case SL::OP_CMP_EQ: return "==";
  77. case SL::OP_CMP_NEQ: return "!=";
  78. case SL::OP_CMP_LEQ: return "<=";
  79. case SL::OP_CMP_GEQ: return ">=";
  80. case SL::OP_CMP_LESS: return "<";
  81. case SL::OP_CMP_GREATER: return ">";
  82. case SL::OP_CMP_OR: return "||";
  83. case SL::OP_CMP_AND: return "&&";
  84. default: return "";
  85. }
  86. return "";
  87. }
  88. //#ifdef DEBUG_SHADER_ENABLED
  89. #if 1
  90. #define ENDL "\n"
  91. #else
  92. #define ENDL ""
  93. #endif
  94. String ShaderCompilerGLES2::dump_node_code(SL::Node *p_node,int p_level,bool p_assign_left) {
  95. String code;
  96. switch(p_node->type) {
  97. case SL::Node::TYPE_PROGRAM: {
  98. SL::ProgramNode *pnode=(SL::ProgramNode*)p_node;
  99. code+=dump_node_code(pnode->body,p_level);
  100. } break;
  101. case SL::Node::TYPE_FUNCTION: {
  102. } break;
  103. case SL::Node::TYPE_BLOCK: {
  104. SL::BlockNode *bnode=(SL::BlockNode*)p_node;
  105. //variables
  106. code+="{"ENDL;
  107. for(Map<StringName,SL::DataType>::Element *E=bnode->variables.front();E;E=E->next()) {
  108. code+=_mktab(p_level)+_typestr(E->value())+" "+replace_string(E->key())+";"ENDL;
  109. }
  110. for(int i=0;i<bnode->statements.size();i++) {
  111. code+=_mktab(p_level)+dump_node_code(bnode->statements[i],p_level)+";"ENDL;
  112. }
  113. code+="}"ENDL;
  114. } break;
  115. case SL::Node::TYPE_VARIABLE: {
  116. SL::VariableNode *vnode=(SL::VariableNode*)p_node;
  117. if (type==ShaderLanguage::SHADER_MATERIAL_VERTEX) {
  118. if (vnode->name==vname_vertex && p_assign_left) {
  119. vertex_code_writes_vertex=true;
  120. }
  121. if (vnode->name==vname_color_interp) {
  122. flags->use_color_interp=true;
  123. }
  124. if (vnode->name==vname_uv_interp) {
  125. flags->use_uv_interp=true;
  126. }
  127. if (vnode->name==vname_uv2_interp) {
  128. flags->use_uv2_interp=true;
  129. }
  130. if (vnode->name==vname_var1_interp) {
  131. flags->use_var1_interp=true;
  132. }
  133. if (vnode->name==vname_var2_interp) {
  134. flags->use_var2_interp=true;
  135. }
  136. if (vnode->name==vname_tangent_interp || vnode->name==vname_binormal_interp) {
  137. flags->use_tangent_interp=true;
  138. }
  139. }
  140. if (type==ShaderLanguage::SHADER_MATERIAL_FRAGMENT) {
  141. if (vnode->name==vname_discard) {
  142. uses_discard=true;
  143. }
  144. if (vnode->name==vname_normalmap) {
  145. uses_normalmap=true;
  146. }
  147. if (vnode->name==vname_screen_uv) {
  148. uses_screen_uv=true;
  149. }
  150. if (vnode->name==vname_diffuse_alpha && p_assign_left) {
  151. uses_alpha=true;
  152. }
  153. if (vnode->name==vname_color_interp) {
  154. flags->use_color_interp=true;
  155. }
  156. if (vnode->name==vname_uv_interp) {
  157. flags->use_uv_interp=true;
  158. }
  159. if (vnode->name==vname_uv2_interp) {
  160. flags->use_uv2_interp=true;
  161. }
  162. if (vnode->name==vname_var1_interp) {
  163. flags->use_var1_interp=true;
  164. }
  165. if (vnode->name==vname_var2_interp) {
  166. flags->use_var2_interp=true;
  167. }
  168. if (vnode->name==vname_tangent_interp || vnode->name==vname_binormal_interp) {
  169. flags->use_tangent_interp=true;
  170. }
  171. }
  172. if (type==ShaderLanguage::SHADER_MATERIAL_LIGHT) {
  173. if (vnode->name==vname_light) {
  174. uses_light=true;
  175. }
  176. }
  177. if (type==ShaderLanguage::SHADER_CANVAS_ITEM_VERTEX) {
  178. if (vnode->name==vname_var1_interp) {
  179. flags->use_var1_interp=true;
  180. }
  181. if (vnode->name==vname_var2_interp) {
  182. flags->use_var2_interp=true;
  183. }
  184. if (vnode->name==vname_world_vec) {
  185. uses_worldvec=true;
  186. }
  187. }
  188. if (type==ShaderLanguage::SHADER_CANVAS_ITEM_FRAGMENT) {
  189. if (vnode->name==vname_texpixel_size) {
  190. uses_texpixel_size=true;
  191. }
  192. if (vnode->name==vname_normal) {
  193. uses_normal=true;
  194. }
  195. if (vnode->name==vname_normalmap || vnode->name==vname_normalmap_depth) {
  196. uses_normalmap=true;
  197. uses_normal=true;
  198. }
  199. if (vnode->name==vname_screen_uv) {
  200. uses_screen_uv=true;
  201. }
  202. if (vnode->name==vname_var1_interp) {
  203. flags->use_var1_interp=true;
  204. }
  205. if (vnode->name==vname_var2_interp) {
  206. flags->use_var2_interp=true;
  207. }
  208. }
  209. if (type==ShaderLanguage::SHADER_CANVAS_ITEM_LIGHT) {
  210. if (vnode->name==vname_light) {
  211. uses_light=true;
  212. }
  213. if (vnode->name==vname_normal) {
  214. uses_normal=true;
  215. }
  216. if (vnode->name==vname_shadow) {
  217. uses_shadow_color=true;
  218. }
  219. }
  220. if (vnode->name==vname_time) {
  221. uses_time=true;
  222. }
  223. code=replace_string(vnode->name);
  224. } break;
  225. case SL::Node::TYPE_CONSTANT: {
  226. SL::ConstantNode *cnode=(SL::ConstantNode*)p_node;
  227. switch(cnode->datatype) {
  228. case SL::TYPE_BOOL: code=cnode->value.operator bool()?"true":"false"; break;
  229. case SL::TYPE_FLOAT: code=_mknum(cnode->value); break; //force zeros, so GLSL doesn't confuse with integer.
  230. case SL::TYPE_VEC2: { Vector2 v = cnode->value; code="vec2("+_mknum(v.x)+", "+_mknum(v.y)+")"; } break;
  231. case SL::TYPE_VEC3: { Vector3 v = cnode->value; code="vec3("+_mknum(v.x)+", "+_mknum(v.y)+", "+_mknum(v.z)+")"; } break;
  232. case SL::TYPE_VEC4: { Plane v = cnode->value; code="vec4("+_mknum(v.normal.x)+", "+_mknum(v.normal.y)+", "+_mknum(v.normal.z)+", "+_mknum(v.d)+")"; } break;
  233. case SL::TYPE_MAT2: { Matrix32 x = cnode->value; code="mat2( vec2("+_mknum(x[0][0])+", "+_mknum(x[0][1])+"), vec2("+_mknum(x[1][0])+", "+_mknum(x[1][1])+"))"; } break;
  234. case SL::TYPE_MAT3: { Matrix3 x = cnode->value; code="mat3( vec3("+_mknum(x.get_axis(0).x)+", "+_mknum(x.get_axis(0).y)+", "+_mknum(x.get_axis(0).z)+"), vec3("+_mknum(x.get_axis(1).x)+", "+_mknum(x.get_axis(1).y)+", "+_mknum(x.get_axis(1).z)+"), vec3("+_mknum(x.get_axis(2).x)+", "+_mknum(x.get_axis(2).y)+", "+_mknum(x.get_axis(2).z)+"))"; } break;
  235. case SL::TYPE_MAT4: { Transform x = cnode->value; code="mat4( vec4("+_mknum(x.basis.get_axis(0).x)+", "+_mknum(x.basis.get_axis(0).y)+", "+_mknum(x.basis.get_axis(0).z)+",0.0), vec4("+_mknum(x.basis.get_axis(1).x)+", "+_mknum(x.basis.get_axis(1).y)+", "+_mknum(x.basis.get_axis(1).z)+",0.0), vec4("+_mknum(x.basis.get_axis(2).x)+", "+_mknum(x.basis.get_axis(2).y)+", "+_mknum(x.basis.get_axis(2).z)+",0.0), vec4("+_mknum(x.origin.x)+", "+_mknum(x.origin.y)+", "+_mknum(x.origin.z)+",1.0))"; } break;
  236. default: code="<error: "+Variant::get_type_name(cnode->value.get_type())+" ("+itos(cnode->datatype)+">";
  237. }
  238. } break;
  239. case SL::Node::TYPE_OPERATOR: {
  240. SL::OperatorNode *onode=(SL::OperatorNode*)p_node;
  241. switch(onode->op) {
  242. case SL::OP_ASSIGN_MUL: {
  243. if (onode->arguments[0]->get_datatype()==SL::TYPE_VEC3 && onode->arguments[1]->get_datatype()==SL::TYPE_MAT4) {
  244. String mul_l=dump_node_code(onode->arguments[0],p_level,true);
  245. String mul_r=dump_node_code(onode->arguments[1],p_level);
  246. code=mul_l+"=(vec4("+mul_l+",1.0)*("+mul_r+")).xyz";
  247. break;
  248. } else if (onode->arguments[0]->get_datatype()==SL::TYPE_MAT4 && onode->arguments[1]->get_datatype()==SL::TYPE_VEC3) {
  249. String mul_l=dump_node_code(onode->arguments[0],p_level,true);
  250. String mul_r=dump_node_code(onode->arguments[1],p_level);
  251. code=mul_l+"=(("+mul_l+")*vec4("+mul_r+",1.0)).xyz";
  252. break;
  253. } else if (onode->arguments[0]->get_datatype()==SL::TYPE_VEC2 && onode->arguments[1]->get_datatype()==SL::TYPE_MAT4) {
  254. String mul_l=dump_node_code(onode->arguments[0],p_level,true);
  255. String mul_r=dump_node_code(onode->arguments[1],p_level);
  256. code=mul_l+"=(vec4("+mul_l+",0.0,1.0)*("+mul_r+")).xy";
  257. break;
  258. } else if (onode->arguments[0]->get_datatype()==SL::TYPE_MAT4 && onode->arguments[1]->get_datatype()==SL::TYPE_VEC2) {
  259. String mul_l=dump_node_code(onode->arguments[0],p_level,true);
  260. String mul_r=dump_node_code(onode->arguments[1],p_level);
  261. code=mul_l+"=(("+mul_l+")*vec4("+mul_r+",0.0,1.0)).xy";
  262. break;
  263. } else if (onode->arguments[0]->get_datatype()==SL::TYPE_VEC2 && onode->arguments[1]->get_datatype()==SL::TYPE_MAT3) {
  264. String mul_l=dump_node_code(onode->arguments[0],p_level,true);
  265. String mul_r=dump_node_code(onode->arguments[1],p_level);
  266. code=mul_l+"=(("+mul_l+")*vec3("+mul_r+",1.0)).xy";
  267. break;
  268. }
  269. };
  270. case SL::OP_ASSIGN:
  271. case SL::OP_ASSIGN_ADD:
  272. case SL::OP_ASSIGN_SUB:
  273. case SL::OP_ASSIGN_DIV:
  274. code="("+dump_node_code(onode->arguments[0],p_level,true)+_opstr(onode->op)+dump_node_code(onode->arguments[1],p_level)+")";
  275. break;
  276. case SL::OP_MUL:
  277. if (onode->arguments[0]->get_datatype()==SL::TYPE_MAT4 && onode->arguments[1]->get_datatype()==SL::TYPE_VEC3) {
  278. code="("+dump_node_code(onode->arguments[0],p_level)+"*vec4("+dump_node_code(onode->arguments[1],p_level)+",1.0)).xyz";
  279. break;
  280. } else if (onode->arguments[0]->get_datatype()==SL::TYPE_VEC3 && onode->arguments[1]->get_datatype()==SL::TYPE_MAT4) {
  281. code="(vec4("+dump_node_code(onode->arguments[0],p_level)+",1.0)*"+dump_node_code(onode->arguments[1],p_level)+").xyz";
  282. break;
  283. } else if (onode->arguments[0]->get_datatype()==SL::TYPE_MAT4 && onode->arguments[1]->get_datatype()==SL::TYPE_VEC2) {
  284. code="("+dump_node_code(onode->arguments[0],p_level)+"*vec4("+dump_node_code(onode->arguments[1],p_level)+",0.0,1.0)).xy";
  285. break;
  286. } else if (onode->arguments[0]->get_datatype()==SL::TYPE_VEC2 && onode->arguments[1]->get_datatype()==SL::TYPE_MAT4) {
  287. code="(vec4("+dump_node_code(onode->arguments[0],p_level)+",0.0,1.0)*"+dump_node_code(onode->arguments[1],p_level)+").xy";
  288. break;
  289. } else if (onode->arguments[0]->get_datatype()==SL::TYPE_MAT3 && onode->arguments[1]->get_datatype()==SL::TYPE_VEC2) {
  290. code="("+dump_node_code(onode->arguments[0],p_level)+"*vec3("+dump_node_code(onode->arguments[1],p_level)+",1.0)).xy";
  291. break;
  292. } else if (onode->arguments[0]->get_datatype()==SL::TYPE_VEC2 && onode->arguments[1]->get_datatype()==SL::TYPE_MAT3) {
  293. code="(vec3("+dump_node_code(onode->arguments[0],p_level)+",1.0)*"+dump_node_code(onode->arguments[1],p_level)+").xy";
  294. break;
  295. }
  296. case SL::OP_ADD:
  297. case SL::OP_SUB:
  298. case SL::OP_DIV:
  299. case SL::OP_CMP_EQ:
  300. case SL::OP_CMP_NEQ:
  301. case SL::OP_CMP_LEQ:
  302. case SL::OP_CMP_GEQ:
  303. case SL::OP_CMP_LESS:
  304. case SL::OP_CMP_GREATER:
  305. case SL::OP_CMP_OR:
  306. case SL::OP_CMP_AND:
  307. //handle binary
  308. code="("+dump_node_code(onode->arguments[0],p_level)+_opstr(onode->op)+dump_node_code(onode->arguments[1],p_level)+")";
  309. break;
  310. case SL::OP_NEG:
  311. case SL::OP_NOT:
  312. //handle unary
  313. code=_opstr(onode->op)+dump_node_code(onode->arguments[0],p_level);
  314. break;
  315. case SL::OP_CONSTRUCT:
  316. case SL::OP_CALL: {
  317. String callfunc=dump_node_code(onode->arguments[0],p_level);
  318. code=callfunc+"(";
  319. /*if (callfunc=="mat4") {
  320. //fix constructor for mat4
  321. for(int i=1;i<onode->arguments.size();i++) {
  322. if (i>1)
  323. code+=", ";
  324. //transform
  325. code+="vec4( "+dump_node_code(onode->arguments[i],p_level)+(i==4?",1.0)":",0.0)");
  326. }
  327. } else*/ if (callfunc=="tex") {
  328. code="texture2D( "+dump_node_code(onode->arguments[1],p_level)+","+dump_node_code(onode->arguments[2],p_level)+")";
  329. break;
  330. } else if (callfunc=="texcube") {
  331. code="(textureCube( "+dump_node_code(onode->arguments[1],p_level)+",("+dump_node_code(onode->arguments[2],p_level)+")).xyz";
  332. break;
  333. } else if (callfunc=="texscreen") {
  334. //create the call to sample the screen, and clamp it
  335. uses_texscreen=true;
  336. code="(texture2D( texscreen_tex, clamp(("+dump_node_code(onode->arguments[1],p_level)+").xy*texscreen_screen_mult,texscreen_screen_clamp.xy,texscreen_screen_clamp.zw))).rgb";
  337. //code="(texture2D( screen_texture, ("+dump_node_code(onode->arguments[1],p_level)+").xy).rgb";
  338. break;
  339. } else if (callfunc=="texpos") {
  340. //create the call to sample the screen, and clamp it
  341. uses_texpos=true;
  342. code="get_texpos("+dump_node_code(onode->arguments[1],p_level)+"";
  343. // code="get_texpos(gl_ProjectionMatrixInverse * texture2D( depth_texture, clamp(("+dump_node_code(onode->arguments[1],p_level)+").xy,vec2(0.0),vec2(1.0))*gl_LightSource[5].specular.zw+gl_LightSource[5].specular.xy)";
  344. //code="(texture2D( screen_texture, ("+dump_node_code(onode->arguments[1],p_level)+").xy).rgb";
  345. break;
  346. } else if (custom_h && callfunc=="cosh_custom") {
  347. if (!cosh_used) {
  348. global_code= "float cosh_custom(float val)\n"\
  349. "{\n"\
  350. " float tmp = exp(val);\n"\
  351. " float cosH = (tmp + 1.0 / tmp) / 2.0;\n"\
  352. " return cosH;\n"\
  353. "}\n"+global_code;
  354. cosh_used=true;
  355. }
  356. code="cosh_custom("+dump_node_code(onode->arguments[1],p_level)+"";
  357. } else if (custom_h && callfunc=="sinh_custom") {
  358. if (!sinh_used) {
  359. global_code= "float sinh_custom(float val)\n"\
  360. "{\n"\
  361. " float tmp = exp(val);\n"\
  362. " float sinH = (tmp - 1.0 / tmp) / 2.0;\n"\
  363. " return sinH;\n"\
  364. "}\n"+global_code;
  365. sinh_used=true;
  366. }
  367. code="sinh_custom("+dump_node_code(onode->arguments[1],p_level)+"";
  368. } else if (custom_h && callfunc=="tanh_custom") {
  369. if (!tanh_used) {
  370. global_code= "float tanh_custom(float val)\n"\
  371. "{\n"\
  372. " float tmp = exp(val);\n"\
  373. " float tanH = (tmp - 1.0 / tmp) / (tmp + 1.0 / tmp);\n"\
  374. " return tanH;\n"\
  375. "}\n"+global_code;
  376. tanh_used=true;
  377. }
  378. code="tanh_custom("+dump_node_code(onode->arguments[1],p_level)+"";
  379. } else {
  380. for(int i=1;i<onode->arguments.size();i++) {
  381. if (i>1)
  382. code+=", ";
  383. //transform
  384. code+=dump_node_code(onode->arguments[i],p_level);
  385. }
  386. }
  387. code+=")";
  388. break;
  389. } break;
  390. default: {}
  391. }
  392. } break;
  393. case SL::Node::TYPE_CONTROL_FLOW: {
  394. SL::ControlFlowNode *cfnode=(SL::ControlFlowNode*)p_node;
  395. if (cfnode->flow_op==SL::FLOW_OP_IF) {
  396. code+="if ("+dump_node_code(cfnode->statements[0],p_level)+") {"ENDL;
  397. code+=dump_node_code(cfnode->statements[1],p_level+1);
  398. if (cfnode->statements.size()==3) {
  399. code+="} else {"ENDL;
  400. code+=dump_node_code(cfnode->statements[2],p_level+1);
  401. }
  402. code+="}"ENDL;
  403. } else if (cfnode->flow_op==SL::FLOW_OP_RETURN) {
  404. if (cfnode->statements.size()) {
  405. code="return "+dump_node_code(cfnode->statements[0],p_level);
  406. } else {
  407. code="return";
  408. }
  409. }
  410. } break;
  411. case SL::Node::TYPE_MEMBER: {
  412. SL::MemberNode *mnode=(SL::MemberNode*)p_node;
  413. String m;
  414. if (mnode->basetype==SL::TYPE_MAT4) {
  415. if (mnode->name=="x")
  416. m="[0]";
  417. else if (mnode->name=="y")
  418. m="[1]";
  419. else if (mnode->name=="z")
  420. m="[2]";
  421. else if (mnode->name=="w")
  422. m="[3]";
  423. } else if (mnode->basetype==SL::TYPE_MAT2) {
  424. if (mnode->name=="x")
  425. m="[0]";
  426. else if (mnode->name=="y")
  427. m="[1]";
  428. } else if (mnode->basetype==SL::TYPE_MAT3) {
  429. if (mnode->name=="x")
  430. m="[0]";
  431. else if (mnode->name=="y")
  432. m="[1]";
  433. else if (mnode->name=="z")
  434. m="[2]";
  435. } else {
  436. m="."+mnode->name;
  437. }
  438. code=dump_node_code(mnode->owner,p_level)+m;
  439. } break;
  440. }
  441. return code;
  442. }
  443. Error ShaderCompilerGLES2::compile_node(SL::ProgramNode *p_program) {
  444. // feed the local replace table and global code
  445. global_code="";
  446. // uniforms first!
  447. int ubase=0;
  448. if (uniforms)
  449. ubase=uniforms->size();
  450. for(Map<StringName,SL::Uniform>::Element *E=p_program->uniforms.front();E;E=E->next()) {
  451. String uline="uniform "+_typestr(E->get().type)+" _"+E->key().operator String()+";"ENDL;
  452. global_code+=uline;
  453. if (uniforms) {
  454. //if (uniforms->has(E->key())) {
  455. // //repeated uniform, error
  456. // ERR_EXPLAIN("Uniform already exists from other shader: "+String(E->key()));
  457. // ERR_FAIL_COND_V(uniforms->has(E->key()),ERR_ALREADY_EXISTS);
  458. //
  459. // }
  460. SL::Uniform u = E->get();
  461. u.order+=ubase;
  462. uniforms->insert(E->key(),u);
  463. }
  464. }
  465. for(int i=0;i<p_program->functions.size();i++) {
  466. SL::FunctionNode *fnode=p_program->functions[i].function;
  467. StringName funcname=fnode->name;
  468. String newfuncname=replace_string(funcname);
  469. String header;
  470. header=_typestr(fnode->return_type)+" "+newfuncname+"(";
  471. for(int i=0;i<fnode->arguments.size();i++) {
  472. if (i>0)
  473. header+=", ";
  474. header+=_typestr(fnode->arguments[i].type)+" "+replace_string(fnode->arguments[i].name);
  475. }
  476. header+=") {"ENDL;
  477. String fcode=header;
  478. fcode+=dump_node_code(fnode->body,1);
  479. fcode+="}"ENDL;
  480. global_code+=fcode;
  481. }
  482. /* for(Map<StringName,SL::DataType>::Element *E=p_program->preexisting_variables.front();E;E=E->next()) {
  483. StringName varname=E->key();
  484. String newvarname=replace_string(varname);
  485. global_code+="uniform "+_typestr(E->get())+" "+newvarname+";"ENDL;
  486. }*/
  487. code=dump_node_code(p_program,0);
  488. #ifdef DEBUG_SHADER_ENABLED
  489. print_line("GLOBAL CODE:\n\n");
  490. print_line(global_code);
  491. global_code=global_code.replace("\n","");
  492. print_line("CODE:\n\n");
  493. print_line(code);
  494. code=code.replace("\n","");
  495. #endif
  496. return OK;
  497. }
  498. Error ShaderCompilerGLES2::create_glsl_120_code(void *p_str,SL::ProgramNode *p_program) {
  499. ShaderCompilerGLES2 *compiler=(ShaderCompilerGLES2*)p_str;
  500. return compiler->compile_node(p_program);
  501. }
  502. String ShaderCompilerGLES2::replace_string(const StringName& p_string) {
  503. Map<StringName,StringName>::Element *E=NULL;
  504. E=replace_table.find(p_string);
  505. if (E)
  506. return E->get();
  507. E=mode_replace_table[type].find(p_string);
  508. if (E)
  509. return E->get();
  510. return "_"+p_string.operator String();
  511. }
  512. Error ShaderCompilerGLES2::compile(const String& p_code, ShaderLanguage::ShaderType p_type, String& r_code_line, String& r_globals_line, Flags& r_flags, Map<StringName,ShaderLanguage::Uniform> *r_uniforms) {
  513. uses_texscreen=false;
  514. uses_texpos=false;
  515. uses_alpha=false;
  516. uses_discard=false;
  517. uses_screen_uv=false;
  518. uses_light=false;
  519. uses_time=false;
  520. uses_normalmap=false;
  521. uses_normal=false;
  522. uses_texpixel_size=false;
  523. uses_worldvec=false;
  524. vertex_code_writes_vertex=false;
  525. uses_shadow_color=false;
  526. uniforms=r_uniforms;
  527. flags=&r_flags;
  528. r_flags.use_color_interp=false;
  529. r_flags.use_uv_interp=false;
  530. r_flags.use_uv2_interp=false;
  531. r_flags.use_tangent_interp=false;
  532. r_flags.use_var1_interp=false;
  533. r_flags.use_var2_interp=false;
  534. r_flags.uses_normalmap=false;
  535. r_flags.uses_normal=false;
  536. sinh_used=false;
  537. tanh_used=false;
  538. cosh_used=false;
  539. String error;
  540. int errline,errcol;
  541. type=p_type;
  542. Error err = SL::compile(p_code,p_type,create_glsl_120_code,this,&error,&errline,&errcol);
  543. if (err) {
  544. print_line("***Error precompiling shader: "+error);
  545. print_line("error "+itos(errline)+":"+itos(errcol));
  546. return err;
  547. }
  548. r_flags.uses_alpha=uses_alpha;
  549. r_flags.uses_texscreen=uses_texscreen;
  550. r_flags.uses_texpos=uses_texpos;
  551. r_flags.vertex_code_writes_vertex=vertex_code_writes_vertex;
  552. r_flags.uses_discard=uses_discard;
  553. r_flags.uses_screen_uv=uses_screen_uv;
  554. r_flags.uses_light=uses_light;
  555. r_flags.uses_time=uses_time;
  556. r_flags.uses_normalmap=uses_normalmap;
  557. r_flags.uses_normal=uses_normal;
  558. r_flags.uses_texpixel_size=uses_texpixel_size;
  559. r_flags.uses_worldvec=uses_worldvec;
  560. r_flags.uses_shadow_color=uses_shadow_color;
  561. r_code_line=code;
  562. r_globals_line=global_code;
  563. return OK;
  564. }
  565. ShaderCompilerGLES2::ShaderCompilerGLES2() {
  566. #ifdef GLEW_ENABLED
  567. //use custom functions because they are not supported in GLSL120
  568. custom_h=true;
  569. #else
  570. custom_h=false;
  571. #endif
  572. replace_table["bool"]= "bool";
  573. replace_table["float" ]= "float";
  574. replace_table["vec2" ]= "vec2";
  575. replace_table["vec3" ]= "vec3";
  576. replace_table["vec4" ]= "vec4";
  577. replace_table["mat2" ]= "mat2";
  578. replace_table["mat3" ]= "mat3";
  579. replace_table["mat4" ]= "mat4";
  580. replace_table["texture" ]= "sampler2D";
  581. replace_table["cubemap" ]= "samplerCube";
  582. replace_table["sin"]= "sin";
  583. replace_table["cos" ]= "cos";
  584. replace_table["tan" ]= "tan";
  585. replace_table["asin" ]= "asin";
  586. replace_table["acos" ]= "acos";
  587. replace_table["atan" ]= "atan";
  588. replace_table["atan2"]= "atan";
  589. if (custom_h) {
  590. replace_table["sinh" ]= "sinh_custom";
  591. replace_table["cosh" ]= "cosh_custom";
  592. replace_table["tanh" ]= "tanh_custom";
  593. } else {
  594. replace_table["sinh" ]= "sinh";
  595. replace_table["cosh" ]= "cosh";
  596. replace_table["tanh" ]= "tanh";
  597. }
  598. replace_table["pow" ]= "pow";
  599. replace_table["exp" ]= "exp";
  600. replace_table["log" ]= "log";
  601. replace_table["sqrt"]= "sqrt";
  602. replace_table["abs" ]= "abs";
  603. replace_table["sign"]= "sign";
  604. replace_table["floor"]= "floor";
  605. replace_table["trunc"]= "trunc";
  606. #ifdef GLEW_ENABLED
  607. replace_table["round"]= "roundfix";
  608. #else
  609. replace_table["round"]= "round";
  610. #endif
  611. replace_table["ceil" ]= "ceil";
  612. replace_table["fract"]= "fract";
  613. replace_table["mod" ]= "mod";
  614. replace_table["min" ]= "min";
  615. replace_table["max"]= "max";
  616. replace_table["clamp"]= "clamp";
  617. replace_table["mix" ]= "mix";
  618. replace_table["step" ]= "step";
  619. replace_table["smoothstep" ]= "smoothstep";
  620. replace_table["length"]= "length";
  621. replace_table["distance"]= "distance";
  622. replace_table["dot" ]= "dot";
  623. replace_table["cross" ]="cross";
  624. replace_table["normalize"]= "normalize";
  625. replace_table["reflect"]= "reflect";
  626. replace_table["refract"]= "refract";
  627. replace_table["tex"]= "tex";
  628. replace_table["texa"]= "texa";
  629. replace_table["tex2"]= "tex2";
  630. replace_table["texcube"]= "textureCube";
  631. replace_table["texscreen"]= "texscreen";
  632. replace_table["texpos"]= "texpos";
  633. mode_replace_table[0]["SRC_VERTEX"]="vertex_in.xyz";
  634. mode_replace_table[0]["SRC_NORMAL"]="normal_in";
  635. mode_replace_table[0]["SRC_TANGENT"]="tangent_in";
  636. mode_replace_table[0]["SRC_BINORMALF"]="binormalf";
  637. mode_replace_table[0]["VERTEX"]="vertex_interp";
  638. mode_replace_table[0]["NORMAL"]="normal_interp";
  639. mode_replace_table[0]["TANGENT"]="tangent_interp";
  640. mode_replace_table[0]["BINORMAL"]="binormal_interp";
  641. mode_replace_table[0]["UV"]="uv_interp.xy";
  642. mode_replace_table[0]["UV2"]="uv_interp.zw";
  643. mode_replace_table[0]["COLOR"]="color_interp";
  644. //@TODO convert to glsl stuff
  645. mode_replace_table[0]["SPEC_EXP"]="vertex_specular_exp";
  646. mode_replace_table[0]["WORLD_MATRIX"]="world_transform";
  647. mode_replace_table[0]["INV_CAMERA_MATRIX"]="camera_inverse_transform";
  648. mode_replace_table[0]["PROJECTION_MATRIX"]="projection_transform";
  649. mode_replace_table[0]["MODELVIEW_MATRIX"]="modelview";
  650. mode_replace_table[0]["POINT_SIZE"]="gl_PointSize";
  651. mode_replace_table[0]["VAR1"]="var1_interp";
  652. mode_replace_table[0]["VAR2"]="var2_interp";
  653. // mode_replace_table[0]["SCREEN_POS"]="SCREEN_POS";
  654. // mode_replace_table[0]["SCREEN_SIZE"]="SCREEN_SIZE";
  655. mode_replace_table[0]["INSTANCE_ID"]="instance_id";
  656. mode_replace_table[0]["TIME"]="time";
  657. mode_replace_table[1]["VERTEX"]="vertex";
  658. //mode_replace_table[1]["POSITION"]="IN_POSITION";
  659. mode_replace_table[1]["NORMAL"]="normal";
  660. mode_replace_table[1]["TANGENT"]="tangent";
  661. mode_replace_table[1]["POSITION"]="gl_Position";
  662. mode_replace_table[1]["BINORMAL"]="binormal";
  663. mode_replace_table[1]["NORMALMAP"]="normalmap";
  664. mode_replace_table[1]["NORMALMAP_DEPTH"]="normaldepth";
  665. mode_replace_table[1]["VAR1"]="var1_interp";
  666. mode_replace_table[1]["VAR2"]="var2_interp";
  667. mode_replace_table[1]["UV"]="uv";
  668. mode_replace_table[1]["UV2"]="uv2";
  669. mode_replace_table[1]["SCREEN_UV"]="screen_uv";
  670. mode_replace_table[1]["VAR1"]="var1_interp";
  671. mode_replace_table[1]["VAR2"]="var2_interp";
  672. mode_replace_table[1]["COLOR"]="color";
  673. mode_replace_table[1]["DIFFUSE"]="diffuse.rgb";
  674. mode_replace_table[1]["DIFFUSE_ALPHA"]="diffuse";
  675. mode_replace_table[1]["SPECULAR"]="specular";
  676. mode_replace_table[1]["EMISSION"]="emission";
  677. mode_replace_table[1]["SHADE_PARAM"]="shade_param";
  678. mode_replace_table[1]["SPEC_EXP"]="specular_exp";
  679. mode_replace_table[1]["GLOW"]="glow";
  680. mode_replace_table[1]["DISCARD"]="discard_";
  681. mode_replace_table[1]["POINT_COORD"]="gl_PointCoord";
  682. mode_replace_table[1]["INV_CAMERA_MATRIX"]="camera_inverse_transform";
  683. //mode_replace_table[1]["SCREEN_POS"]="SCREEN_POS";
  684. //mode_replace_table[1]["SCREEN_TEXEL_SIZE"]="SCREEN_TEXEL_SIZE";
  685. mode_replace_table[1]["TIME"]="time";
  686. //////////////
  687. mode_replace_table[2]["NORMAL"]="normal";
  688. //mode_replace_table[2]["POSITION"]="IN_POSITION";
  689. mode_replace_table[2]["LIGHT_DIR"]="light_dir";
  690. mode_replace_table[2]["LIGHT_DIFFUSE"]="light_diffuse";
  691. mode_replace_table[2]["LIGHT_SPECULAR"]="light_specular";
  692. mode_replace_table[2]["EYE_VEC"]="eye_vec";
  693. mode_replace_table[2]["DIFFUSE"]="mdiffuse";
  694. mode_replace_table[2]["SPECULAR"]="specular";
  695. mode_replace_table[2]["SPECULAR_EXP"]="specular_exp";
  696. mode_replace_table[2]["SHADE_PARAM"]="shade_param";
  697. mode_replace_table[2]["LIGHT"]="light";
  698. mode_replace_table[2]["POINT_COORD"]="gl_PointCoord";
  699. mode_replace_table[2]["TIME"]="time";
  700. mode_replace_table[3]["SRC_VERTEX"]="src_vtx";
  701. mode_replace_table[3]["VERTEX"]="outvec.xy";
  702. mode_replace_table[3]["WORLD_VERTEX"]="outvec.xy";
  703. mode_replace_table[3]["UV"]="uv_interp";
  704. mode_replace_table[3]["COLOR"]="color_interp";
  705. mode_replace_table[3]["VAR1"]="var1_interp";
  706. mode_replace_table[3]["VAR2"]="var2_interp";
  707. mode_replace_table[3]["POINT_SIZE"]="gl_PointSize";
  708. mode_replace_table[3]["WORLD_MATRIX"]="modelview_matrix";
  709. mode_replace_table[3]["PROJECTION_MATRIX"]="projection_matrix";
  710. mode_replace_table[3]["EXTRA_MATRIX"]="extra_matrix";
  711. mode_replace_table[3]["TIME"]="time";
  712. mode_replace_table[4]["POSITION"]="gl_Position";
  713. mode_replace_table[4]["NORMAL"]="normal";
  714. mode_replace_table[4]["NORMALMAP"]="normal_map";
  715. mode_replace_table[4]["NORMALMAP_DEPTH"]="normal_depth";
  716. mode_replace_table[4]["UV"]="uv_interp";
  717. mode_replace_table[4]["SRC_COLOR"]="color_interp";
  718. mode_replace_table[4]["COLOR"]="color";
  719. mode_replace_table[4]["TEXTURE"]="texture";
  720. mode_replace_table[4]["TEXTURE_PIXEL_SIZE"]="texpixel_size";
  721. mode_replace_table[4]["VAR1"]="var1_interp";
  722. mode_replace_table[4]["VAR2"]="var2_interp";
  723. mode_replace_table[4]["SCREEN_UV"]="screen_uv";
  724. mode_replace_table[4]["POINT_COORD"]="gl_PointCoord";
  725. mode_replace_table[4]["TIME"]="time";
  726. mode_replace_table[5]["POSITION"]="gl_Position";
  727. mode_replace_table[5]["NORMAL"]="normal";
  728. mode_replace_table[5]["UV"]="uv_interp";
  729. mode_replace_table[5]["COLOR"]="color";
  730. mode_replace_table[5]["TEXTURE"]="texture";
  731. mode_replace_table[5]["TEXTURE_PIXEL_SIZE"]="texpixel_size";
  732. mode_replace_table[5]["VAR1"]="var1_interp";
  733. mode_replace_table[5]["VAR2"]="var2_interp";
  734. mode_replace_table[5]["LIGHT_VEC"]="light_vec";
  735. mode_replace_table[5]["LIGHT_HEIGHT"]="light_height";
  736. mode_replace_table[5]["LIGHT_COLOR"]="light";
  737. mode_replace_table[5]["LIGHT_UV"]="light_uv";
  738. mode_replace_table[5]["LIGHT"]="light_out";
  739. mode_replace_table[5]["SHADOW"]="shadow_color";
  740. mode_replace_table[5]["SCREEN_UV"]="screen_uv";
  741. mode_replace_table[5]["POINT_COORD"]="gl_PointCoord";
  742. mode_replace_table[5]["TIME"]="time";
  743. //mode_replace_table[2]["SCREEN_POS"]="SCREEN_POS";
  744. //mode_replace_table[2]["SCREEN_TEXEL_SIZE"]="SCREEN_TEXEL_SIZE";
  745. out_vertex_name="VERTEX";
  746. vname_discard="DISCARD";
  747. vname_screen_uv="SCREEN_UV";
  748. vname_diffuse_alpha="DIFFUSE_ALPHA";
  749. vname_color_interp="COLOR";
  750. vname_uv_interp="UV";
  751. vname_uv2_interp="UV2";
  752. vname_tangent_interp="TANGENT";
  753. vname_binormal_interp="BINORMAL";
  754. vname_var1_interp="VAR1";
  755. vname_var2_interp="VAR2";
  756. vname_vertex="VERTEX";
  757. vname_light="LIGHT";
  758. vname_time="TIME";
  759. vname_normalmap="NORMALMAP";
  760. vname_normalmap_depth="NORMALMAP_DEPTH";
  761. vname_normal="NORMAL";
  762. vname_texpixel_size="TEXTURE_PIXEL_SIZE";
  763. vname_world_vec="WORLD_VERTEX";
  764. vname_shadow="SHADOW";
  765. }