From 1e41bfa9cf525d031a63919ef23e54350ef24620 Mon Sep 17 00:00:00 2001 From: marynate Date: Thu, 22 May 2014 16:24:46 +0800 Subject: [PATCH] Use cStringIO to write editor_icons.cpp, lower the opportunity file access conflit when buiding with spawn_jobs --- tools/editor/icons/SCsub | 36 +++++++++++++++++++++--------------- 1 file changed, 21 insertions(+), 15 deletions(-) diff --git a/tools/editor/icons/SCsub b/tools/editor/icons/SCsub index a7e550feac2..aea053d22b0 100644 --- a/tools/editor/icons/SCsub +++ b/tools/editor/icons/SCsub @@ -3,13 +3,15 @@ Import('env') def make_editor_icons_action(target, source, env): import os + import cStringIO dst = target[0].srcnode().abspath pixmaps = source + + s = cStringIO.StringIO() - f = open(dst,"wb") - f.write("#include \"editor_icons.h\"\n\n") - f.write("#include \"scene/resources/theme.h\"\n\n") + s.write("#include \"editor_icons.h\"\n\n") + s.write("#include \"scene/resources/theme.h\"\n\n") for x in pixmaps: @@ -17,37 +19,41 @@ def make_editor_icons_action(target, source, env): var_str=os.path.basename(x)[:-4]+"_png"; #print(var_str) - f.write("static const unsigned char "+ var_str +"[]={\n"); + s.write("static const unsigned char "+ var_str +"[]={\n"); pngf=open(x,"rb"); b=pngf.read(1); while(len(b)==1): - f.write(hex(ord(b))) + s.write(hex(ord(b))) b=pngf.read(1); if (len(b)==1): - f.write(",") + s.write(",") - f.write("\n};\n\n\n"); + s.write("\n};\n\n\n"); pngf.close(); - f.write("static Ref make_icon(const uint8_t* p_png) {\n") - f.write("\tRef texture( memnew( ImageTexture ) );\n") - f.write("\ttexture->create_from_image( Image(p_png),ImageTexture::FLAG_FILTER );\n") - f.write("\treturn texture;\n") - f.write("}\n\n") + s.write("static Ref make_icon(const uint8_t* p_png) {\n") + s.write("\tRef texture( memnew( ImageTexture ) );\n") + s.write("\ttexture->create_from_image( Image(p_png),ImageTexture::FLAG_FILTER );\n") + s.write("\treturn texture;\n") + s.write("}\n\n") - f.write("void editor_register_icons(Ref p_theme) {\n\n") + s.write("void editor_register_icons(Ref p_theme) {\n\n") for x in pixmaps: x=os.path.basename(str(x)) type=x[5:-4].title().replace("_",""); var_str=x[:-4]+"_png"; - f.write("\tp_theme->set_icon(\""+type+"\",\"EditorIcons\",make_icon("+var_str+"));\n"); + s.write("\tp_theme->set_icon(\""+type+"\",\"EditorIcons\",make_icon("+var_str+"));\n"); - f.write("\n\n}\n\n"); + s.write("\n\n}\n\n"); + + f = open(dst,"wb") + f.write(s.getvalue()) f.close() + s.close() make_editor_icons_builder = Builder(action=make_editor_icons_action, suffix = '.cpp',