* use a nicer method to replace the emitter

* don't write required files on runtime, added them to cvs


git-svn-id: https://svn.code.sf.net/p/nsis/code/NSIS/trunk@4159 212acab6-be3b-0410-9dea-997c60f758d6
This commit is contained in:
kichik 2005-07-02 17:53:06 +00:00
parent 3824ddf262
commit de7378b40b

View file

@ -90,21 +90,7 @@ util_env.Append(LINKFLAGS = '$ALIGN_FLAG') # 512 bytes align
# sure the sections will be written in the correct order. # sure the sections will be written in the correct order.
# #
script_path = File('#.sconf_temp/linker_script').path stub_env.Append(LINKFLAGS = '-Wl,%s' % File('linker_script').abspath)
open(script_path, 'w').write("""
SECTIONS
{
.text : { *(.text) }
.data : { *(.data) }
.rdata : { *(.rdata) }
.bss : { *(.bss) }
.idata : { *(.idata) }
.ndata BLOCK(__section_alignment__) : { [ .ndata ] }
.rsrc : { *(.rsrc) }
}
""")
stub_env.Append(LINKFLAGS = '-Wl,%s' % script_path)
# #
# GCC requires some functions from the CRT to be present, if certain # GCC requires some functions from the CRT to be present, if certain
@ -113,9 +99,6 @@ stub_env.Append(LINKFLAGS = '-Wl,%s' % script_path)
# buffer with zeros. # buffer with zeros.
# #
funcs_file = None
funcs_obj = None
def check_requirement(ctx, func, trigger): def check_requirement(ctx, func, trigger):
ctx.Message('Checking for %s requirement... ' % func) ctx.Message('Checking for %s requirement... ' % func)
@ -131,95 +114,43 @@ def check_requirement(ctx, func, trigger):
} }
""" % trigger """ % trigger
ret = not ctx.TryLink(test, '.c') result = not ctx.TryLink(test, '.c')
ctx.Result(ret) ctx.Result(result)
ctx.env['LINKFLAGS'] = flags ctx.env['LINKFLAGS'] = flags
return ret return result
def replace_emitter(env, builder_name): def add_file_to_emitter(env, emitter_name, file):
builder = env['BUILDERS'][builder_name] try:
original_emitter = env[emitter_name]
except KeyError:
original_emitter = None
def new_emitter(target, source, env): def emitter(target, source, env):
res = builder.emitter(target, source, env) if original_emitter:
target, source = original_emitter(target, source, env)
if '$NODEFLIBS_FLAG' not in env['LINKFLAGS']: if '$NODEFLIBS_FLAG' not in env['LINKFLAGS']:
return res return target, source
global funcs_file, funcs_obj return target, source + [file]
if not funcs_obj: env[emitter_name] = emitter
funcs_obj = env.SharedObject(funcs_file)
res[1].append(funcs_obj)
return res def add_file(file):
file = File(file)
env['BUILDERS'][builder_name] = Builder( add_file_to_emitter(stub_env, 'PROGEMITTER', file)
action = builder.action, add_file_to_emitter(util_env, 'PROGEMITTER', file)
prefix = builder.prefix, add_file_to_emitter(plugin_env, 'SHLIBEMITTER', file)
suffix = builder.suffix,
src_suffix = builder.src_suffix,
target_scanner = builder.target_scanner,
source_scanner = builder.source_scanner,
target_factory = builder.target_factory,
source_factory = builder.source_factory,
emitter = new_emitter, # only thing being replaced
src_builder = builder.src_builder,
single_source = builder.single_source
)
def add_func(func):
global funcs_file
if not funcs_file:
import os
funcs_file = File('#.sconf_temp/funcs.c')
try:
os.unlink(funcs_file.abspath)
except OSError:
pass
f = file(funcs_file.abspath, 'a')
f.write(func)
f.write('\n')
f.close()
conf = defenv.Configure(custom_tests = { 'CheckRequirement' : check_requirement }) conf = defenv.Configure(custom_tests = { 'CheckRequirement' : check_requirement })
if conf.CheckRequirement('memcpy', 'struct s { char c[128]; } t = { "test" };'): if conf.CheckRequirement('memcpy', 'struct s { char c[128]; } t = { "test" };'):
add_func(""" add_file('memcpy.c')
#include <stdlib.h> // for size_t
void *memcpy(void *out, const void *in, size_t len)
{
char *c_out=(char*)out;
char *c_in=(char *)in;
while (len-- > 0)
{
*c_out++=*c_in++;
}
return out;
}
""")
if conf.CheckRequirement('memset', 'char c[128] = "test";'): if conf.CheckRequirement('memset', 'char c[128] = "test";'):
add_func(""" add_file('memset.c')
#include <stdlib.h> // for size_t
void *memset(void *mem, int c, size_t len)
{
char *p=(char*)mem;
while (len-- > 0)
{
*p++=c;
}
return mem;
}
""")
if funcs_file:
replace_emitter(stub_env, 'Program')
replace_emitter(plugin_env, 'SharedLibrary')
replace_emitter(util_env, 'Program')
conf.Finish() conf.Finish()