add back datatoc, use this instead of cmake script which was too slow.

This commit is contained in:
Campbell Barton 2012-08-11 16:25:31 +00:00
parent 35ef09372a
commit ca7c07cda9
8 changed files with 172 additions and 50 deletions

@ -496,7 +496,7 @@ def data_to_c_simple(FILE_FROM):
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")

@ -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")

@ -729,19 +729,21 @@ endmacro()
# 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 @@ macro(data_to_c_simple
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()

@ -89,6 +89,7 @@ set(SRC_DNA_INC
${CMAKE_CURRENT_SOURCE_DIR}/makesdna/DNA_mask_types.h
)
add_subdirectory(datatoc)
add_subdirectory(editors)
add_subdirectory(windowmanager)
add_subdirectory(blenkernel)

@ -644,7 +644,6 @@ list(APPEND INC
${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}")

@ -288,7 +288,7 @@ void WorkScheduler::initialize()
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) {

@ -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})

@ -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) {
fprintf(stderr, "Unable to open output <%s>\n", argv[2]);
exit(1);
}
fprintf(fpout, "/* DataToC output of file <%s> */\n\n", argv[1]);
fprintf(fpout, "int datatoc_%s_size = %s;\n", argv[1], sizest);
fprintf(fpout, "char datatoc_%s[] = {\n", argv[1]);
while (size--) {
if (size % 32 == 31) {
fprintf(fpout, "\n");
}
/* fprintf (fpout, "\\x%02x", getc(fpin)); */
fprintf(fpout, "%3d,", getc(fpin));
}
fprintf(fpout, "\n};\n\n");
fclose(fpin);
fclose(fpout);
return 0;
}