Compare commits

..

1 Commits

2 changed files with 5 additions and 25 deletions

View File

@ -80,14 +80,7 @@ for entry in os.listdir(ROOT):
headers[f'{entry}/{file}'] = Header(f'{entry}/{file}')
def merge_c_files():
c_files = [
COPYRIGHT,
'\n',
'#define PK_IS_AMALGAMATED_C',
'\n',
'#include "pocketpy.h"',
'\n'
]
c_files = [COPYRIGHT, '\n', '#include "pocketpy.h"', '\n']
# merge internal headers
internal_h = []
@ -130,12 +123,7 @@ def merge_c_files():
return ''.join(c_files)
def merge_h_files():
h_files = [
COPYRIGHT,
'#pragma once',
'\n',
'#define PK_IS_PUBLIC_INCLUDE',
]
h_files = [COPYRIGHT, '#pragma once']
def _replace(m):
path = m.group(1)
@ -160,15 +148,9 @@ write_file('amalgamated/pocketpy.h', merge_h_files())
shutil.copy("src2/main.c", "amalgamated/main.c")
def checked_sh(cmd):
ok = os.system(cmd)
assert ok == 0, f"command failed: {cmd}"
if sys.platform in ['linux', 'darwin']:
common_flags = "-O1 --std=c11 -lm -ldl -lpthread -Iamalgamated"
checked_sh(f"gcc -o main amalgamated/pocketpy.c src2/example.c {common_flags}")
checked_sh("./main && rm -f ./main")
checked_sh(f"gcc -o main amalgamated/pocketpy.c amalgamated/main.c {common_flags}")
ok = os.system("gcc -o main amalgamated/pocketpy.c amalgamated/main.c -O1 --std=c11 -lm -ldl -lpthread")
if ok == 0:
print("Test build success!")
print("amalgamated/pocketpy.h")

View File

@ -28,7 +28,6 @@ typedef double py_f64;
/// A generic destructor function.
typedef void (*py_Dtor)(void*);
#ifndef PK_IS_AMALGAMATED_C
#ifdef PK_IS_PUBLIC_INCLUDE
typedef struct py_TValue {
py_Type type;
@ -41,7 +40,6 @@ typedef struct py_TValue {
};
} py_TValue;
#endif
#endif
/// A string view type. It is helpful for passing strings which are not null-terminated.
typedef struct c11_sv {