[DEV] remove some unneeded elements
This commit is contained in:
parent
2a58657df5
commit
134e0b523e
8
lutin.py
8
lutin.py
@ -34,7 +34,6 @@ myLutinArg.add(lutinArg.ArgDefine("c", "compilator", list=[["clang",""],["gcc","
|
||||
myLutinArg.add(lutinArg.ArgDefine("m", "mode", list=[["debug",""],["release",""]], desc="Compile in release or debug mode (default release)"))
|
||||
myLutinArg.add(lutinArg.ArgDefine("a", "arch", list=[["auto","Automatic choice"],["arm","Arm processer"],["x86","Generic PC : AMD/Intel"],["ppc","Power PC"]], desc="Architecture to compile"))
|
||||
myLutinArg.add(lutinArg.ArgDefine("b", "bus", list=[["auto","Automatic choice"],["32","32 bits"],["64","64 bits"]], desc="Adressing size (Bus size)"))
|
||||
myLutinArg.add(lutinArg.ArgDefine("r", "prj", desc="Use external project management (not build with lutin..."))
|
||||
myLutinArg.add(lutinArg.ArgDefine("p", "package", desc="Disable the package generation (usefull when just compile for test on linux ...)"))
|
||||
myLutinArg.add(lutinArg.ArgDefine("g", "gcov", desc="Enable code coverage intrusion in code"))
|
||||
myLutinArg.add(lutinArg.ArgDefine("", "simulation", desc="simulater mode (availlable only for IOS)"))
|
||||
@ -50,6 +49,7 @@ localArgument = myLutinArg.parse()
|
||||
def usage():
|
||||
# generic argument displayed :
|
||||
myLutinArg.display()
|
||||
print " All target can finish with '-clean' '-dump' ..."
|
||||
print " all"
|
||||
print " build all (only for the current selected board) (bynary and packages)"
|
||||
print " clean"
|
||||
@ -58,7 +58,7 @@ def usage():
|
||||
print " Dump all the module dependency and properties"
|
||||
listOfAllModule = lutinModule.list_all_module_with_desc()
|
||||
for mod in listOfAllModule:
|
||||
print " " + mod[0] + " / " + mod[0] + "-clean / " + mod[0] + "-dump"
|
||||
print " " + mod[0]
|
||||
if mod[1] != "":
|
||||
print " " + mod[1]
|
||||
print " ex: " + sys.argv[0] + " all --target=Android all -t Windows -m debug all"
|
||||
@ -142,7 +142,6 @@ def Start():
|
||||
"arch":"auto",
|
||||
"generate-package":True,
|
||||
"simulation":False,
|
||||
"extern-build":False,
|
||||
"gcov":False
|
||||
}
|
||||
# load the default target :
|
||||
@ -158,8 +157,6 @@ def Start():
|
||||
config["simulation"]=True
|
||||
elif argument.get_option_nName() == "gcov":
|
||||
config["gcov"]=True
|
||||
elif argument.get_option_nName() == "prj":
|
||||
config["extern-build"]=True
|
||||
elif argument.get_option_nName() == "bus":
|
||||
config["bus-size"]=argument.get_arg()
|
||||
elif argument.get_option_nName() == "arch":
|
||||
@ -183,7 +180,6 @@ def Start():
|
||||
"arch":"auto",
|
||||
"generate-package":True,
|
||||
"simulation":False,
|
||||
"extern-build":False,
|
||||
"gcov":False
|
||||
}
|
||||
#remove previous target
|
||||
|
@ -1,22 +0,0 @@
|
||||
#!/usr/bin/python
|
||||
##
|
||||
## @author Edouard DUPIN
|
||||
##
|
||||
## @copyright 2012, Edouard DUPIN, all right reserved
|
||||
##
|
||||
## @license APACHE v2.0 (see license file)
|
||||
##
|
||||
|
||||
import lutinDebug as debug
|
||||
import datetime
|
||||
import lutinTools
|
||||
import lutinModule
|
||||
|
||||
class ExtProjectGenerator:
|
||||
def __init__(self, extType):
|
||||
self.extType = extType
|
||||
self.name = "emptyName"
|
||||
#This is a distionnaty of all groups :
|
||||
self.groups = {}
|
||||
|
||||
|
@ -1,701 +0,0 @@
|
||||
#!/usr/bin/python
|
||||
##
|
||||
## @author Edouard DUPIN
|
||||
##
|
||||
## @copyright 2012, Edouard DUPIN, all right reserved
|
||||
##
|
||||
## @license APACHE v2.0 (see license file)
|
||||
##
|
||||
|
||||
import lutinDebug as debug
|
||||
import datetime
|
||||
import lutinTools as tools
|
||||
import os
|
||||
import fnmatch
|
||||
import lutinExtProjectGenerator
|
||||
from collections import defaultdict
|
||||
|
||||
|
||||
# id example : FFBA2F79187F44AE0034CC66
|
||||
genericID = 100000
|
||||
|
||||
def convert_name_in_base_id(name,fill=True):
|
||||
out = "FF"
|
||||
for element in name.lower():
|
||||
if element == "a": out += "01"
|
||||
elif element == "b": out += "02"
|
||||
elif element == "c": out += "03"
|
||||
elif element == "d": out += "04"
|
||||
elif element == "e": out += "05"
|
||||
elif element == "f": out += "06"
|
||||
elif element == "g": out += "07"
|
||||
elif element == "h": out += "08"
|
||||
elif element == "i": out += "09"
|
||||
elif element == "j": out += "10"
|
||||
elif element == "k": out += "11"
|
||||
elif element == "l": out += "12"
|
||||
elif element == "m": out += "13"
|
||||
elif element == "n": out += "14"
|
||||
elif element == "o": out += "15"
|
||||
elif element == "p": out += "16"
|
||||
elif element == "q": out += "17"
|
||||
elif element == "r": out += "18"
|
||||
elif element == "s": out += "19"
|
||||
elif element == "t": out += "20"
|
||||
elif element == "u": out += "21"
|
||||
elif element == "v": out += "22"
|
||||
elif element == "w": out += "23"
|
||||
elif element == "x": out += "24"
|
||||
elif element == "y": out += "25"
|
||||
elif element == "z": out += "27"
|
||||
else: out += "FF"
|
||||
if len(out) >= 18:
|
||||
return out
|
||||
if fill == True:
|
||||
for iii in range(0,256):
|
||||
out += "A"
|
||||
if len(out) >= 18:
|
||||
return out
|
||||
return out
|
||||
|
||||
|
||||
dictId = {}
|
||||
|
||||
def convert_folder_in_base_id(name, package):
|
||||
global dictId
|
||||
debug.verbose(" generate Id for : " + package + ":" + name);
|
||||
if package not in dictId.keys():
|
||||
dictId[package] = {"lastID": 100000, "sub":{}}
|
||||
if name not in dictId[package]["sub"].keys():
|
||||
generatedID = convert_name_in_base_id(package) + str(dictId[package]["lastID"])
|
||||
dictId[package]["lastID"] = dictId[package]["lastID"] + 1
|
||||
dictId[package]["sub"][name] = {"id":generatedID}
|
||||
return dictId[package]["sub"][name]["id"]
|
||||
|
||||
FILE_MARKER = '<files>'
|
||||
|
||||
##
|
||||
## @brief generate a tree from the specific file
|
||||
##
|
||||
def attach(branch, trunk):
|
||||
parts = branch.split('/', 1)
|
||||
if len(parts) == 1: # branch is a file
|
||||
trunk[FILE_MARKER].append(parts[0])
|
||||
else:
|
||||
node, others = parts
|
||||
if node not in trunk:
|
||||
trunk[node] = defaultdict(dict, ((FILE_MARKER, []),))
|
||||
attach(others, trunk[node])
|
||||
|
||||
##
|
||||
## @brief display a specific path tree field
|
||||
##
|
||||
def prettify(d, indent=0):
|
||||
for key, value in d.iteritems():
|
||||
if key == FILE_MARKER:
|
||||
if value:
|
||||
debug.debug(' ' * indent + str(value))
|
||||
else:
|
||||
debug.debug(' ' * indent + str(key))
|
||||
if isinstance(value, dict):
|
||||
prettify(value, indent+1)
|
||||
else:
|
||||
debug.debug(' ' * (indent+1) + str(value))
|
||||
|
||||
|
||||
def generate_tree(treedata, package, tree = []):
|
||||
data = ""
|
||||
tmpPath = "?tree?"
|
||||
if len(tree) != 0:
|
||||
tmpPath = ""
|
||||
for elem in tree:
|
||||
if tmpPath != "":
|
||||
tmpPath += '/'
|
||||
tmpPath += elem
|
||||
if len(tree) == 0:
|
||||
data +=' ' + convert_folder_in_base_id(tmpPath, package) + ' /* ' + package + ' */ = {\n'
|
||||
else:
|
||||
data +=' ' + convert_folder_in_base_id(tmpPath, package) + ' /* ' + tree[-1] + ' */ = {\n'
|
||||
data +=' isa = PBXGroup;\n'
|
||||
data +=' children = (\n'
|
||||
"""
|
||||
data +=' FFBA2F8B187F44AE0034CC66 /* AppDelegate.h */,\n'
|
||||
data +=' FFBA2F8C187F44AE0034CC66 /* AppDelegate.m */,\n'
|
||||
data +=' FFBA2F8E187F44AE0034CC66 /* Main_iPhone.storyboard */,\n'
|
||||
data +=' FFBA2F91187F44AE0034CC66 /* Main_iPad.storyboard */,\n'
|
||||
data +=' FFBA2F94187F44AE0034CC66 /* Shader.fsh */,\n'
|
||||
data +=' FFBA2F96187F44AE0034CC66 /* Shader.vsh */,\n'
|
||||
data +=' FFBA2F98187F44AE0034CC66 /* ViewController.h */,\n'
|
||||
data +=' FFBA2F99187F44AE0034CC66 /* ViewController.m */,\n'
|
||||
data +=' FFBA2F9B187F44AE0034CC66 /* Images.xcassets */,\n'
|
||||
data +=' FFBA2F83187F44AE0034CC66 /* Supporting Files */,\n'
|
||||
"""
|
||||
for key, value in treedata.iteritems():
|
||||
if key == FILE_MARKER:
|
||||
for file in value:
|
||||
data +=' ' + convert_folder_in_base_id(tmpPath + '/' + file, package) + ' /* ' + file + ' */,\n'
|
||||
else:
|
||||
# TODO : Check if folder is empty ...
|
||||
data +=' ' + convert_folder_in_base_id(tmpPath + '/' + key, package) + ' /* ' + key + ' */,\n'
|
||||
"""
|
||||
debug.debug(' ' * indent + str(key))
|
||||
if isinstance(value, dict):
|
||||
prettify(value, indent+1)
|
||||
else:
|
||||
debug.debug(' ' * (indent+1) + str(value))
|
||||
"""
|
||||
data +=' );\n'
|
||||
if len(tree) == 0:
|
||||
data +=' path = ' + package + ';\n'
|
||||
else:
|
||||
data +=' path = ' + tree[-1] + ';\n'
|
||||
data +=' sourceTree = "<group>";\n'
|
||||
data +=' };\n'
|
||||
# generate all subFolder :
|
||||
for key, value in treedata.iteritems():
|
||||
if key == FILE_MARKER:
|
||||
continue
|
||||
tree.append(key)
|
||||
data += generate_tree(value, package, tree)
|
||||
tree.pop()
|
||||
|
||||
return data
|
||||
|
||||
|
||||
XCodeTypeElements = {
|
||||
'a': ('archive.ar', 'PBXFrameworksBuildPhase', ''),
|
||||
'xcodeproj': ('wrapper.pb-project', None, '""'),
|
||||
'app': ('wrapper.application', None, ''),
|
||||
'framework': ('wrapper.framework', 'PBXFrameworksBuildPhase', 'SDKROOT'),
|
||||
'dylib': ('compiled.mach-o.dylib', 'PBXFrameworksBuildPhase', '"<group>"'),
|
||||
'h': ('sourcecode.c.h', None, '"<group>"'),
|
||||
'H': ('sourcecode.c.h', None, '"<group>"'),
|
||||
'hpp': ('sourcecode.c.h', None, '"<group>"'),
|
||||
'hxx': ('sourcecode.c.h', None, '"<group>"'),
|
||||
'S': ('sourcecode.asm', 'PBXSourcesBuildPhase', '"<group>"'),
|
||||
's': ('sourcecode.asm', 'PBXSourcesBuildPhase', '"<group>"'),
|
||||
'c': ('sourcecode.c.c', 'PBXSourcesBuildPhase', '"<group>"'),
|
||||
'cpp': ('sourcecode.cpp.cpp', 'PBXSourcesBuildPhase', '"<group>"'),
|
||||
'cxx': ('sourcecode.cpp.cpp', 'PBXSourcesBuildPhase', '"<group>"'),
|
||||
'm': ('sourcecode.c.objc', 'PBXSourcesBuildPhase', '"<group>"'),
|
||||
'j': ('sourcecode.c.objc', 'PBXSourcesBuildPhase', '"<group>"'),
|
||||
'mm': ('sourcecode.cpp.objcpp', 'PBXSourcesBuildPhase', '"<group>"'),
|
||||
'icns': ('image.icns', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'nib': ('wrapper.nib', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'plist': ('text.plist.xml', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'json': ('text.json', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'rtf': ('text.rtf', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'png': ('image.png', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'tiff': ('image.tiff', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'txt': ('text', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'fsh': ('sourcecode.glsl', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'frag': ('sourcecode.glsl', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'vsh': ('sourcecode.glsl', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'vert': ('sourcecode.glsl', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'svg': ('image.png', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'xml': ('sourcecode.xml', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'prog': ('text.xml', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'ttf': ('text', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'conf': ('text', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'emf': ('text', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'xib': ('file.xib', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'strings': ('text.plist.strings', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'bundle': ('wrapper.plug-in', 'PBXResourcesBuildPhase', '"<group>"'),
|
||||
'storyboard':('file.storyboard', 'PBXResourcesBuildPhase', '"<group>"')
|
||||
}
|
||||
|
||||
class ExtProjectGeneratorXCode(lutinExtProjectGenerator.ExtProjectGenerator):
|
||||
def __init__(self):
|
||||
lutinExtProjectGenerator.ExtProjectGenerator.__init__(self, "XCode")
|
||||
self.baseId = "FFFFFFFFFFFFFFFFFF"
|
||||
|
||||
# set default framwork:
|
||||
self.add_files("Frameworks",
|
||||
"System/Library/Frameworks",
|
||||
[ "Foundation.framework",
|
||||
"CoreGraphics.framework",
|
||||
"UIKit.framework",
|
||||
"GLKit.framework",
|
||||
"OpenGLES.framework",
|
||||
"XCTest.framework" ]);
|
||||
|
||||
def set_project_name(self, name):
|
||||
self.name = name
|
||||
self.baseId = convert_name_in_base_id(name)
|
||||
|
||||
def add_files(self, group, basePath, srcList):
|
||||
if group not in self.groups.keys() :
|
||||
self.groups[group] = {
|
||||
"list-files" : [],
|
||||
"extra-flags" : []
|
||||
}
|
||||
for element in srcList:
|
||||
debug.info("plop : " + str(element))
|
||||
debug.info("plop : " + str(basePath))
|
||||
path = basePath + "/" + element
|
||||
pos = path.rfind('/')
|
||||
simpleName = path
|
||||
if pos >= 0:
|
||||
simpleName = path[pos+1:]
|
||||
pos = simpleName.rfind('.')
|
||||
extention = "";
|
||||
if pos >= 0:
|
||||
extention = simpleName[pos+1:]
|
||||
|
||||
self.groups[group]["list-files"].append({
|
||||
"path" : path,
|
||||
"name" : simpleName,
|
||||
"extention":extention,
|
||||
"declare-name":element})
|
||||
|
||||
def add_data_file(self, basePath, srcList):
|
||||
realBasePath = os.path.realpath(basePath)
|
||||
if realBasePath[-1] == "/":
|
||||
realBasePath = realBasePath[:-1]
|
||||
debug.debug("add data file : " + str(srcList))
|
||||
for realName,destName in srcList:
|
||||
tools.copy_file(realBasePath+'/'+realName, 'out/iOs/' + self.name + '/data/' + destName, force=True)
|
||||
self.add_files("data", 'out/iOs/' + self.name + 'xcodeprj/data', [destName])
|
||||
|
||||
def add_data_folder(self, basePath, srcList):
|
||||
realBasePath = basePath
|
||||
if realBasePath[-1] == "/":
|
||||
realBasePath = realBasePath[:-1]
|
||||
debug.debug("add data folder : " + str(srcList))
|
||||
for inputPath,outputPath in srcList:
|
||||
tmpPath = os.path.dirname(os.path.realpath(realBasePath + '/' + inputPath))
|
||||
tmpRule = os.path.basename(inputPath)
|
||||
debug.warning(" add folder : '" + tmpPath + "' rule : '" + tmpRule + "'")
|
||||
for root, dirnames, filenames in os.walk(tmpPath):
|
||||
tmpList = filenames
|
||||
if len(tmpRule)>0:
|
||||
tmpList = fnmatch.filter(filenames, tmpRule)
|
||||
# Import the module :
|
||||
for cycleFile in tmpList:
|
||||
#for cycleFile in filenames:
|
||||
self.add_data_file(tmpPath, [[cycleFile, outputPath+cycleFile]])
|
||||
|
||||
def generate_project_file(self):
|
||||
|
||||
|
||||
#debug.error(" list : " + str(self.groups))
|
||||
|
||||
data ='// !$*UTF8*$!\n'
|
||||
data +='{\n'
|
||||
data +=' archiveVersion = 1;\n'
|
||||
data +=' classes = {\n'
|
||||
data +=' };\n'
|
||||
data +=' objectVersion = 46;\n'
|
||||
data +=' objects = {\n'
|
||||
data +='\n'
|
||||
data +='/* Begin PBXBuildFile section */\n'
|
||||
for group in self.groups:
|
||||
element = self.groups[group]
|
||||
for files in element["list-files"]:
|
||||
debug.debug(" PBXBuildFile ?? " + str(files))
|
||||
if files["extention"] in XCodeTypeElements.keys():
|
||||
if XCodeTypeElements[files["extention"]][1] == "PBXSourcesBuildPhase" \
|
||||
or XCodeTypeElements[files["extention"]][1] == "PBXFrameworksBuildPhase"\
|
||||
or XCodeTypeElements[files["extention"]][1] == "PBXSourcesBuildPhase"\
|
||||
or XCodeTypeElements[files["extention"]][1] == "PBXVariantGroup":
|
||||
data +=' ' + convert_folder_in_base_id(files["declare-name"] + '_PBXBuildFile', group)
|
||||
data +=' /* ' + files["name"] + ' in ' + group + ' */ = {'
|
||||
data +=' isa = PBXBuildFile;'
|
||||
data +=' fileRef = ' + convert_folder_in_base_id(files["declare-name"], group) + ';'
|
||||
data +=' };\n'
|
||||
data +='/* End PBXBuildFile section */\n'
|
||||
data +='\n'
|
||||
data +='/* Begin PBXContainerItemProxy section */\n'
|
||||
|
||||
# I did not understand this section ...
|
||||
data +=' ' + convert_folder_in_base_id("?PBXContainerItemProxy?", self.name) + ' /* PBXContainerItemProxy */ = {\n'
|
||||
data +=' isa = PBXContainerItemProxy;\n'
|
||||
data +=' containerPortal = ' + convert_folder_in_base_id("?PBXProject?", self.name) + ' /* Project object */;\n'
|
||||
data +=' proxyType = 1;\n'
|
||||
data +=' remoteGlobalIDString = ' + convert_folder_in_base_id("?PBXNativeTarget?sectio", self.name) + ';\n'
|
||||
data +=' remoteInfo = ' + self.name + ';\n'
|
||||
data +=' };\n'
|
||||
|
||||
data +='/* End PBXContainerItemProxy section */\n'
|
||||
data +='\n'
|
||||
data +='/* Begin PBXFileReference section */\n'
|
||||
|
||||
data +=' ' + convert_folder_in_base_id("?app?", self.name) + ' /* ' + self.name + '.app */ = {\n'
|
||||
data +=' isa = PBXFileReference;\n'
|
||||
data +=' explicitFileType = wrapper.application;\n'
|
||||
data +=' includeInIndex = 0;\n'
|
||||
data +=' path = ' + self.name + '.app;\n'
|
||||
data +=' sourceTree = BUILT_PRODUCTS_DIR;\n'
|
||||
data +=' };\n'
|
||||
for group in self.groups:
|
||||
element = self.groups[group]
|
||||
for files in element["list-files"]:
|
||||
debug.debug(" PBXBuildFile ?? " + str(files))
|
||||
data +=' /* ' + files["name"] + ' */\n'
|
||||
if files["extention"] in XCodeTypeElements.keys():
|
||||
data +=' ' + convert_folder_in_base_id(files["declare-name"], group) + ' = {'
|
||||
data +=' isa = PBXBuildFile;'
|
||||
data +=' lastKnownFileType = ' + XCodeTypeElements[files["extention"]][0] + ';'
|
||||
data +=' path = ' + files["path"] + ';'
|
||||
data +=' name = ' + files["name"] + ';'
|
||||
data +=' sourceTree = ' + XCodeTypeElements[files["extention"]][2] + '; };\n'
|
||||
else:
|
||||
data +=' ' + convert_folder_in_base_id(files["declare-name"], group) + ' = {'
|
||||
data +=' isa = PBXBuildFile;'
|
||||
#data +=' lastKnownFileType = ' + XCodeTypeElements[files["extention"]][0] + ';'
|
||||
data +=' path = ' + files["path"] + ';'
|
||||
data +=' name = ' + files["name"] + ';'
|
||||
data +=' sourceTree = "<group>"; };\n'
|
||||
|
||||
data +='/* End PBXFileReference section */\n'
|
||||
data +='\n'
|
||||
data +='/* Begin PBXFrameworksBuildPhase section */\n'
|
||||
|
||||
data +=' ' + convert_folder_in_base_id("?Frameworks?", self.name) + ' /* Frameworks */ = {\n'
|
||||
data +=' isa = PBXFrameworksBuildPhase;\n'
|
||||
data +=' buildActionMask = 2147483647;\n'
|
||||
data +=' files = (\n'
|
||||
for group in self.groups:
|
||||
element = self.groups[group]
|
||||
for files in element["list-files"]:
|
||||
if files["extention"] not in XCodeTypeElements.keys():
|
||||
continue
|
||||
if XCodeTypeElements[files["extention"]][1] == "PBXFrameworksBuildPhase":
|
||||
data +=' ' + convert_folder_in_base_id(files["declare-name"] + '_PBXBuildFile', group)
|
||||
data +=' /* ' + files["name"] + ' in ' + group + '*/,\n'
|
||||
data +=' );\n'
|
||||
data +=' runOnlyForDeploymentPostprocessing = 0;\n'
|
||||
data +=' };\n'
|
||||
|
||||
data +='/* End PBXFrameworksBuildPhase section */\n'
|
||||
data +='\n'
|
||||
data +='/* Begin PBXGroup section */\n'
|
||||
|
||||
data +=' ' + convert_folder_in_base_id("?mainTreeGroup?", self.name) + ' = {\n'
|
||||
data +=' isa = PBXGroup;\n'
|
||||
data +=' children = (\n'
|
||||
for group in self.groups:
|
||||
data +=' ' + convert_folder_in_base_id("?tree?", group) + ' /* ' + group + ' */,\n'
|
||||
data +=' ' + convert_folder_in_base_id("?tree?", "Products") + ' /* Products */,\n'
|
||||
data +=' );\n'
|
||||
data +=' sourceTree = "<group>";\n'
|
||||
data +=' };\n'
|
||||
data +=' ' + convert_folder_in_base_id("?tree?", "Products") + ' /* Products */ = {\n'
|
||||
data +=' isa = PBXGroup;\n'
|
||||
data +=' children = (\n'
|
||||
data +=' ' + convert_folder_in_base_id("?app?", self.name) + ' /* ' + self.name + '.app */,\n'
|
||||
data +=' );\n'
|
||||
data +=' name = Products;\n'
|
||||
data +=' sourceTree = "<group>";\n'
|
||||
data +=' };\n'
|
||||
# treeview :
|
||||
for group in self.groups:
|
||||
element = self.groups[group]
|
||||
main_dict = defaultdict(dict, ((FILE_MARKER, []),))
|
||||
for line in element["list-files"]:
|
||||
attach(line["declare-name"], main_dict)
|
||||
#prettify(main_dict);
|
||||
data += generate_tree(main_dict, group)
|
||||
|
||||
data +='/* End PBXGroup section */\n'
|
||||
data +='\n'
|
||||
data +='/* Begin PBXNativeTarget section */\n'
|
||||
|
||||
data +=' ' + convert_folder_in_base_id("?PBXNativeTarget?sectio", self.name) + ' /* edn */ = {\n'
|
||||
data +=' isa = PBXNativeTarget;\n'
|
||||
data +=' buildConfigurationList = ' + convert_folder_in_base_id("?PBXNativeTarget?", self.name) + ' /* Build configuration list for PBXNativeTarget "edn" */;\n'
|
||||
data +=' buildPhases = (\n'
|
||||
data +=' FFBA2F71187F44AE0034CC66 /* Sources */,\n'
|
||||
data +=' ' + convert_folder_in_base_id("?Frameworks?", self.name) + ' /* Frameworks */,\n'
|
||||
data +=' ' + convert_folder_in_base_id("?Resources?", self.name) + ' /* Resources */,\n'
|
||||
data +=' );\n'
|
||||
data +=' buildRules = (\n'
|
||||
data +=' );\n'
|
||||
data +=' dependencies = (\n'
|
||||
data +=' );\n'
|
||||
data +=' name = edn;\n'
|
||||
data +=' productName = edn;\n'
|
||||
data +=' productReference = ' + convert_folder_in_base_id("?app?", self.name) + ' /* ' + self.name + '.app */;\n'
|
||||
data +=' productType = "com.apple.product-type.application";\n'
|
||||
data +=' };\n'
|
||||
|
||||
data +='/* End PBXNativeTarget section */\n'
|
||||
data +='\n'
|
||||
data +='/* Begin PBXProject section */\n'
|
||||
|
||||
data +=' ' + convert_folder_in_base_id("?Project-object?", self.name) + ' /* Project object */ = {\n'
|
||||
data +=' isa = PBXProject;\n'
|
||||
data +=' attributes = {\n'
|
||||
data +=' LastUpgradeCheck = 0500;\n'
|
||||
data +=' ORGANIZATIONNAME = "Edouard DUPIN";\n'
|
||||
data +=' TargetAttributes = {\n'
|
||||
data +=' ' + convert_folder_in_base_id("?Project-object?targetAttribute", self.name) + ' = {\n'
|
||||
data +=' TestTargetID = ' + convert_folder_in_base_id("?PBXNativeTarget?sectio", self.name) + ';\n'
|
||||
data +=' };\n'
|
||||
data +=' };\n'
|
||||
data +=' };\n'
|
||||
data +=' buildConfigurationList = ' + convert_folder_in_base_id("?PBXProject?", self.name) + ' /* Build configuration list for PBXProject "edn" */;\n'
|
||||
data +=' compatibilityVersion = "Xcode 3.2";\n'
|
||||
data +=' developmentRegion = English;\n'
|
||||
data +=' hasScannedForEncodings = 0;\n'
|
||||
data +=' knownRegions = (\n'
|
||||
data +=' en,\n'
|
||||
data +=' Base,\n'
|
||||
data +=' );\n'
|
||||
data +=' mainGroup = ' + convert_folder_in_base_id("?mainTreeGroup?", self.name) + ';\n'
|
||||
data +=' productRefGroup = ' + convert_folder_in_base_id("?tree?", "Products") + ' /* Products */;\n'
|
||||
data +=' projectDirPath = "";\n'
|
||||
data +=' projectRoot = "";\n'
|
||||
data +=' targets = (\n'
|
||||
data +=' ' + convert_folder_in_base_id("?PBXNativeTarget?sectio", self.name) + ' /* edn */,\n'
|
||||
data +=' );\n'
|
||||
data +=' };\n'
|
||||
data +='/* End PBXProject section */\n'
|
||||
data +='\n'
|
||||
data +='/* Begin PBXResourcesBuildPhase section */\n'
|
||||
|
||||
data +=' ' + convert_folder_in_base_id("?Resources?", self.name) + ' /* Resources */ = {\n'
|
||||
data +=' isa = PBXResourcesBuildPhase;\n'
|
||||
data +=' buildActionMask = 2147483647;\n'
|
||||
data +=' files = (\n'
|
||||
# list of all resources to copy
|
||||
for group in self.groups:
|
||||
element = self.groups[group]
|
||||
for files in element["list-files"]:
|
||||
if files["extention"] in XCodeTypeElements.keys():
|
||||
if XCodeTypeElements[files["extention"]][1] == "PBXResourcesBuildPhase":
|
||||
data +=' ' + convert_folder_in_base_id(files["declare-name"] + '_PBXBuildFile', group) + ' = {'
|
||||
data +=' /* ' + files["name"] + ' in ' + group + ' */'
|
||||
data +=' ,\n'
|
||||
data +=' );\n'
|
||||
data +=' runOnlyForDeploymentPostprocessing = 0;\n'
|
||||
data +=' };\n'
|
||||
|
||||
data +='/* End PBXResourcesBuildPhase section */\n'
|
||||
data +='\n'
|
||||
data +='/* Begin PBXSourcesBuildPhase section */\n'
|
||||
|
||||
data +=' FFBA2F71187F44AE0034CC66 /* Sources */ = {\n'
|
||||
data +=' isa = PBXSourcesBuildPhase;\n'
|
||||
data +=' buildActionMask = 2147483647;\n'
|
||||
data +=' files = (\n'
|
||||
# list of all file to compile ...
|
||||
# TODO : review this ==> generate to many files ...
|
||||
for group in self.groups:
|
||||
element = self.groups[group]
|
||||
for files in element["list-files"]:
|
||||
if files["extention"] not in XCodeTypeElements.keys():
|
||||
continue
|
||||
if XCodeTypeElements[files["extention"]][1] == "PBXSourcesBuildPhase":
|
||||
data +=' ' + convert_folder_in_base_id(files["declare-name"] + '_PBXBuildFile', group)
|
||||
data +=' /* ' + group + " : " + files["name"] + ' */,\n'
|
||||
data +=' );\n'
|
||||
data +=' runOnlyForDeploymentPostprocessing = 0;\n'
|
||||
data +=' };\n'
|
||||
|
||||
data +='/* End PBXSourcesBuildPhase section */\n'
|
||||
data +='\n'
|
||||
data +='/* Begin PBXTargetDependency section */\n'
|
||||
# nothing ...
|
||||
data +='/* End PBXTargetDependency section */\n'
|
||||
data +='\n'
|
||||
data +='/* Begin PBXVariantGroup section */\n'
|
||||
# not really needed, because it is for internal system data position ==> maybe change it if necessary ...
|
||||
"""
|
||||
for group in self.groups:
|
||||
element = self.groups[group]
|
||||
for files in element["list-files"]:
|
||||
if files["extention"] not in XCodeTypeElements.keys():
|
||||
continue
|
||||
if XCodeTypeElements[files["extention"]][1] == "PBXSourcesBuildPhase":
|
||||
data +=' ' + convert_folder_in_base_id(files["declare-name"] + '_PBXBuildFile', group)
|
||||
"""
|
||||
|
||||
"""
|
||||
data +=' FFBA2F85187F44AE0034CC66 /* InfoPlist.strings */ = {\n'
|
||||
data +=' isa = PBXVariantGroup;\n'
|
||||
data +=' children = (\n'
|
||||
data +=' FFBA2F86187F44AE0034CC66 /* en */,\n'
|
||||
data +=' );\n'
|
||||
data +=' name = InfoPlist.strings;\n'
|
||||
data +=' sourceTree = "<group>";\n'
|
||||
data +=' };\n'
|
||||
data +=' FFBA2F8E187F44AE0034CC66 /* Main_iPhone.storyboard */ = {\n'
|
||||
data +=' isa = PBXVariantGroup;\n'
|
||||
data +=' children = (\n'
|
||||
data +=' FFBA2F8F187F44AE0034CC66 /* Base */,\n'
|
||||
data +=' );\n'
|
||||
data +=' name = Main_iPhone.storyboard;\n'
|
||||
data +=' sourceTree = "<group>";\n'
|
||||
data +=' };\n'
|
||||
data +=' FFBA2F91187F44AE0034CC66 /* Main_iPad.storyboard */ = {\n'
|
||||
data +=' isa = PBXVariantGroup;\n'
|
||||
data +=' children = (\n'
|
||||
data +=' FFBA2F92187F44AE0034CC66 /* Base */,\n'
|
||||
data +=' );\n'
|
||||
data +=' name = Main_iPad.storyboard;\n'
|
||||
data +=' sourceTree = "<group>";\n'
|
||||
data +=' };\n'
|
||||
data +=' FFBA2FAB187F44AF0034CC66 /* InfoPlist.strings */ = {\n'
|
||||
data +=' isa = PBXVariantGroup;\n'
|
||||
data +=' children = (\n'
|
||||
data +=' FFBA2FAC187F44AF0034CC66 /* en */,\n'
|
||||
data +=' );\n'
|
||||
data +=' name = InfoPlist.strings;\n'
|
||||
data +=' sourceTree = "<group>";\n'
|
||||
data +=' };\n'
|
||||
"""
|
||||
data +='/* End PBXVariantGroup section */\n'
|
||||
data +='\n'
|
||||
data +='/* Begin XCBuildConfiguration section */\n'
|
||||
data +=' ' + convert_folder_in_base_id("?PBXProject?Debug", self.name) + ' /* Debug */ = {\n'
|
||||
data +=' isa = XCBuildConfiguration;\n'
|
||||
data +=' buildSettings = {\n'
|
||||
data +=' ALWAYS_SEARCH_USER_PATHS = NO;\n'
|
||||
data +=' ARCHS = "$(ARCHS_STANDARD_INCLUDING_64_BIT)";\n'
|
||||
data +=' CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";\n'
|
||||
data +=' CLANG_CXX_LIBRARY = "libc++";\n'
|
||||
data +=' CLANG_ENABLE_MODULES = YES;\n'
|
||||
data +=' CLANG_ENABLE_OBJC_ARC = YES;\n'
|
||||
data +=' CLANG_WARN_BOOL_CONVERSION = YES;\n'
|
||||
data +=' CLANG_WARN_CONSTANT_CONVERSION = YES;\n'
|
||||
data +=' CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;\n'
|
||||
data +=' CLANG_WARN_EMPTY_BODY = YES;\n'
|
||||
data +=' CLANG_WARN_ENUM_CONVERSION = YES;\n'
|
||||
data +=' CLANG_WARN_INT_CONVERSION = YES;\n'
|
||||
data +=' CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;\n'
|
||||
data +=' CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;\n'
|
||||
data +=' "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";\n'
|
||||
data +=' COPY_PHASE_STRIP = NO;\n'
|
||||
data +=' GCC_C_LANGUAGE_STANDARD = gnu99;\n'
|
||||
data +=' GCC_DYNAMIC_NO_PIC = NO;\n'
|
||||
data +=' GCC_OPTIMIZATION_LEVEL = 0;\n'
|
||||
data +=' GCC_PREPROCESSOR_DEFINITIONS = (\n'
|
||||
data +=' "DEBUG=1",\n'
|
||||
data +=' "$(inherited)",\n'
|
||||
data +=' );\n'
|
||||
data +=' GCC_SYMBOLS_PRIVATE_EXTERN = NO;\n'
|
||||
data +=' GCC_WARN_64_TO_32_BIT_CONVERSION = YES;\n'
|
||||
data +=' GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;\n'
|
||||
data +=' GCC_WARN_UNDECLARED_SELECTOR = YES;\n'
|
||||
data +=' GCC_WARN_UNINITIALIZED_AUTOS = YES;\n'
|
||||
data +=' GCC_WARN_UNUSED_FUNCTION = YES;\n'
|
||||
data +=' GCC_WARN_UNUSED_VARIABLE = YES;\n'
|
||||
data +=' IPHONEOS_DEPLOYMENT_TARGET = 7.0;\n'
|
||||
data +=' ONLY_ACTIVE_ARCH = YES;\n'
|
||||
data +=' SDKROOT = iphoneos;\n'
|
||||
data +=' TARGETED_DEVICE_FAMILY = "1,2";\n'
|
||||
data +=' };\n'
|
||||
data +=' name = Debug;\n'
|
||||
data +=' };\n'
|
||||
data +=' ' + convert_folder_in_base_id("?PBXProject?Release", self.name) + ' /* Release */ = {\n'
|
||||
data +=' isa = XCBuildConfiguration;\n'
|
||||
data +=' buildSettings = {\n'
|
||||
data +=' ALWAYS_SEARCH_USER_PATHS = NO;\n'
|
||||
data +=' ARCHS = "$(ARCHS_STANDARD_INCLUDING_64_BIT)";\n'
|
||||
data +=' CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";\n'
|
||||
data +=' CLANG_CXX_LIBRARY = "libc++";\n'
|
||||
data +=' CLANG_ENABLE_MODULES = YES;\n'
|
||||
data +=' CLANG_ENABLE_OBJC_ARC = YES;\n'
|
||||
data +=' CLANG_WARN_BOOL_CONVERSION = YES;\n'
|
||||
data +=' CLANG_WARN_CONSTANT_CONVERSION = YES;\n'
|
||||
data +=' CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;\n'
|
||||
data +=' CLANG_WARN_EMPTY_BODY = YES;\n'
|
||||
data +=' CLANG_WARN_ENUM_CONVERSION = YES;\n'
|
||||
data +=' CLANG_WARN_INT_CONVERSION = YES;\n'
|
||||
data +=' CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;\n'
|
||||
data +=' CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;\n'
|
||||
data +=' "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";\n'
|
||||
data +=' COPY_PHASE_STRIP = YES;\n'
|
||||
data +=' ENABLE_NS_ASSERTIONS = NO;\n'
|
||||
data +=' GCC_C_LANGUAGE_STANDARD = gnu99;\n'
|
||||
data +=' GCC_WARN_64_TO_32_BIT_CONVERSION = YES;\n'
|
||||
data +=' GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;\n'
|
||||
data +=' GCC_WARN_UNDECLARED_SELECTOR = YES;\n'
|
||||
data +=' GCC_WARN_UNINITIALIZED_AUTOS = YES;\n'
|
||||
data +=' GCC_WARN_UNUSED_FUNCTION = YES;\n'
|
||||
data +=' GCC_WARN_UNUSED_VARIABLE = YES;\n'
|
||||
data +=' IPHONEOS_DEPLOYMENT_TARGET = 7.0;\n'
|
||||
data +=' SDKROOT = iphoneos;\n'
|
||||
data +=' TARGETED_DEVICE_FAMILY = "1,2";\n'
|
||||
data +=' VALIDATE_PRODUCT = YES;\n'
|
||||
data +=' };\n'
|
||||
data +=' name = Release;\n'
|
||||
data +=' };\n'
|
||||
data +=' ' + convert_folder_in_base_id("?PBXNativeTarget?Debug", self.name) + ' /* Debug */ = {\n'
|
||||
data +=' isa = XCBuildConfiguration;\n'
|
||||
data +=' buildSettings = {\n'
|
||||
data +=' ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;\n'
|
||||
data +=' ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage;\n'
|
||||
data +=' GCC_PRECOMPILE_PREFIX_HEADER = YES;\n'
|
||||
data +=' GCC_PREFIX_HEADER = "edn/edn-Prefix.pch";\n'
|
||||
data +=' INFOPLIST_FILE = "edn/edn-Info.plist";\n'
|
||||
data +=' PRODUCT_NAME = "$(TARGET_NAME)";\n'
|
||||
data +=' WRAPPER_EXTENSION = app;\n'
|
||||
data +=' };\n'
|
||||
data +=' name = Debug;\n'
|
||||
data +=' };\n'
|
||||
data +=' ' + convert_folder_in_base_id("?PBXNativeTarget?Release", self.name) + ' /* Release */ = {\n'
|
||||
data +=' isa = XCBuildConfiguration;\n'
|
||||
data +=' buildSettings = {\n'
|
||||
data +=' ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;\n'
|
||||
data +=' ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage;\n'
|
||||
data +=' GCC_PRECOMPILE_PREFIX_HEADER = YES;\n'
|
||||
data +=' GCC_PREFIX_HEADER = "edn/edn-Prefix.pch";\n'
|
||||
data +=' INFOPLIST_FILE = "edn/edn-Info.plist";\n'
|
||||
data +=' PRODUCT_NAME = "$(TARGET_NAME)";\n'
|
||||
data +=' WRAPPER_EXTENSION = app;\n'
|
||||
data +=' };\n'
|
||||
data +=' name = Release;\n'
|
||||
data +=' };\n'
|
||||
|
||||
data += '/* End XCBuildConfiguration section */\n'
|
||||
data += '\n'
|
||||
data += '/* Begin XCConfigurationList section */\n'
|
||||
|
||||
data +=' ' + convert_folder_in_base_id("?PBXProject?", self.name) + ' /* Build configuration list for PBXProject "' + self.name + '" */ = {\n'
|
||||
data +=' isa = XCConfigurationList;\n'
|
||||
data +=' buildConfigurations = (\n'
|
||||
data +=' ' + convert_folder_in_base_id("?PBXProject?Debug", self.name) + ' /* Debug */,\n'
|
||||
data +=' ' + convert_folder_in_base_id("?PBXProject?Release", self.name) + ' /* Release */,\n'
|
||||
data +=' );\n'
|
||||
data +=' defaultConfigurationIsVisible = 0;\n'
|
||||
data +=' defaultConfigurationName = Release;\n'
|
||||
data +=' };\n'
|
||||
data +=' ' + convert_folder_in_base_id("?PBXNativeTarget?", self.name) + ' /* Build configuration list for PBXNativeTarget "PBXNativeTarget" */ = {\n'
|
||||
data +=' isa = XCConfigurationList;\n'
|
||||
data +=' buildConfigurations = (\n'
|
||||
data +=' ' + convert_folder_in_base_id("?PBXNativeTarget?Debug", self.name) + ' /* Debug */,\n'
|
||||
data +=' ' + convert_folder_in_base_id("?PBXNativeTarget?Release", self.name) + ' /* Release */,\n'
|
||||
data +=' );\n'
|
||||
data +=' defaultConfigurationIsVisible = 0;\n'
|
||||
data +=' };\n'
|
||||
data +='/* End XCConfigurationList section */\n'
|
||||
data +=' };\n'
|
||||
data +=' rootObject = ' + convert_folder_in_base_id("?PBXProject?", self.name) + ' /* Project object */;\n'
|
||||
data +='}\n'
|
||||
|
||||
#debug.info(data)
|
||||
|
||||
outName = 'out/iOs/' + self.name + '.xcodeproj/project.pbxproj'
|
||||
tools.create_directory_of_file(outName)
|
||||
tools.file_write_data(outName, data)
|
||||
# TODO : Generate all dependency files ...
|
||||
"""
|
||||
# this is a file generated by xcode for his internal properties ...
|
||||
# create workspace file:
|
||||
data = '<?xml version="1.0" encoding="UTF-8"?>\n'
|
||||
data += '<Workspace\n'
|
||||
data += ' version = "1.0">\n'
|
||||
data += ' <FileRef\n'
|
||||
data += ' location = "self:' + self.name + '.xcodeproj">\n'
|
||||
data += ' </FileRef>\n'
|
||||
data += '</Workspace>\n'
|
||||
|
||||
outName = 'out/iOs/' + self.name + '.xcodeproj/project.xcworkspace/contents.xcworkspacedata'
|
||||
tools.create_directory_of_file(outName)
|
||||
tools.file_write_data(outName, data)
|
||||
"""
|
||||
|
||||
|
||||
|
@ -13,7 +13,6 @@ import lutinTools
|
||||
import lutinImage
|
||||
import os
|
||||
import stat
|
||||
import lutinExtProjectGeneratorXCode
|
||||
import lutinMultiprocess
|
||||
import lutinHost
|
||||
import random
|
||||
@ -75,9 +74,6 @@ class Target(lutinTarget.Target):
|
||||
|
||||
self.global_flags_m.append("-fobjc-arc")
|
||||
#self.global_flags_m.append("-fmodules")
|
||||
|
||||
#add a project generator:
|
||||
self.externProjectManager = lutinExtProjectGeneratorXCode.ExtProjectGeneratorXCode()
|
||||
|
||||
def get_staging_folder(self, binaryName):
|
||||
return lutinTools.get_run_folder() + self.folder_out + self.folder_staging + "/" + binaryName + ".app/"
|
||||
|
@ -66,7 +66,7 @@ class Target(lutinTarget.Target):
|
||||
tmpFile.write(" <string>"+pkgName+"</string>\n")
|
||||
tmpFile.write(" <key>CFBundleIdentifier</key>\n")
|
||||
tmpFile.write(" <string>" + pkgProperties["COMPAGNY_TYPE"] + "." + pkgProperties["COMPAGNY_NAME2"] + "." + pkgName + "</string>\n")
|
||||
tmpFile.write(" <key>CFBundleSignature</key>\n")
|
||||
tmpFile.write(" <key>CFBundleSignature</key>\n")
|
||||
tmpFile.write(" <string>????</string>\n")
|
||||
tmpFile.write(" <key>CFBundleIconFile</key>\n")
|
||||
tmpFile.write(" <string>icon.icns</string>\n")
|
||||
|
1403
xcodeprojExporter.py
1403
xcodeprojExporter.py
File diff suppressed because it is too large
Load Diff
Loading…
x
Reference in New Issue
Block a user