X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=genbindings.sh;h=a378a1e154eaadfda05cb08ecf9a5b4a220e4394;hb=fd56c3464060f7df8ec0c21a831682d7b085fd10;hp=912cc1cdce44e892d349291de5a179c064f67a7c;hpb=db55d4ed1b9ee1b2712db1df0f9b0081a70e269b;p=ldk-java diff --git a/genbindings.sh b/genbindings.sh index 912cc1cd..a378a1e1 100755 --- a/genbindings.sh +++ b/genbindings.sh @@ -1,15 +1,17 @@ #!/bin/bash usage() { - echo "USAGE: path/to/ldk-c-bindings \"JNI_CFLAGS\" debug android" + echo "USAGE: path/to/ldk-c-bindings \"JNI_CFLAGS\" debug android web" echo "For JNI_CFLAGS you probably want -I/usr/lib/jvm/java-11-openjdk-amd64/include/ -I/usr/lib/jvm/java-11-openjdk-amd64/include/linux/" echo "debug should either be true, false, or leaks" echo "debug of leaks turns on leak tracking on an optimized release bianry" echo "android should either be true or false" + echo "web should either be true or false" exit 1 } [ "$1" = "" ] && usage [ "$3" != "true" -a "$3" != "false" -a "$3" != "leaks" ] && usage [ "$4" != "true" -a "$4" != "false" ] && usage +[ "$5" != "true" -a "$5" != "false" ] && usage set -x @@ -78,7 +80,15 @@ if [ "$4" = "true" ]; then else ./genbindings.py "./lightning.h" src/main/java/org/ldk/impl src/main/java/org/ldk src/main/jni/ $DEBUG_ARG java $4 fi -echo "#define LDKCVec_C2Tuple_TxidCVec_C2Tuple_u32TxOutZZZZ LDKCVec_TransactionOutputsZ" > src/main/jni/bindings.c +rm -f src/main/jni/bindings.c +if [ "$3" = "true" ]; then + echo "#define LDK_DEBUG_BUILD" > src/main/jni/bindings.c +elif [ "$3" = "leaks" ]; then + # For leak checking we use release libldk which doesn't expose + # __unmangle_inner_ptr, but the C code expects to be able to call it. + echo "#define __unmangle_inner_ptr(a) (a)" > src/main/jni/bindings.c +fi +echo "#define LDKCVec_C2Tuple_TxidCVec_C2Tuple_u32TxOutZZZZ LDKCVec_TransactionOutputsZ" >> src/main/jni/bindings.c echo "#define CVec_C2Tuple_TxidCVec_C2Tuple_u32TxOutZZZZ_free CVec_TransactionOutputsZ_free" >> src/main/jni/bindings.c cat src/main/jni/bindings.c.body >> src/main/jni/bindings.c javac -h src/main/jni src/main/java/org/ldk/enums/*.java src/main/java/org/ldk/impl/*.java @@ -165,9 +175,21 @@ fi echo "Creating TS bindings..." mkdir -p ts/{enums,structs} -rm -f ts/{enums,structs}/*.ts -./genbindings.py "./lightning.h" ts ts ts $DEBUG_ARG typescript -echo "#define LDKCVec_C2Tuple_TxidCVec_C2Tuple_u32TxOutZZZZ LDKCVec_TransactionOutputsZ" > ts/bindings.c +rm -f ts/{enums,structs,}/*.{mjs,mts} +if [ "$5" = "true" ]; then + ./genbindings.py "./lightning.h" ts ts ts $DEBUG_ARG typescript node +else + ./genbindings.py "./lightning.h" ts ts ts $DEBUG_ARG typescript browser +fi +rm -f ts/bindings.c +if [ "$3" = "true" ]; then + echo "#define LDK_DEBUG_BUILD" > ts/bindings.c +elif [ "$3" = "leaks" ]; then + # For leak checking we use release libldk which doesn't expose + # __unmangle_inner_ptr, but the C code expects to be able to call it. + echo "#define __unmangle_inner_ptr(a) (a)" > ts/bindings.c +fi +echo "#define LDKCVec_C2Tuple_TxidCVec_C2Tuple_u32TxOutZZZZ LDKCVec_TransactionOutputsZ" >> ts/bindings.c echo "#define CVec_C2Tuple_TxidCVec_C2Tuple_u32TxOutZZZZ_free CVec_TransactionOutputsZ_free" >> ts/bindings.c cat ts/bindings.c.body >> ts/bindings.c @@ -182,3 +204,20 @@ if [ "$3" = "true" ]; then else $COMPILE -o liblightningjs_release.wasm -s -Os -I"$1"/lightning-c-bindings/include/ ts/bindings.c "$1"/lightning-c-bindings/target/wasm32-wasi/release/libldk.a $EXTRA_LINK fi + +if [ -x "$(which tsc)" ]; then + cd ts +rm -r structs # TODO: Make the human-types compile + if [ "$5" = "false" ]; then + tsc + else + tsc --types node --typeRoots . + cd .. + if [ -x "$(which node)" ]; then + NODE_V="$(node --version)" + if [ "${NODE_V:1:2}" -gt 14 ]; then + node ts/test/ + fi + fi + fi +fi