fix cjson compile issues

This commit is contained in:
ading2210 2024-01-03 22:46:02 -05:00
parent e030ca6712
commit e695b1d14a
6 changed files with 47 additions and 24 deletions

View file

@ -1,5 +1,6 @@
{ {
"clangd.fallbackFlags": [ "clangd.fallbackFlags": [
"-I${workspaceFolder}/client/build/curl-wasm/include",
"-I/usr/share/emscripten/cache/sysroot/include/", "-I/usr/share/emscripten/cache/sysroot/include/",
"-I/usr/lib/emscripten/system/include" "-I/usr/lib/emscripten/system/include"
] ]

View file

@ -8,19 +8,15 @@ CACERT_FILE="cacert.pem"
OUT_FILE="out/libcurl.js" OUT_FILE="out/libcurl.js"
EXPORTED_FUNCS="_main,_perform_request,_copy_bytes" EXPORTED_FUNCS="_main,_perform_request,_copy_bytes"
RUNTIME_METHODS="addFunction,removeFunction" RUNTIME_METHODS="addFunction,removeFunction,allocate"
COMPILER_OPTIONS="-o $OUT_FILE -lcurl -lssl -lcrypto -I $INCLUDE_DIR -L $LIB_DIR" COMPILER_OPTIONS="-o $OUT_FILE -lcurl -lssl -lcrypto -lcjson -I $INCLUDE_DIR -L $LIB_DIR"
EMSCRIPTEN_OPTIONS="-lwebsocket.js -sWEBSOCKET_URL=wss://debug.ading.dev/ws -sASYNCIFY -sALLOW_TABLE_GROWTH -sEXPORTED_FUNCTIONS=$EXPORTED_FUNCS -sEXPORTED_RUNTIME_METHODS=$RUNTIME_METHODS --preload-file $CACERT_FILE" EMSCRIPTEN_OPTIONS="-lwebsocket.js -sWEBSOCKET_URL=wss://debug.ading.dev/ws -sASYNCIFY -sALLOW_TABLE_GROWTH -sEXPORTED_FUNCTIONS=$EXPORTED_FUNCS -sEXPORTED_RUNTIME_METHODS=$RUNTIME_METHODS --preload-file $CACERT_FILE"
if [ ! -f $CACERT_FILE ]; then if [ ! -f $CACERT_FILE ]; then
wget "https://curl.se/ca/cacert.pem" -O $CACERT_FILE wget "https://curl.se/ca/cacert.pem" -O $CACERT_FILE
fi fi
if [ ! -d $INCLUDE_DIR ]; then tools/all_deps.sh
mkdir -p build
tools/openssl.sh
tools/curl.sh
fi
mkdir -p out mkdir -p out
COMPILE_CMD="emcc main.c $COMPILER_OPTIONS $EMSCRIPTEN_OPTIONS" COMPILE_CMD="emcc main.c $COMPILER_OPTIONS $EMSCRIPTEN_OPTIONS"

View file

@ -1,9 +1,11 @@
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h> #include <stdio.h>
#include <curl/curl.h>
#include <emscripten.h> #include <emscripten.h>
#include <string.h> #include <string.h>
#include <curl/curl.h>
#include <cjson/cJSON.h>
int write_function(void *data, size_t size, size_t nmemb, void(*data_callback)(char* chunk_ptr, int chunk_size)) { int write_function(void *data, size_t size, size_t nmemb, void(*data_callback)(char* chunk_ptr, int chunk_size)) {
long real_size = size * nmemb; long real_size = size * nmemb;
char* chunk = malloc(real_size); char* chunk = malloc(real_size);
@ -12,8 +14,8 @@ int write_function(void *data, size_t size, size_t nmemb, void(*data_callback)(c
free(chunk); free(chunk);
return real_size; return real_size;
} }
void perform_request(const char* url, void(*data_callback)(char* chunk_ptr, int chunk_size), void(*end_callback)()) { void perform_request(const char* url, const char* json_params, void(*data_callback)(char* chunk_ptr, int chunk_size), void(*end_callback)(int error)) {
printf("downloading %s\n", url); printf("downloading %s\n", url);
CURL *http_handle; CURL *http_handle;
@ -32,13 +34,23 @@ void perform_request(const char* url, void(*data_callback)(char* chunk_ptr, int
//callbacks to pass the response data back to js //callbacks to pass the response data back to js
curl_easy_setopt(http_handle, CURLOPT_WRITEFUNCTION, &write_function); curl_easy_setopt(http_handle, CURLOPT_WRITEFUNCTION, &write_function);
curl_easy_setopt(http_handle, CURLOPT_WRITEDATA, data_callback); curl_easy_setopt(http_handle, CURLOPT_WRITEDATA, data_callback);
//parse json options
cJSON* json = cJSON_Parse(json_params);
cJSON* item = NULL;
cJSON_ArrayForEach(item, json) {
char* key = item->string;
printf("%s\n", key);
}
cJSON_Delete(json);
multi_handle = curl_multi_init(); multi_handle = curl_multi_init();
curl_multi_add_handle(multi_handle, http_handle); curl_multi_add_handle(multi_handle, http_handle);
CURLMcode mc;
do { do {
CURLMcode mc = curl_multi_perform(multi_handle, &still_running); mc = curl_multi_perform(multi_handle, &still_running);
if(!mc) if(!mc)
mc = curl_multi_poll(multi_handle, NULL, 0, 1000, NULL); mc = curl_multi_poll(multi_handle, NULL, 0, 1000, NULL);
@ -58,7 +70,8 @@ void perform_request(const char* url, void(*data_callback)(char* chunk_ptr, int
curl_multi_cleanup(multi_handle); curl_multi_cleanup(multi_handle);
curl_global_cleanup(); curl_global_cleanup();
(*end_callback)(); int error = (int) mc;
(*end_callback)(error);
} }
char* copy_bytes(const char* ptr, const int size) { char* copy_bytes(const char* ptr, const int size) {

View file

@ -29,17 +29,21 @@ function silence_errs() {
} }
//low level interface with c code //low level interface with c code
function perform_request(url, js_data_callback, js_end_callback) { function perform_request(url, params, js_data_callback, js_end_callback) {
let params_str = JSON.stringify(params);
let end_callback_ptr; let end_callback_ptr;
let data_callback_ptr; let data_callback_ptr;
let url_ptr = allocate_str(url); let url_ptr = allocate_str(url);
let params_ptr = allocate_str(params_str);
let end_callback = () => { let end_callback = (error) => {
Module.removeFunction(end_callback_ptr); Module.removeFunction(end_callback_ptr);
Module.removeFunction(data_callback_ptr); Module.removeFunction(data_callback_ptr);
_free(url_ptr); _free(url_ptr);
_free(params_ptr);
js_end_callback(); if (error) console.error("request failed with error code "+error);
js_end_callback(error);
} }
let data_callback = (chunk_ptr, chunk_size) => { let data_callback = (chunk_ptr, chunk_size) => {
@ -48,9 +52,9 @@ function perform_request(url, js_data_callback, js_end_callback) {
js_data_callback(chunk); js_data_callback(chunk);
} }
end_callback_ptr = Module.addFunction(end_callback, "v"); end_callback_ptr = Module.addFunction(end_callback, "vi");
data_callback_ptr = Module.addFunction(data_callback, "vii"); data_callback_ptr = Module.addFunction(data_callback, "vii");
_perform_request(url_ptr, data_callback_ptr, end_callback_ptr); _perform_request(url_ptr, params_ptr, data_callback_ptr, end_callback_ptr);
} }
function merge_arrays(arrays) { function merge_arrays(arrays) {
@ -64,7 +68,7 @@ function merge_arrays(arrays) {
return new_array; return new_array;
} }
function libcurl_fetch(url) { function libcurl_fetch(url, params={}) {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
let chunks = []; let chunks = [];
let data_callback = (new_data) => { let data_callback = (new_data) => {
@ -75,7 +79,7 @@ function libcurl_fetch(url) {
let response_str = new TextDecoder().decode(response_data); let response_str = new TextDecoder().decode(response_data);
resolve(response_str); resolve(response_str);
} }
perform_request(url, data_callback, finish_callback); perform_request(url, params, data_callback, finish_callback);
}) })
} }

View file

@ -8,9 +8,15 @@ OPENSSL_PREFIX=$(realpath build/openssl-wasm)
CJSON_PREFIX=$(realpath build/cjson-wasm) CJSON_PREFIX=$(realpath build/cjson-wasm)
CURL_PREFIX=$(realpath build/curl-wasm) CURL_PREFIX=$(realpath build/curl-wasm)
tools/openssl.sh if [ ! -d $OPENSSL_PREFIX ]; then
tools/cjson.sh tools/openssl.sh
tools/curl.sh fi
if [ ! -d $CJSON_PREFIX ]; then
tools/cjson.sh
fi
if [ ! -d $CURL_PREFIX ]; then
tools/curl.sh
fi
cp -r $OPENSSL_PREFIX/* $CURL_PREFIX cp -r $OPENSSL_PREFIX/* $CURL_PREFIX
cp -r $CJSON_PREFIX/* $CURL_PREFIX cp -r $CJSON_PREFIX/* $CURL_PREFIX

View file

@ -14,7 +14,10 @@ rm -rf cjson
git clone -b master --depth=1 https://github.com/DaveGamble/cJSON cjson git clone -b master --depth=1 https://github.com/DaveGamble/cJSON cjson
cd cjson cd cjson
emmake make all sed -i 's/-fstack-protector-strong//' Makefile
sed -i 's/-fstack-protector//' Makefile
emmake make CC="emcc" static
INCLUDE_FILES="cJSON.h cJSON_Utils.h" INCLUDE_FILES="cJSON.h cJSON_Utils.h"
LIB_FILES="libcjson.a libcjson_utils.a" LIB_FILES="libcjson.a libcjson_utils.a"