summaryrefslogtreecommitdiff
path: root/core/SCsub
blob: d3429c57a8250548e0f44f57d0df91b59efca622 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#!/usr/bin/env python

Import('env')

env.core_sources=[]


gd_call=""
gd_inc=""

for x in env.global_defaults:
    env.core_sources.append("#platform/"+x+"/globals/global_defaults.cpp")
    gd_inc+='#include "platform/'+x+'/globals/global_defaults.h"\n'
    gd_call+="\tregister_"+x+"_global_defaults();\n"

gd_cpp='#include "globals.h"\n'
gd_cpp+=gd_inc
gd_cpp+="void Globals::register_global_defaults() {\n"+gd_call+"\n}\n"

f = open("global_defaults.cpp","wb")
f.write(gd_cpp)
f.close()

import os
txt = "0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0"
if ("SCRIPT_AES256_ENCRYPTION_KEY" in os.environ):
    e=os.environ["SCRIPT_AES256_ENCRYPTION_KEY"]
    txt = ""
    ec_valid=True
    if (len(e)!=64):
        ec_valid=False
    else:

        for i in range(len(e)>>1):
            if (i>0):
                txt+=","
            txts="0x"+e[i*2:i*2+2]
            try:
                int(txts,16)
            except:
                ec_valid=False
            txt+=txts
    if (not ec_valid):
        txt = "0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0"
        print("Invalid AES256 encryption key, not 64 bits hex: "+e)

f = open("script_encryption_key.cpp", "wb")
f.write("#include \"globals.h\"\nuint8_t script_encryption_key[32]={" + txt + "};\n")
f.close()


env.add_source_files(env.core_sources,"*.cpp")


Export('env')

import make_binders
env.Command(['method_bind.inc','method_bind_ext.inc'], 'make_binders.py', make_binders.run)

SConscript('os/SCsub');
SConscript('math/SCsub');
SConscript('io/SCsub');
SConscript('bind/SCsub');

lib = env.Library("core",env.core_sources)

env.Prepend(LIBS=[lib])