[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [49813] trunk/blender: add back datatoc, use this instead of cmake script which was too slow.
Campbell Barton
ideasman42 at gmail.com
Sat Aug 11 18:25:31 CEST 2012
Revision: 49813
http://projects.blender.org/scm/viewvc.php?view=rev&root=bf-blender&revision=49813
Author: campbellbarton
Date: 2012-08-11 16:25:31 +0000 (Sat, 11 Aug 2012)
Log Message:
-----------
add back datatoc, use this instead of cmake script which was too slow.
Modified Paths:
--------------
trunk/blender/SConstruct
trunk/blender/build_files/cmake/macros.cmake
trunk/blender/source/blender/CMakeLists.txt
trunk/blender/source/blender/compositor/CMakeLists.txt
trunk/blender/source/blender/compositor/intern/COM_WorkScheduler.cpp
Added Paths:
-----------
trunk/blender/source/blender/datatoc/
trunk/blender/source/blender/datatoc/CMakeLists.txt
trunk/blender/source/blender/datatoc/datatoc.c
Removed Paths:
-------------
trunk/blender/build_files/cmake/data_to_c.cmake
Modified: trunk/blender/SConstruct
===================================================================
--- trunk/blender/SConstruct 2012-08-11 16:20:30 UTC (rev 49812)
+++ trunk/blender/SConstruct 2012-08-11 16:25:31 UTC (rev 49813)
@@ -496,7 +496,7 @@
data_to_c("source/blender/compositor/operations/COM_OpenCLKernels.cl",
B.root_build_dir + "data_headers/COM_OpenCLKernels.cl.h",
- "clkernelstoh_COM_OpenCLKernels_cl")
+ "datatoc_COM_OpenCLKernels_cl")
data_to_c_simple("release/datafiles/startup.blend")
data_to_c_simple("release/datafiles/preview.blend")
Deleted: trunk/blender/build_files/cmake/data_to_c.cmake
===================================================================
--- trunk/blender/build_files/cmake/data_to_c.cmake 2012-08-11 16:20:30 UTC (rev 49812)
+++ trunk/blender/build_files/cmake/data_to_c.cmake 2012-08-11 16:25:31 UTC (rev 49813)
@@ -1,25 +0,0 @@
-# cmake script, to be called on its own with 3 defined args
-#
-# - FILE_FROM
-# - FILE_TO
-# - VAR_NAME
-
-# not highly optimal, may replace with generated C program like makesdna
-file(READ ${FILE_FROM} file_from_string HEX)
-string(LENGTH ${file_from_string} _max_index)
-math(EXPR size_on_disk ${_max_index}/2)
-
-file(REMOVE ${FILE_TO})
-
-file(APPEND ${FILE_TO} "int ${VAR_NAME}_size = ${size_on_disk};\n")
-file(APPEND ${FILE_TO} "char ${VAR_NAME}[] = {")
-
-set(_index 0)
-
-while(NOT _index EQUAL _max_index)
- string(SUBSTRING "${file_from_string}" ${_index} 2 _pair)
- file(APPEND ${FILE_TO} "0x${_pair},")
- math(EXPR _index ${_index}+2)
-endwhile()
-# null terminator not essential but good if we want plane strings encoded
-file(APPEND ${FILE_TO} "0x00};\n")
Modified: trunk/blender/build_files/cmake/macros.cmake
===================================================================
--- trunk/blender/build_files/cmake/macros.cmake 2012-08-11 16:20:30 UTC (rev 49812)
+++ trunk/blender/build_files/cmake/macros.cmake 2012-08-11 16:25:31 UTC (rev 49813)
@@ -729,19 +729,21 @@
# TODO, create a C binary and call it instead!, doing this in cmake its slow
macro(data_to_c
- file_from file_to var_name
+ file_from file_to
list_to_add)
list(APPEND ${list_to_add} ${file_to})
+ get_filename_component(_file_to_path ${file_to} PATH)
+
add_custom_command(
OUTPUT ${file_to}
- COMMAND ${CMAKE_COMMAND}
- -DFILE_FROM=${file_from}
- -DFILE_TO=${file_to}
- -DVAR_NAME=${var_name}
- -P ${CMAKE_SOURCE_DIR}/build_files/cmake/data_to_c.cmake
+ COMMAND ${CMAKE_COMMAND} -E make_directory ${_file_to_path}
+ COMMAND ${CMAKE_BINARY_DIR}/bin/${CMAKE_CFG_INTDIR}/datatoc
+ ${file_from}
+ ${file_to}
DEPENDS ${file_from})
+ unset(_file_to_path)
endmacro()
# same as above but generates the var name and output automatic.
@@ -749,26 +751,22 @@
file_from
list_to_add)
- # get var name automatic from name
- get_filename_component(_file_from_only ${file_from} NAME)
- string(REPLACE "." "_" _file_from_only ${_file_from_only})
- set(_var_name "datatoc_${_file_from_only}")
+ # only to avoid confusion
+ set(_file_to ${file_from}.c)
- # only to avoid confusion
- set(_file_to ${file_from}.c)
-
list(APPEND ${list_to_add} ${CMAKE_CURRENT_BINARY_DIR}/${_file_to})
+ get_filename_component(_file_to_path ${_file_to} PATH)
+
add_custom_command(
OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${_file_to}
- COMMAND ${CMAKE_COMMAND}
- -DFILE_FROM=${CMAKE_CURRENT_SOURCE_DIR}/${file_from}
- -DFILE_TO=${CMAKE_CURRENT_BINARY_DIR}/${_file_to}
- -DVAR_NAME=${_var_name}
- -P ${CMAKE_SOURCE_DIR}/build_files/cmake/data_to_c.cmake
+ COMMAND ${CMAKE_COMMAND} -E make_directory ${_file_to_path}
+ COMMAND ${CMAKE_BINARY_DIR}/bin/${CMAKE_CFG_INTDIR}/datatoc
+ ${CMAKE_CURRENT_SOURCE_DIR}/${file_from}
+ ${CMAKE_CURRENT_BINARY_DIR}/${_file_to}
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${file_from})
- unset(_file_from_only)
- unset(_var_name)
- unset(_file_to)
+ unset(_var_name)
+ unset(_file_to)
+ unset(_file_to_path)
endmacro()
Modified: trunk/blender/source/blender/CMakeLists.txt
===================================================================
--- trunk/blender/source/blender/CMakeLists.txt 2012-08-11 16:20:30 UTC (rev 49812)
+++ trunk/blender/source/blender/CMakeLists.txt 2012-08-11 16:25:31 UTC (rev 49813)
@@ -89,6 +89,7 @@
${CMAKE_CURRENT_SOURCE_DIR}/makesdna/DNA_mask_types.h
)
+add_subdirectory(datatoc)
add_subdirectory(editors)
add_subdirectory(windowmanager)
add_subdirectory(blenkernel)
Modified: trunk/blender/source/blender/compositor/CMakeLists.txt
===================================================================
--- trunk/blender/source/blender/compositor/CMakeLists.txt 2012-08-11 16:20:30 UTC (rev 49812)
+++ trunk/blender/source/blender/compositor/CMakeLists.txt 2012-08-11 16:25:31 UTC (rev 49813)
@@ -644,7 +644,6 @@
${CMAKE_CURRENT_BINARY_DIR}/operations
)
data_to_c(${CMAKE_CURRENT_SOURCE_DIR}/operations/COM_OpenCLKernels.cl
- ${CMAKE_CURRENT_BINARY_DIR}/operations/COM_OpenCLKernels.cl.h
- clkernelstoh_COM_OpenCLKernels_cl SRC)
+ ${CMAKE_CURRENT_BINARY_DIR}/operations/COM_OpenCLKernels.cl.h SRC)
blender_add_lib(bf_compositor "${SRC}" "${INC}" "${INC_SYS}")
Modified: trunk/blender/source/blender/compositor/intern/COM_WorkScheduler.cpp
===================================================================
--- trunk/blender/source/blender/compositor/intern/COM_WorkScheduler.cpp 2012-08-11 16:20:30 UTC (rev 49812)
+++ trunk/blender/source/blender/compositor/intern/COM_WorkScheduler.cpp 2012-08-11 16:25:31 UTC (rev 49813)
@@ -288,7 +288,7 @@
g_context = clCreateContext(NULL, numberOfDevices, cldevices, clContextError, NULL, &error);
if (error != CL_SUCCESS) { printf("CLERROR[%d]: %s\n", error, clewErrorString(error)); }
- const char *cl_str[2] = {clkernelstoh_COM_OpenCLKernels_cl, NULL};
+ const char *cl_str[2] = {datatoc_COM_OpenCLKernels_cl, NULL};
g_program = clCreateProgramWithSource(g_context, 1, cl_str, 0, &error);
error = clBuildProgram(g_program, numberOfDevices, cldevices, 0, 0, 0);
if (error != CL_SUCCESS) {
Added: trunk/blender/source/blender/datatoc/CMakeLists.txt
===================================================================
--- trunk/blender/source/blender/datatoc/CMakeLists.txt (rev 0)
+++ trunk/blender/source/blender/datatoc/CMakeLists.txt 2012-08-11 16:25:31 UTC (rev 49813)
@@ -0,0 +1,29 @@
+# ***** BEGIN GPL LICENSE BLOCK *****
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public LicenseS
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# Contributor(s): Campbell Barton.
+#
+# ***** END GPL LICENSE BLOCK *****
+
+
+# -----------------------------------------------------------------------------
+# Build makesdna executable
+set(SRC
+ datatoc.c
+)
+
+# SRC_DNA_INC is defined in the parent dir
+add_executable(datatoc ${SRC})
Added: trunk/blender/source/blender/datatoc/datatoc.c
===================================================================
--- trunk/blender/source/blender/datatoc/datatoc.c (rev 0)
+++ trunk/blender/source/blender/datatoc/datatoc.c 2012-08-11 16:25:31 UTC (rev 49813)
@@ -0,0 +1,120 @@
+/*
+ * ***** BEGIN GPL LICENSE BLOCK *****
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ *
+ * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
+ * All rights reserved.
+ *
+ * The Original Code is: all of this file.
+ *
+ * Contributor(s): none yet.
+ *
+ * ***** END GPL LICENSE BLOCK *****
+ */
+
+#include <stdio.h>
+#include <string.h>
+#include <stdlib.h>
+
+/* #define VERBOSE */
+
+#define MAX2(x, y) ( (x) > (y) ? (x) : (y) )
+#define MAX3(x, y, z) MAX2(MAX2((x), (y)), (z) )
+
+static char *basename(char *string)
+{
+ char *lfslash, *lbslash;
+
+ lfslash = strrchr(string, '/');
+ lbslash = strrchr(string, '\\');
+ if (lbslash) lbslash++;
+ if (lfslash) lfslash++;
+
+ return MAX3(string, lfslash, lbslash);
+}
+
+int main(int argc, char **argv)
+{
+ FILE *fpin, *fpout;
+ char sizest[256];
+ long size;
+ int i;
+
+ if (argc < 2) {
+ printf("Usage: datatoc <data_file_from> <data_file_to>\n");
+ exit(1);
+ }
+
+ fpin = fopen(argv[1], "rb");
+ if (!fpin) {
+ printf("Unable to open input <%s>\n", argv[1]);
+ exit(1);
+ }
+
+ argv[1] = basename(argv[1]);
+
+ fseek(fpin, 0L, SEEK_END);
+ size = ftell(fpin);
+ fseek(fpin, 0L, SEEK_SET);
+
+ if (argv[1][0] == '.') argv[1]++;
+
+#ifdef VERBOSE
+ printf("Making C file <%s>\n", argv[2]);
+#endif
+
+ for (i = 0; i < (int)strlen(argv[1]); i++)
+ if (argv[1][i] == '.') argv[1][i] = '_';
+
+ sprintf(sizest, "%d", (int)size);
+
+#ifdef VERBOSE
+ printf("Input filesize is %d, Output size should be %d\n",
+ (int)size,
+ (int)(((int)size) * 4 +
+ strlen("/* DataToC output of file <> */\n\n") +
+ strlen("char datatoc_[] = {\"") +
+ strlen("\"};\n") +
+ (strlen(argv[1]) * 3) +
+ strlen(sizest) +
+ strlen("int datatoc__size = ;\n") +
+ (((int)(size / 256) + 1) * 5)));
+#endif
+
+ fpout = fopen(argv[2], "w");
+ if (!fpout) {
@@ Diff output truncated at 10240 characters. @@
More information about the Bf-blender-cvs
mailing list