mirror of
https://github.com/ading2210/libcurl.js.git
synced 2025-05-11 13:30:01 -04:00
fix cjson compile issues
This commit is contained in:
parent
e030ca6712
commit
e695b1d14a
6 changed files with 47 additions and 24 deletions
1
.vscode/settings.json
vendored
1
.vscode/settings.json
vendored
|
@ -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"
|
||||||
]
|
]
|
||||||
|
|
|
@ -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"
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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);
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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
|
|
@ -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"
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue