3 # ***** BEGIN GPL LICENSE BLOCK *****
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.
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.
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19 # Contributor(s): Campbell Barton, M.G. Kishalmi
21 # ***** END GPL LICENSE BLOCK *****
27 python3 ~/blender-git/blender/build_files/cmake/cmake_netbeans_project.py ~/blender-git/cmake
29 Windows not supported so far
34 # until we have arg parsing
36 if not project_info.init(sys.argv[-1]):
39 from project_info import (
49 cmake_compiler_defines,
56 from os.path import join, dirname, normpath, relpath, exists
59 def create_nb_project_main():
60 from xml.sax.saxutils import escape
62 files = list(source_list(SOURCE_DIR, filename_check=is_project_file))
63 files_rel = [relpath(f, start=PROJECT_DIR) for f in files]
66 if SIMPLE_PROJECTFILE:
69 includes, defines = cmake_advanced_info()
71 if (includes, defines) == (None, None):
74 # for some reason it doesnt give all internal includes
75 includes = list(set(includes) | set(dirname(f) for f in files if is_c_header(f)))
79 PROJECT_NAME = "Blender"
81 # be tricky, get the project name from git if we can!
82 PROJECT_NAME = project_name_get()
84 make_exe = cmake_cache_var("CMAKE_MAKE_PROGRAM")
85 make_exe_basename = os.path.basename(make_exe)
87 # --------------- NB spesific
88 defines = [("%s=%s" % cdef) if cdef[1] else cdef[0] for cdef in defines]
89 defines += [cdef.replace("#define", "").strip() for cdef in cmake_compiler_defines()]
91 def file_list_to_nested(files):
92 # convert paths to hierarchy
95 def ensure_path(filepath):
96 filepath_split = filepath.split(os.sep)
99 for subdir in filepath_split[:-1]:
100 pn = pn.setdefault(subdir, {})
101 pn[filepath_split[-1]] = None
107 PROJECT_DIR_NB = join(PROJECT_DIR, "nbproject")
108 if not exists(PROJECT_DIR_NB):
109 os.mkdir(PROJECT_DIR_NB)
111 # SOURCE_DIR_REL = relpath(SOURCE_DIR, PROJECT_DIR)
113 f = open(join(PROJECT_DIR_NB, "project.xml"), 'w')
115 f.write('<?xml version="1.0" encoding="UTF-8"?>\n')
116 f.write('<project xmlns="http://www.netbeans.org/ns/project/1">\n')
117 f.write(' <type>org.netbeans.modules.cnd.makeproject</type>\n')
118 f.write(' <configuration>\n')
119 f.write(' <data xmlns="http://www.netbeans.org/ns/make-project/1">\n')
120 f.write(' <name>%s</name>\n' % PROJECT_NAME)
121 f.write(' <c-extensions>c,m</c-extensions>\n')
122 f.write(' <cpp-extensions>cpp,cxx,cc,mm</cpp-extensions>\n')
123 f.write(' <header-extensions>h,hxx,hh,hpp,inl</header-extensions>\n')
124 f.write(' <sourceEncoding>UTF-8</sourceEncoding>\n')
125 f.write(' <make-dep-projects/>\n')
126 f.write(' <sourceRootList>\n')
127 f.write(' <sourceRootElem>%s</sourceRootElem>\n' % SOURCE_DIR) # base_root_rel
128 f.write(' </sourceRootList>\n')
129 f.write(' <confList>\n')
130 f.write(' <confElem>\n')
131 f.write(' <name>Default</name>\n')
132 f.write(' <type>0</type>\n')
133 f.write(' </confElem>\n')
134 f.write(' </confList>\n')
135 f.write(' <formatting>\n')
136 f.write(' <project-formatting-style>false</project-formatting-style>\n')
137 f.write(' </formatting>\n')
138 f.write(' </data>\n')
139 f.write(' </configuration>\n')
140 f.write('</project>\n')
144 f = open(join(PROJECT_DIR_NB, "configurations.xml"), 'w')
146 f.write('<?xml version="1.0" encoding="UTF-8"?>\n')
147 f.write('<configurationDescriptor version="95">\n')
148 f.write(' <logicalFolder name="root" displayName="root" projectFiles="true" kind="ROOT">\n')
149 f.write(' <df root="%s" name="0">\n' % SOURCE_DIR) # base_root_rel
152 files_rel_local = [normpath(relpath(join(CMAKE_DIR, path), SOURCE_DIR)) for path in files_rel]
153 files_rel_hierarchy = file_list_to_nested(files_rel_local)
154 # print(files_rel_hierarchy)
156 def write_df(hdir, ident):
159 for key, item in sorted(hdir.items()):
163 dirs.append((key, item))
165 for key, item in dirs:
166 f.write('%s <df name="%s">\n' % (ident, key))
167 write_df(item, ident + " ")
168 f.write('%s </df>\n' % ident)
171 f.write('%s<in>%s</in>\n' % (ident, key))
173 write_df(files_rel_hierarchy, ident=" ")
177 f.write(' <logicalFolder name="ExternalFiles"\n')
178 f.write(' displayName="Important Files"\n')
179 f.write(' projectFiles="false"\n')
180 f.write(' kind="IMPORTANT_FILES_FOLDER">\n')
181 # f.write(' <itemPath>../GNUmakefile</itemPath>\n')
182 f.write(' </logicalFolder>\n')
184 f.write(' </logicalFolder>\n')
185 # default, but this dir is infact not in blender dir so we can ignore it
186 # f.write(' <sourceFolderFilter>^(nbproject)$</sourceFolderFilter>\n')
187 f.write(' <sourceFolderFilter>^(nbproject|__pycache__|.*\.py|.*\.html|.*\.blend)$</sourceFolderFilter>\n')
189 f.write(' <sourceRootList>\n')
190 f.write(' <Elem>%s</Elem>\n' % SOURCE_DIR) # base_root_rel
191 f.write(' </sourceRootList>\n')
193 f.write(' <projectmakefile>Makefile</projectmakefile>\n')
196 f.write(' <confs>\n')
197 f.write(' <conf name="Default" type="0">\n')
199 f.write(' <toolsSet>\n')
200 f.write(' <compilerSet>default</compilerSet>\n')
201 f.write(' <dependencyChecking>false</dependencyChecking>\n')
202 f.write(' <rebuildPropChanged>false</rebuildPropChanged>\n')
203 f.write(' </toolsSet>\n')
204 f.write(' <codeAssistance>\n')
205 f.write(' </codeAssistance>\n')
206 f.write(' <makefileType>\n')
208 f.write(' <makeTool>\n')
209 f.write(' <buildCommandWorkingDir>.</buildCommandWorkingDir>\n')
211 if make_exe_basename == "ninja":
213 clean_cmd = "ninja -t clean"
215 build_cmd = "${MAKE} -f Makefile"
216 clean_cmd = "${MAKE} -f Makefile clean"
218 f.write(' <buildCommand>%s</buildCommand>\n' % escape(build_cmd))
219 f.write(' <cleanCommand>%s</cleanCommand>\n' % escape(clean_cmd))
220 f.write(' <executablePath>./bin/blender</executablePath>\n')
221 del build_cmd, clean_cmd
223 def write_toolinfo():
224 f.write(' <incDir>\n')
226 f.write(' <pElem>%s</pElem>\n' % inc)
227 f.write(' </incDir>\n')
228 f.write(' <preprocessorList>\n')
230 f.write(' <Elem>%s</Elem>\n' % escape(cdef))
231 f.write(' </preprocessorList>\n')
233 f.write(' <cTool>\n')
235 f.write(' </cTool>\n')
237 f.write(' <ccTool>\n')
239 f.write(' </ccTool>\n')
241 f.write(' </makeTool>\n')
242 f.write(' </makefileType>\n')
243 # finishe makefle info
247 for path in files_rel_local:
248 is_c = path.endswith(".c")
249 f.write(' <item path="%s"\n' % path)
250 f.write(' ex="false"\n')
251 f.write(' tool="%d"\n' % (0 if is_c else 1))
252 f.write(' flavor2="%d">\n' % (3 if is_c else 0))
253 f.write(' </item>\n')
255 f.write(' <runprofile version="9">\n')
256 f.write(' <runcommandpicklist>\n')
257 f.write(' </runcommandpicklist>\n')
258 f.write(' <runcommand>%s</runcommand>\n' % os.path.join(CMAKE_DIR, "bin/blender"))
259 f.write(' <rundir>%s</rundir>\n' % SOURCE_DIR)
260 f.write(' <buildfirst>false</buildfirst>\n')
261 f.write(' <terminal-type>0</terminal-type>\n')
262 f.write(' <remove-instrumentation>0</remove-instrumentation>\n')
263 f.write(' <environment>\n')
264 f.write(' </environment>\n')
265 f.write(' </runprofile>\n')
267 f.write(' </conf>\n')
268 f.write(' </confs>\n')
272 f.write('</configurationDescriptor>\n')
278 create_nb_project_main()
281 if __name__ == "__main__":