Module: kamailio
Branch: master
Commit: a99f581a519123e7c47479b724308a5dc239393a
URL:
https://github.com/kamailio/kamailio/commit/a99f581a519123e7c47479b724308a5…
Author: Daniel-Constantin Mierla <miconda(a)gmail.com>
Committer: Daniel-Constantin Mierla <miconda(a)gmail.com>
Date: 2021-12-09T20:42:01+01:00
misc: kemi-code-gen.py - generate code for javascript functions with xval return
---
Modified: misc/tools/kemi/kemi-code-gen.py
---
Diff:
https://github.com/kamailio/kamailio/commit/a99f581a519123e7c47479b724308a5…
Patch:
https://github.com/kamailio/kamailio/commit/a99f581a519123e7c47479b724308a5…
---
diff --git a/misc/tools/kemi/kemi-code-gen.py b/misc/tools/kemi/kemi-code-gen.py
index 6c2893a688..dd77d61655 100644
--- a/misc/tools/kemi/kemi-code-gen.py
+++ b/misc/tools/kemi/kemi-code-gen.py
@@ -4,7 +4,7 @@
PRINTPARAMS=3
# - print mode: typedefs, js, lua, python, pythonparams, ruby, sqlang
-PRINTMODE="lua"
+PRINTMODE="js"
# - two tabs for python params, three for the other cases
# PRINTTABS="\t\t"
PRINTTABS="\t\t\t"
@@ -31,33 +31,42 @@ def printCodeIfEnd(sretfunc):
def printCodeIfJS(prefix):
global PRINTELSE
- sfunc = PRINTTABS + "\tret = ((sr_kemi_fm" + prefix +
"_f)(ket->func))(env_J->msg,\n" + PRINTTABS + "\t\t\t"
+ sparams = ""
for i, c in enumerate(prefix):
if i==0:
if c == 's':
print(PRINTTABS + PRINTELSE + "if(ket->ptypes[0]==SR_KEMIP_STR")
- sfunc += "&vps[" + str(i) +"].s, "
+ sparams += "&vps[" + str(i) +"].s, "
else:
print(PRINTTABS + PRINTELSE + "if(ket->ptypes[0]==SR_KEMIP_INT")
- sfunc += "vps[" + str(i) +"].n, "
+ sparams += "vps[" + str(i) +"].n, "
PRINTELSE = "} else "
elif i==PRINTPARAMS-1:
if c == 's':
print(PRINTTABS + "\t\t&& ket->ptypes[" + str(i) +
"]==SR_KEMIP_STR) {")
- sfunc += "&vps[" + str(i) +"].s);"
+ sparams += "&vps[" + str(i) +"].s);"
else:
print(PRINTTABS + "\t\t&& ket->ptypes[" + str(i) +
"]==SR_KEMIP_INT) {")
- sfunc += "vps[" + str(i) +"].n);"
+ sparams += "vps[" + str(i) +"].n);"
else:
if c == 's':
print(PRINTTABS + "\t\t&& ket->ptypes[" + str(i) +
"]==SR_KEMIP_STR")
- sfunc += "&vps[" + str(i) +"].s, "
+ sparams += "&vps[" + str(i) +"].s, "
else:
print(PRINTTABS + "\t\t&& ket->ptypes[" + str(i) +
"]==SR_KEMIP_INT")
- sfunc += "vps[" + str(i) +"].n, "
+ sparams += "vps[" + str(i) +"].n, "
- print(sfunc)
- print(PRINTTABS + "\treturn sr_kemi_jsdt_return_int(J, ket, ret);")
+ print("\t\t\t\tif(ket->rtype==SR_KEMIP_XVAL) {")
+ sfunc = PRINTTABS + "\t\txret = ((sr_kemi_xfm" + prefix +
"_f)(ket->func))(env_J->msg,\n" + PRINTTABS + "\t\t\t"
+ print(sfunc + sparams)
+ print(PRINTTABS + "\t\treturn sr_kemi_jsdt_return_xval(J, ket, xret);")
+
+ print("\t\t\t\t} else {")
+ sfunc = PRINTTABS + "\t\tret = ((sr_kemi_fm" + prefix +
"_f)(ket->func))(env_J->msg,\n" + PRINTTABS + "\t\t\t"
+
+ print(sfunc + sparams)
+ print(PRINTTABS + "\t\treturn sr_kemi_jsdt_return_int(J, ket, ret);")
+ print("\t\t\t\t}")
def printCodeIfLua(prefix):