svn merge https://svn.blender.org/svnroot/bf-blender/trunk/blender -r22717:22875
[blender.git] / release / datafiles / datatoc.py
1 #!/usr/bin/python3
2 #
3 # ***** BEGIN GPL LICENSE BLOCK *****
4 #
5 # This program is free software; you can redistribute it and/or
6 # modify it under the terms of the GNU General Public License
7 # as published by the Free Software Foundation; either version 2
8 # of the License, or (at your option) any later version.
9 #
10 # This program is distributed in the hope that it will be useful,
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 # GNU General Public License for more details.
14 #
15 # You should have received a copy of the GNU General Public License
16 # along with this program; if not, write to the Free Software Foundation,
17 # Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
18 #
19 # The Original Code is Copyright (C) 2009 Blender Foundation.
20 # All rights reserved.
21 #
22 # Contributor(s): Jörg Müller
23 #
24 # ***** END GPL LICENCE BLOCK *****
25
26 import sys
27
28 if len(sys.argv) < 2:
29         print("Usage: datatoc <data_file>")
30         sys.exit(1)
31
32 filename = sys.argv[1]
33
34 try:
35         fpin = open(filename, "rb");
36 except:
37         print("Unable to open input <{0}>".format(sys.argv[1]))
38         sys.exit(1)
39
40 size = fpin.seek(0, 2)
41 fpin.seek(0)
42
43 if filename[0] == ".":
44         filename = filename[1:]
45
46 cname = filename + ".c"
47 print("Making C file <{0}>".format(cname))
48
49 filename = filename.replace(".", "_")
50
51 try:
52         fpout = open(cname, "w")
53 except:
54         print("Unable to open output <{0}>".format(cname))
55         sys.exit(1)
56
57 fpout.write("/* DataToC output of file <{0}> */\n\n".format(filename))
58 fpout.write("int datatoc_{0}_size= {1};\n".format(filename, size))
59
60 fpout.write("char datatoc_{0}[]= {{\n".format(filename))
61
62 while size > 0:
63         size -= 1
64         if size % 32 == 31:
65                 fpout.write("\n")
66         
67         fpout.write("{0:3d},".format(ord(fpin.read(1))))
68
69 fpout.write("\n  0};\n\n")
70
71 fpin.close()
72 fpout.close()