Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNathan Letwory <nathan@letworyinteractive.com>2006-10-03 15:33:41 +0400
committerNathan Letwory <nathan@letworyinteractive.com>2006-10-03 15:33:41 +0400
commit859ea2fc0172f82c65e485d5fd94cdd86f2880ef (patch)
treeaaac89b20cbacf63105c952ced4fe3ea9663c8fb /extern/verse
parent9726cdc493ce3a38dd669208eab4fc10ac9526c8 (diff)
* make verse compile with new verse release
* added -src/-dst patch from Emil (on my request - is already in verse CVS)
Diffstat (limited to 'extern/verse')
-rw-r--r--extern/verse/dist/SConstruct106
-rw-r--r--extern/verse/dist/v_cmd_gen.c56
2 files changed, 83 insertions, 79 deletions
diff --git a/extern/verse/dist/SConstruct b/extern/verse/dist/SConstruct
index f2256c225af..15fbaa80bd0 100644
--- a/extern/verse/dist/SConstruct
+++ b/extern/verse/dist/SConstruct
@@ -10,18 +10,14 @@
#
import os
+import os.path
import sys
import re
import time
import string
from distutils import sysconfig
-root_build_dir = '..' + os.sep + 'build' + os.sep
-
-config_file = 'config.opts'
-version = '1.0'
-
-env = Environment ()
+Import('env')
defines = []
cflags = []
@@ -33,72 +29,34 @@ platform_libs = []
platform_libpath = []
platform_linkflags = []
-if sys.platform == 'win32':
+ourplatform = env['OURPLATFORM']
+if ourplatform == 'win32-vc':
print "Building on win32"
defines += ['_WIN32']
warn_flags = ['/Wall']
platform_libs = ['ws2_32']
-elif sys.platform == 'linux2':
+elif ourplatform == 'win32-mingw':
+ defines += ['_WIN32', 'WIN32']
+ platform_libs = ['shell32', 'kernel32', 'gdi32', 'user32', 'ws2_32']
+elif ourplatform == 'linux2':
print "Building on linux2"
-elif sys.platform == 'openbsd3':
+elif ourplatform == 'openbsd3':
print "Building on openbsd3"
+root_build_dir = env['BF_BUILDDIR']
-env_dict = env.Dictionary()
-if os.path.exists (config_file):
- print "Using config file: " + config_file
-else:
- print "Creating new config file: " + config_file
- config = open (config_file, 'w')
- config.write ("#Configuration file for verse SCons user definable options.\n")
- config.write ("BUILD_BINARY = 'release'\n")
- config.write ("\n# Compiler information.\n")
- config.write ("HOST_CC = %r\n"%(env_dict['CC']))
- config.write ("HOST_CXX = %r\n"%(env_dict['CXX']))
- config.write ("TARGET_CC = %r\n"%(env_dict['CC']))
- config.write ("TARGET_CXX = %r\n"%(env_dict['CXX']))
- config.write ("TARGET_AR = %r\n"%(env_dict['AR']))
- config.write ("PATH = %r\n"%(os.environ['PATH']))
-
-user_options_env = Environment()
-user_options = Options (config_file)
-user_options.AddOptions(
- (EnumOption ('BUILD_BINARY',
- 'Build a release or debug binary.', 'release',
- allowed_values = ('release', 'debug'))),
- ('BUILD_DIR', 'Target directory for intermediate files.',
- root_build_dir),
- (EnumOption ('REGEN_PROTO',
- 'Whether to regenerate the protocol files', 'no',
- allowed_values = ('yes', 'no'))),
- ('HOST_CC', 'C compiler for the host platfor. This is the same as target platform when not cross compiling.', env_dict['CC']),
- ('HOST_CXX', 'C++ compiler for the host platform. This is the same as target platform when not cross compiling.', env_dict['CXX']),
- ('TARGET_CC', 'C compiler for the target platform.', env_dict['CC']),
- ('TARGET_CXX', 'C++ compiler for the target platform.', env_dict['CXX']),
- ('TARGET_AR', 'Linker command for linking libraries.', env_dict['AR']),
- ('PATH', 'Standard search path', os.environ['PATH'])
-)
-user_options.Update (user_options_env)
-user_options_dict = user_options_env.Dictionary()
-
-root_build_dir = user_options_dict['BUILD_DIR']
-
-if user_options_dict['BUILD_BINARY'] == 'release':
+if env['VERSE_BUILD_BINARY'] == 'release':
cflags = extra_flags + release_flags + warn_flags
- if sys.platform == 'win32':
+ if ourplatform == 'win32-vc':
defines += ['NDEBUG']
else:
cflags = extra_flags + debug_flags + warn_flags
- if sys.platform == 'win32':
+ if ourplatform == 'win32-vc':
#defines += ['_DEBUG'] specifying this makes msvc want to link to python22_d.lib??
platform_linkflags += ['/DEBUG','/PDB:verse.pdb']
-env = Environment()
-env.Replace (CC = user_options_dict['TARGET_CC'])
-env.Replace (CXX = user_options_dict['TARGET_CXX'])
-env.Replace (PATH = user_options_dict['PATH'])
-env.Replace (AR = user_options_dict['TARGET_AR'])
+verse_env = env.Copy()
cmd_gen_files = (['v_cmd_gen.c',
'v_cmd_def_a.c',
@@ -117,23 +75,32 @@ proto_env = env.Copy()
proto_env.Append(CPPDEFINES=['V_GENERATE_FUNC_MODE'])
mkprot_tool = proto_env.Program(target = 'mkprot', source = cmd_gen_files)
+print os.getcwd()
+
mkprot_re = re.compile('v_cmd_def_([a-z]{1}).c')
def mkprot_emitter(target = None, source = None, env = None):
newtargets = list()
for s in source:
- m = mkprot_re.match(str(s))
+ p, f = os.path.split(str(s))
+ m = mkprot_re.match(f)
if m:
newtargets.append("v_gen_pack_"+m.group(1)+"_node.c")
newtargets.extend(['verse.h'])
env.Depends(newtargets, mkprot_tool)
return (newtargets, source)
-mkprot_bld = Builder(action = "\"" + mkprot_tool[0].abspath + "\"",
+mkprot_bld = Builder(action = "\"" + mkprot_tool[0].abspath + "\" -src=\""+os.getcwd()+os.sep+"extern"+os.sep+"verse"+os.sep+"dist"+os.sep+os.sep+"\" -dst=\""+os.path.abspath(env['BF_BUILDDIR'])+os.sep+"extern"+os.sep+"verse"+os.sep+"dist"+os.sep+os.sep+"\"",
emitter = mkprot_emitter)
-env['BUILDERS']['Protocol'] = mkprot_bld
+verse_env['BUILDERS']['Protocol'] = mkprot_bld
-cmd_gen_deps.extend(env.Protocol('do_mkprot', cmd_gen_files))
+cmd_gen_deps.extend(verse_env.Protocol('do_mkprot', cmd_gen_files))
+
+
+print "XXXXXXXXXXXXXXXXX"
+for i in cmd_gen_deps:
+ print i
+print "XXXXXXXXXXXXXXXXX"
cmd_gen_deps.pop()
lib_source_files = (['v_cmd_buf.c',
@@ -169,25 +136,18 @@ server_source_files = (['vs_connection.c',
'vs_node_text.c'
])
-verse_example_sources = (['examples/list-nodes.c'])
-
-verselib_env = env.Copy()
+verselib_env = verse_env.Copy()
verselib_env.Append(CPPDEFINES = defines)
-verseserver_env = env.Copy()
+verseserver_env = verse_env.Copy()
verseserver_env.Append(CPPDEFINES = defines)
verseserver_env.Append (LIBS=['libverse'])
verseserver_env.Append (LIBPATH = ['.'])
verseserver_env.Append (LIBS= platform_libs)
-verseexample_env = env.Copy()
-verseexample_env.Append(CPPDEFINES = defines)
-verseexample_env.Append (LIBS=['libverse'])
-verseexample_env.Append (LIBPATH = ['.'])
-verseexample_env.Append (LIBS= platform_libs)
-verseexample_env.Append (CPPPATH = ['.'])
+#verselib =
+verselib_env.BlenderLib(libname='verse', sources=lib_source_files, includes=["."], defines = defines, libtype=['core', 'intern'], priority = [5, 5])
+verseserver_env.BlenderProg(builddir="#"+root_build_dir, progname='verse', sources=server_source_files, libs=['verse'],
+libpath='#'+env['BF_BUILDDIR']+'/lib')
-verselib = verselib_env.Library(target='libverse', source=lib_source_files)
-verseserver_env.Program(target='verse', source=server_source_files)
-verseexample_env.Program(target='list-nodes', source=verse_example_sources)
diff --git a/extern/verse/dist/v_cmd_gen.c b/extern/verse/dist/v_cmd_gen.c
index 55b1eabfe97..2305f94ebc4 100644
--- a/extern/verse/dist/v_cmd_gen.c
+++ b/extern/verse/dist/v_cmd_gen.c
@@ -10,6 +10,11 @@
#include "v_cmd_gen.h"
+#if defined _WIN32
+#define chdir _chdir
+#define snprintf _snprintf
+#endif
+
#if defined V_GENERATE_FUNC_MODE
#define MAX_PARAMS_PER_CMD 32
@@ -43,8 +48,9 @@ extern void v_gen_text_cmd_def(void);
extern void v_gen_curve_cmd_def(void);
extern void v_gen_audio_cmd_def(void);
-static void v_cg_init(void)
+static int v_cg_init(const char *src_path)
{
+ char buf[1024];
int i;
FILE *f;
@@ -105,11 +111,21 @@ static void v_cg_init(void)
"#endif\n\n"
"#define\tVERSE_H\n\n");
/* Copy contents of "verse_header.h" into output "verse.h". */
- f = fopen("verse_header.h", "r");
- while((i = fgetc(f)) != EOF)
- fputc(i, VCGData.verse_h);
- fclose(f);
+ snprintf(buf, sizeof buf, "%sverse_header.h", src_path);
+ f = fopen(buf, "r");
+ if(f != NULL)
+ {
+ while((i = fgetc(f)) != EOF)
+ fputc(i, VCGData.verse_h);
+ fclose(f);
+ }
+ else
+ {
+ fprintf(stderr, "mkprot: Couldn't find \"%s\" input file\n", buf);
+ return 0;
+ }
fprintf(VCGData.verse_h, "\n/* Command sending functions begin. ----------------------------------------- */\n\n");
+ return 1;
}
static void v_cg_close(void)
@@ -865,8 +881,36 @@ void v_cg_end_cmd(void)
int main(int argc, char *argv[])
{
+ const char *src = "";
+ int i;
+
+ for(i = 1; argv[i] != NULL; i++)
+ {
+ if(strcmp(argv[i], "-h") == 0)
+ {
+ printf("Verse protocol generation tool.\nUsage:\n");
+ printf(" -h\t\tPrint this usage information, and exit.\n");
+ printf(" -src=PATH\tSets source path prefix to PATH. It must be possible to find\n");
+ printf("\t\tthe \"verse_header.h\" input file by appending that name to PATH.\n");
+ printf("\t\tThus, PATH must end with a proper directory separator character.\n");
+ printf(" -dst=PATH\tSets output directory, where all output files are written.\n");
+ printf("\t\tIf used, use -src to point to where \"verse_header.h\" is.\n");
+ return EXIT_SUCCESS;
+ }
+ else if(strncmp(argv[i], "-src=", 5) == 0)
+ src = argv[i] + 5;
+ else if(strncmp(argv[i], "-dst=", 5) == 0)
+ {
+ if(chdir(argv[i] + 5) != 0)
+ fprintf(stderr, "%s: Couldn't set output directory to \"%s\"\n", argv[0], argv[i]+5);
+ }
+ else
+ fprintf(stderr, "%s: Ignoring unknown uption \"%s\"\n", argv[0], argv[i]);
+ }
+
printf("start\n");
- v_cg_init();
+ if(!v_cg_init(src))
+ return EXIT_FAILURE;
v_gen_system_cmd_def();
fprintf(VCGData.verse_h, "\n");
v_gen_object_cmd_def();