Filling in branch from trunk
This commit is contained in:
81
CMake/macros.cmake
Normal file
81
CMake/macros.cmake
Normal file
@@ -0,0 +1,81 @@
|
|||||||
|
MACRO(BLENDERLIB_NOLIST
|
||||||
|
name
|
||||||
|
sources
|
||||||
|
includes)
|
||||||
|
|
||||||
|
# Gather all headers
|
||||||
|
FILE(GLOB_RECURSE INC_ALL *.h)
|
||||||
|
|
||||||
|
INCLUDE_DIRECTORIES(${includes})
|
||||||
|
ADD_LIBRARY(${name} ${INC_ALL} ${sources})
|
||||||
|
|
||||||
|
# Group by location on disk
|
||||||
|
SOURCE_GROUP(Files FILES CMakeLists.txt)
|
||||||
|
SET(ALL_FILES ${sources} ${INC_ALL})
|
||||||
|
FOREACH(SRC ${ALL_FILES})
|
||||||
|
STRING(REGEX REPLACE ${CMAKE_CURRENT_SOURCE_DIR} "Files" REL_DIR "${SRC}")
|
||||||
|
STRING(REGEX REPLACE "[\\\\/][^\\\\/]*$" "" REL_DIR "${REL_DIR}")
|
||||||
|
STRING(REGEX REPLACE "^[\\\\/]" "" REL_DIR "${REL_DIR}")
|
||||||
|
IF(REL_DIR)
|
||||||
|
SOURCE_GROUP(${REL_DIR} FILES ${SRC})
|
||||||
|
ELSE(REL_DIR)
|
||||||
|
SOURCE_GROUP(Files FILES ${SRC})
|
||||||
|
ENDIF(REL_DIR)
|
||||||
|
ENDFOREACH(SRC)
|
||||||
|
|
||||||
|
MESSAGE(STATUS "Configuring library ${name}")
|
||||||
|
ENDMACRO(BLENDERLIB_NOLIST)
|
||||||
|
|
||||||
|
MACRO(BLENDERLIB
|
||||||
|
name
|
||||||
|
sources
|
||||||
|
includes)
|
||||||
|
|
||||||
|
BLENDERLIB_NOLIST(${name} "${sources}" "${includes}")
|
||||||
|
|
||||||
|
# Add to blender's list of libraries
|
||||||
|
FILE(APPEND ${CMAKE_BINARY_DIR}/cmake_blender_libs.txt "${name};")
|
||||||
|
ENDMACRO(BLENDERLIB)
|
||||||
|
|
||||||
|
MACRO(SETUP_LIBDIRS)
|
||||||
|
LINK_DIRECTORIES(${PYTHON_LIBPATH} ${SDL_LIBPATH} ${JPEG_LIBPATH} ${PNG_LIBPATH} ${ZLIB_LIBPATH} ${ICONV_LIBPATH} ${OPENEXR_LIBPATH} ${QUICKTIME_LIBPATH} ${FFMPEG_LIBPATH})
|
||||||
|
IF(WITH_INTERNATIONAL)
|
||||||
|
LINK_DIRECTORIES(${GETTEXT_LIBPATH})
|
||||||
|
LINK_DIRECTORIES(${FREETYPE_LIBPATH})
|
||||||
|
ENDIF(WITH_INTERNATIONAL)
|
||||||
|
IF(WITH_OPENAL)
|
||||||
|
LINK_DIRECTORIES(${OPENAL_LIBPATH})
|
||||||
|
ENDIF(WITH_OPENAL)
|
||||||
|
|
||||||
|
IF(WIN32)
|
||||||
|
LINK_DIRECTORIES(${PTHREADS_LIBPATH})
|
||||||
|
ENDIF(WIN32)
|
||||||
|
ENDMACRO(SETUP_LIBDIRS)
|
||||||
|
|
||||||
|
MACRO(SETUP_LIBLINKS
|
||||||
|
target)
|
||||||
|
SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${PLATFORM_LINKFLAGS} ")
|
||||||
|
TARGET_LINK_LIBRARIES(${target} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} ${PYTHON_LIB} ${PYTHON_LINKFLAGS} ${JPEG_LIB} ${PNG_LIB} ${ZLIB_LIB} ${SDL_LIB} ${LLIBS})
|
||||||
|
IF(WITH_INTERNATIONAL)
|
||||||
|
TARGET_LINK_LIBRARIES(${target} ${FREETYPE_LIB})
|
||||||
|
TARGET_LINK_LIBRARIES(${target} ${GETTEXT_LIB})
|
||||||
|
ENDIF(WITH_INTERNATIONAL)
|
||||||
|
IF(WITH_OPENAL)
|
||||||
|
TARGET_LINK_LIBRARIES(${target} ${OPENAL_LIB})
|
||||||
|
ENDIF(WITH_OPENAL)
|
||||||
|
IF(WIN32)
|
||||||
|
TARGET_LINK_LIBRARIES(${target} ${ICONV_LIB})
|
||||||
|
ENDIF(WIN32)
|
||||||
|
IF(WITH_QUICKTIME)
|
||||||
|
TARGET_LINK_LIBRARIES(${target} ${QUICKTIME_LIB})
|
||||||
|
ENDIF(WITH_QUICKTIME)
|
||||||
|
IF(WITH_OPENEXR)
|
||||||
|
TARGET_LINK_LIBRARIES(${target} ${OPENEXR_LIB})
|
||||||
|
ENDIF(WITH_OPENEXR)
|
||||||
|
IF(WITH_FFMPEG)
|
||||||
|
TARGET_LINK_LIBRARIES(${target} ${FFMPEG_LIB})
|
||||||
|
ENDIF(WITH_FFMPEG)
|
||||||
|
IF(WIN32)
|
||||||
|
TARGET_LINK_LIBRARIES(${target} ${PTHREADS_LIB})
|
||||||
|
ENDIF(WIN32)
|
||||||
|
ENDMACRO(SETUP_LIBLINKS)
|
||||||
408
CMakeLists.txt
Normal file
408
CMakeLists.txt
Normal file
@@ -0,0 +1,408 @@
|
|||||||
|
# $Id$
|
||||||
|
# ***** BEGIN GPL/BL DUAL 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. The Blender
|
||||||
|
# Foundation also sells licenses for use in proprietary software under
|
||||||
|
# the Blender License. See http://www.blender.org/BL/ for information
|
||||||
|
# about this.
|
||||||
|
#
|
||||||
|
# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
#
|
||||||
|
# The Original Code is Copyright (C) 2006, Blender Foundation
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# The Original Code is: all of this file.
|
||||||
|
#
|
||||||
|
# Contributor(s): Jacques Beaurain.
|
||||||
|
#
|
||||||
|
# ***** END GPL/BL DUAL LICENSE BLOCK *****
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# We don't allow in-source builds. This causes no end of troubles because
|
||||||
|
# all out-of-source builds will use the CMakeCache.txt file there and even
|
||||||
|
# build the libs and objects in it. It will also conflict with the current
|
||||||
|
# Makefile system for Blender
|
||||||
|
|
||||||
|
IF(${CMAKE_SOURCE_DIR} STREQUAL ${CMAKE_BINARY_DIR})
|
||||||
|
MESSAGE(FATAL_ERROR "CMake generation for blender is not allowed within the source directory!
|
||||||
|
Remove the CMakeCache.txt file and try again from another folder, e.g.:
|
||||||
|
|
||||||
|
rm CMakeCache.txt
|
||||||
|
cd ..
|
||||||
|
mkdir cmake-make
|
||||||
|
cd cmake-make
|
||||||
|
cmake -G \"Unix Makefiles\" ../blender
|
||||||
|
")
|
||||||
|
ENDIF(${CMAKE_SOURCE_DIR} STREQUAL ${CMAKE_BINARY_DIR})
|
||||||
|
|
||||||
|
CMAKE_MINIMUM_REQUIRED(VERSION 2.4)
|
||||||
|
PROJECT(Blender)
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# Redirect output files
|
||||||
|
|
||||||
|
SET(EXECUTABLE_OUTPUT_PATH ${CMAKE_BINARY_DIR}/bin)
|
||||||
|
SET(LIBRARY_OUTPUT_PATH ${CMAKE_BINARY_DIR}/lib)
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# Set default config options
|
||||||
|
OPTION(WITH_PLAYER "Build Player" OFF)
|
||||||
|
OPTION(WITH_GAMEENGINE "Enable Game Engine" ON)
|
||||||
|
OPTION(WITH_BULLET "Enable Bullet (Physics Engine)" ON)
|
||||||
|
OPTION(WITH_INTERNATIONAL "Enable I18N (International fonts and text)" ON)
|
||||||
|
OPTION(WITH_VERSE "Enable Verse (http://verse.blender.org)" OFF)
|
||||||
|
OPTION(WITH_ELBEEM "Enable Elbeem (Fluid Simulation)" ON)
|
||||||
|
OPTION(WITH_QUICKTIME "Enable Quicktime Support" OFF)
|
||||||
|
OPTION(WITH_OPENEXR "Enable OpenEXR Support (http://www.openexr.com)" OFF)
|
||||||
|
OPTION(WITH_FFMPEG "Enable FFMPeg Support (http://ffmpeg.mplayerhq.hu/)" OFF)
|
||||||
|
OPTION(WITH_OPENAL "Enable OpenAL Support (http://www.openal.org)" ON)
|
||||||
|
OPTION(YESIAMSTUPID "Enable execution on 64-bit platforms" OFF)
|
||||||
|
|
||||||
|
IF(NOT WITH_GAMEENGINE AND WITH_PLAYER)
|
||||||
|
MESSAGE("WARNING: WITH_PLAYER needs WITH_GAMEENGINE")
|
||||||
|
ENDIF(NOT WITH_GAMEENGINE AND WITH_PLAYER)
|
||||||
|
|
||||||
|
# For alternate Python locations the commandline can be used to override detected/default cache settings, e.g:
|
||||||
|
# On Unix:
|
||||||
|
# cmake -D PYTHON_LIB=/usr/local/lib/python2.3/config/libpython2.3.so -D PYTHON_INC=/usr/local/include/python2.3 -D PYTHON_BINARY=/usr/local/bin/python2.3 -G "Unix Makefiles" ../blender
|
||||||
|
# On Macs:
|
||||||
|
# cmake -D PYTHON_INC=/System/Library/Frameworks/Python.framework/Versions/2.5/include/python2.5 -D PYTHON_LIBPATH=/System/Library/Frameworks/Python.framework/Versions/2.5/lib/python2.5/config -D PYTHON_BINARY=/System/Library/Frameworks/Python.framework/Versions/2.5/bin/python2.5 -G Xcode ../blender
|
||||||
|
#
|
||||||
|
# When changing any of this remember to update the notes in doc/blender-cmake.txt
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# Load some macros.
|
||||||
|
INCLUDE(CMake/macros.cmake)
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
#Platform specifics
|
||||||
|
|
||||||
|
IF(UNIX)
|
||||||
|
INCLUDE(${CMAKE_ROOT}/Modules/FindOpenAL.cmake)
|
||||||
|
IF(OPENAL_FOUND)
|
||||||
|
SET(WITH_OPENAL ON)
|
||||||
|
SET(OPENAL_LIB ${OPENAL_LIBRARY})
|
||||||
|
SET(OPENAL_INC ${OPENAL_INCLUDE_DIR})
|
||||||
|
ELSE(OPENAL_FOUND)
|
||||||
|
SET(WITH_OPENAL OFF)
|
||||||
|
ENDIF(OPENAL_FOUND)
|
||||||
|
|
||||||
|
FIND_LIBRARY(ALUT_LIBRARY
|
||||||
|
NAMES alut
|
||||||
|
PATHS
|
||||||
|
/usr/local/lib
|
||||||
|
/usr/lib
|
||||||
|
/sw/lib
|
||||||
|
/opt/local/lib
|
||||||
|
/opt/csw/lib
|
||||||
|
/opt/lib
|
||||||
|
)
|
||||||
|
IF(ALUT_LIBRARY)
|
||||||
|
SET(OPENAL_LIB ${OPENAL_LIB} ${ALUT_LIBRARY})
|
||||||
|
ENDIF(ALUT_LIBRARY)
|
||||||
|
|
||||||
|
FIND_LIBRARY(INTL_LIBRARY
|
||||||
|
NAMES intl
|
||||||
|
PATHS
|
||||||
|
/usr/local/lib
|
||||||
|
/usr/lib
|
||||||
|
/sw/lib
|
||||||
|
/opt/local/lib
|
||||||
|
/opt/csw/lib
|
||||||
|
/opt/lib
|
||||||
|
)
|
||||||
|
FIND_LIBRARY(ICONV_LIBRARY
|
||||||
|
NAMES iconv
|
||||||
|
PATHS
|
||||||
|
/usr/local/lib
|
||||||
|
/usr/lib
|
||||||
|
/sw/lib
|
||||||
|
/opt/local/lib
|
||||||
|
/opt/csw/lib
|
||||||
|
/opt/lib
|
||||||
|
)
|
||||||
|
IF(INTL_LIBRARY AND ICONV_LIBRARY)
|
||||||
|
SET(GETTEXT_LIB ${INTL_LIBRARY} ${ICONV_LIBRARY})
|
||||||
|
ENDIF(INTL_LIBRARY AND ICONV_LIBRARY)
|
||||||
|
|
||||||
|
FIND_PATH(FREETYPE_INC
|
||||||
|
freetype
|
||||||
|
PATHS
|
||||||
|
/usr/local/include/freetype2
|
||||||
|
/usr/include/freetype2
|
||||||
|
/sw/include/freetype2
|
||||||
|
/opt/local/include/freetype2
|
||||||
|
/opt/csw/include/freetype2
|
||||||
|
/opt/include/freetype2
|
||||||
|
NO_DEFAULT_PATH
|
||||||
|
)
|
||||||
|
SET(FREETYPE_LIB freetype)
|
||||||
|
|
||||||
|
INCLUDE(${CMAKE_ROOT}/Modules/FindPythonLibs.cmake)
|
||||||
|
SET(PYTHON_INC "${PYTHON_INCLUDE_PATH}" CACHE STRING "")
|
||||||
|
SET(PYTHON_LIB "${PYTHON_LIBRARIES}" CACHE STRING "")
|
||||||
|
INCLUDE(${CMAKE_ROOT}/Modules/FindPythonInterp.cmake)
|
||||||
|
SET(PYTHON_BINARY ${PYTHON_EXECUTABLE} CACHE STRING "")
|
||||||
|
SET(PYTHON_LINKFLAGS "-Xlinker -export-dynamic")
|
||||||
|
|
||||||
|
INCLUDE(${CMAKE_ROOT}/Modules/FindSDL.cmake)
|
||||||
|
SET(SDL_INC ${SDL_INCLUDE_DIR})
|
||||||
|
SET(SDL_LIB ${SDL_LIBRARY})
|
||||||
|
|
||||||
|
FIND_PATH(OPENEXR_INC
|
||||||
|
ImfXdr.h
|
||||||
|
PATHS
|
||||||
|
/usr/local/include/OpenEXR
|
||||||
|
/usr/include/OpenEXR
|
||||||
|
/sw/include/OpenEXR
|
||||||
|
/opt/local/include/OpenEXR
|
||||||
|
/opt/csw/include/OpenEXR
|
||||||
|
/opt/include/OpenEXR
|
||||||
|
)
|
||||||
|
SET(OPENEXR_LIB Half IlmImf Iex Imath)
|
||||||
|
|
||||||
|
SET(FFMPEG /usr)
|
||||||
|
SET(FFMPEG_INC ${FFMPEG}/include)
|
||||||
|
SET(FFMPEG_LIB avformat avcodec avutil)
|
||||||
|
SET(FFMPEG_LIBPATH ${FFMPEG}/lib)
|
||||||
|
|
||||||
|
SET(JPEG_LIB jpeg)
|
||||||
|
|
||||||
|
SET(PNG_LIB png)
|
||||||
|
|
||||||
|
SET(ZLIB_LIB z)
|
||||||
|
|
||||||
|
SET(LLIBS "-lXi -lutil -lc -lm -lpthread -lstdc++")
|
||||||
|
|
||||||
|
SET(PLATFORM_CFLAGS "-pipe -fPIC -funsigned-char -fno-strict-aliasing -DXP_UNIX -Wno-char-subscripts")
|
||||||
|
|
||||||
|
SET(PLATFORM_LINKFLAGS "-pthread")
|
||||||
|
|
||||||
|
INCLUDE_DIRECTORIES(/usr/include /usr/local/include)
|
||||||
|
ENDIF(UNIX)
|
||||||
|
|
||||||
|
IF(WIN32)
|
||||||
|
INCLUDE(${CMAKE_ROOT}/Modules/Platform/Windows-cl.cmake)
|
||||||
|
|
||||||
|
SET(LIBDIR ${CMAKE_SOURCE_DIR}/../lib/windows)
|
||||||
|
|
||||||
|
SET(PYTHON ${LIBDIR}/python)
|
||||||
|
SET(PYTHON_VERSION 2.5)
|
||||||
|
SET(PYTHON_INC "${PYTHON}/include/python${PYTHON_VERSION}")
|
||||||
|
SET(PYTHON_BINARY python)
|
||||||
|
SET(PYTHON_LIB python25)
|
||||||
|
SET(PYTHON_LIBPATH ${PYTHON}/lib)
|
||||||
|
|
||||||
|
#SET(WITH_OPENAL ON)
|
||||||
|
SET(OPENAL ${LIBDIR}/openal)
|
||||||
|
SET(OPENAL_INC ${OPENAL}/include ${OPENAL}/include/AL)
|
||||||
|
SET(OPENAL_LIB openal_static)
|
||||||
|
SET(OPENAL_LIBPATH ${OPENAL}/lib)
|
||||||
|
|
||||||
|
SET(PNG_LIB libpng_st)
|
||||||
|
SET(JPEG_LIB libjpeg)
|
||||||
|
|
||||||
|
SET(ZLIB ${LIBDIR}/zlib)
|
||||||
|
SET(ZLIB_INC ${ZLIB}/include)
|
||||||
|
SET(ZLIB_LIB libz)
|
||||||
|
SET(ZLIB_LIBPATH ${ZLIB}/lib)
|
||||||
|
|
||||||
|
SET(PTHREADS ${LIBDIR}/pthreads)
|
||||||
|
SET(PTHREADS_INC ${PTHREADS}/include)
|
||||||
|
SET(PTHREADS_LIB pthreadVC2)
|
||||||
|
SET(PTHREADS_LIBPATH ${PTHREADS}/lib)
|
||||||
|
|
||||||
|
SET(ICONV ${LIBDIR}/iconv)
|
||||||
|
SET(ICONV_INC ${ICONV}/include)
|
||||||
|
SET(ICONV_LIB iconv)
|
||||||
|
SET(ICONV_LIBPATH ${ICONV}/lib)
|
||||||
|
|
||||||
|
SET(GETTEXT ${LIBDIR}/gettext)
|
||||||
|
SET(GETTEXT_INC ${GETTEXT}/include)
|
||||||
|
SET(GETTEXT_LIB gnu_gettext)
|
||||||
|
SET(GETTEXT_LIBPATH ${GETTEXT}/lib)
|
||||||
|
|
||||||
|
SET(FREETYPE ${LIBDIR}/freetype)
|
||||||
|
SET(FREETYPE_INC ${FREETYPE}/include ${FREETYPE}/include/freetype2)
|
||||||
|
SET(FREETYPE_LIBPATH ${FREETYPE}/lib)
|
||||||
|
SET(FREETYPE_LIB freetype2ST)
|
||||||
|
|
||||||
|
SET(OPENEXR ${LIBDIR}/openexr)
|
||||||
|
SET(OPENEXR_INC ${OPENEXR}/include ${OPENEXR}/include/IlmImf ${OPENEXR}/include/Iex ${OPENEXR}/include/Imath)
|
||||||
|
SET(OPENEXR_LIB Iex Half IlmImf Imath IlmThread)
|
||||||
|
IF (MSVC80)
|
||||||
|
SET(OPENEXR_LIBPATH ${OPENEXR}/lib_vs2005)
|
||||||
|
ELSE (MSVC80)
|
||||||
|
SET(OPENEXR_LIBPATH ${OPENEXR}/lib_msvc)
|
||||||
|
ENDIF(MSVC80)
|
||||||
|
|
||||||
|
SET(QUICKTIME ${LIBDIR}/QTDevWin)
|
||||||
|
SET(QUICKTIME_INC ${QUICKTIME}/CIncludes)
|
||||||
|
SET(QUICKTIME_LIB qtmlClient)
|
||||||
|
SET(QUICKTIME_LIBPATH ${QUICKTIME}/Libraries)
|
||||||
|
|
||||||
|
SET(FFMPEG ${LIBDIR}/ffmpeg)
|
||||||
|
SET(FFMPEG_INC ${FFMPEG}/include)
|
||||||
|
SET(FFMPEG_LIB avcodec-51 avformat-51 avutil-49)
|
||||||
|
SET(FFMPEG_LIBPATH ${FFMPEG}/lib)
|
||||||
|
|
||||||
|
SET(LLIBS kernel32 user32 gdi32 comdlg32 advapi32 shell32 ole32 oleaut32 uuid ws2_32 vfw32 winmm)
|
||||||
|
IF(WITH_OPENAL)
|
||||||
|
SET(LLIBS ${LLIBS} dxguid)
|
||||||
|
ENDIF(WITH_OPENAL)
|
||||||
|
|
||||||
|
SET(CMAKE_CXX_FLAGS_DEBUG "/D_CRT_NONSTDC_NO_DEPRECATE /D_CRT_SECURE_NO_DEPRECATE /D_SCL_SECURE_NO_DEPRECATE /wd4800 /wd4244 /wd4305 /D_DEBUG /Od /Gm /EHsc /RTC1 /MTd /W3 /nologo /ZI /J" CACHE STRING "MSVC MT flags " FORCE)
|
||||||
|
SET(CMAKE_CXX_FLAGS_RELEASE "/D_CRT_NONSTDC_NO_DEPRECATE /D_CRT_SECURE_NO_DEPRECATE /D_SCL_SECURE_NO_DEPRECATE /wd4800 /wd4244 /wd4305 /O2 /Ob2 /DNDEBUG /EHsc /MT /W3 /nologo /J" CACHE STRING "MSVC MT flags " FORCE)
|
||||||
|
SET(CMAKE_CXX_FLAGS_MINSIZEREL "/D_CRT_NONSTDC_NO_DEPRECATE /D_CRT_SECURE_NO_DEPRECATE /D_SCL_SECURE_NO_DEPRECATE /wd4800 /wd4244 /wd4305 /O1 /Ob1 /DNDEBUG /EHsc /MT /W3 /nologo /J" CACHE STRING "MSVC MT flags " FORCE)
|
||||||
|
SET(CMAKE_CXX_FLAGS_RELWITHDEBINFO "/D_CRT_NONSTDC_NO_DEPRECATE /D_CRT_SECURE_NO_DEPRECATE /D_SCL_SECURE_NO_DEPRECATE /wd4800 /wd4244 /wd4305 /O2 /Ob1 /DNDEBUG /EHsc /MT /W3 /nologo /Zi /J" CACHE STRING "MSVC MT flags " FORCE)
|
||||||
|
SET(CMAKE_C_FLAGS_DEBUG "/D_CRT_NONSTDC_NO_DEPRECATE /D_CRT_SECURE_NO_DEPRECATE /D_SCL_SECURE_NO_DEPRECATE /wd4800 /wd4244 /wd4305 /D_DEBUG /Od /Gm /EHsc /RTC1 /MTd /W3 /nologo /ZI /J" CACHE STRING "MSVC MT flags " FORCE)
|
||||||
|
SET(CMAKE_C_FLAGS_RELEASE "/D_CRT_NONSTDC_NO_DEPRECATE /D_CRT_SECURE_NO_DEPRECATE /D_SCL_SECURE_NO_DEPRECATE /wd4800 /wd4244 /wd4305 /O2 /Ob2 /DNDEBUG /EHsc /MT /W3 /nologo /J" CACHE STRING "MSVC MT flags " FORCE)
|
||||||
|
SET(CMAKE_C_FLAGS_MINSIZEREL "/D_CRT_NONSTDC_NO_DEPRECATE /D_CRT_SECURE_NO_DEPRECATE /D_SCL_SECURE_NO_DEPRECATE /wd4800 /wd4244 /wd4305 /O1 /Ob1 /DNDEBUG /EHsc /MT /W3 /nologo /J" CACHE STRING "MSVC MT flags " FORCE)
|
||||||
|
SET(CMAKE_C_FLAGS_RELWITHDEBINFO "/D_CRT_NONSTDC_NO_DEPRECATE /D_CRT_SECURE_NO_DEPRECATE /D_SCL_SECURE_NO_DEPRECATE /wd4800 /wd4244 /wd4305 /O2 /Ob1 /DNDEBUG /EHsc /MT /W3 /nologo /Zi /J" CACHE STRING "MSVC MT flags " FORCE)
|
||||||
|
|
||||||
|
SET(SDL ${LIBDIR}/sdl)
|
||||||
|
SET(SDL_INC ${SDL}/include)
|
||||||
|
SET(SDL_LIB SDL)
|
||||||
|
SET(SDL_LIBPATH ${SDL}/lib)
|
||||||
|
|
||||||
|
SET(PNG "${LIBDIR}/png")
|
||||||
|
SET(PNG_INC "${PNG}/include")
|
||||||
|
SET(PNG_LIBPATH ${PNG}/lib)
|
||||||
|
|
||||||
|
SET(JPEG "${LIBDIR}/jpeg")
|
||||||
|
SET(JPEG_INC "${JPEG}/include")
|
||||||
|
SET(JPEG_LIBPATH ${JPEG}/lib)
|
||||||
|
|
||||||
|
SET(TIFF ${LIBDIR}/tiff)
|
||||||
|
SET(TIFF_INC ${TIFF}/include)
|
||||||
|
|
||||||
|
SET(WINTAB_INC ${LIBDIR}/wintab/include)
|
||||||
|
|
||||||
|
SET(PLATFORM_LINKFLAGS "/NODEFAULTLIB:libc.lib")
|
||||||
|
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBUG} /NODEFAULTLIB:libcmt.lib ")
|
||||||
|
ENDIF(WIN32)
|
||||||
|
|
||||||
|
IF(APPLE)
|
||||||
|
IF(CMAKE_OSX_ARCHITECTURES MATCHES i386)
|
||||||
|
SET(LIBDIR ${CMAKE_SOURCE_DIR}/../lib/darwin-8.x.i386)
|
||||||
|
ELSE(CMAKE_OSX_ARCHITECTURES MATCHES i386)
|
||||||
|
SET(LIBDIR ${CMAKE_SOURCE_DIR}/../lib/darwin-6.1-powerpc)
|
||||||
|
ENDIF(CMAKE_OSX_ARCHITECTURES MATCHES i386)
|
||||||
|
|
||||||
|
INCLUDE(${CMAKE_ROOT}/Modules/FindOpenAL.cmake)
|
||||||
|
IF(OPENAL_FOUND)
|
||||||
|
SET(WITH_OPENAL ON)
|
||||||
|
SET(OPENAL_LIB ${OPENAL_LIBRARY})
|
||||||
|
SET(OPENAL_INC ${OPENAL_INCLUDE_DIR})
|
||||||
|
ELSE(OPENAL_FOUND)
|
||||||
|
SET(WITH_OPENAL OFF)
|
||||||
|
ENDIF(OPENAL_FOUND)
|
||||||
|
|
||||||
|
SET(PYTHON /System/Library/Frameworks/Python.framework/Versions/)
|
||||||
|
SET(PYTHON_VERSION 2.3)
|
||||||
|
SET(PYTHON_INC "${PYTHON}${PYTHON_VERSION}/include/python${PYTHON_VERSION}" CACHE STRING "")
|
||||||
|
SET(PYTHON_BINARY ${PYTHON}${PYTHON_VERSION}/bin/python${PYTHON_VERSION} CACHE STRING "")
|
||||||
|
SET(PYTHON_LIB "")
|
||||||
|
SET(PYTHON_LIBPATH ${PYTHON}${PYTHON_VERSION}/lib/python${PYTHON_VERSION}/config CACHE STRING "")
|
||||||
|
SET(PYTHON_LINKFLAGS "-u __dummy -u _PyMac_Error -framework System -framework Python")
|
||||||
|
|
||||||
|
SET(GETTEXT ${LIBDIR}/gettext)
|
||||||
|
SET(GETTEXT_INC "${GETTEXT}/include")
|
||||||
|
SET(GETTEXT_LIB intl iconv)
|
||||||
|
SET(GETTEXT_LIBPATH ${GETTEXT}/lib)
|
||||||
|
|
||||||
|
SET(PNG_LIB png)
|
||||||
|
SET(JPEG_LIB jpeg)
|
||||||
|
|
||||||
|
SET(ZLIB /usr)
|
||||||
|
SET(ZLIB_INC "${ZLIB}/include")
|
||||||
|
SET(ZLIB_LIB z)
|
||||||
|
|
||||||
|
SET(FREETYPE ${LIBDIR}/freetype)
|
||||||
|
SET(FREETYPE_INC ${FREETYPE}/include ${FREETYPE}/include/freetype2)
|
||||||
|
SET(FREETYPE_LIBPATH ${FREETYPE}/lib)
|
||||||
|
SET(FREETYPE_LIB freetype)
|
||||||
|
|
||||||
|
SET(OPENEXR ${LIBDIR}/openexr)
|
||||||
|
SET(OPENEXR_INC ${OPENEXR}/include/OpenEXR ${OPENEXR}/include)
|
||||||
|
IF(CMAKE_OSX_ARCHITECTURES MATCHES i386)
|
||||||
|
SET(OPENEXR_LIB Iex Half IlmImf Imath IlmThread)
|
||||||
|
ELSE(CMAKE_OSX_ARCHITECTURES MATCHES i386)
|
||||||
|
SET(OPENEXR_LIB Iex Half IlmImf Imath)
|
||||||
|
ENDIF(CMAKE_OSX_ARCHITECTURES MATCHES i386)
|
||||||
|
SET(OPENEXR_LIBPATH ${OPENEXR}/lib)
|
||||||
|
|
||||||
|
SET(LLIBS stdc++ SystemStubs)
|
||||||
|
|
||||||
|
SET(PLATFORM_CFLAGS "-pipe -fPIC -funsigned-char -fno-strict-aliasing")
|
||||||
|
SET(PLATFORM_LINKFLAGS "-fexceptions -framework CoreServices -framework Foundation -framework IOKit -framework AppKit -framework Carbon -framework AGL -framework AudioUnit -framework AudioToolbox -framework CoreAudio -framework QuickTime")
|
||||||
|
|
||||||
|
SET(SDL ${LIBDIR}/sdl)
|
||||||
|
SET(SDL_INC ${SDL}/include)
|
||||||
|
SET(SDL_LIB SDL)
|
||||||
|
SET(SDL_LIBPATH ${SDL}/lib)
|
||||||
|
|
||||||
|
SET(PNG "${LIBDIR}/png")
|
||||||
|
SET(PNG_INC "${PNG}/include")
|
||||||
|
SET(PNG_LIBPATH ${PNG}/lib)
|
||||||
|
|
||||||
|
SET(JPEG "${LIBDIR}/jpeg")
|
||||||
|
SET(JPEG_INC "${JPEG}/include")
|
||||||
|
SET(JPEG_LIBPATH ${JPEG}/lib)
|
||||||
|
|
||||||
|
SET(TIFF ${LIBDIR}/tiff)
|
||||||
|
SET(TIFF_INC ${TIFF}/include)
|
||||||
|
|
||||||
|
SET(EXETYPE MACOSX_BUNDLE)
|
||||||
|
ENDIF(APPLE)
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# Common.
|
||||||
|
SET(VERSE_INC ${CMAKE_SOURCE_DIR}/extern/verse/dist)
|
||||||
|
|
||||||
|
SET(FTGL ${CMAKE_SOURCE_DIR}/extern/bFTGL)
|
||||||
|
SET(FTGL_INC ${FTGL}/include)
|
||||||
|
SET(FTGL_LIB extern_ftgl)
|
||||||
|
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# Configure OpenGL.
|
||||||
|
INCLUDE(${CMAKE_ROOT}/Modules/FindOpenGL.cmake)
|
||||||
|
INCLUDE_DIRECTORIES(${OPENGL_INCLUDE_DIR})
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# Extra compile flags
|
||||||
|
IF(WITH_GAMEENGINE)
|
||||||
|
SET(PLATFORM_CFLAGS "${PLATFORM_CFLAGS} -DGAMEBLENDER ")
|
||||||
|
ENDIF(WITH_GAMEENGINE)
|
||||||
|
SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${PLATFORM_CFLAGS} ")
|
||||||
|
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${PLATFORM_CFLAGS} ")
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# Libraries
|
||||||
|
FILE(WRITE ${CMAKE_BINARY_DIR}/cmake_blender_libs.txt "")
|
||||||
|
SUBDIRS(
|
||||||
|
intern
|
||||||
|
extern
|
||||||
|
source
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# Blender Application
|
||||||
|
SUBDIRS(source/creator)
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
# Blender Player
|
||||||
|
IF(WITH_PLAYER)
|
||||||
|
SUBDIRS(blenderplayer)
|
||||||
|
ENDIF(WITH_PLAYER)
|
||||||
3
COPYING
Normal file
3
COPYING
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
Please read over both of the following files:
|
||||||
|
doc/GPL-license.txt
|
||||||
|
doc/BL-license.txt
|
||||||
61
Makefile
Normal file
61
Makefile
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
# $Id$
|
||||||
|
#
|
||||||
|
# ***** BEGIN GPL/BL DUAL 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. The Blender
|
||||||
|
# Foundation also sells licenses for use in proprietary software under
|
||||||
|
# the Blender License. See http://www.blender.org/BL/ for information
|
||||||
|
# about this.
|
||||||
|
#
|
||||||
|
# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
#
|
||||||
|
# The Original Code is Copyright (C) 2002 by Wouter van Heyst
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# The Original Code is: revision 1.1
|
||||||
|
#
|
||||||
|
# Contributor(s): Hans Lambermont
|
||||||
|
#
|
||||||
|
# ***** END GPL/BL DUAL LICENSE BLOCK *****
|
||||||
|
#
|
||||||
|
# Toplevel Makefile for blender. Bounces make to subdirectories.
|
||||||
|
# Available targets: 'all' 'debug' 'release'
|
||||||
|
|
||||||
|
# If the user wants to override some of the build
|
||||||
|
# vars they can put it in the file user-def.mk which
|
||||||
|
# will get included if it exists (please do not commit
|
||||||
|
# user-def.mk to cvs).
|
||||||
|
|
||||||
|
sinclude user-def.mk
|
||||||
|
|
||||||
|
# To build without openAL, uncomment the following line, or set it as
|
||||||
|
# an environment variable, or put it uncommented in user-def.mk:
|
||||||
|
# export NAN_NO_OPENAL=true
|
||||||
|
|
||||||
|
export NANBLENDERHOME=$(shell pwd)
|
||||||
|
MAKEFLAGS=-I$(NANBLENDERHOME)/source --no-print-directory
|
||||||
|
|
||||||
|
SOURCEDIR =
|
||||||
|
ifeq ($(FREE_WINDOWS),true)
|
||||||
|
DIRS ?= dlltool extern intern source po
|
||||||
|
endif
|
||||||
|
|
||||||
|
DIRS ?= extern intern source po
|
||||||
|
include source/nan_subdirs.mk
|
||||||
|
|
||||||
|
.PHONY: release
|
||||||
|
release:
|
||||||
|
@echo "====> $(MAKE) $@ in $(SOURCEDIR)/$@" ;\
|
||||||
|
$(MAKE) -C $@ $@ || exit 1;
|
||||||
|
|
||||||
|
|
||||||
45
README
Normal file
45
README
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
Welcome to the fun world of open source.
|
||||||
|
|
||||||
|
For instructions on building and installing Blender, please see the file named
|
||||||
|
INSTALL.
|
||||||
|
|
||||||
|
|
||||||
|
---------------------.Blanguages and the .blender directory---------------------
|
||||||
|
|
||||||
|
The .blender directory holds various data files for Blender.
|
||||||
|
In the 2.28a release those are the .Blanguages file containing a list of
|
||||||
|
translations, the translations themselves and a default ttf font.
|
||||||
|
|
||||||
|
Blender checks for the presence of this directory in several locations:
|
||||||
|
- the current directory
|
||||||
|
- your home directory
|
||||||
|
- On OSX, the blender bundle is also checked
|
||||||
|
- On Windows, the installation dir is checked.
|
||||||
|
|
||||||
|
If you get a 'File ".Blanguages" not found' warning, try to copy the .blender
|
||||||
|
dir to one of these locations (your home directory being recommended).
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
-------------------------------------Links--------------------------------------
|
||||||
|
|
||||||
|
Getting Involved:
|
||||||
|
http://www.blender.org/docs/get_involved.html
|
||||||
|
|
||||||
|
Community:
|
||||||
|
http://www.blender3d.org/Community/
|
||||||
|
|
||||||
|
Main blender development site:
|
||||||
|
http://www.blender.org/
|
||||||
|
|
||||||
|
The Blender project homepage:
|
||||||
|
http://projects.blender.org/projects/bf-blender/
|
||||||
|
|
||||||
|
Documentation:
|
||||||
|
http://www.blender.org/modules.php?op=modload&name=documentation&file=index
|
||||||
|
|
||||||
|
Bug tracker:
|
||||||
|
http://projects.blender.org/tracker/?atid=125&group_id=9&func=browse
|
||||||
|
|
||||||
|
Feature request tracker:
|
||||||
|
http://projects.blender.org/tracker/?atid=128&group_id=9&func=browse
|
||||||
447
SConstruct
Normal file
447
SConstruct
Normal file
@@ -0,0 +1,447 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
# $Id$
|
||||||
|
# ***** BEGIN GPL/BL DUAL 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. The Blender
|
||||||
|
# Foundation also sells licenses for use in proprietary software under
|
||||||
|
# the Blender License. See http://www.blender.org/BL/ for information
|
||||||
|
# about this.
|
||||||
|
#
|
||||||
|
# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
#
|
||||||
|
# The Original Code is Copyright (C) 2006, Blender Foundation
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# The Original Code is: all of this file.
|
||||||
|
#
|
||||||
|
# Contributor(s): Nathan Letwory.
|
||||||
|
#
|
||||||
|
# ***** END GPL/BL DUAL LICENSE BLOCK *****
|
||||||
|
#
|
||||||
|
# Main entry-point for the SCons building system
|
||||||
|
# Set up some custom actions and target/argument handling
|
||||||
|
# Then read all SConscripts and build
|
||||||
|
|
||||||
|
import sys
|
||||||
|
import os
|
||||||
|
import os.path
|
||||||
|
import string
|
||||||
|
import shutil
|
||||||
|
import glob
|
||||||
|
import re
|
||||||
|
|
||||||
|
import tools.Blender
|
||||||
|
import tools.btools
|
||||||
|
import tools.bcolors
|
||||||
|
|
||||||
|
BlenderEnvironment = tools.Blender.BlenderEnvironment
|
||||||
|
btools = tools.btools
|
||||||
|
B = tools.Blender
|
||||||
|
|
||||||
|
### globals ###
|
||||||
|
platform = sys.platform
|
||||||
|
quickie = None
|
||||||
|
quickdebug = None
|
||||||
|
nsis_build = None
|
||||||
|
|
||||||
|
##### BEGIN SETUP #####
|
||||||
|
|
||||||
|
B.possible_types = ['core', 'common', 'blender', 'intern',
|
||||||
|
'international', 'game', 'game2',
|
||||||
|
'player', 'player2', 'system']
|
||||||
|
|
||||||
|
B.binarykind = ['blender' , 'blenderplayer']
|
||||||
|
##################################
|
||||||
|
# target and argument validation #
|
||||||
|
##################################
|
||||||
|
# XX cheating for BF_FANCY, we check for BF_FANCY before args are validated
|
||||||
|
use_color = ARGUMENTS.get('BF_FANCY', '1')
|
||||||
|
if platform=='win32':
|
||||||
|
use_color = None
|
||||||
|
|
||||||
|
if not use_color=='1':
|
||||||
|
B.bc.disable()
|
||||||
|
|
||||||
|
#on defaut white Os X terminal, some colors are totally unlegible
|
||||||
|
if platform=='darwin':
|
||||||
|
B.bc.OKGREEN = '\033[34m'
|
||||||
|
B.bc.WARNING = '\033[36m'
|
||||||
|
|
||||||
|
# arguments
|
||||||
|
print B.bc.HEADER+'Command-line arguments'+B.bc.ENDC
|
||||||
|
B.arguments = btools.validate_arguments(ARGUMENTS, B.bc)
|
||||||
|
btools.print_arguments(B.arguments, B.bc)
|
||||||
|
|
||||||
|
# targets
|
||||||
|
print B.bc.HEADER+'Command-line targets'+B.bc.ENDC
|
||||||
|
B.targets = btools.validate_targets(COMMAND_LINE_TARGETS, B.bc)
|
||||||
|
btools.print_targets(B.targets, B.bc)
|
||||||
|
|
||||||
|
##########################
|
||||||
|
# setting up environment #
|
||||||
|
##########################
|
||||||
|
|
||||||
|
# handling cmd line arguments & config file
|
||||||
|
|
||||||
|
# first check cmdline for toolset and we create env to work on
|
||||||
|
quickie = B.arguments.get('BF_QUICK', None)
|
||||||
|
quickdebug = B.arguments.get('BF_QUICKDEBUG', None)
|
||||||
|
|
||||||
|
if quickdebug:
|
||||||
|
B.quickdebug=string.split(quickdebug, ',')
|
||||||
|
else:
|
||||||
|
B.quickdebug=[]
|
||||||
|
|
||||||
|
if quickie:
|
||||||
|
B.quickie=string.split(quickie,',')
|
||||||
|
else:
|
||||||
|
B.quickie=[]
|
||||||
|
|
||||||
|
toolset = B.arguments.get('BF_TOOLSET', None)
|
||||||
|
if toolset:
|
||||||
|
print "Using " + toolset
|
||||||
|
if toolset=='mstoolkit':
|
||||||
|
env = BlenderEnvironment(ENV = os.environ)
|
||||||
|
env.Tool('mstoolkit', ['tools'])
|
||||||
|
else:
|
||||||
|
env = BlenderEnvironment(tools=[toolset], ENV = os.environ)
|
||||||
|
if env:
|
||||||
|
btools.SetupSpawn(env)
|
||||||
|
else:
|
||||||
|
env = BlenderEnvironment(ENV = os.environ)
|
||||||
|
|
||||||
|
if not env:
|
||||||
|
print "Could not create a build environment"
|
||||||
|
Exit()
|
||||||
|
|
||||||
|
|
||||||
|
cc = B.arguments.get('CC', None)
|
||||||
|
cxx = B.arguments.get('CXX', None)
|
||||||
|
if cc:
|
||||||
|
env['CC'] = cc
|
||||||
|
if cxx:
|
||||||
|
env['CXX'] = cxx
|
||||||
|
|
||||||
|
if env['CC'] in ['cl', 'cl.exe'] and sys.platform=='win32':
|
||||||
|
platform = 'win32-vc'
|
||||||
|
elif env['CC'] in ['gcc'] and sys.platform=='win32':
|
||||||
|
platform = 'win32-mingw'
|
||||||
|
|
||||||
|
env.SConscriptChdir(0)
|
||||||
|
|
||||||
|
crossbuild = B.arguments.get('BF_CROSS', None)
|
||||||
|
if crossbuild and platform!='win32':
|
||||||
|
platform = 'linuxcross'
|
||||||
|
|
||||||
|
env['OURPLATFORM'] = platform
|
||||||
|
|
||||||
|
configfile = B.arguments.get('BF_CONFIG', 'config'+os.sep+platform+'-config.py')
|
||||||
|
|
||||||
|
if os.path.exists(configfile):
|
||||||
|
print B.bc.OKGREEN + "Using config file: " + B.bc.ENDC + configfile
|
||||||
|
else:
|
||||||
|
print B.bc.FAIL + configfile + " doesn't exist" + B.bc.ENDC
|
||||||
|
|
||||||
|
if crossbuild and env['PLATFORM'] != 'win32':
|
||||||
|
print B.bc.HEADER+"Preparing for crossbuild"+B.bc.ENDC
|
||||||
|
env.Tool('crossmingw', ['tools'])
|
||||||
|
# todo: determine proper libs/includes etc.
|
||||||
|
# Needed for gui programs, console programs should do without it
|
||||||
|
env.Append(LINKFLAGS=['-mwindows'])
|
||||||
|
|
||||||
|
# first read platform config. B.arguments will override
|
||||||
|
optfiles = [configfile]
|
||||||
|
if os.path.exists('user-config.py'):
|
||||||
|
print B.bc.OKGREEN + "Using config file: " + B.bc.ENDC + 'user-config.py'
|
||||||
|
optfiles += ['user-config.py']
|
||||||
|
else:
|
||||||
|
print B.bc.WARNING + 'user-config.py' + " not found, no user overrides" + B.bc.ENDC
|
||||||
|
|
||||||
|
opts = btools.read_opts(optfiles, B.arguments)
|
||||||
|
opts.Update(env)
|
||||||
|
|
||||||
|
# disable elbeem (fluidsim) compilation?
|
||||||
|
if env['BF_NO_ELBEEM'] == 1:
|
||||||
|
env['CPPFLAGS'].append('-DDISABLE_ELBEEM')
|
||||||
|
env['CXXFLAGS'].append('-DDISABLE_ELBEEM')
|
||||||
|
env['CCFLAGS'].append('-DDISABLE_ELBEEM')
|
||||||
|
|
||||||
|
#check for additional debug libnames
|
||||||
|
|
||||||
|
if env.has_key('BF_DEBUG_LIBS'):
|
||||||
|
B.quickdebug += env['BF_DEBUG_LIBS']
|
||||||
|
|
||||||
|
printdebug = B.arguments.get('BF_LISTDEBUG', 0)
|
||||||
|
|
||||||
|
# see if this linux distro has libalut
|
||||||
|
|
||||||
|
if env['OURPLATFORM'] == 'linux2' :
|
||||||
|
if env['WITH_BF_OPENAL']:
|
||||||
|
mylib_test_source_file = """
|
||||||
|
#include "AL/alut.h"
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
alutGetMajorVersion();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
"""
|
||||||
|
|
||||||
|
def CheckFreeAlut(context,env):
|
||||||
|
context.Message( B.bc.OKGREEN + "Linux platform detected:\n checking for FreeAlut... " + B.bc.ENDC )
|
||||||
|
env['LIBS'] = 'alut'
|
||||||
|
result = context.TryLink(mylib_test_source_file, '.c')
|
||||||
|
context.Result(result)
|
||||||
|
return result
|
||||||
|
|
||||||
|
env2 = env.Copy( LIBPATH = env['BF_OPENAL'] )
|
||||||
|
conf = Configure( env2, {'CheckFreeAlut' : CheckFreeAlut}, '.sconf_temp', '/dev/null' )
|
||||||
|
if conf.CheckFreeAlut( env2 ):
|
||||||
|
env['BF_OPENAL_LIB'] += ' alut'
|
||||||
|
del env2
|
||||||
|
for root, dirs, files in os.walk('.sconf_temp', topdown=False):
|
||||||
|
for name in files:
|
||||||
|
os.remove(os.path.join(root, name))
|
||||||
|
for name in dirs:
|
||||||
|
os.rmdir(os.path.join(root, name))
|
||||||
|
os.rmdir(root)
|
||||||
|
|
||||||
|
if len(B.quickdebug) > 0 and printdebug != 0:
|
||||||
|
print B.bc.OKGREEN + "Buildings these libs with debug symbols:" + B.bc.ENDC
|
||||||
|
for l in B.quickdebug:
|
||||||
|
print "\t" + l
|
||||||
|
|
||||||
|
# check target for blenderplayer. Set WITH_BF_PLAYER if found on cmdline
|
||||||
|
if 'blenderplayer' in B.targets:
|
||||||
|
env['WITH_BF_PLAYER'] = True
|
||||||
|
|
||||||
|
if 'blendernogame' in B.targets:
|
||||||
|
env['WITH_BF_GAMEENGINE'] = False
|
||||||
|
|
||||||
|
# lastly we check for root_build_dir ( we should not do before, otherwise we might do wrong builddir
|
||||||
|
#B.root_build_dir = B.arguments.get('BF_BUILDDIR', '..'+os.sep+'build'+os.sep+platform+os.sep)
|
||||||
|
B.root_build_dir = env['BF_BUILDDIR']
|
||||||
|
env['BUILDDIR'] = B.root_build_dir
|
||||||
|
if not B.root_build_dir[-1]==os.sep:
|
||||||
|
B.root_build_dir += os.sep
|
||||||
|
|
||||||
|
# We do a shortcut for clean when no quicklist is given: just delete
|
||||||
|
# builddir without reading in SConscripts
|
||||||
|
do_clean = None
|
||||||
|
if 'clean' in B.targets:
|
||||||
|
do_clean = True
|
||||||
|
|
||||||
|
if not quickie and do_clean:
|
||||||
|
if os.path.exists(B.root_build_dir):
|
||||||
|
print B.bc.HEADER+'Cleaning...'+B.bc.ENDC
|
||||||
|
dirs = os.listdir(B.root_build_dir)
|
||||||
|
for dir in dirs:
|
||||||
|
if os.path.isdir(B.root_build_dir + dir) == 1:
|
||||||
|
print "clean dir %s"%(B.root_build_dir+dir)
|
||||||
|
shutil.rmtree(B.root_build_dir+dir)
|
||||||
|
print B.bc.OKGREEN+'...done'+B.bc.ENDC
|
||||||
|
else:
|
||||||
|
print B.bc.HEADER+'Already Clean, nothing to do.'+B.bc.ENDC
|
||||||
|
Exit()
|
||||||
|
|
||||||
|
if not os.path.isdir ( B.root_build_dir):
|
||||||
|
os.makedirs ( B.root_build_dir )
|
||||||
|
os.makedirs ( B.root_build_dir + 'source' )
|
||||||
|
os.makedirs ( B.root_build_dir + 'intern' )
|
||||||
|
os.makedirs ( B.root_build_dir + 'extern' )
|
||||||
|
os.makedirs ( B.root_build_dir + 'lib' )
|
||||||
|
os.makedirs ( B.root_build_dir + 'bin' )
|
||||||
|
|
||||||
|
Help(opts.GenerateHelpText(env))
|
||||||
|
|
||||||
|
# default is new quieter output, but if you need to see the
|
||||||
|
# commands, do 'scons BF_QUIET=0'
|
||||||
|
bf_quietoutput = B.arguments.get('BF_QUIET', '1')
|
||||||
|
if bf_quietoutput=='1':
|
||||||
|
B.set_quiet_output(env)
|
||||||
|
else:
|
||||||
|
if toolset=='msvc':
|
||||||
|
B.msvc_hack(env)
|
||||||
|
|
||||||
|
print B.bc.HEADER+'Building in '+B.bc.ENDC+B.root_build_dir
|
||||||
|
env.SConsignFile(B.root_build_dir+'scons-signatures')
|
||||||
|
B.init_lib_dict()
|
||||||
|
|
||||||
|
##### END SETUP ##########
|
||||||
|
|
||||||
|
Export('env')
|
||||||
|
|
||||||
|
BuildDir(B.root_build_dir+'/intern', 'intern', duplicate=0)
|
||||||
|
SConscript(B.root_build_dir+'/intern/SConscript')
|
||||||
|
BuildDir(B.root_build_dir+'/extern', 'extern', duplicate=0)
|
||||||
|
SConscript(B.root_build_dir+'/extern/SConscript')
|
||||||
|
BuildDir(B.root_build_dir+'/source', 'source', duplicate=0)
|
||||||
|
SConscript(B.root_build_dir+'/source/SConscript')
|
||||||
|
|
||||||
|
# now that we have read all SConscripts, we know what
|
||||||
|
# libraries will be built. Create list of
|
||||||
|
# libraries to give as objects to linking phase
|
||||||
|
mainlist = []
|
||||||
|
for tp in B.possible_types:
|
||||||
|
if not tp == 'player' and not tp == 'player2':
|
||||||
|
mainlist += B.create_blender_liblist(env, tp)
|
||||||
|
|
||||||
|
if B.arguments.get('BF_PRIORITYLIST', '0')=='1':
|
||||||
|
B.propose_priorities()
|
||||||
|
|
||||||
|
dobj = B.buildinfo(env, "dynamic") + B.resources
|
||||||
|
thestatlibs, thelibincs = B.setup_staticlibs(env)
|
||||||
|
thesyslibs = B.setup_syslibs(env)
|
||||||
|
|
||||||
|
env.BlenderProg(B.root_build_dir, "blender", dobj + mainlist + thestatlibs, [], thesyslibs, [B.root_build_dir+'/lib'] + thelibincs, 'blender')
|
||||||
|
if env['WITH_BF_PLAYER']:
|
||||||
|
playerlist = B.create_blender_liblist(env, 'player')
|
||||||
|
env.BlenderProg(B.root_build_dir, "blenderplayer", dobj + playerlist + thestatlibs, [], thesyslibs, [B.root_build_dir+'/lib'] + thelibincs, 'blenderplayer')
|
||||||
|
|
||||||
|
##### Now define some targets
|
||||||
|
|
||||||
|
|
||||||
|
#------------ INSTALL
|
||||||
|
|
||||||
|
#-- binaries
|
||||||
|
blenderinstall = []
|
||||||
|
if env['OURPLATFORM']=='darwin':
|
||||||
|
for prg in B.program_list:
|
||||||
|
bundle = '%s.app' % prg[0]
|
||||||
|
bundledir = os.path.dirname(bundle)
|
||||||
|
for dp, dn, df in os.walk(bundle):
|
||||||
|
if 'CVS' in dn:
|
||||||
|
dn.remove('CVS')
|
||||||
|
if '.svn' in dn:
|
||||||
|
dn.remove('.svn')
|
||||||
|
dir=env['BF_INSTALLDIR']+dp[len(bundledir):]
|
||||||
|
source=[dp+os.sep+f for f in df]
|
||||||
|
blenderinstall.append(env.Install(dir=dir,source=source))
|
||||||
|
else:
|
||||||
|
blenderinstall = env.Install(dir=env['BF_INSTALLDIR'], source=B.program_list)
|
||||||
|
|
||||||
|
#-- .blender
|
||||||
|
dotblendlist = []
|
||||||
|
dottargetlist = []
|
||||||
|
for dp, dn, df in os.walk('bin/.blender'):
|
||||||
|
if 'CVS' in dn:
|
||||||
|
dn.remove('CVS')
|
||||||
|
if '.svn' in dn:
|
||||||
|
dn.remove('.svn')
|
||||||
|
for f in df:
|
||||||
|
dotblendlist.append(dp+os.sep+f)
|
||||||
|
dottargetlist.append(env['BF_INSTALLDIR']+dp[3:]+os.sep+f)
|
||||||
|
|
||||||
|
dotblenderinstall = []
|
||||||
|
for targetdir,srcfile in zip(dottargetlist, dotblendlist):
|
||||||
|
td, tf = os.path.split(targetdir)
|
||||||
|
dotblenderinstall.append(env.Install(dir=td, source=srcfile))
|
||||||
|
|
||||||
|
#-- .blender/scripts
|
||||||
|
scriptinstall = []
|
||||||
|
scriptpath='release/scripts'
|
||||||
|
for dp, dn, df in os.walk(scriptpath):
|
||||||
|
if 'CVS' in dn:
|
||||||
|
dn.remove('CVS')
|
||||||
|
if '.svn' in dn:
|
||||||
|
dn.remove('.svn')
|
||||||
|
dir=env['BF_INSTALLDIR']+'/.blender/scripts'+dp[len(scriptpath):]
|
||||||
|
source=[dp+os.sep+f for f in df]
|
||||||
|
scriptinstall.append(env.Install(dir=dir,source=source))
|
||||||
|
|
||||||
|
#-- plugins
|
||||||
|
pluglist = []
|
||||||
|
plugtargetlist = []
|
||||||
|
for tp, tn, tf in os.walk('release/plugins'):
|
||||||
|
if 'CVS' in tn:
|
||||||
|
tn.remove('CVS')
|
||||||
|
if '.svn' in tn:
|
||||||
|
tn.remove('.svn')
|
||||||
|
for f in tf:
|
||||||
|
pluglist.append(tp+os.sep+f)
|
||||||
|
plugtargetlist.append(env['BF_INSTALLDIR']+tp[7:]+os.sep+f)
|
||||||
|
|
||||||
|
plugininstall = []
|
||||||
|
for targetdir,srcfile in zip(plugtargetlist, pluglist):
|
||||||
|
td, tf = os.path.split(targetdir)
|
||||||
|
plugininstall.append(env.Install(dir=td, source=srcfile))
|
||||||
|
|
||||||
|
textlist = []
|
||||||
|
texttargetlist = []
|
||||||
|
for tp, tn, tf in os.walk('release/text'):
|
||||||
|
if 'CVS' in tn:
|
||||||
|
tn.remove('CVS')
|
||||||
|
if '.svn' in tn:
|
||||||
|
tn.remove('.svn')
|
||||||
|
for f in tf:
|
||||||
|
textlist.append(tp+os.sep+f)
|
||||||
|
|
||||||
|
textinstall = env.Install(dir=env['BF_INSTALLDIR'], source=textlist)
|
||||||
|
|
||||||
|
allinstall = [blenderinstall, dotblenderinstall, scriptinstall, plugininstall, textinstall]
|
||||||
|
|
||||||
|
if env['OURPLATFORM'] in ('win32-vc', 'win32-mingw'):
|
||||||
|
dllsources = ['${LCGDIR}/gettext/lib/gnu_gettext.dll',
|
||||||
|
'${LCGDIR}/png/lib/libpng.dll',
|
||||||
|
'#release/windows/extra/python25.zip',
|
||||||
|
'#release/windows/extra/zlib.pyd',
|
||||||
|
'${LCGDIR}/sdl/lib/SDL.dll',
|
||||||
|
'${LCGDIR}/zlib/lib/zlib.dll',
|
||||||
|
'${LCGDIR}/tiff/lib/libtiff.dll']
|
||||||
|
if env['BF_DEBUG']:
|
||||||
|
dllsources.append('${LCGDIR}/python/lib/${BF_PYTHON_LIB}.dll')
|
||||||
|
else:
|
||||||
|
dllsources.append('${LCGDIR}/python/lib/${BF_PYTHON_LIB}.dll')
|
||||||
|
if env['OURPLATFORM'] == 'win32-mingw':
|
||||||
|
dllsources += ['${LCGDIR}/pthreads/lib/pthreadGC2.dll']
|
||||||
|
else:
|
||||||
|
dllsources += ['${LCGDIR}/pthreads/lib/pthreadVC2.dll']
|
||||||
|
if env['WITH_BF_ICONV']:
|
||||||
|
dllsources += ['${LCGDIR}/iconv/lib/iconv.dll']
|
||||||
|
if env['WITH_BF_FFMPEG']:
|
||||||
|
dllsources += ['${LCGDIR}/ffmpeg/lib/avcodec-51.dll',
|
||||||
|
'${LCGDIR}/ffmpeg/lib/avformat-51.dll',
|
||||||
|
'${LCGDIR}/ffmpeg/lib/avutil-49.dll']
|
||||||
|
windlls = env.Install(dir=env['BF_INSTALLDIR'], source = dllsources)
|
||||||
|
allinstall += windlls
|
||||||
|
|
||||||
|
installtarget = env.Alias('install', allinstall)
|
||||||
|
bininstalltarget = env.Alias('install-bin', blenderinstall)
|
||||||
|
|
||||||
|
nsisaction = env.Action(btools.NSIS_Installer, btools.NSIS_print)
|
||||||
|
nsiscmd = env.Command('nsisinstaller', None, nsisaction)
|
||||||
|
nsisalias = env.Alias('nsis', nsiscmd)
|
||||||
|
|
||||||
|
if env['WITH_BF_PLAYER']:
|
||||||
|
blenderplayer = env.Alias('blenderplayer', B.program_list)
|
||||||
|
Depends(blenderplayer,installtarget)
|
||||||
|
|
||||||
|
if not env['WITH_BF_GAMEENGINE']:
|
||||||
|
blendernogame = env.Alias('blendernogame', B.program_list)
|
||||||
|
Depends(blendernogame,installtarget)
|
||||||
|
|
||||||
|
Depends(nsiscmd, allinstall)
|
||||||
|
|
||||||
|
Default(B.program_list)
|
||||||
|
|
||||||
|
if not env['WITHOUT_BF_INSTALL']:
|
||||||
|
Default(installtarget)
|
||||||
|
|
||||||
|
#------------ RELEASE
|
||||||
|
# TODO: zipup the installation
|
||||||
|
|
||||||
|
#------------ BLENDERPLAYER
|
||||||
|
# TODO: build stubs and link into blenderplayer
|
||||||
|
|
||||||
|
#------------ EPYDOC
|
||||||
|
# TODO: run epydoc
|
||||||
|
|
||||||
21
bin/.blender/.Blanguages
Normal file
21
bin/.blender/.Blanguages
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
English:en_US
|
||||||
|
Japanese:ja_JP
|
||||||
|
Dutch:nl_NL
|
||||||
|
Italian:it_IT
|
||||||
|
German:de_DE
|
||||||
|
Finnish:fi_FI
|
||||||
|
Swedish:sv_SE
|
||||||
|
French:fr_FR
|
||||||
|
Spanish:es_ES
|
||||||
|
Catalan:ca_ES
|
||||||
|
Czech:cs_CZ
|
||||||
|
Brazilian Portuguese:pt_BR
|
||||||
|
Simplified Chinese:zh_CN
|
||||||
|
Russian:ru_RU
|
||||||
|
Croatian:hr_HR
|
||||||
|
Serbian:sr
|
||||||
|
Ukrainian:uk
|
||||||
|
Polish:pl_PL
|
||||||
|
Romanian:ro
|
||||||
|
Arabic:ar
|
||||||
|
Bulgarian:bg
|
||||||
BIN
bin/.blender/.bfont.ttf
Normal file
BIN
bin/.blender/.bfont.ttf
Normal file
Binary file not shown.
124
blenderplayer/CMakeLists.txt
Normal file
124
blenderplayer/CMakeLists.txt
Normal file
@@ -0,0 +1,124 @@
|
|||||||
|
# $Id$
|
||||||
|
# ***** BEGIN GPL/BL DUAL 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. The Blender
|
||||||
|
# Foundation also sells licenses for use in proprietary software under
|
||||||
|
# the Blender License. See http://www.blender.org/BL/ for information
|
||||||
|
# about this.
|
||||||
|
#
|
||||||
|
# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
#
|
||||||
|
# The Original Code is Copyright (C) 2006, Blender Foundation
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# The Original Code is: all of this file.
|
||||||
|
#
|
||||||
|
# Contributor(s): Jacques Beaurain.
|
||||||
|
#
|
||||||
|
# ***** END GPL/BL DUAL LICENSE BLOCK *****
|
||||||
|
|
||||||
|
MESSAGE(STATUS "Configuring blenderplayer")
|
||||||
|
|
||||||
|
SETUP_LIBDIRS()
|
||||||
|
|
||||||
|
IF(WITH_QUICKTIME)
|
||||||
|
ADD_DEFINITIONS(-DWITH_QUICKTIME)
|
||||||
|
ENDIF(WITH_QUICKTIME)
|
||||||
|
|
||||||
|
ADD_CUSTOM_COMMAND(
|
||||||
|
OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/dna.c
|
||||||
|
COMMAND ${CMAKE_BINARY_DIR}/bin/${CMAKE_CFG_INTDIR}/makesdna ${CMAKE_CURRENT_BINARY_DIR}/dna.c ${CMAKE_SOURCE_DIR}/source/blender/makesdna/
|
||||||
|
DEPENDS ${CMAKE_BINARY_DIR}/bin/${CMAKE_CFG_INTDIR}/makesdna
|
||||||
|
)
|
||||||
|
|
||||||
|
IF(WIN32)
|
||||||
|
ADD_EXECUTABLE(blenderplayer ${EXETYPE} ${CMAKE_CURRENT_BINARY_DIR}/dna.c ../source/icons/winblender.rc)
|
||||||
|
ELSE(WIN32)
|
||||||
|
ADD_EXECUTABLE(blenderplayer ${CMAKE_CURRENT_BINARY_DIR}/dna.c)
|
||||||
|
ENDIF(WIN32)
|
||||||
|
|
||||||
|
ADD_DEPENDENCIES(blenderplayer makesdna)
|
||||||
|
|
||||||
|
FILE(READ ${CMAKE_BINARY_DIR}/cmake_blender_libs.txt BLENDER_LINK_LIBS)
|
||||||
|
|
||||||
|
SET(BLENDER_LINK_LIBS ${BLENDER_LINK_LIBS} gp_common gp_ghost blenkernel_blc)
|
||||||
|
|
||||||
|
IF(UNIX)
|
||||||
|
# Sort libraries
|
||||||
|
SET(BLENDER_SORTED_LIBS
|
||||||
|
gp_ghost
|
||||||
|
gp_common
|
||||||
|
bf_string
|
||||||
|
bf_ghost
|
||||||
|
bf_blenkernel
|
||||||
|
verse
|
||||||
|
bf_blenkernel
|
||||||
|
bf_decimation
|
||||||
|
bf_blenloader
|
||||||
|
bf_blenpluginapi
|
||||||
|
bf_blroutines
|
||||||
|
bf_converter
|
||||||
|
bf_sumo
|
||||||
|
bf_ketsji
|
||||||
|
extern_solid
|
||||||
|
extern_qhull
|
||||||
|
bf_bullet
|
||||||
|
bf_common
|
||||||
|
bf_dummy
|
||||||
|
bf_logic
|
||||||
|
bf_rasterizer
|
||||||
|
bf_oglrasterizer
|
||||||
|
bf_expressions
|
||||||
|
bf_scenegraph
|
||||||
|
bf_moto
|
||||||
|
bf_soundsystem
|
||||||
|
bf_kernel
|
||||||
|
bf_nodes
|
||||||
|
bf_imbuf
|
||||||
|
bf_avi
|
||||||
|
kx_network
|
||||||
|
bf_ngnetwork
|
||||||
|
bf_loopbacknetwork
|
||||||
|
extern_bullet
|
||||||
|
bf_guardedalloc
|
||||||
|
bf_memutil
|
||||||
|
bf_bmfont
|
||||||
|
bf_blenlib
|
||||||
|
bf_cineon
|
||||||
|
bf_openexr
|
||||||
|
bf_ftfont
|
||||||
|
extern_ftgl
|
||||||
|
bf_readblenfile
|
||||||
|
blenkernel_blc
|
||||||
|
bf_quicktime
|
||||||
|
)
|
||||||
|
|
||||||
|
FOREACH(SORTLIB ${BLENDER_SORTED_LIBS})
|
||||||
|
SET(REMLIB ${SORTLIB})
|
||||||
|
FOREACH(SEARCHLIB ${BLENDER_LINK_LIBS})
|
||||||
|
IF(${SEARCHLIB} STREQUAL ${SORTLIB})
|
||||||
|
SET(REMLIB "")
|
||||||
|
ENDIF(${SEARCHLIB} STREQUAL ${SORTLIB})
|
||||||
|
ENDFOREACH(SEARCHLIB)
|
||||||
|
IF(REMLIB)
|
||||||
|
MESSAGE(STATUS "Removing library ${REMLIB} from blenderplayer linking because: not configured")
|
||||||
|
LIST(REMOVE_ITEM BLENDER_SORTED_LIBS ${REMLIB})
|
||||||
|
ENDIF(REMLIB)
|
||||||
|
ENDFOREACH(SORTLIB)
|
||||||
|
|
||||||
|
TARGET_LINK_LIBRARIES(blenderplayer ${BLENDER_SORTED_LIBS})
|
||||||
|
ELSE(UNIX)
|
||||||
|
TARGET_LINK_LIBRARIES(blenderplayer ${BLENDER_LINK_LIBS})
|
||||||
|
ENDIF(UNIX)
|
||||||
|
|
||||||
|
SETUP_LIBLINKS(blenderplayer)
|
||||||
185
config/darwin-config.py
Normal file
185
config/darwin-config.py
Normal file
@@ -0,0 +1,185 @@
|
|||||||
|
LCGDIR = '#../lib/darwin-6.1-powerpc'
|
||||||
|
LIBDIR = '${LCGDIR}'
|
||||||
|
|
||||||
|
# enable ffmpeg support
|
||||||
|
WITH_BF_FFMPEG = 'true' # -DWITH_FFMPEG
|
||||||
|
BF_FFMPEG = LIBDIR +'/ffmpeg'
|
||||||
|
BF_FFMPEG_INC = '${BF_FFMPEG}/include'
|
||||||
|
BF_FFMPEG_LIBPATH='${BF_FFMPEG}/lib'
|
||||||
|
BF_FFMPEG_LIB = 'avformat.a avcodec.a avutil.a'
|
||||||
|
|
||||||
|
WITH_BF_VERSE = 'false'
|
||||||
|
BF_VERSE = "#extern/verse/dist"
|
||||||
|
BF_VERSE_LIBPATH = "${BF_BUILDDIR}/extern/verse/dist"
|
||||||
|
BF_VERSE_INCLUDE = BF_VERSE
|
||||||
|
BF_VERSE_LIBS = "libverse"
|
||||||
|
|
||||||
|
# python.org libs install in /library
|
||||||
|
BF_PYTHON_VERSION = '2.3'
|
||||||
|
if BF_PYTHON_VERSION=='2.3':
|
||||||
|
BF_PYTHON = '/System/Library/Frameworks/Python.framework/Versions/'
|
||||||
|
else:
|
||||||
|
BF_PYTHON = '/Library/Frameworks/Python.framework/Versions/'
|
||||||
|
|
||||||
|
BF_PYTHON_INC = '${BF_PYTHON}${BF_PYTHON_VERSION}/include/python${BF_PYTHON_VERSION}'
|
||||||
|
BF_PYTHON_BINARY = '${BF_PYTHON}${BF_PYTHON_VERSION}/bin/python${BF_PYTHON_VERSION}'
|
||||||
|
BF_PYTHON_LIB = ''
|
||||||
|
BF_PYTHON_LIBPATH = '${BF_PYTHON}${BF_PYTHON_VERSION}/lib/python${BF_PYTHON_VERSION}/config'
|
||||||
|
BF_PYTHON_LINKFLAGS = '-u __dummy -u _PyMac_Error -framework System -framework Python'
|
||||||
|
|
||||||
|
WITH_BF_OPENAL = 'true'
|
||||||
|
#different lib must be used following version of gcc
|
||||||
|
# for gcc 3.3
|
||||||
|
#BF_OPENAL = LIBDIR + '/openal'
|
||||||
|
# for gcc 3.4
|
||||||
|
BF_OPENAL = '#../lib/darwin-8.0.0-powerpc/openal'
|
||||||
|
|
||||||
|
BF_OPENAL_INC = '${BF_OPENAL}/include'
|
||||||
|
BF_OPENAL_LIB = 'openal'
|
||||||
|
BF_OPENAL_LIBPATH = '${BF_OPENAL}/lib'
|
||||||
|
|
||||||
|
WITH_BF_SDL = 'true'
|
||||||
|
BF_SDL = LIBDIR + '/sdl' #$(shell sdl-config --prefix)
|
||||||
|
BF_SDL_INC = '${BF_SDL}/include' #$(shell $(BF_SDL)/bin/sdl-config --cflags)
|
||||||
|
BF_SDL_LIB = 'SDL' #BF_SDL #$(shell $(BF_SDL)/bin/sdl-config --libs) -lSDL_mixer
|
||||||
|
BF_SDL_LIBPATH = '${BF_SDL}/lib'
|
||||||
|
|
||||||
|
WITH_BF_FMOD = 'false'
|
||||||
|
BF_FMOD = LIBDIR + '/fmod'
|
||||||
|
|
||||||
|
WITH_BF_OPENEXR = 'true'
|
||||||
|
BF_OPENEXR = '${LCGDIR}/openexr'
|
||||||
|
BF_OPENEXR_INC = '${BF_OPENEXR}/include ${BF_OPENEXR}/include/OpenEXR'
|
||||||
|
BF_OPENEXR_LIB = ' Iex Half IlmImf Imath IlmThread'
|
||||||
|
BF_OPENEXR_LIBPATH = '${BF_OPENEXR}/lib'
|
||||||
|
|
||||||
|
WITH_BF_DDS = 'true'
|
||||||
|
|
||||||
|
WITH_BF_JPEG = 'true'
|
||||||
|
BF_JPEG = LIBDIR + '/jpeg'
|
||||||
|
BF_JPEG_INC = '${BF_JPEG}/include'
|
||||||
|
BF_JPEG_LIB = 'jpeg'
|
||||||
|
BF_JPEG_LIBPATH = '${BF_JPEG}/lib'
|
||||||
|
|
||||||
|
WITH_BF_PNG = 'true'
|
||||||
|
BF_PNG = LIBDIR + '/png'
|
||||||
|
BF_PNG_INC = '${BF_PNG}/include'
|
||||||
|
BF_PNG_LIB = 'png'
|
||||||
|
BF_PNG_LIBPATH = '${BF_PNG}/lib'
|
||||||
|
|
||||||
|
BF_TIFF = LIBDIR + '/tiff'
|
||||||
|
BF_TIFF_INC = '${BF_TIFF}/include'
|
||||||
|
|
||||||
|
WITH_BF_ZLIB = 'true'
|
||||||
|
BF_ZLIB = '/usr'
|
||||||
|
BF_ZLIB_INC = '${BF_ZLIB}/include'
|
||||||
|
BF_ZLIB_LIB = 'z'
|
||||||
|
|
||||||
|
WITH_BF_INTERNATIONAL = 'true'
|
||||||
|
|
||||||
|
BF_GETTEXT = LIBDIR + '/gettext'
|
||||||
|
BF_GETTEXT_INC = '${BF_GETTEXT}/include'
|
||||||
|
BF_GETTEXT_LIB = 'intl'
|
||||||
|
BF_GETTEXT_LIBPATH = '${BF_GETTEXT}/lib'
|
||||||
|
|
||||||
|
WITH_BF_FTGL = 'true'
|
||||||
|
BF_FTGL = '#extern/bFTGL'
|
||||||
|
BF_FTGL_INC = '${BF_FTGL}/include'
|
||||||
|
BF_FTGL_LIB = 'extern_ftgl'
|
||||||
|
|
||||||
|
WITH_BF_GAMEENGINE='true'
|
||||||
|
WITH_BF_PLAYER='true'
|
||||||
|
|
||||||
|
WITH_BF_ODE = 'false'
|
||||||
|
BF_ODE = LIBDIR + '/ode'
|
||||||
|
BF_ODE_INC = '${BF_ODE}/include'
|
||||||
|
BF_ODE_LIB = '${BF_ODE}/lib/libode.a'
|
||||||
|
|
||||||
|
WITH_BF_BULLET = 'true'
|
||||||
|
BF_BULLET = '#extern/bullet2/src'
|
||||||
|
BF_BULLET_INC = '${BF_BULLET}'
|
||||||
|
BF_BULLET_LIB = 'extern_bullet'
|
||||||
|
|
||||||
|
BF_SOLID = '#extern/solid'
|
||||||
|
BF_SOLID_INC = '${BF_SOLID}'
|
||||||
|
BF_SOLID_LIB = 'extern_solid'
|
||||||
|
|
||||||
|
WITH_BF_YAFRAY = 'true'
|
||||||
|
|
||||||
|
#WITH_BF_NSPR = 'true'
|
||||||
|
#BF_NSPR = $(LIBDIR)/nspr
|
||||||
|
#BF_NSPR_INC = -I$(BF_NSPR)/include -I$(BF_NSPR)/include/nspr
|
||||||
|
#BF_NSPR_LIB =
|
||||||
|
|
||||||
|
# Uncomment the following line to use Mozilla inplace of netscape
|
||||||
|
#CPPFLAGS += -DMOZ_NOT_NET
|
||||||
|
# Location of MOZILLA/Netscape header files...
|
||||||
|
#BF_MOZILLA = $(LIBDIR)/mozilla
|
||||||
|
#BF_MOZILLA_INC = -I$(BF_MOZILLA)/include/mozilla/nspr -I$(BF_MOZILLA)/include/mozilla -I$(BF_MOZILLA)/include/mozilla/xpcom -I$(BF_MOZILLA)/include/mozilla/idl
|
||||||
|
#BF_MOZILLA_LIB =
|
||||||
|
# Will fall back to look in BF_MOZILLA_INC/nspr and BF_MOZILLA_LIB
|
||||||
|
# if this is not set.
|
||||||
|
#
|
||||||
|
# Be paranoid regarding library creation (do not update archives)
|
||||||
|
#BF_PARANOID = 'true'
|
||||||
|
|
||||||
|
# enable freetype2 support for text objects
|
||||||
|
BF_FREETYPE = LIBDIR + '/freetype'
|
||||||
|
BF_FREETYPE_INC = '${BF_FREETYPE}/include ${BF_FREETYPE}/include/freetype2'
|
||||||
|
BF_FREETYPE_LIB = 'freetype'
|
||||||
|
BF_FREETYPE_LIBPATH = '${BF_FREETYPE}/lib'
|
||||||
|
|
||||||
|
WITH_BF_QUICKTIME = 'true' # -DWITH_QUICKTIME
|
||||||
|
|
||||||
|
WITH_BF_ICONV = 'false'
|
||||||
|
BF_ICONV = LIBDIR + "/iconv"
|
||||||
|
BF_ICONV_INC = '${BF_ICONV}/include'
|
||||||
|
BF_ICONV_LIB = 'iconv'
|
||||||
|
BF_ICONV_LIBPATH = '${BF_ICONV}/lib'
|
||||||
|
|
||||||
|
# Mesa Libs should go here if your using them as well....
|
||||||
|
WITH_BF_STATICOPENGL = 'true'
|
||||||
|
BF_OPENGL_LIB = 'GL GLU'
|
||||||
|
BF_OPENGL_LIBPATH = '/System/Library/Frameworks/OpenGL.framework/Libraries'
|
||||||
|
BF_OPENGL_LINKFLAGS = '-framework OpenGL'
|
||||||
|
|
||||||
|
##
|
||||||
|
##CC = gcc
|
||||||
|
##CCC = g++
|
||||||
|
##ifeq ($CPU),alpha)
|
||||||
|
## CFLAGS += -pipe -fPIC -funsigned-char -fno-strict-aliasing -mieee
|
||||||
|
|
||||||
|
CFLAGS = ['-pipe','-fPIC','-funsigned-char','-fno-strict-aliasing']
|
||||||
|
|
||||||
|
CPPFLAGS = ['-fpascal-strings']
|
||||||
|
CCFLAGS = ['-pipe','-fPIC','-funsigned-char','-fno-strict-aliasing', '-fpascal-strings']
|
||||||
|
CXXFLAGS = ['-pipe','-fPIC','-funsigned-char','-fno-strict-aliasing', '-fpascal-strings']
|
||||||
|
PLATFORM_LINKFLAGS = '-fexceptions -framework CoreServices -framework Foundation -framework IOKit -framework AppKit -framework Carbon -framework AGL -framework AudioUnit -framework AudioToolbox -framework CoreAudio -framework QuickTime'
|
||||||
|
REL_CFLAGS = ['-O2']
|
||||||
|
REL_CCFLAGS = ['-O2']
|
||||||
|
##BF_DEPEND = 'true'
|
||||||
|
##
|
||||||
|
##AR = ar
|
||||||
|
##ARFLAGS = ruv
|
||||||
|
##ARFLAGSQUIET = ru
|
||||||
|
##
|
||||||
|
CC = 'gcc'
|
||||||
|
CXX = 'g++'
|
||||||
|
C_WARN = ' -Wall -Wno-long-double -Wdeclaration-after-statement '
|
||||||
|
|
||||||
|
CC_WARN = ' -Wall -Wno-long-double'
|
||||||
|
|
||||||
|
##FIX_STUBS_WARNINGS = -Wno-unused
|
||||||
|
|
||||||
|
LLIBS = 'stdc++ SystemStubs'
|
||||||
|
##LOPTS = --dynamic
|
||||||
|
##DYNLDFLAGS = -shared $(LDFLAGS)
|
||||||
|
|
||||||
|
BF_PROFILE_FLAGS = ' -pg -g '
|
||||||
|
BF_PROFILE = 'false'
|
||||||
|
|
||||||
|
BF_DEBUG = 'false'
|
||||||
|
BF_DEBUG_FLAGS = '-g'
|
||||||
|
|
||||||
|
BF_BUILDDIR='../build/darwin'
|
||||||
|
BF_INSTALLDIR='../install/darwin'
|
||||||
175
config/linux2-config.py
Normal file
175
config/linux2-config.py
Normal file
@@ -0,0 +1,175 @@
|
|||||||
|
LCGDIR = '../lib/linux2'
|
||||||
|
LIBDIR = "${LCGDIR}"
|
||||||
|
|
||||||
|
WITH_BF_VERSE = 'false'
|
||||||
|
BF_VERSE_INCLUDE = "#extern/verse/dist"
|
||||||
|
|
||||||
|
BF_PYTHON = '/usr'
|
||||||
|
BF_PYTHON_VERSION = '2.5'
|
||||||
|
BF_PYTHON_INC = '${BF_PYTHON}/include/python${BF_PYTHON_VERSION}'
|
||||||
|
BF_PYTHON_BINARY = '${BF_PYTHON}/bin/python${BF_PYTHON_VERSION}'
|
||||||
|
BF_PYTHON_LIB = 'python${BF_PYTHON_VERSION}' #BF_PYTHON+'/lib/python'+BF_PYTHON_VERSION+'/config/libpython'+BF_PYTHON_VERSION+'.a'
|
||||||
|
BF_PYTHON_LINKFLAGS = ['-Xlinker', '-export-dynamic']
|
||||||
|
|
||||||
|
WITH_BF_OPENAL = 'true'
|
||||||
|
BF_OPENAL = '/usr'
|
||||||
|
BF_OPENAL_INC = '${BF_OPENAL}/include'
|
||||||
|
BF_OPENAL_LIB = 'openal'
|
||||||
|
# some distros have a separate libalut
|
||||||
|
# if you get linker complaints, you need to uncomment the line below
|
||||||
|
# BF_OPENAL_LIB = 'openal alut'
|
||||||
|
|
||||||
|
WITH_BF_SDL = 'true'
|
||||||
|
BF_SDL = '/usr' #$(shell sdl-config --prefix)
|
||||||
|
BF_SDL_INC = '${BF_SDL}/include/SDL' #$(shell $(BF_SDL)/bin/sdl-config --cflags)
|
||||||
|
BF_SDL_LIB = 'SDL' #BF_SDL #$(shell $(BF_SDL)/bin/sdl-config --libs) -lSDL_mixer
|
||||||
|
|
||||||
|
WITH_BF_FMOD = 'false'
|
||||||
|
BF_FMOD = LIBDIR + '/fmod'
|
||||||
|
|
||||||
|
WITH_BF_OPENEXR = 'true'
|
||||||
|
BF_OPENEXR = '/usr'
|
||||||
|
BF_OPENEXR_INC = '${BF_OPENEXR}/include/OpenEXR'
|
||||||
|
BF_OPENEXR_LIB = 'Half IlmImf Iex Imath '
|
||||||
|
|
||||||
|
WITH_BF_DDS = 'true'
|
||||||
|
|
||||||
|
WITH_BF_JPEG = 'true'
|
||||||
|
BF_JPEG = '/usr'
|
||||||
|
BF_JPEG_INC = '${BF_JPEG}/include'
|
||||||
|
BF_JPEG_LIB = 'jpeg'
|
||||||
|
|
||||||
|
WITH_BF_PNG = 'true'
|
||||||
|
BF_PNG = '/usr'
|
||||||
|
BF_PNG_INC = '${BF_PNG}/include'
|
||||||
|
BF_PNG_LIB = 'png'
|
||||||
|
|
||||||
|
BF_TIFF = '/usr'
|
||||||
|
BF_TIFF_INC = '${BF_TIFF}/include'
|
||||||
|
|
||||||
|
WITH_BF_ZLIB = 'true'
|
||||||
|
BF_ZLIB = '/usr'
|
||||||
|
BF_ZLIB_INC = '${BF_ZLIB}/include'
|
||||||
|
BF_ZLIB_LIB = 'z'
|
||||||
|
|
||||||
|
WITH_BF_INTERNATIONAL = 'true'
|
||||||
|
|
||||||
|
BF_GETTEXT = '/usr'
|
||||||
|
BF_GETTEXT_INC = '${BF_GETTEXT}/include'
|
||||||
|
BF_GETTEXT_LIB = 'gettextlib'
|
||||||
|
BF_GETTEXT_LIBPATH = '${BF_GETTEXT}/lib'
|
||||||
|
|
||||||
|
WITH_BF_FTGL = 'true'
|
||||||
|
BF_FTGL = '#extern/bFTGL'
|
||||||
|
BF_FTGL_INC = '${BF_FTGL}/include'
|
||||||
|
BF_FTGL_LIB = 'extern_ftgl'
|
||||||
|
|
||||||
|
WITH_BF_GAMEENGINE='false'
|
||||||
|
|
||||||
|
WITH_BF_ODE = 'false'
|
||||||
|
BF_ODE = LIBDIR + '/ode'
|
||||||
|
BF_ODE_INC = BF_ODE + '/include'
|
||||||
|
BF_ODE_LIB = BF_ODE + '/lib/libode.a'
|
||||||
|
|
||||||
|
WITH_BF_BULLET = 'true'
|
||||||
|
BF_BULLET = '#extern/bullet2/src'
|
||||||
|
BF_BULLET_INC = '${BF_BULLET}'
|
||||||
|
BF_BULLET_LIB = 'extern_bullet'
|
||||||
|
|
||||||
|
BF_SOLID = '#extern/solid'
|
||||||
|
BF_SOLID_INC = '${BF_SOLID}'
|
||||||
|
BF_SOLID_LIB = 'extern_solid'
|
||||||
|
|
||||||
|
WITH_BF_YAFRAY = 'true'
|
||||||
|
|
||||||
|
#WITH_BF_NSPR = 'true'
|
||||||
|
#BF_NSPR = $(LIBDIR)/nspr
|
||||||
|
#BF_NSPR_INC = -I$(BF_NSPR)/include -I$(BF_NSPR)/include/nspr
|
||||||
|
#BF_NSPR_LIB =
|
||||||
|
|
||||||
|
# Uncomment the following line to use Mozilla inplace of netscape
|
||||||
|
#CPPFLAGS += -DMOZ_NOT_NET
|
||||||
|
# Location of MOZILLA/Netscape header files...
|
||||||
|
#BF_MOZILLA = $(LIBDIR)/mozilla
|
||||||
|
#BF_MOZILLA_INC = -I$(BF_MOZILLA)/include/mozilla/nspr -I$(BF_MOZILLA)/include/mozilla -I$(BF_MOZILLA)/include/mozilla/xpcom -I$(BF_MOZILLA)/include/mozilla/idl
|
||||||
|
#BF_MOZILLA_LIB =
|
||||||
|
# Will fall back to look in BF_MOZILLA_INC/nspr and BF_MOZILLA_LIB
|
||||||
|
# if this is not set.
|
||||||
|
#
|
||||||
|
# Be paranoid regarding library creation (do not update archives)
|
||||||
|
#BF_PARANOID = 'true'
|
||||||
|
|
||||||
|
# enable freetype2 support for text objects
|
||||||
|
BF_FREETYPE = '/usr'
|
||||||
|
BF_FREETYPE_INC = '${BF_FREETYPE}/include ${BF_FREETYPE}/include/freetype2'
|
||||||
|
BF_FREETYPE_LIB = 'freetype'
|
||||||
|
|
||||||
|
WITH_BF_QUICKTIME = 'false' # -DWITH_QUICKTIME
|
||||||
|
BF_QUICKTIME = '/usr/local'
|
||||||
|
BF_QUICKTIME_INC = '${BF_QUICKTIME}/include'
|
||||||
|
|
||||||
|
WITH_BF_ICONV = 'false'
|
||||||
|
BF_ICONV = LIBDIR + "/iconv"
|
||||||
|
BF_ICONV_INC = '${BF_ICONV}/include'
|
||||||
|
BF_ICONV_LIB = 'iconv'
|
||||||
|
BF_ICONV_LIBPATH = '${BF_ICONV}/lib'
|
||||||
|
|
||||||
|
# enable ffmpeg support
|
||||||
|
WITH_BF_FFMPEG = 'true' # -DWITH_FFMPEG
|
||||||
|
BF_FFMPEG = '#extern/ffmpeg'
|
||||||
|
BF_FFMPEG_LIB = ''
|
||||||
|
# Uncomment the following two lines to use system's ffmpeg
|
||||||
|
# BF_FFMPEG = '/usr'
|
||||||
|
# BF_FFMPEG_LIB = 'avformat avcodec swscale avutil'
|
||||||
|
BF_FFMPEG_INC = '${BF_FFMPEG}/include'
|
||||||
|
BF_FFMPEG_LIBPATH='${BF_FFMPEG}/lib'
|
||||||
|
|
||||||
|
# Mesa Libs should go here if your using them as well....
|
||||||
|
WITH_BF_STATICOPENGL = 'false'
|
||||||
|
BF_OPENGL = '/usr'
|
||||||
|
BF_OPENGL_INC = '${BF_OPENGL}/include'
|
||||||
|
BF_OPENGL_LIB = 'GL GLU X11 Xi'
|
||||||
|
BF_OPENGL_LIBPATH = '/usr/X11R6/lib'
|
||||||
|
BF_OPENGL_LIB_STATIC = '${BF_OPENGL}/libGL.a ${BF_OPENGL}/libGLU.a ${BF_OPENGL}/libXxf86vm.a ${BF_OPENGL}/libX11.a ${BF_OPENGL}/libXi.a ${BF_OPENGL}/libXext.a ${BF_OPENGL}/libXxf86vm.a'
|
||||||
|
|
||||||
|
##
|
||||||
|
CC = 'gcc'
|
||||||
|
CXX = 'g++'
|
||||||
|
##ifeq ($CPU),alpha)
|
||||||
|
## CFLAGS += -pipe -fPIC -funsigned-char -fno-strict-aliasing -mieee
|
||||||
|
|
||||||
|
CCFLAGS = ['-pipe','-fPIC','-funsigned-char','-fno-strict-aliasing']
|
||||||
|
|
||||||
|
CPPFLAGS = ['-DXP_UNIX']
|
||||||
|
CXXFLAGS = ['-pipe','-fPIC','-funsigned-char','-fno-strict-aliasing']
|
||||||
|
REL_CFLAGS = ['-O2']
|
||||||
|
REL_CCFLAGS = ['-O2']
|
||||||
|
##BF_DEPEND = 'true'
|
||||||
|
##
|
||||||
|
##AR = ar
|
||||||
|
##ARFLAGS = ruv
|
||||||
|
##ARFLAGSQUIET = ru
|
||||||
|
##
|
||||||
|
C_WARN = '-Wall -Wno-char-subscripts -Wdeclaration-after-statement'
|
||||||
|
|
||||||
|
CC_WARN = '-Wall'
|
||||||
|
|
||||||
|
##FIX_STUBS_WARNINGS = -Wno-unused
|
||||||
|
|
||||||
|
LLIBS = 'util c m dl pthread stdc++'
|
||||||
|
##LOPTS = --dynamic
|
||||||
|
##DYNLDFLAGS = -shared $(LDFLAGS)
|
||||||
|
|
||||||
|
BF_PROFILE_FLAGS = ['-pg','-g']
|
||||||
|
BF_PROFILE = 'false'
|
||||||
|
|
||||||
|
BF_DEBUG = 'false'
|
||||||
|
BF_DEBUG_FLAGS = '-g'
|
||||||
|
|
||||||
|
BF_BUILDDIR = '../build/linux2'
|
||||||
|
BF_INSTALLDIR='../install/linux2'
|
||||||
|
|
||||||
|
|
||||||
|
#Link against pthread
|
||||||
|
PLATFORM_LINKFLAGS = ['-pthread']
|
||||||
|
|
||||||
139
config/linuxcross-config.py
Normal file
139
config/linuxcross-config.py
Normal file
@@ -0,0 +1,139 @@
|
|||||||
|
LCGDIR = '../lib/windows'
|
||||||
|
LIBDIR = '${LCGDIR}'
|
||||||
|
|
||||||
|
WITH_BF_VERSE = 'false'
|
||||||
|
BF_VERSE_INCLUDE = "#extern/verse/dist"
|
||||||
|
|
||||||
|
WITH_BF_YAFRAY = 'true'
|
||||||
|
|
||||||
|
BF_PYTHON = LIBDIR + '/python'
|
||||||
|
BF_PYTHON_VERSION = '2.5'
|
||||||
|
BF_PYTHON_INC = '${BF_PYTHON}/include/python${BF_PYTHON_VERSION}'
|
||||||
|
BF_PYTHON_BINARY = 'python'
|
||||||
|
BF_PYTHON_LIB = 'python25'
|
||||||
|
BF_PYTHON_LIBPATH = '${BF_PYTHON}/lib'
|
||||||
|
|
||||||
|
WITH_BF_OPENAL = 'true'
|
||||||
|
BF_OPENAL = LIBDIR + '/openal'
|
||||||
|
BF_OPENAL_INC = '${BF_OPENAL}/include'
|
||||||
|
BF_OPENAL_LIB = 'openal_static'
|
||||||
|
BF_OPENAL_LIBPATH = '${BF_OPENAL}/lib'
|
||||||
|
|
||||||
|
WITH_BF_SDL = 'true'
|
||||||
|
BF_SDL = LIBDIR + '/sdl'
|
||||||
|
BF_SDL_INC = '${BF_SDL}/include'
|
||||||
|
BF_SDL_LIB = 'SDL'
|
||||||
|
BF_SDL_LIBPATH = '${BF_SDL}/lib'
|
||||||
|
|
||||||
|
BF_PTHREADS = LIBDIR + '/pthreads'
|
||||||
|
BF_PTHREADS_INC = '${BF_PTHREADS}/include'
|
||||||
|
BF_PTHREADS_LIB = 'pthreadGC2'
|
||||||
|
BF_PTHREADS_LIBPATH = '${BF_PTHREADS}/lib'
|
||||||
|
|
||||||
|
WITH_BF_FMOD = 'false'
|
||||||
|
BF_FMOD = LIBDIR + '/fmod'
|
||||||
|
|
||||||
|
WITH_BF_OPENEXR = 'true'
|
||||||
|
BF_OPENEXR = LIBDIR + '/gcc/openexr'
|
||||||
|
BF_OPENEXR_INC = '${BF_OPENEXR}/include ${BF_OPENEXR}/include/OpenEXR'
|
||||||
|
BF_OPENEXR_LIB = ' Half IlmImf Iex '
|
||||||
|
BF_OPENEXR_LIBPATH = '${BF_OPENEXR}/lib'
|
||||||
|
|
||||||
|
WITH_BF_DDS = 'true'
|
||||||
|
|
||||||
|
WITH_BF_JPEG = 'true'
|
||||||
|
BF_JPEG = LIBDIR + '/jpeg'
|
||||||
|
BF_JPEG_INC = '${BF_JPEG}/include'
|
||||||
|
BF_JPEG_LIB = 'jpeg'
|
||||||
|
BF_JPEG_LIBPATH = '${BF_JPEG}/lib'
|
||||||
|
|
||||||
|
WITH_BF_PNG = 'true'
|
||||||
|
BF_PNG = LIBDIR + '/png'
|
||||||
|
BF_PNG_INC = '${BF_PNG}/include'
|
||||||
|
BF_PNG_LIB = 'png'
|
||||||
|
BF_PNG_LIBPATH = '${BF_PNG}/lib'
|
||||||
|
|
||||||
|
BF_TIFF = LIBDIR + '/tiff'
|
||||||
|
BF_TIFF_INC = '${BF_TIFF}/include'
|
||||||
|
|
||||||
|
WITH_BF_ZLIB = 'true'
|
||||||
|
BF_ZLIB = LIBDIR + '/zlib'
|
||||||
|
BF_ZLIB_INC = '${BF_ZLIB}/include'
|
||||||
|
#BF_ZLIB_LIB = 'z'
|
||||||
|
BF_ZLIB_LIBPATH = '${BF_ZLIB}/lib'
|
||||||
|
|
||||||
|
WITH_BF_INTERNATIONAL = 'true'
|
||||||
|
|
||||||
|
BF_GETTEXT = LIBDIR + '/gettext'
|
||||||
|
BF_GETTEXT_INC = '${BF_GETTEXT}/include'
|
||||||
|
BF_GETTEXT_LIB = 'gnu_gettext'
|
||||||
|
BF_GETTEXT_LIBPATH = '${BF_GETTEXT}/lib'
|
||||||
|
|
||||||
|
WITH_BF_FTGL = 'true'
|
||||||
|
BF_FTGL = LIBDIR + '/ftgl'
|
||||||
|
BF_FTGL_INC = '${BF_FTGL}/include'
|
||||||
|
BF_FTGL_LIB = 'extern_ftgl'
|
||||||
|
|
||||||
|
WITH_BF_GAMEENGINE = 'false'
|
||||||
|
|
||||||
|
WITH_BF_ODE = 'true'
|
||||||
|
BF_ODE = LIBDIR + '/ode'
|
||||||
|
BF_ODE_INC = BF_ODE + '/include'
|
||||||
|
BF_ODE_LIB = BF_ODE + '/lib/libode.a'
|
||||||
|
|
||||||
|
WITH_BF_BULLET = 'true'
|
||||||
|
BF_BULLET = '#extern/bullet2/src'
|
||||||
|
BF_BULLET_INC = '${BF_BULLET}'
|
||||||
|
BF_BULLET_LIB = 'extern_bullet'
|
||||||
|
|
||||||
|
BF_SOLID = '#extern/solid'
|
||||||
|
BF_SOLID_INC = '${BF_SOLID}'
|
||||||
|
BF_SOLID_LIB = 'extern_solid'
|
||||||
|
|
||||||
|
# enable freetype2 support for text objects
|
||||||
|
BF_FREETYPE = LIBDIR + '/gcc/freetype'
|
||||||
|
BF_FREETYPE_INC = '${BF_FREETYPE}/include ${BF_FREETYPE}/include/freetype2'
|
||||||
|
BF_FREETYPE_LIB = 'freetype'
|
||||||
|
BF_FREETYPE_LIBPATH = '${BF_FREETYPE}/lib'
|
||||||
|
|
||||||
|
WITH_BF_QUICKTIME = 'false' # -DWITH_QUICKTIME
|
||||||
|
BF_QUICKTIME = '/usr/local'
|
||||||
|
BF_QUICKTIME_INC = '${BF_QUICKTIME}/include'
|
||||||
|
|
||||||
|
WITH_BF_ICONV = 'false'
|
||||||
|
BF_ICONV = LIBDIR + "/iconv"
|
||||||
|
BF_ICONV_INC = '${BF_ICONV}/include'
|
||||||
|
BF_ICONV_LIB = 'iconv'
|
||||||
|
BF_ICONV_LIBPATH = '${BF_ICONV}/lib'
|
||||||
|
|
||||||
|
# Mesa Libs should go here if your using them as well....
|
||||||
|
WITH_BF_STATICOPENGL = 'false'
|
||||||
|
BF_OPENGL = 'C:\\MingW'
|
||||||
|
BF_OPENGL_INC = '${BF_OPENGL}/include'
|
||||||
|
BF_OPENGL_LIBINC = '${BF_OPENGL}/lib'
|
||||||
|
BF_OPENGL_LIB = 'opengl32 glu32'
|
||||||
|
BF_OPENGL_LIB_STATIC = [ '${BF_OPENGL}/lib/libGL.a', '${BF_OPENGL}/lib/libGLU.a',
|
||||||
|
'${BF_OPENGL}/lib/libXmu.a', '${BF_OPENGL}/lib/libXext.a',
|
||||||
|
'${BF_OPENGL}/lib/libX11.a', '${BF_OPENGL}/lib/libXi.a' ]
|
||||||
|
|
||||||
|
CC = 'i586-mingw32msvc-gcc'
|
||||||
|
CXX = 'i586-mingw32msvc-g++'
|
||||||
|
|
||||||
|
CCFLAGS = [ '-pipe', '-funsigned-char', '-fno-strict-aliasing' ]
|
||||||
|
|
||||||
|
CPPFLAGS = [ '-DXP_UNIX', '-DWIN32', '-DFREE_WINDOWS' ]
|
||||||
|
CXXFLAGS = ['-pipe', '-mwindows', '-funsigned-char', '-fno-strict-aliasing' ]
|
||||||
|
REL_CFLAGS = [ '-O2' ]
|
||||||
|
REL_CCFLAGS = [ '-O2' ]
|
||||||
|
C_WARN = [ '-Wall' , '-Wno-char-subscripts', '-Wdeclaration-after-statement' ]
|
||||||
|
|
||||||
|
CC_WARN = [ '-Wall' ]
|
||||||
|
|
||||||
|
|
||||||
|
LLIBS = [ '-ldxguid', '-lgdi32', '-lmsvcrt', '-lwinmm', '-lmingw32', '-lm', '-lws2_32', '-lz'] #'-lutil', '-lc', '-lm', '-ldl', '-lpthread' ]
|
||||||
|
|
||||||
|
BF_DEBUG = 'false'
|
||||||
|
BF_DEBUG_FLAGS= ''
|
||||||
|
|
||||||
|
BF_BUILDDIR = '../build/linuxcross'
|
||||||
|
BF_INSTALLDIR='../install/linuxcross'
|
||||||
160
config/openbsd3-config.py
Normal file
160
config/openbsd3-config.py
Normal file
@@ -0,0 +1,160 @@
|
|||||||
|
LCGDIR = '../lib/openbsd3'
|
||||||
|
LIBDIR = '${LCGDIR}'
|
||||||
|
|
||||||
|
BF_PYTHON = '/usr/local'
|
||||||
|
BF_PYTHON_VERSION = '2.5'
|
||||||
|
BF_PYTHON_INC = '${BF_PYTHON}/include/python${BF_PYTHON_VERSION}'
|
||||||
|
BF_PYTHON_BINARY = '${BF_PYTHON}/bin/python${BF_PYTHON_VERSION}'
|
||||||
|
BF_PYTHON_LIB = 'python${BF_PYTHON_VERSION}'
|
||||||
|
BF_PYTHON_LIBPATH = '${BF_PYTHON}/lib/python${BF_PYTHON_VERSION}/config'
|
||||||
|
|
||||||
|
WITH_BF_OPENAL = 'false'
|
||||||
|
#BF_OPENAL = LIBDIR + '/openal'
|
||||||
|
#BF_OPENAL_INC = '${BF_OPENAL}/include'
|
||||||
|
#BF_OPENAL_LIB = 'openal'
|
||||||
|
#BF_OPENAL_LIBPATH = '${BF_OPENAL}/lib'
|
||||||
|
|
||||||
|
WITH_BF_SDL = 'true'
|
||||||
|
BF_SDL = '/usr/local' #$(shell sdl-config --prefix)
|
||||||
|
BF_SDL_INC = '${BF_SDL}/include/SDL' #$(shell $(BF_SDL)/bin/sdl-config --cflags)
|
||||||
|
BF_SDL_LIB = 'SDL' #BF_SDL #$(shell $(BF_SDL)/bin/sdl-config --libs) -lSDL_mixer
|
||||||
|
BF_SDL_LIBPATH = '${BF_SDL}/lib'
|
||||||
|
|
||||||
|
WITH_BF_FMOD = 'false'
|
||||||
|
BF_FMOD = LIBDIR + '/fmod'
|
||||||
|
|
||||||
|
WITH_BF_OPENEXR = 'false'
|
||||||
|
BF_OPENEXR = '/usr/local'
|
||||||
|
BF_OPENEXR_INC = '${BF_OPENEXR}/include/OpenEXR'
|
||||||
|
BF_OPENEXR_LIB = 'Half IlmImf Iex Imath '
|
||||||
|
|
||||||
|
WITH_BF_DDS = 'true'
|
||||||
|
|
||||||
|
WITH_BF_JPEG = 'true'
|
||||||
|
BF_JPEG = '/usr/local'
|
||||||
|
BF_JPEG_INC = '${BF_JPEG}/include'
|
||||||
|
BF_JPEG_LIB = 'jpeg'
|
||||||
|
BF_JPEG_LIBPATH = '${BF_JPEG}/lib'
|
||||||
|
|
||||||
|
WITH_BF_PNG = 'true'
|
||||||
|
BF_PNG = '/usr/local'
|
||||||
|
BF_PNG_INC = '${BF_PNG}/include/libpng'
|
||||||
|
BF_PNG_LIB = 'png'
|
||||||
|
BF_PNG_LIBPATH = '${BF_PNG}/lib'
|
||||||
|
|
||||||
|
BF_TIFF = '/usr/local'
|
||||||
|
BF_TIFF_INC = '${BF_TIFF}/include'
|
||||||
|
|
||||||
|
WITH_BF_ZLIB = 'true'
|
||||||
|
BF_ZLIB = '/usr/local'
|
||||||
|
BF_ZLIB_INC = '${BF_ZLIB}/include'
|
||||||
|
BF_ZLIB_LIB = 'z'
|
||||||
|
|
||||||
|
WITH_BF_INTERNATIONAL = 'true'
|
||||||
|
|
||||||
|
BF_GETTEXT = '/usr/local'
|
||||||
|
BF_GETTEXT_INC = '${BF_GETTEXT}/include'
|
||||||
|
BF_GETTEXT_LIB = 'intl iconv'
|
||||||
|
BF_GETTEXT_LIBPATH = '${BF_GETTEXT}/lib'
|
||||||
|
|
||||||
|
WITH_BF_FTGL = 'true'
|
||||||
|
BF_FTGL = '#extern/bFTGL'
|
||||||
|
BF_FTGL_INC = '${BF_FTGL}/include'
|
||||||
|
BF_FTGL_LIB = 'extern_ftgl'
|
||||||
|
|
||||||
|
WITH_BF_GAMEENGINE='false'
|
||||||
|
|
||||||
|
WITH_BF_ODE = 'false'
|
||||||
|
BF_ODE = LIBDIR + '/ode'
|
||||||
|
BF_ODE_INC = '${BF_ODE}/include'
|
||||||
|
BF_ODE_LIB = '${BF_ODE}/lib/libode.a'
|
||||||
|
|
||||||
|
WITH_BF_BULLET = 'true'
|
||||||
|
BF_BULLET = '#extern/bullet2/src'
|
||||||
|
BF_BULLET_INC = '${BF_BULLET}'
|
||||||
|
BF_BULLET_LIB = 'extern_bullet'
|
||||||
|
|
||||||
|
BF_SOLID = '#extern/solid'
|
||||||
|
BF_SOLID_INC = '${BF_SOLID}'
|
||||||
|
BF_SOLID_LIB = 'extern_solid'
|
||||||
|
|
||||||
|
WITH_BF_YAFRAY = 'true'
|
||||||
|
|
||||||
|
#WITH_BF_NSPR = 'true'
|
||||||
|
#BF_NSPR = $(LIBDIR)/nspr
|
||||||
|
#BF_NSPR_INC = -I$(BF_NSPR)/include -I$(BF_NSPR)/include/nspr
|
||||||
|
#BF_NSPR_LIB =
|
||||||
|
|
||||||
|
# Uncomment the following line to use Mozilla inplace of netscape
|
||||||
|
#CPPFLAGS += -DMOZ_NOT_NET
|
||||||
|
# Location of MOZILLA/Netscape header files...
|
||||||
|
#BF_MOZILLA = $(LIBDIR)/mozilla
|
||||||
|
#BF_MOZILLA_INC = -I$(BF_MOZILLA)/include/mozilla/nspr -I$(BF_MOZILLA)/include/mozilla -I$(BF_MOZILLA)/include/mozilla/xpcom -I$(BF_MOZILLA)/include/mozilla/idl
|
||||||
|
#BF_MOZILLA_LIB =
|
||||||
|
# Will fall back to look in BF_MOZILLA_INC/nspr and BF_MOZILLA_LIB
|
||||||
|
# if this is not set.
|
||||||
|
#
|
||||||
|
# Be paranoid regarding library creation (do not update archives)
|
||||||
|
#BF_PARANOID = 'true'
|
||||||
|
|
||||||
|
# enable freetype2 support for text objects
|
||||||
|
BF_FREETYPE = '/usr/X11R6'
|
||||||
|
BF_FREETYPE_INC = '${BF_FREETYPE}/include ${BF_FREETYPE}/include/freetype2'
|
||||||
|
BF_FREETYPE_LIB = 'freetype'
|
||||||
|
BF_FREETYPE_LIBPATH = '${BF_FREETYPE}/lib'
|
||||||
|
|
||||||
|
WITH_BF_QUICKTIME = 'false' # -DWITH_QUICKTIME
|
||||||
|
|
||||||
|
WITH_BF_ICONV = 'false'
|
||||||
|
BF_ICONV = LIBDIR + "/iconv"
|
||||||
|
BF_ICONV_INC = '${BF_ICONV}/include'
|
||||||
|
BF_ICONV_LIB = 'iconv'
|
||||||
|
BF_ICONV_LIBPATH = '${BF_ICONV}/lib'
|
||||||
|
|
||||||
|
# Mesa Libs should go here if your using them as well....
|
||||||
|
WITH_BF_STATICOPENGL = 'true'
|
||||||
|
BF_OPENGL = '/usr/X11R6'
|
||||||
|
BF_OPENGL_INC = '${BF_OPENGL}/include'
|
||||||
|
BF_OPENGL_LIB = 'GL GLU X11 Xi'
|
||||||
|
BF_OPENGL_LIBPATH = '${BF_OPENGL}/lib'
|
||||||
|
BF_OPENGL_LIB_STATIC = '${BF_OPENGL_LIBPATH}/libGL.a ${BF_OPENGL_LIBPATH}/libGLU.a ${BF_OPENGL_LIBPATH}/libXxf86vm.a ${BF_OPENGL_LIBPATH}/libX11.a ${BF_OPENGL_LIBPATH}/libXi.a ${BF_OPENGL_LIBPATH}/libXext.a ${BF_OPENGL_LIBPATH}/libXxf86vm.a'
|
||||||
|
|
||||||
|
##
|
||||||
|
##CC = gcc
|
||||||
|
##CCC = g++
|
||||||
|
##ifeq ($CPU),alpha)
|
||||||
|
## CFLAGS += -pipe -fPIC -funsigned-char -fno-strict-aliasing -mieee
|
||||||
|
|
||||||
|
CFLAGS = ['-pipe','-fPIC','-funsigned-char','-fno-strict-aliasing']
|
||||||
|
|
||||||
|
CPPFLAGS = []
|
||||||
|
CCFLAGS = ['-pipe','-fPIC','-funsigned-char','-fno-strict-aliasing']
|
||||||
|
CXXFLAGS = ['-pipe','-fPIC','-funsigned-char','-fno-strict-aliasing']
|
||||||
|
REL_CFLAGS = ['-O2']
|
||||||
|
REL_CCFLAGS = ['-O2']
|
||||||
|
##BF_DEPEND = 'true'
|
||||||
|
##
|
||||||
|
##AR = ar
|
||||||
|
##ARFLAGS = ruv
|
||||||
|
##ARFLAGSQUIET = ru
|
||||||
|
##
|
||||||
|
CC = 'gcc'
|
||||||
|
CXX = 'g++'
|
||||||
|
C_WARN = '-Wall -Wdeclaration-after-statement'
|
||||||
|
|
||||||
|
CC_WARN = '-Wall'
|
||||||
|
|
||||||
|
##FIX_STUBS_WARNINGS = -Wno-unused
|
||||||
|
|
||||||
|
LLIBS = 'm stdc++ pthread util'
|
||||||
|
##LOPTS = --dynamic
|
||||||
|
##DYNLDFLAGS = -shared $(LDFLAGS)
|
||||||
|
|
||||||
|
BF_PROFILE_FLAGS = ' -pg -g '
|
||||||
|
BF_PROFILE = 'false'
|
||||||
|
|
||||||
|
BF_DEBUG = 'false'
|
||||||
|
BF_DEBUG_FLAGS = '-g'
|
||||||
|
|
||||||
|
BF_BUILDDIR='../build/openbsd3'
|
||||||
|
BF_INSTALLDIR='../install/openbsd3'
|
||||||
171
config/sunos5-config.py
Normal file
171
config/sunos5-config.py
Normal file
@@ -0,0 +1,171 @@
|
|||||||
|
LCGDIR = '../lib/sunos5'
|
||||||
|
LIBDIR = '${LCGDIR}'
|
||||||
|
|
||||||
|
BF_PYTHON = '/usr/local'
|
||||||
|
BF_PYTHON_VERSION = '2.5'
|
||||||
|
BF_PYTHON_INC = '${BF_PYTHON}/include/python${BF_PYTHON_VERSION}'
|
||||||
|
BF_PYTHON_BINARY = '${BF_PYTHON}/bin/python${BF_PYTHON_VERSION}'
|
||||||
|
BF_PYTHON_LIB = 'python${BF_PYTHON_VERSION}' #BF_PYTHON+'/lib/python'+BF_PYTHON_VERSION+'/config/libpython'+BF_PYTHON_VERSION+'.a'
|
||||||
|
BF_PYTHON_LINKFLAGS = ['-Xlinker', '-export-dynamic']
|
||||||
|
|
||||||
|
WITH_BF_OPENAL = 'true'
|
||||||
|
BF_OPENAL = '/usr/local'
|
||||||
|
BF_OPENAL_INC = '${BF_OPENAL}/include'
|
||||||
|
BF_OPENAL_LIBPATH = '${BF_OPENAL}/lib'
|
||||||
|
BF_OPENAL_LIB = 'openal'
|
||||||
|
|
||||||
|
WITH_BF_SDL = 'true'
|
||||||
|
BF_SDL = '/usr/local' #$(shell sdl-config --prefix)
|
||||||
|
BF_SDL_INC = '${BF_SDL}/include/SDL' #$(shell $(BF_SDL)/bin/sdl-config --cflags)
|
||||||
|
BF_SDL_LIBPATH = '${BF_SDL}/lib'
|
||||||
|
BF_SDL_LIB = 'SDL' #BF_SDL #$(shell $(BF_SDL)/bin/sdl-config --libs) -lSDL_mixer
|
||||||
|
|
||||||
|
WITH_BF_FMOD = 'false'
|
||||||
|
BF_FMOD = LIBDIR + '/fmod'
|
||||||
|
|
||||||
|
WITH_BF_OPENEXR = 'true'
|
||||||
|
BF_OPENEXR = '/usr/local'
|
||||||
|
BF_OPENEXR_INC = ['${BF_OPENEXR}/include', '${BF_OPENEXR}/include/OpenEXR' ]
|
||||||
|
BF_OPENEXR_LIBPATH = '${BF_OPENEXR}/lib'
|
||||||
|
BF_OPENEXR_LIB = 'Half IlmImf Iex Imath '
|
||||||
|
|
||||||
|
WITH_BF_DDS = 'true'
|
||||||
|
|
||||||
|
WITH_BF_JPEG = 'true'
|
||||||
|
BF_JPEG = '/usr/local'
|
||||||
|
BF_JPEG_INC = '${BF_JPEG}/include'
|
||||||
|
BF_JPEG_LIBPATH = '${BF_JPEG}/lib'
|
||||||
|
BF_JPEG_LIB = 'jpeg'
|
||||||
|
|
||||||
|
WITH_BF_PNG = 'true'
|
||||||
|
BF_PNG = '/usr/local'
|
||||||
|
BF_PNG_INC = '${BF_PNG}/include'
|
||||||
|
BF_PNG_LIBPATH = '${BF_PNG}/lib'
|
||||||
|
BF_PNG_LIB = 'png'
|
||||||
|
|
||||||
|
BF_TIFF = '/usr/local'
|
||||||
|
BF_TIFF_INC = '${BF_TIFF}/include'
|
||||||
|
|
||||||
|
WITH_BF_ZLIB = 'true'
|
||||||
|
BF_ZLIB = '/usr'
|
||||||
|
BF_ZLIB_INC = '${BF_ZLIB}/include'
|
||||||
|
BF_ZLIB_LIBPATH = '${BF_ZLIB}/lib'
|
||||||
|
BF_ZLIB_LIB = 'z'
|
||||||
|
|
||||||
|
WITH_BF_INTERNATIONAL = 'true'
|
||||||
|
|
||||||
|
BF_GETTEXT = '/usr/local'
|
||||||
|
BF_GETTEXT_INC = '${BF_GETTEXT}/include'
|
||||||
|
BF_GETTEXT_LIB = 'gettextlib'
|
||||||
|
BF_GETTEXT_LIBPATH = '${BF_GETTEXT}/lib'
|
||||||
|
|
||||||
|
WITH_BF_FTGL = 'true'
|
||||||
|
BF_FTGL = '#extern/bFTGL'
|
||||||
|
BF_FTGL_INC = '${BF_FTGL}/include'
|
||||||
|
BF_FTGL_LIB = 'extern_ftgl'
|
||||||
|
|
||||||
|
WITH_BF_GAMEENGINE='false'
|
||||||
|
|
||||||
|
WITH_BF_ODE = 'false'
|
||||||
|
BF_ODE = LIBDIR + '/ode'
|
||||||
|
BF_ODE_INC = BF_ODE + '/include'
|
||||||
|
BF_ODE_LIB = BF_ODE + '/lib/libode.a'
|
||||||
|
|
||||||
|
WITH_BF_BULLET = 'true'
|
||||||
|
BF_BULLET = '#extern/bullet2/src'
|
||||||
|
BF_BULLET_INC = '${BF_BULLET}'
|
||||||
|
BF_BULLET_LIB = 'extern_bullet'
|
||||||
|
|
||||||
|
BF_SOLID = '#extern/solid'
|
||||||
|
BF_SOLID_INC = '${BF_SOLID}'
|
||||||
|
BF_SOLID_LIB = 'extern_solid'
|
||||||
|
|
||||||
|
WITH_BF_YAFRAY = 'true'
|
||||||
|
|
||||||
|
#WITH_BF_NSPR = 'true'
|
||||||
|
#BF_NSPR = $(LIBDIR)/nspr
|
||||||
|
#BF_NSPR_INC = -I$(BF_NSPR)/include -I$(BF_NSPR)/include/nspr
|
||||||
|
#BF_NSPR_LIB =
|
||||||
|
|
||||||
|
# Uncomment the following line to use Mozilla inplace of netscape
|
||||||
|
#CPPFLAGS += -DMOZ_NOT_NET
|
||||||
|
# Location of MOZILLA/Netscape header files...
|
||||||
|
#BF_MOZILLA = $(LIBDIR)/mozilla
|
||||||
|
#BF_MOZILLA_INC = -I$(BF_MOZILLA)/include/mozilla/nspr -I$(BF_MOZILLA)/include/mozilla -I$(BF_MOZILLA)/include/mozilla/xpcom -I$(BF_MOZILLA)/include/mozilla/idl
|
||||||
|
#BF_MOZILLA_LIB =
|
||||||
|
# Will fall back to look in BF_MOZILLA_INC/nspr and BF_MOZILLA_LIB
|
||||||
|
# if this is not set.
|
||||||
|
#
|
||||||
|
# Be paranoid regarding library creation (do not update archives)
|
||||||
|
#BF_PARANOID = 'true'
|
||||||
|
|
||||||
|
# enable freetype2 support for text objects
|
||||||
|
BF_FREETYPE = '/usr/local'
|
||||||
|
BF_FREETYPE_INC = '${BF_FREETYPE}/include ${BF_FREETYPE}/include/freetype2'
|
||||||
|
BF_FREETYPE_LIBPATH = '${BF_FREETYPE}/lib'
|
||||||
|
BF_FREETYPE_LIB = 'freetype'
|
||||||
|
|
||||||
|
WITH_BF_QUICKTIME = 'false' # -DWITH_QUICKTIME
|
||||||
|
BF_QUICKTIME = '/usr/local'
|
||||||
|
BF_QUICKTIME_INC = '${BF_QUICKTIME}/include'
|
||||||
|
|
||||||
|
WITH_BF_ICONV = 'true'
|
||||||
|
BF_ICONV = "/usr"
|
||||||
|
BF_ICONV_INC = '${BF_ICONV}/include'
|
||||||
|
BF_ICONV_LIB = 'iconv'
|
||||||
|
BF_ICONV_LIBPATH = '${BF_ICONV}/lib'
|
||||||
|
|
||||||
|
# enable ffmpeg support
|
||||||
|
WITH_BF_FFMPEG = 'false' # -DWITH_FFMPEG
|
||||||
|
BF_FFMPEG = '/usr/local'
|
||||||
|
BF_FFMPEG_INC = '${BF_FFMPEG}/include'
|
||||||
|
BF_FFMPEG_LIBPATH='${BF_FFMPEG}/lib'
|
||||||
|
BF_FFMPEG_LIB = 'avformat avcodec avutil'
|
||||||
|
|
||||||
|
# Mesa Libs should go here if your using them as well....
|
||||||
|
WITH_BF_STATICOPENGL = 'false'
|
||||||
|
BF_OPENGL = '/usr/openwin'
|
||||||
|
BF_OPENGL_INC = '${BF_OPENGL}/include'
|
||||||
|
BF_OPENGL_LIB = 'GL GLU X11 Xi'
|
||||||
|
BF_OPENGL_LIBPATH = '${BF_OPENGL}/lib'
|
||||||
|
BF_OPENGL_LIB_STATIC = '${BF_OPENGL_LIBPATH}/libGL.a ${BF_OPENGL_LIBPATH}/libGLU.a ${BF_OPENGL_LIBPATH}/libXxf86vm.a ${BF_OPENGL_LIBPATH}/libX11.a ${BF_OPENGL_LIBPATH}/libXi.a ${BF_OPENGL_LIBPATH}/libXext.a ${BF_OPENGL_LIBPATH}/libXxf86vm.a'
|
||||||
|
|
||||||
|
##
|
||||||
|
CC = 'gcc'
|
||||||
|
CXX = 'g++'
|
||||||
|
##ifeq ($CPU),alpha)
|
||||||
|
## CFLAGS += -pipe -fPIC -funsigned-char -fno-strict-aliasing -mieee
|
||||||
|
|
||||||
|
CCFLAGS = ['-pipe','-fPIC','-funsigned-char','-fno-strict-aliasing']
|
||||||
|
|
||||||
|
CPPFLAGS = ['-DXP_UNIX', '-DSUN_OGL_NO_VERTEX_MACROS']
|
||||||
|
CXXFLAGS = ['-pipe','-fPIC','-funsigned-char','-fno-strict-aliasing']
|
||||||
|
REL_CFLAGS = ['-O2']
|
||||||
|
REL_CCFLAGS = ['-O2']
|
||||||
|
##BF_DEPEND = 'true'
|
||||||
|
##
|
||||||
|
##AR = ar
|
||||||
|
##ARFLAGS = ruv
|
||||||
|
##ARFLAGSQUIET = ru
|
||||||
|
##
|
||||||
|
C_WARN = '-Wall -Wno-char-subscripts -Wdeclaration-after-statement'
|
||||||
|
|
||||||
|
CC_WARN = '-Wall'
|
||||||
|
|
||||||
|
##FIX_STUBS_WARNINGS = -Wno-unused
|
||||||
|
|
||||||
|
LLIBS = 'c m dl pthread stdc++'
|
||||||
|
##LOPTS = --dynamic
|
||||||
|
##DYNLDFLAGS = -shared $(LDFLAGS)
|
||||||
|
|
||||||
|
BF_PROFILE_FLAGS = ['-pg','-g']
|
||||||
|
BF_PROFILE = 'false'
|
||||||
|
|
||||||
|
BF_DEBUG = 'false'
|
||||||
|
BF_DEBUG_FLAGS = ''
|
||||||
|
|
||||||
|
BF_BUILDDIR = '../build/sunos5'
|
||||||
|
BF_INSTALLDIR='../install/sunos5'
|
||||||
|
|
||||||
|
|
||||||
|
PLATFORM_LINKFLAGS = ['']
|
||||||
160
config/win32-mingw-config.py
Normal file
160
config/win32-mingw-config.py
Normal file
@@ -0,0 +1,160 @@
|
|||||||
|
LCGDIR = '#../lib/windows'
|
||||||
|
LIBDIR = "${LCGDIR}"
|
||||||
|
|
||||||
|
WITH_BF_VERSE = 'false'
|
||||||
|
BF_VERSE_INCLUDE = "#extern/verse/dist"
|
||||||
|
|
||||||
|
BF_PYTHON = LIBDIR + '/python'
|
||||||
|
BF_PYTHON_VERSION = '2.5'
|
||||||
|
BF_PYTHON_INC = '${BF_PYTHON}/include/python${BF_PYTHON_VERSION}'
|
||||||
|
BF_PYTHON_BINARY = 'python'
|
||||||
|
BF_PYTHON_LIB = 'python25'
|
||||||
|
BF_PYTHON_LIBPATH = '${BF_PYTHON}/lib'
|
||||||
|
|
||||||
|
WITH_BF_OPENAL = 'true'
|
||||||
|
BF_OPENAL = LIBDIR + '/openal'
|
||||||
|
BF_OPENAL_INC = '${BF_OPENAL}/include'
|
||||||
|
BF_OPENAL_LIB = 'openal_static'
|
||||||
|
BF_OPENAL_LIBPATH = '${BF_OPENAL}/lib'
|
||||||
|
|
||||||
|
WITH_BF_FFMPEG = 'false'
|
||||||
|
BF_FFMPEG_LIB = 'avformat avutil avcodec'
|
||||||
|
BF_FFMPEG_LIBPATH = LIBDIR + '/gcc/ffmpeg/lib'
|
||||||
|
BF_FFMPEG_INC = LIBDIR + '/gcc/ffmpeg/include'
|
||||||
|
|
||||||
|
WITH_BF_SDL = 'true'
|
||||||
|
BF_SDL = LIBDIR + '/sdl'
|
||||||
|
BF_SDL_INC = '${BF_SDL}/include'
|
||||||
|
BF_SDL_LIB = 'SDL'
|
||||||
|
BF_SDL_LIBPATH = '${BF_SDL}/lib'
|
||||||
|
|
||||||
|
BF_PTHREADS = LIBDIR + '/pthreads'
|
||||||
|
BF_PTHREADS_INC = '${BF_PTHREADS}/include'
|
||||||
|
BF_PTHREADS_LIB = 'pthreadGC2'
|
||||||
|
BF_PTHREADS_LIBPATH = '${BF_PTHREADS}/lib'
|
||||||
|
|
||||||
|
WITH_BF_FMOD = 'false'
|
||||||
|
BF_FMOD = LIBDIR + '/fmod'
|
||||||
|
|
||||||
|
WITH_BF_OPENEXR = 'true'
|
||||||
|
BF_OPENEXR = LIBDIR + '/gcc/openexr'
|
||||||
|
BF_OPENEXR_INC = '${BF_OPENEXR}/include ${BF_OPENEXR}/include/OpenEXR'
|
||||||
|
BF_OPENEXR_LIB = ' Half IlmImf Iex '
|
||||||
|
BF_OPENEXR_LIBPATH = '${BF_OPENEXR}/lib'
|
||||||
|
|
||||||
|
WITH_BF_DDS = 'true'
|
||||||
|
|
||||||
|
WITH_BF_JPEG = 'true'
|
||||||
|
BF_JPEG = LIBDIR + '/jpeg'
|
||||||
|
BF_JPEG_INC = '${BF_JPEG}/include'
|
||||||
|
BF_JPEG_LIB = 'jpeg'
|
||||||
|
BF_JPEG_LIBPATH = '${BF_JPEG}/lib'
|
||||||
|
|
||||||
|
WITH_BF_PNG = 'true'
|
||||||
|
BF_PNG = LIBDIR + '/png'
|
||||||
|
BF_PNG_INC = '${BF_PNG}/include'
|
||||||
|
BF_PNG_LIB = 'png'
|
||||||
|
BF_PNG_LIBPATH = '${BF_PNG}/lib'
|
||||||
|
|
||||||
|
BF_TIFF = LIBDIR + '/tiff'
|
||||||
|
BF_TIFF_INC = '${BF_TIFF}/include'
|
||||||
|
|
||||||
|
WITH_BF_ZLIB = 'true'
|
||||||
|
BF_ZLIB = LIBDIR + '/zlib'
|
||||||
|
BF_ZLIB_INC = '${BF_ZLIB}/include'
|
||||||
|
BF_ZLIB_LIBPATH = '${BF_ZLIB}/lib'
|
||||||
|
|
||||||
|
WITH_BF_INTERNATIONAL = 'true'
|
||||||
|
|
||||||
|
BF_GETTEXT = LIBDIR + '/gettext'
|
||||||
|
BF_GETTEXT_INC = '${BF_GETTEXT}/include'
|
||||||
|
BF_GETTEXT_LIB = 'gnu_gettext'
|
||||||
|
BF_GETTEXT_LIBPATH = '${BF_GETTEXT}/lib'
|
||||||
|
|
||||||
|
WITH_BF_FTGL = 'true'
|
||||||
|
BF_FTGL = LIBDIR + '/ftgl'
|
||||||
|
BF_FTGL_INC = '${BF_FTGL}/include'
|
||||||
|
BF_FTGL_LIB = 'extern_ftgl'
|
||||||
|
|
||||||
|
WITH_BF_GAMEENGINE = 'false'
|
||||||
|
|
||||||
|
WITH_BF_ODE = 'true'
|
||||||
|
BF_ODE = LIBDIR + '/ode'
|
||||||
|
BF_ODE_INC = BF_ODE + '/include'
|
||||||
|
BF_ODE_LIB = BF_ODE + '/lib/libode.a'
|
||||||
|
|
||||||
|
WITH_BF_BULLET = 'true'
|
||||||
|
BF_BULLET = '#extern/bullet2/src'
|
||||||
|
BF_BULLET_INC = '${BF_BULLET}'
|
||||||
|
BF_BULLET_LIB = 'extern_bullet'
|
||||||
|
|
||||||
|
BF_SOLID = '#extern/solid'
|
||||||
|
BF_SOLID_INC = '${BF_SOLID}'
|
||||||
|
BF_SOLID_LIB = 'extern_solid'
|
||||||
|
|
||||||
|
BF_WINTAB = LIBDIR + '/wintab'
|
||||||
|
BF_WINTAB_INC = '${BF_WINTAB}/INCLUDE'
|
||||||
|
|
||||||
|
WITH_BF_YAFRAY = 'true'
|
||||||
|
|
||||||
|
#WITH_BF_NSPR = 'true'
|
||||||
|
#BF_NSPR = $(LIBDIR)/nspr
|
||||||
|
#BF_NSPR_INC = -I$(BF_NSPR)/include -I$(BF_NSPR)/include/nspr
|
||||||
|
#BF_NSPR_LIB =
|
||||||
|
|
||||||
|
# Uncomment the following line to use Mozilla inplace of netscape
|
||||||
|
#CPPFLAGS += -DMOZ_NOT_NET
|
||||||
|
# Location of MOZILLA/Netscape header files...
|
||||||
|
#BF_MOZILLA = $(LIBDIR)/mozilla
|
||||||
|
#BF_MOZILLA_INC = -I$(BF_MOZILLA)/include/mozilla/nspr -I$(BF_MOZILLA)/include/mozilla -I$(BF_MOZILLA)/include/mozilla/xpcom -I$(BF_MOZILLA)/include/mozilla/idl
|
||||||
|
#BF_MOZILLA_LIB =
|
||||||
|
# Will fall back to look in BF_MOZILLA_INC/nspr and BF_MOZILLA_LIB
|
||||||
|
# if this is not set.
|
||||||
|
|
||||||
|
# enable freetype2 support for text objects
|
||||||
|
BF_FREETYPE = LIBDIR + '/gcc/freetype'
|
||||||
|
BF_FREETYPE_INC = '${BF_FREETYPE}/include ${BF_FREETYPE}/include/freetype2'
|
||||||
|
BF_FREETYPE_LIB = 'freetype'
|
||||||
|
BF_FREETYPE_LIBPATH = '${BF_FREETYPE}/lib'
|
||||||
|
|
||||||
|
WITH_BF_QUICKTIME = 'false' # -DWITH_QUICKTIME
|
||||||
|
BF_QUICKTIME = '/usr/local'
|
||||||
|
BF_QUICKTIME_INC = '${BF_QUICKTIME}/include'
|
||||||
|
|
||||||
|
WITH_BF_ICONV = 'false'
|
||||||
|
BF_ICONV = LIBDIR + "/iconv"
|
||||||
|
BF_ICONV_INC = '${BF_ICONV}/include'
|
||||||
|
BF_ICONV_LIB = 'iconv'
|
||||||
|
BF_ICONV_LIBPATH = '${BF_ICONV}/lib'
|
||||||
|
|
||||||
|
# Mesa Libs should go here if your using them as well....
|
||||||
|
WITH_BF_STATICOPENGL = 'false'
|
||||||
|
BF_OPENGL = 'C:\\MingW'
|
||||||
|
BF_OPENGL_INC = '${BF_OPENGL}/include'
|
||||||
|
BF_OPENGL_LIBINC = '${BF_OPENGL}/lib'
|
||||||
|
BF_OPENGL_LIB = 'opengl32 glu32'
|
||||||
|
BF_OPENGL_LIB_STATIC = [ '${BF_OPENGL}/lib/libGL.a', '${BF_OPENGL}/lib/libGLU.a',
|
||||||
|
'${BF_OPENGL}/lib/libXmu.a', '${BF_OPENGL}/lib/libXext.a',
|
||||||
|
'${BF_OPENGL}/lib/libX11.a', '${BF_OPENGL}/lib/libXi.a' ]
|
||||||
|
##
|
||||||
|
CC = 'gcc'
|
||||||
|
CXX = 'g++'
|
||||||
|
|
||||||
|
CCFLAGS = [ '-pipe', '-funsigned-char', '-fno-strict-aliasing' ]
|
||||||
|
|
||||||
|
CPPFLAGS = [ '-DXP_UNIX', '-DWIN32', '-DFREE_WINDOWS' ]
|
||||||
|
CXXFLAGS = ['-pipe', '-mwindows', '-funsigned-char', '-fno-strict-aliasing' ]
|
||||||
|
REL_CFLAGS = [ '-O2' ]
|
||||||
|
REL_CCFLAGS = [ '-O2' ]
|
||||||
|
|
||||||
|
C_WARN = [ '-Wall' , '-Wno-char-subscripts', '-Wdeclaration-after-statement' ]
|
||||||
|
|
||||||
|
CC_WARN = [ '-Wall' ]
|
||||||
|
|
||||||
|
LLIBS = ['-lshell32', '-lshfolder', '-ldxguid', '-lgdi32', '-lmsvcrt', '-lwinmm', '-lmingw32', '-lm', '-lws2_32', '-lz', '-lstdc++']
|
||||||
|
|
||||||
|
BF_DEBUG = 'false'
|
||||||
|
BF_DEBUG_FLAGS= '-g'
|
||||||
|
|
||||||
|
BF_BUILDDIR = '..\\build\\win32-mingw'
|
||||||
|
BF_INSTALLDIR='..\\install\\win32-mingw'
|
||||||
175
config/win32-vc-config.py
Normal file
175
config/win32-vc-config.py
Normal file
@@ -0,0 +1,175 @@
|
|||||||
|
LCGDIR = '#../lib/windows'
|
||||||
|
LIBDIR = '${LCGDIR}'
|
||||||
|
|
||||||
|
WITH_BF_VERSE = 'false'
|
||||||
|
BF_VERSE_INCLUDE = "#extern/verse/dist"
|
||||||
|
|
||||||
|
# enable ffmpeg support
|
||||||
|
WITH_BF_FFMPEG = 'false' # -DWITH_FFMPEG
|
||||||
|
BF_FFMPEG = LIBDIR +'/ffmpeg'
|
||||||
|
BF_FFMPEG_INC = '${BF_FFMPEG}/include'
|
||||||
|
BF_FFMPEG_LIBPATH='${BF_FFMPEG}/lib'
|
||||||
|
BF_FFMPEG_LIB = 'avformat-51.lib avcodec-51.lib avutil-49.lib'
|
||||||
|
|
||||||
|
BF_PYTHON = LIBDIR + '/python'
|
||||||
|
BF_PYTHON_VERSION = '2.5'
|
||||||
|
BF_PYTHON_INC = '${BF_PYTHON}/include/python${BF_PYTHON_VERSION}'
|
||||||
|
BF_PYTHON_BINARY = 'python'
|
||||||
|
BF_PYTHON_LIB = 'python25'
|
||||||
|
BF_PYTHON_LIBPATH = '${BF_PYTHON}/lib'
|
||||||
|
|
||||||
|
WITH_BF_OPENAL = 'true'
|
||||||
|
BF_OPENAL = LIBDIR + '/openal'
|
||||||
|
BF_OPENAL_INC = '${BF_OPENAL}/include ${BF_OPENAL}/include/AL '
|
||||||
|
BF_OPENAL_LIB = 'openal_static'
|
||||||
|
BF_OPENAL_LIBPATH = '${BF_OPENAL}/lib'
|
||||||
|
|
||||||
|
WITH_BF_ICONV = 'true'
|
||||||
|
BF_ICONV = LIBDIR + '/iconv'
|
||||||
|
BF_ICONV_INC = '${BF_ICONV}/include'
|
||||||
|
BF_ICONV_LIB = 'iconv'
|
||||||
|
BF_ICONV_LIBPATH = '${BF_ICONV}/lib'
|
||||||
|
|
||||||
|
WITH_BF_SDL = 'true'
|
||||||
|
BF_SDL = LIBDIR + '/sdl'
|
||||||
|
BF_SDL_INC = '${BF_SDL}/include'
|
||||||
|
BF_SDL_LIB = 'SDL.lib'
|
||||||
|
BF_SDL_LIBPATH = '${BF_SDL}/lib'
|
||||||
|
|
||||||
|
BF_PTHREADS = LIBDIR + '/pthreads'
|
||||||
|
BF_PTHREADS_INC = '${BF_PTHREADS}/include'
|
||||||
|
BF_PTHREADS_LIB = 'pthreadVC2'
|
||||||
|
BF_PTHREADS_LIBPATH = '${BF_PTHREADS}/lib'
|
||||||
|
|
||||||
|
WITH_BF_FMOD = 'false'
|
||||||
|
BF_FMOD = LIBDIR + '/fmod'
|
||||||
|
|
||||||
|
WITH_BF_OPENEXR = 'true'
|
||||||
|
BF_OPENEXR = LIBDIR + '/openexr'
|
||||||
|
BF_OPENEXR_INC = '${BF_OPENEXR}/include ${BF_OPENEXR}/include/IlmImf ${BF_OPENEXR}/include/Iex ${BF_OPENEXR}/include/Imath '
|
||||||
|
BF_OPENEXR_LIB = ' Iex Half IlmImf Imath IlmThread '
|
||||||
|
BF_OPENEXR_LIBPATH = '${BF_OPENEXR}/lib_msvc'
|
||||||
|
|
||||||
|
WITH_BF_DDS = 'true'
|
||||||
|
|
||||||
|
WITH_BF_JPEG = 'true'
|
||||||
|
BF_JPEG = LIBDIR + '/jpeg'
|
||||||
|
BF_JPEG_INC = '${BF_JPEG}/include'
|
||||||
|
BF_JPEG_LIB = 'libjpeg'
|
||||||
|
BF_JPEG_LIBPATH = '${BF_JPEG}/lib'
|
||||||
|
|
||||||
|
WITH_BF_PNG = 'true'
|
||||||
|
BF_PNG = LIBDIR + '/png'
|
||||||
|
BF_PNG_INC = '${BF_PNG}/include'
|
||||||
|
BF_PNG_LIB = 'libpng_st'
|
||||||
|
BF_PNG_LIBPATH = '${BF_PNG}/lib'
|
||||||
|
|
||||||
|
BF_TIFF = LIBDIR + '/tiff'
|
||||||
|
BF_TIFF_INC = '${BF_TIFF}/include'
|
||||||
|
|
||||||
|
WITH_BF_ZLIB = 'true'
|
||||||
|
BF_ZLIB = LIBDIR + '/zlib'
|
||||||
|
BF_ZLIB_INC = '${BF_ZLIB}/include'
|
||||||
|
BF_ZLIB_LIB = 'libz'
|
||||||
|
BF_ZLIB_LIBPATH = '${BF_ZLIB}/lib'
|
||||||
|
|
||||||
|
WITH_BF_INTERNATIONAL = 'true'
|
||||||
|
|
||||||
|
BF_GETTEXT = LIBDIR + '/gettext'
|
||||||
|
BF_GETTEXT_INC = '${BF_GETTEXT}/include'
|
||||||
|
BF_GETTEXT_LIB = 'gnu_gettext'
|
||||||
|
BF_GETTEXT_LIBPATH = '${BF_GETTEXT}/lib'
|
||||||
|
|
||||||
|
WITH_BF_FTGL = 'true'
|
||||||
|
BF_FTGL = LIBDIR + '/ftgl'
|
||||||
|
BF_FTGL_INC = '${BF_FTGL}/include'
|
||||||
|
BF_FTGL_LIB = 'extern_ftgl'
|
||||||
|
|
||||||
|
WITH_BF_GAMEENGINE = 'false'
|
||||||
|
|
||||||
|
WITH_BF_ODE = 'true'
|
||||||
|
BF_ODE = LIBDIR + '/ode'
|
||||||
|
BF_ODE_INC = BF_ODE + '/include'
|
||||||
|
BF_ODE_LIB = BF_ODE + '/lib/libode.a'
|
||||||
|
|
||||||
|
WITH_BF_BULLET = 'true'
|
||||||
|
BF_BULLET = '#extern/bullet2/src'
|
||||||
|
BF_BULLET_INC = '${BF_BULLET}'
|
||||||
|
BF_BULLET_LIB = 'extern_bullet'
|
||||||
|
|
||||||
|
BF_SOLID = '#extern/solid'
|
||||||
|
BF_SOLID_INC = '${BF_SOLID}'
|
||||||
|
BF_SOLID_LIB = 'extern_solid'
|
||||||
|
|
||||||
|
BF_WINTAB = LIBDIR + '/wintab'
|
||||||
|
BF_WINTAB_INC = '${BF_WINTAB}/INCLUDE'
|
||||||
|
|
||||||
|
WITH_BF_YAFRAY = 'true'
|
||||||
|
|
||||||
|
#WITH_BF_NSPR = 'true'
|
||||||
|
#BF_NSPR = $(LIBDIR)/nspr
|
||||||
|
#BF_NSPR_INC = -I$(BF_NSPR)/include -I$(BF_NSPR)/include/nspr
|
||||||
|
#BF_NSPR_LIB =
|
||||||
|
|
||||||
|
# Uncomment the following line to use Mozilla inplace of netscape
|
||||||
|
#CPPFLAGS += -DMOZ_NOT_NET
|
||||||
|
# Location of MOZILLA/Netscape header files...
|
||||||
|
#BF_MOZILLA = $(LIBDIR)/mozilla
|
||||||
|
#BF_MOZILLA_INC = -I$(BF_MOZILLA)/include/mozilla/nspr -I$(BF_MOZILLA)/include/mozilla -I$(BF_MOZILLA)/include/mozilla/xpcom -I$(BF_MOZILLA)/include/mozilla/idl
|
||||||
|
#BF_MOZILLA_LIB =
|
||||||
|
# Will fall back to look in BF_MOZILLA_INC/nspr and BF_MOZILLA_LIB
|
||||||
|
# if this is not set.
|
||||||
|
#
|
||||||
|
# Be paranoid regarding library creation (do not update archives)
|
||||||
|
#BF_PARANOID = 'true'
|
||||||
|
|
||||||
|
# enable freetype2 support for text objects
|
||||||
|
BF_FREETYPE = LIBDIR + '/freetype'
|
||||||
|
BF_FREETYPE_INC = '${BF_FREETYPE}/include ${BF_FREETYPE}/include/freetype2'
|
||||||
|
BF_FREETYPE_LIB = 'freetype2ST'
|
||||||
|
BF_FREETYPE_LIBPATH = '${BF_FREETYPE}/lib'
|
||||||
|
|
||||||
|
WITH_BF_QUICKTIME = 'true' # -DWITH_QUICKTIME
|
||||||
|
BF_QUICKTIME = LIBDIR + '/QTDevWin'
|
||||||
|
BF_QUICKTIME_INC = '${BF_QUICKTIME}/CIncludes'
|
||||||
|
BF_QUICKTIME_LIB = 'qtmlClient'
|
||||||
|
BF_QUICKTIME_LIBPATH = '${BF_QUICKTIME}/Libraries'
|
||||||
|
|
||||||
|
WITH_BF_STATICOPENGL = 'false'
|
||||||
|
BF_OPENGL_INC = '${BF_OPENGL}/include'
|
||||||
|
BF_OPENGL_LIBINC = '${BF_OPENGL}/lib'
|
||||||
|
BF_OPENGL_LIB = 'opengl32 glu32'
|
||||||
|
BF_OPENGL_LIB_STATIC = [ '${BF_OPENGL}/lib/libGL.a', '${BF_OPENGL}/lib/libGLU.a',
|
||||||
|
'${BF_OPENGL}/lib/libXmu.a', '${BF_OPENGL}/lib/libXext.a',
|
||||||
|
'${BF_OPENGL}/lib/libX11.a', '${BF_OPENGL}/lib/libXi.a' ]
|
||||||
|
CC = 'cl.exe'
|
||||||
|
CXX = 'cl.exe'
|
||||||
|
|
||||||
|
CCFLAGS = ['/nologo', '/Og', '/Ot', '/Ob1', '/Op', '/G6','/EHsc', '/J', '/W3', '/Gd', '/MT']
|
||||||
|
|
||||||
|
BF_DEBUG_FLAGS = ['/Zi', '/FR${TARGET}.sbr']
|
||||||
|
|
||||||
|
CPPFLAGS = ['-DWIN32','-D_CONSOLE', '-D_LIB', '-DUSE_OPENAL', '-DFTGL_LIBRARY_STATIC', '-D_CRT_SECURE_NO_DEPRECATE']
|
||||||
|
REL_CFLAGS = ['-O2', '-DNDEBUG']
|
||||||
|
REL_CCFLAGS = ['-O2', '-DNDEBUG']
|
||||||
|
C_WARN = []
|
||||||
|
CC_WARN = []
|
||||||
|
|
||||||
|
LLIBS = 'ws2_32 dxguid vfw32 winmm kernel32 user32 gdi32 comdlg32 advapi32 shell32 ole32 oleaut32 uuid'
|
||||||
|
|
||||||
|
PLATFORM_LINKFLAGS = '''
|
||||||
|
/SUBSYSTEM:CONSOLE
|
||||||
|
/MACHINE:IX86
|
||||||
|
/ENTRY:mainCRTStartup
|
||||||
|
/INCREMENTAL:NO
|
||||||
|
/NODEFAULTLIB:"msvcprt.lib"
|
||||||
|
/NODEFAULTLIB:"glut32.lib"
|
||||||
|
/NODEFAULTLIB:"libc.lib"
|
||||||
|
/NODEFAULTLIB:"libcd.lib"
|
||||||
|
/NODEFAULTLIB:"libcpd.lib"
|
||||||
|
/NODEFAULTLIB:"libcp.lib"
|
||||||
|
/NODEFAULTLIB:"libcmtd.lib"
|
||||||
|
'''
|
||||||
|
|
||||||
|
BF_BUILDDIR = '..\\build\\win32-vc'
|
||||||
|
BF_INSTALLDIR='..\\install\\win32-vc'
|
||||||
35
doc/BL-license.txt
Normal file
35
doc/BL-license.txt
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
Blender License (the "BL", see http://www.blender.org/BL/ ).
|
||||||
|
|
||||||
|
Copyright (C) 2002-2005 Blender Foundation. All Rights Reserved.
|
||||||
|
|
||||||
|
This text supersedes the previous BL description, called Blender License 1.0.
|
||||||
|
|
||||||
|
When the Blender source code was released in 2002, the Blender Foundation reserved
|
||||||
|
the right to offer licenses outside of the GNU GPL. This so-called "dual license"
|
||||||
|
model was chosen to provide potential revenues for the Blender Foundation.
|
||||||
|
|
||||||
|
The BL has not been activated yet. Partially because;
|
||||||
|
|
||||||
|
- there has to be a clear benefit for Blender itself and its community of
|
||||||
|
developers and users.
|
||||||
|
- the developers who have copyrighted additions to the source code need to approve
|
||||||
|
the decision.
|
||||||
|
- the (c) holder NaN Holding has to approve on a standard License Contract
|
||||||
|
|
||||||
|
But most important;
|
||||||
|
|
||||||
|
- the Blender Foundation is financially healthy, based on community support
|
||||||
|
(e-shop sales), sponsoring and subsidy grants
|
||||||
|
- current focus for the Blender Foundation is to not set up any commercial
|
||||||
|
activity related to Blender development.
|
||||||
|
- the GNU GPL provides sufficient freedom for third parties to conduct business
|
||||||
|
with Blender
|
||||||
|
|
||||||
|
For these reasons we've decided to cancel the BL offering for an indefinite period.
|
||||||
|
|
||||||
|
Third parties interested to discuss usage or exploitation of Blender can email
|
||||||
|
license@blender.org for further information.
|
||||||
|
|
||||||
|
Ton Roosendaal
|
||||||
|
Chairman Blender Foundation.
|
||||||
|
June 2005
|
||||||
943
doc/Doxyfile
Normal file
943
doc/Doxyfile
Normal file
@@ -0,0 +1,943 @@
|
|||||||
|
# Doxyfile 1.2.15
|
||||||
|
|
||||||
|
# This file describes the settings to be used by the documentation system
|
||||||
|
# doxygen (www.doxygen.org) for a project
|
||||||
|
#
|
||||||
|
# All text after a hash (#) is considered a comment and will be ignored
|
||||||
|
# The format is:
|
||||||
|
# TAG = value [value, ...]
|
||||||
|
# For lists items can also be appended using:
|
||||||
|
# TAG += value [value, ...]
|
||||||
|
# Values that contain spaces should be placed between quotes (" ")
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# General configuration options
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# The PROJECT_NAME tag is a single word (or a sequence of words surrounded
|
||||||
|
# by quotes) that should identify the project.
|
||||||
|
|
||||||
|
PROJECT_NAME = Blender
|
||||||
|
|
||||||
|
# The PROJECT_NUMBER tag can be used to enter a project or revision number.
|
||||||
|
# This could be handy for archiving the generated documentation or
|
||||||
|
# if some version control system is used.
|
||||||
|
|
||||||
|
PROJECT_NUMBER = V2.27
|
||||||
|
|
||||||
|
# The OUTPUT_DIRECTORY tag is used to specify the (relative or absolute)
|
||||||
|
# base path where the generated documentation will be put.
|
||||||
|
# If a relative path is entered, it will be relative to the location
|
||||||
|
# where doxygen was started. If left blank the current directory will be used.
|
||||||
|
|
||||||
|
OUTPUT_DIRECTORY =
|
||||||
|
|
||||||
|
# The OUTPUT_LANGUAGE tag is used to specify the language in which all
|
||||||
|
# documentation generated by doxygen is written. Doxygen will use this
|
||||||
|
# information to generate all constant output in the proper language.
|
||||||
|
# The default language is English, other supported languages are:
|
||||||
|
# Brazilian, Chinese, Croatian, Czech, Danish, Dutch, Finnish, French,
|
||||||
|
# German, Greek, Hungarian, Italian, Japanese, Korean, Norwegian, Polish,
|
||||||
|
# Portuguese, Romanian, Russian, Slovak, Slovene, Spanish and Swedish.
|
||||||
|
|
||||||
|
OUTPUT_LANGUAGE = English
|
||||||
|
|
||||||
|
# If the EXTRACT_ALL tag is set to YES doxygen will assume all entities in
|
||||||
|
# documentation are documented, even if no documentation was available.
|
||||||
|
# Private class members and static file members will be hidden unless
|
||||||
|
# the EXTRACT_PRIVATE and EXTRACT_STATIC tags are set to YES
|
||||||
|
|
||||||
|
EXTRACT_ALL = NO
|
||||||
|
|
||||||
|
# If the EXTRACT_PRIVATE tag is set to YES all private members of a class
|
||||||
|
# will be included in the documentation.
|
||||||
|
|
||||||
|
EXTRACT_PRIVATE = NO
|
||||||
|
|
||||||
|
# If the EXTRACT_STATIC tag is set to YES all static members of a file
|
||||||
|
# will be included in the documentation.
|
||||||
|
|
||||||
|
EXTRACT_STATIC = YES
|
||||||
|
|
||||||
|
# If the EXTRACT_LOCAL_CLASSES tag is set to YES classes (and structs)
|
||||||
|
# defined locally in source files will be included in the documentation.
|
||||||
|
# If set to NO only classes defined in header files are included.
|
||||||
|
|
||||||
|
EXTRACT_LOCAL_CLASSES = YES
|
||||||
|
|
||||||
|
# If the HIDE_UNDOC_MEMBERS tag is set to YES, Doxygen will hide all
|
||||||
|
# undocumented members of documented classes, files or namespaces.
|
||||||
|
# If set to NO (the default) these members will be included in the
|
||||||
|
# various overviews, but no documentation section is generated.
|
||||||
|
# This option has no effect if EXTRACT_ALL is enabled.
|
||||||
|
|
||||||
|
HIDE_UNDOC_MEMBERS = NO
|
||||||
|
|
||||||
|
# If the HIDE_UNDOC_CLASSES tag is set to YES, Doxygen will hide all
|
||||||
|
# undocumented classes that are normally visible in the class hierarchy.
|
||||||
|
# If set to NO (the default) these class will be included in the various
|
||||||
|
# overviews. This option has no effect if EXTRACT_ALL is enabled.
|
||||||
|
|
||||||
|
HIDE_UNDOC_CLASSES = NO
|
||||||
|
|
||||||
|
# If the BRIEF_MEMBER_DESC tag is set to YES (the default) Doxygen will
|
||||||
|
# include brief member descriptions after the members that are listed in
|
||||||
|
# the file and class documentation (similar to JavaDoc).
|
||||||
|
# Set to NO to disable this.
|
||||||
|
|
||||||
|
BRIEF_MEMBER_DESC = YES
|
||||||
|
|
||||||
|
# If the REPEAT_BRIEF tag is set to YES (the default) Doxygen will prepend
|
||||||
|
# the brief description of a member or function before the detailed description.
|
||||||
|
# Note: if both HIDE_UNDOC_MEMBERS and BRIEF_MEMBER_DESC are set to NO, the
|
||||||
|
# brief descriptions will be completely suppressed.
|
||||||
|
|
||||||
|
REPEAT_BRIEF = YES
|
||||||
|
|
||||||
|
# If the ALWAYS_DETAILED_SEC and REPEAT_BRIEF tags are both set to YES then
|
||||||
|
# Doxygen will generate a detailed section even if there is only a brief
|
||||||
|
# description.
|
||||||
|
|
||||||
|
ALWAYS_DETAILED_SEC = NO
|
||||||
|
|
||||||
|
# If the INLINE_INHERITED_MEMB tag is set to YES, doxygen will show all inherited
|
||||||
|
# members of a class in the documentation of that class as if those members were
|
||||||
|
# ordinary class members. Constructors, destructors and assignment operators of
|
||||||
|
# the base classes will not be shown.
|
||||||
|
|
||||||
|
INLINE_INHERITED_MEMB = NO
|
||||||
|
|
||||||
|
# If the FULL_PATH_NAMES tag is set to YES then Doxygen will prepend the full
|
||||||
|
# path before files name in the file list and in the header files. If set
|
||||||
|
# to NO the shortest path that makes the file name unique will be used.
|
||||||
|
|
||||||
|
FULL_PATH_NAMES = NO
|
||||||
|
|
||||||
|
# If the FULL_PATH_NAMES tag is set to YES then the STRIP_FROM_PATH tag
|
||||||
|
# can be used to strip a user defined part of the path. Stripping is
|
||||||
|
# only done if one of the specified strings matches the left-hand part of
|
||||||
|
# the path. It is allowed to use relative paths in the argument list.
|
||||||
|
|
||||||
|
STRIP_FROM_PATH =
|
||||||
|
|
||||||
|
# The INTERNAL_DOCS tag determines if documentation
|
||||||
|
# that is typed after a \internal command is included. If the tag is set
|
||||||
|
# to NO (the default) then the documentation will be excluded.
|
||||||
|
# Set it to YES to include the internal documentation.
|
||||||
|
|
||||||
|
INTERNAL_DOCS = YES
|
||||||
|
|
||||||
|
# Setting the STRIP_CODE_COMMENTS tag to YES (the default) will instruct
|
||||||
|
# doxygen to hide any special comment blocks from generated source code
|
||||||
|
# fragments. Normal C and C++ comments will always remain visible.
|
||||||
|
|
||||||
|
STRIP_CODE_COMMENTS = YES
|
||||||
|
|
||||||
|
# If the CASE_SENSE_NAMES tag is set to NO then Doxygen will only generate
|
||||||
|
# file names in lower case letters. If set to YES upper case letters are also
|
||||||
|
# allowed. This is useful if you have classes or files whose names only differ
|
||||||
|
# in case and if your file system supports case sensitive file names. Windows
|
||||||
|
# users are adviced to set this option to NO.
|
||||||
|
|
||||||
|
CASE_SENSE_NAMES = YES
|
||||||
|
|
||||||
|
# If the SHORT_NAMES tag is set to YES, doxygen will generate much shorter
|
||||||
|
# (but less readable) file names. This can be useful is your file systems
|
||||||
|
# doesn't support long names like on DOS, Mac, or CD-ROM.
|
||||||
|
|
||||||
|
SHORT_NAMES = NO
|
||||||
|
|
||||||
|
# If the HIDE_SCOPE_NAMES tag is set to NO (the default) then Doxygen
|
||||||
|
# will show members with their full class and namespace scopes in the
|
||||||
|
# documentation. If set to YES the scope will be hidden.
|
||||||
|
|
||||||
|
HIDE_SCOPE_NAMES = NO
|
||||||
|
|
||||||
|
# If the VERBATIM_HEADERS tag is set to YES (the default) then Doxygen
|
||||||
|
# will generate a verbatim copy of the header file for each class for
|
||||||
|
# which an include is specified. Set to NO to disable this.
|
||||||
|
|
||||||
|
VERBATIM_HEADERS = YES
|
||||||
|
|
||||||
|
# If the SHOW_INCLUDE_FILES tag is set to YES (the default) then Doxygen
|
||||||
|
# will put list of the files that are included by a file in the documentation
|
||||||
|
# of that file.
|
||||||
|
|
||||||
|
SHOW_INCLUDE_FILES = YES
|
||||||
|
|
||||||
|
# If the JAVADOC_AUTOBRIEF tag is set to YES then Doxygen
|
||||||
|
# will interpret the first line (until the first dot) of a JavaDoc-style
|
||||||
|
# comment as the brief description. If set to NO, the JavaDoc
|
||||||
|
# comments will behave just like the Qt-style comments (thus requiring an
|
||||||
|
# explict @brief command for a brief description.
|
||||||
|
|
||||||
|
JAVADOC_AUTOBRIEF = NO
|
||||||
|
|
||||||
|
# If the INHERIT_DOCS tag is set to YES (the default) then an undocumented
|
||||||
|
# member inherits the documentation from any documented member that it
|
||||||
|
# reimplements.
|
||||||
|
|
||||||
|
INHERIT_DOCS = YES
|
||||||
|
|
||||||
|
# If the INLINE_INFO tag is set to YES (the default) then a tag [inline]
|
||||||
|
# is inserted in the documentation for inline members.
|
||||||
|
|
||||||
|
INLINE_INFO = YES
|
||||||
|
|
||||||
|
# If the SORT_MEMBER_DOCS tag is set to YES (the default) then doxygen
|
||||||
|
# will sort the (detailed) documentation of file and class members
|
||||||
|
# alphabetically by member name. If set to NO the members will appear in
|
||||||
|
# declaration order.
|
||||||
|
|
||||||
|
SORT_MEMBER_DOCS = YES
|
||||||
|
|
||||||
|
# If member grouping is used in the documentation and the DISTRIBUTE_GROUP_DOC
|
||||||
|
# tag is set to YES, then doxygen will reuse the documentation of the first
|
||||||
|
# member in the group (if any) for the other members of the group. By default
|
||||||
|
# all members of a group must be documented explicitly.
|
||||||
|
|
||||||
|
DISTRIBUTE_GROUP_DOC = YES
|
||||||
|
|
||||||
|
# The TAB_SIZE tag can be used to set the number of spaces in a tab.
|
||||||
|
# Doxygen uses this value to replace tabs by spaces in code fragments.
|
||||||
|
|
||||||
|
TAB_SIZE = 8
|
||||||
|
|
||||||
|
# The GENERATE_TODOLIST tag can be used to enable (YES) or
|
||||||
|
# disable (NO) the todo list. This list is created by putting \todo
|
||||||
|
# commands in the documentation.
|
||||||
|
|
||||||
|
GENERATE_TODOLIST = YES
|
||||||
|
|
||||||
|
# The GENERATE_TESTLIST tag can be used to enable (YES) or
|
||||||
|
# disable (NO) the test list. This list is created by putting \test
|
||||||
|
# commands in the documentation.
|
||||||
|
|
||||||
|
GENERATE_TESTLIST = YES
|
||||||
|
|
||||||
|
# The GENERATE_BUGLIST tag can be used to enable (YES) or
|
||||||
|
# disable (NO) the bug list. This list is created by putting \bug
|
||||||
|
# commands in the documentation.
|
||||||
|
|
||||||
|
GENERATE_BUGLIST = YES
|
||||||
|
|
||||||
|
# This tag can be used to specify a number of aliases that acts
|
||||||
|
# as commands in the documentation. An alias has the form "name=value".
|
||||||
|
# For example adding "sideeffect=\par Side Effects:\n" will allow you to
|
||||||
|
# put the command \sideeffect (or @sideeffect) in the documentation, which
|
||||||
|
# will result in a user defined paragraph with heading "Side Effects:".
|
||||||
|
# You can put \n's in the value part of an alias to insert newlines.
|
||||||
|
|
||||||
|
ALIASES =
|
||||||
|
|
||||||
|
# The ENABLED_SECTIONS tag can be used to enable conditional
|
||||||
|
# documentation sections, marked by \if sectionname ... \endif.
|
||||||
|
|
||||||
|
ENABLED_SECTIONS =
|
||||||
|
|
||||||
|
# The MAX_INITIALIZER_LINES tag determines the maximum number of lines
|
||||||
|
# the initial value of a variable or define consist of for it to appear in
|
||||||
|
# the documentation. If the initializer consists of more lines than specified
|
||||||
|
# here it will be hidden. Use a value of 0 to hide initializers completely.
|
||||||
|
# The appearance of the initializer of individual variables and defines in the
|
||||||
|
# documentation can be controlled using \showinitializer or \hideinitializer
|
||||||
|
# command in the documentation regardless of this setting.
|
||||||
|
|
||||||
|
MAX_INITIALIZER_LINES = 30
|
||||||
|
|
||||||
|
# Set the OPTIMIZE_OUTPUT_FOR_C tag to YES if your project consists of C sources
|
||||||
|
# only. Doxygen will then generate output that is more tailored for C.
|
||||||
|
# For instance some of the names that are used will be different. The list
|
||||||
|
# of all members will be omitted, etc.
|
||||||
|
|
||||||
|
OPTIMIZE_OUTPUT_FOR_C = NO
|
||||||
|
|
||||||
|
# Set the OPTIMIZE_OUTPUT_JAVA tag to YES if your project consists of Java sources
|
||||||
|
# only. Doxygen will then generate output that is more tailored for Java.
|
||||||
|
# For instance namespaces will be presented as packages, qualified scopes
|
||||||
|
# will look different, etc.
|
||||||
|
|
||||||
|
OPTIMIZE_OUTPUT_JAVA = NO
|
||||||
|
|
||||||
|
# Set the SHOW_USED_FILES tag to NO to disable the list of files generated
|
||||||
|
# at the bottom of the documentation of classes and structs. If set to YES the
|
||||||
|
# list will mention the files that were used to generate the documentation.
|
||||||
|
|
||||||
|
SHOW_USED_FILES = YES
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to warning and progress messages
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# The QUIET tag can be used to turn on/off the messages that are generated
|
||||||
|
# by doxygen. Possible values are YES and NO. If left blank NO is used.
|
||||||
|
|
||||||
|
QUIET = NO
|
||||||
|
|
||||||
|
# The WARNINGS tag can be used to turn on/off the warning messages that are
|
||||||
|
# generated by doxygen. Possible values are YES and NO. If left blank
|
||||||
|
# NO is used.
|
||||||
|
|
||||||
|
WARNINGS = YES
|
||||||
|
|
||||||
|
# If WARN_IF_UNDOCUMENTED is set to YES, then doxygen will generate warnings
|
||||||
|
# for undocumented members. If EXTRACT_ALL is set to YES then this flag will
|
||||||
|
# automatically be disabled.
|
||||||
|
|
||||||
|
WARN_IF_UNDOCUMENTED = YES
|
||||||
|
|
||||||
|
# The WARN_FORMAT tag determines the format of the warning messages that
|
||||||
|
# doxygen can produce. The string should contain the $file, $line, and $text
|
||||||
|
# tags, which will be replaced by the file and line number from which the
|
||||||
|
# warning originated and the warning text.
|
||||||
|
|
||||||
|
WARN_FORMAT = "$file:$line: $text"
|
||||||
|
|
||||||
|
# The WARN_LOGFILE tag can be used to specify a file to which warning
|
||||||
|
# and error messages should be written. If left blank the output is written
|
||||||
|
# to stderr.
|
||||||
|
|
||||||
|
WARN_LOGFILE =
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the input files
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# The INPUT tag can be used to specify the files and/or directories that contain
|
||||||
|
# documented source files. You may enter file names like "myfile.cpp" or
|
||||||
|
# directories like "/usr/src/myproject". Separate the files or directories
|
||||||
|
# with spaces.
|
||||||
|
|
||||||
|
INPUT = doxygen.main ../source/creator/ ../source/blender/src/B.blend.c ../source/blender/src/blenderbuttons.c ../source/blender/readblenfile/intern/BLO_readblenfile.c ../intern/ghost/GHOST_C-api.h ../source/blender/imbuf/ ../source/blender/src/mainqueue.c
|
||||||
|
|
||||||
|
# cmccad - The following lines are directories which will eventually be included:
|
||||||
|
#
|
||||||
|
# ../source/blender/blenkernel/ ../source/blender/imbuf/ ../source/blender/render/
|
||||||
|
# ../source/blender/blenlib/ ../source/blender/include
|
||||||
|
|
||||||
|
# If the value of the INPUT tag contains directories, you can use the
|
||||||
|
# FILE_PATTERNS tag to specify one or more wildcard pattern (like *.cpp
|
||||||
|
# and *.h) to filter out the source-files in the directories. If left
|
||||||
|
# blank the following patterns are tested:
|
||||||
|
# *.c *.cc *.cxx *.cpp *.c++ *.java *.ii *.ixx *.ipp *.i++ *.inl *.h *.hh *.hxx *.hpp
|
||||||
|
# *.h++ *.idl *.odl
|
||||||
|
|
||||||
|
FILE_PATTERNS =
|
||||||
|
|
||||||
|
# The RECURSIVE tag can be used to turn specify whether or not subdirectories
|
||||||
|
# should be searched for input files as well. Possible values are YES and NO.
|
||||||
|
# If left blank NO is used.
|
||||||
|
|
||||||
|
RECURSIVE = YES
|
||||||
|
|
||||||
|
# The EXCLUDE tag can be used to specify files and/or directories that should
|
||||||
|
# excluded from the INPUT source files. This way you can easily exclude a
|
||||||
|
# subdirectory from a directory tree whose root is specified with the INPUT tag.
|
||||||
|
|
||||||
|
EXCLUDE =
|
||||||
|
|
||||||
|
# The EXCLUDE_SYMLINKS tag can be used select whether or not files or directories
|
||||||
|
# that are symbolic links (a Unix filesystem feature) are excluded from the input.
|
||||||
|
|
||||||
|
EXCLUDE_SYMLINKS = NO
|
||||||
|
|
||||||
|
# If the value of the INPUT tag contains directories, you can use the
|
||||||
|
# EXCLUDE_PATTERNS tag to specify one or more wildcard patterns to exclude
|
||||||
|
# certain files from those directories.
|
||||||
|
|
||||||
|
EXCLUDE_PATTERNS =
|
||||||
|
|
||||||
|
# The EXAMPLE_PATH tag can be used to specify one or more files or
|
||||||
|
# directories that contain example code fragments that are included (see
|
||||||
|
# the \include command).
|
||||||
|
|
||||||
|
EXAMPLE_PATH =
|
||||||
|
|
||||||
|
# If the value of the EXAMPLE_PATH tag contains directories, you can use the
|
||||||
|
# EXAMPLE_PATTERNS tag to specify one or more wildcard pattern (like *.cpp
|
||||||
|
# and *.h) to filter out the source-files in the directories. If left
|
||||||
|
# blank all files are included.
|
||||||
|
|
||||||
|
EXAMPLE_PATTERNS =
|
||||||
|
|
||||||
|
# If the EXAMPLE_RECURSIVE tag is set to YES then subdirectories will be
|
||||||
|
# searched for input files to be used with the \include or \dontinclude
|
||||||
|
# commands irrespective of the value of the RECURSIVE tag.
|
||||||
|
# Possible values are YES and NO. If left blank NO is used.
|
||||||
|
|
||||||
|
EXAMPLE_RECURSIVE = NO
|
||||||
|
|
||||||
|
# The IMAGE_PATH tag can be used to specify one or more files or
|
||||||
|
# directories that contain image that are included in the documentation (see
|
||||||
|
# the \image command).
|
||||||
|
|
||||||
|
IMAGE_PATH =
|
||||||
|
|
||||||
|
# The INPUT_FILTER tag can be used to specify a program that doxygen should
|
||||||
|
# invoke to filter for each input file. Doxygen will invoke the filter program
|
||||||
|
# by executing (via popen()) the command <filter> <input-file>, where <filter>
|
||||||
|
# is the value of the INPUT_FILTER tag, and <input-file> is the name of an
|
||||||
|
# input file. Doxygen will then use the output that the filter program writes
|
||||||
|
# to standard output.
|
||||||
|
|
||||||
|
INPUT_FILTER =
|
||||||
|
|
||||||
|
# If the FILTER_SOURCE_FILES tag is set to YES, the input filter (if set using
|
||||||
|
# INPUT_FILTER) will be used to filter the input files when producing source
|
||||||
|
# files to browse.
|
||||||
|
|
||||||
|
FILTER_SOURCE_FILES = NO
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to source browsing
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# If the SOURCE_BROWSER tag is set to YES then a list of source files will
|
||||||
|
# be generated. Documented entities will be cross-referenced with these sources.
|
||||||
|
|
||||||
|
SOURCE_BROWSER = YES
|
||||||
|
|
||||||
|
# Setting the INLINE_SOURCES tag to YES will include the body
|
||||||
|
# of functions and classes directly in the documentation.
|
||||||
|
|
||||||
|
INLINE_SOURCES = NO
|
||||||
|
|
||||||
|
# If the REFERENCED_BY_RELATION tag is set to YES (the default)
|
||||||
|
# then for each documented function all documented
|
||||||
|
# functions referencing it will be listed.
|
||||||
|
|
||||||
|
REFERENCED_BY_RELATION = YES
|
||||||
|
|
||||||
|
# If the REFERENCES_RELATION tag is set to YES (the default)
|
||||||
|
# then for each documented function all documented entities
|
||||||
|
# called/used by that function will be listed.
|
||||||
|
|
||||||
|
REFERENCES_RELATION = YES
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the alphabetical class index
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# If the ALPHABETICAL_INDEX tag is set to YES, an alphabetical index
|
||||||
|
# of all compounds will be generated. Enable this if the project
|
||||||
|
# contains a lot of classes, structs, unions or interfaces.
|
||||||
|
|
||||||
|
ALPHABETICAL_INDEX = NO
|
||||||
|
|
||||||
|
# If the alphabetical index is enabled (see ALPHABETICAL_INDEX) then
|
||||||
|
# the COLS_IN_ALPHA_INDEX tag can be used to specify the number of columns
|
||||||
|
# in which this list will be split (can be a number in the range [1..20])
|
||||||
|
|
||||||
|
COLS_IN_ALPHA_INDEX = 5
|
||||||
|
|
||||||
|
# In case all classes in a project start with a common prefix, all
|
||||||
|
# classes will be put under the same header in the alphabetical index.
|
||||||
|
# The IGNORE_PREFIX tag can be used to specify one or more prefixes that
|
||||||
|
# should be ignored while generating the index headers.
|
||||||
|
|
||||||
|
IGNORE_PREFIX =
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the HTML output
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# If the GENERATE_HTML tag is set to YES (the default) Doxygen will
|
||||||
|
# generate HTML output.
|
||||||
|
|
||||||
|
GENERATE_HTML = YES
|
||||||
|
|
||||||
|
# The HTML_OUTPUT tag is used to specify where the HTML docs will be put.
|
||||||
|
# If a relative path is entered the value of OUTPUT_DIRECTORY will be
|
||||||
|
# put in front of it. If left blank `html' will be used as the default path.
|
||||||
|
|
||||||
|
HTML_OUTPUT = html
|
||||||
|
|
||||||
|
# The HTML_FILE_EXTENSION tag can be used to specify the file extension for
|
||||||
|
# each generated HTML page (for example: .htm,.php,.asp). If it is left blank
|
||||||
|
# doxygen will generate files with .html extension.
|
||||||
|
|
||||||
|
HTML_FILE_EXTENSION = .html
|
||||||
|
|
||||||
|
# The HTML_HEADER tag can be used to specify a personal HTML header for
|
||||||
|
# each generated HTML page. If it is left blank doxygen will generate a
|
||||||
|
# standard header.
|
||||||
|
|
||||||
|
HTML_HEADER =
|
||||||
|
|
||||||
|
# The HTML_FOOTER tag can be used to specify a personal HTML footer for
|
||||||
|
# each generated HTML page. If it is left blank doxygen will generate a
|
||||||
|
# standard footer.
|
||||||
|
|
||||||
|
HTML_FOOTER =
|
||||||
|
|
||||||
|
# The HTML_STYLESHEET tag can be used to specify a user defined cascading
|
||||||
|
# style sheet that is used by each HTML page. It can be used to
|
||||||
|
# fine-tune the look of the HTML output. If the tag is left blank doxygen
|
||||||
|
# will generate a default style sheet
|
||||||
|
|
||||||
|
HTML_STYLESHEET =
|
||||||
|
|
||||||
|
# If the HTML_ALIGN_MEMBERS tag is set to YES, the members of classes,
|
||||||
|
# files or namespaces will be aligned in HTML using tables. If set to
|
||||||
|
# NO a bullet list will be used.
|
||||||
|
|
||||||
|
HTML_ALIGN_MEMBERS = YES
|
||||||
|
|
||||||
|
# If the GENERATE_HTMLHELP tag is set to YES, additional index files
|
||||||
|
# will be generated that can be used as input for tools like the
|
||||||
|
# Microsoft HTML help workshop to generate a compressed HTML help file (.chm)
|
||||||
|
# of the generated HTML documentation.
|
||||||
|
|
||||||
|
GENERATE_HTMLHELP = NO
|
||||||
|
|
||||||
|
# If the GENERATE_HTMLHELP tag is set to YES, the GENERATE_CHI flag
|
||||||
|
# controls if a separate .chi index file is generated (YES) or that
|
||||||
|
# it should be included in the master .chm file (NO).
|
||||||
|
|
||||||
|
GENERATE_CHI = NO
|
||||||
|
|
||||||
|
# If the GENERATE_HTMLHELP tag is set to YES, the BINARY_TOC flag
|
||||||
|
# controls whether a binary table of contents is generated (YES) or a
|
||||||
|
# normal table of contents (NO) in the .chm file.
|
||||||
|
|
||||||
|
BINARY_TOC = NO
|
||||||
|
|
||||||
|
# The TOC_EXPAND flag can be set to YES to add extra items for group members
|
||||||
|
# to the contents of the Html help documentation and to the tree view.
|
||||||
|
|
||||||
|
TOC_EXPAND = NO
|
||||||
|
|
||||||
|
# The DISABLE_INDEX tag can be used to turn on/off the condensed index at
|
||||||
|
# top of each HTML page. The value NO (the default) enables the index and
|
||||||
|
# the value YES disables it.
|
||||||
|
|
||||||
|
DISABLE_INDEX = NO
|
||||||
|
|
||||||
|
# This tag can be used to set the number of enum values (range [1..20])
|
||||||
|
# that doxygen will group on one line in the generated HTML documentation.
|
||||||
|
|
||||||
|
ENUM_VALUES_PER_LINE = 4
|
||||||
|
|
||||||
|
# If the GENERATE_TREEVIEW tag is set to YES, a side panel will be
|
||||||
|
# generated containing a tree-like index structure (just like the one that
|
||||||
|
# is generated for HTML Help). For this to work a browser that supports
|
||||||
|
# JavaScript and frames is required (for instance Mozilla, Netscape 4.0+,
|
||||||
|
# or Internet explorer 4.0+). Note that for large projects the tree generation
|
||||||
|
# can take a very long time. In such cases it is better to disable this feature.
|
||||||
|
# Windows users are probably better off using the HTML help feature.
|
||||||
|
|
||||||
|
GENERATE_TREEVIEW = NO
|
||||||
|
|
||||||
|
# If the treeview is enabled (see GENERATE_TREEVIEW) then this tag can be
|
||||||
|
# used to set the initial width (in pixels) of the frame in which the tree
|
||||||
|
# is shown.
|
||||||
|
|
||||||
|
TREEVIEW_WIDTH = 250
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the LaTeX output
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# If the GENERATE_LATEX tag is set to YES (the default) Doxygen will
|
||||||
|
# generate Latex output.
|
||||||
|
|
||||||
|
GENERATE_LATEX = NO
|
||||||
|
|
||||||
|
# The LATEX_OUTPUT tag is used to specify where the LaTeX docs will be put.
|
||||||
|
# If a relative path is entered the value of OUTPUT_DIRECTORY will be
|
||||||
|
# put in front of it. If left blank `latex' will be used as the default path.
|
||||||
|
|
||||||
|
LATEX_OUTPUT = latex
|
||||||
|
|
||||||
|
# The LATEX_CMD_NAME tag can be used to specify the LaTeX command name to be invoked. If left blank `latex' will be used as the default command name.
|
||||||
|
|
||||||
|
LATEX_CMD_NAME = latex
|
||||||
|
|
||||||
|
# The MAKEINDEX_CMD_NAME tag can be used to specify the command name to
|
||||||
|
# generate index for LaTeX. If left blank `makeindex' will be used as the
|
||||||
|
# default command name.
|
||||||
|
|
||||||
|
MAKEINDEX_CMD_NAME = makeindex
|
||||||
|
|
||||||
|
# If the COMPACT_LATEX tag is set to YES Doxygen generates more compact
|
||||||
|
# LaTeX documents. This may be useful for small projects and may help to
|
||||||
|
# save some trees in general.
|
||||||
|
|
||||||
|
COMPACT_LATEX = NO
|
||||||
|
|
||||||
|
# The PAPER_TYPE tag can be used to set the paper type that is used
|
||||||
|
# by the printer. Possible values are: a4, a4wide, letter, legal and
|
||||||
|
# executive. If left blank a4wide will be used.
|
||||||
|
|
||||||
|
PAPER_TYPE = a4wide
|
||||||
|
|
||||||
|
# The EXTRA_PACKAGES tag can be to specify one or more names of LaTeX
|
||||||
|
# packages that should be included in the LaTeX output.
|
||||||
|
|
||||||
|
EXTRA_PACKAGES =
|
||||||
|
|
||||||
|
# The LATEX_HEADER tag can be used to specify a personal LaTeX header for
|
||||||
|
# the generated latex document. The header should contain everything until
|
||||||
|
# the first chapter. If it is left blank doxygen will generate a
|
||||||
|
# standard header. Notice: only use this tag if you know what you are doing!
|
||||||
|
|
||||||
|
LATEX_HEADER =
|
||||||
|
|
||||||
|
# If the PDF_HYPERLINKS tag is set to YES, the LaTeX that is generated
|
||||||
|
# is prepared for conversion to pdf (using ps2pdf). The pdf file will
|
||||||
|
# contain links (just like the HTML output) instead of page references
|
||||||
|
# This makes the output suitable for online browsing using a pdf viewer.
|
||||||
|
|
||||||
|
PDF_HYPERLINKS = NO
|
||||||
|
|
||||||
|
# If the USE_PDFLATEX tag is set to YES, pdflatex will be used instead of
|
||||||
|
# plain latex in the generated Makefile. Set this option to YES to get a
|
||||||
|
# higher quality PDF documentation.
|
||||||
|
|
||||||
|
USE_PDFLATEX = NO
|
||||||
|
|
||||||
|
# If the LATEX_BATCHMODE tag is set to YES, doxygen will add the \\batchmode.
|
||||||
|
# command to the generated LaTeX files. This will instruct LaTeX to keep
|
||||||
|
# running if errors occur, instead of asking the user for help.
|
||||||
|
# This option is also used when generating formulas in HTML.
|
||||||
|
|
||||||
|
LATEX_BATCHMODE = NO
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the RTF output
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# If the GENERATE_RTF tag is set to YES Doxygen will generate RTF output
|
||||||
|
# The RTF output is optimised for Word 97 and may not look very pretty with
|
||||||
|
# other RTF readers or editors.
|
||||||
|
|
||||||
|
GENERATE_RTF = NO
|
||||||
|
|
||||||
|
# The RTF_OUTPUT tag is used to specify where the RTF docs will be put.
|
||||||
|
# If a relative path is entered the value of OUTPUT_DIRECTORY will be
|
||||||
|
# put in front of it. If left blank `rtf' will be used as the default path.
|
||||||
|
|
||||||
|
RTF_OUTPUT = rtf
|
||||||
|
|
||||||
|
# If the COMPACT_RTF tag is set to YES Doxygen generates more compact
|
||||||
|
# RTF documents. This may be useful for small projects and may help to
|
||||||
|
# save some trees in general.
|
||||||
|
|
||||||
|
COMPACT_RTF = NO
|
||||||
|
|
||||||
|
# If the RTF_HYPERLINKS tag is set to YES, the RTF that is generated
|
||||||
|
# will contain hyperlink fields. The RTF file will
|
||||||
|
# contain links (just like the HTML output) instead of page references.
|
||||||
|
# This makes the output suitable for online browsing using WORD or other
|
||||||
|
# programs which support those fields.
|
||||||
|
# Note: wordpad (write) and others do not support links.
|
||||||
|
|
||||||
|
RTF_HYPERLINKS = NO
|
||||||
|
|
||||||
|
# Load stylesheet definitions from file. Syntax is similar to doxygen's
|
||||||
|
# config file, i.e. a series of assigments. You only have to provide
|
||||||
|
# replacements, missing definitions are set to their default value.
|
||||||
|
|
||||||
|
RTF_STYLESHEET_FILE =
|
||||||
|
|
||||||
|
# Set optional variables used in the generation of an rtf document.
|
||||||
|
# Syntax is similar to doxygen's config file.
|
||||||
|
|
||||||
|
RTF_EXTENSIONS_FILE =
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the man page output
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# If the GENERATE_MAN tag is set to YES (the default) Doxygen will
|
||||||
|
# generate man pages
|
||||||
|
|
||||||
|
GENERATE_MAN = NO
|
||||||
|
|
||||||
|
# The MAN_OUTPUT tag is used to specify where the man pages will be put.
|
||||||
|
# If a relative path is entered the value of OUTPUT_DIRECTORY will be
|
||||||
|
# put in front of it. If left blank `man' will be used as the default path.
|
||||||
|
|
||||||
|
MAN_OUTPUT = man
|
||||||
|
|
||||||
|
# The MAN_EXTENSION tag determines the extension that is added to
|
||||||
|
# the generated man pages (default is the subroutine's section .3)
|
||||||
|
|
||||||
|
MAN_EXTENSION = .3
|
||||||
|
|
||||||
|
# If the MAN_LINKS tag is set to YES and Doxygen generates man output,
|
||||||
|
# then it will generate one additional man file for each entity
|
||||||
|
# documented in the real man page(s). These additional files
|
||||||
|
# only source the real man page, but without them the man command
|
||||||
|
# would be unable to find the correct page. The default is NO.
|
||||||
|
|
||||||
|
MAN_LINKS = NO
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the XML output
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# If the GENERATE_XML tag is set to YES Doxygen will
|
||||||
|
# generate an XML file that captures the structure of
|
||||||
|
# the code including all documentation. Note that this
|
||||||
|
# feature is still experimental and incomplete at the
|
||||||
|
# moment.
|
||||||
|
|
||||||
|
GENERATE_XML = NO
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options for the AutoGen Definitions output
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# If the GENERATE_AUTOGEN_DEF tag is set to YES Doxygen will
|
||||||
|
# generate an AutoGen Definitions (see autogen.sf.net) file
|
||||||
|
# that captures the structure of the code including all
|
||||||
|
# documentation. Note that this feature is still experimental
|
||||||
|
# and incomplete at the moment.
|
||||||
|
|
||||||
|
GENERATE_AUTOGEN_DEF = NO
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# Configuration options related to the preprocessor
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# If the ENABLE_PREPROCESSING tag is set to YES (the default) Doxygen will
|
||||||
|
# evaluate all C-preprocessor directives found in the sources and include
|
||||||
|
# files.
|
||||||
|
|
||||||
|
ENABLE_PREPROCESSING = YES
|
||||||
|
|
||||||
|
# If the MACRO_EXPANSION tag is set to YES Doxygen will expand all macro
|
||||||
|
# names in the source code. If set to NO (the default) only conditional
|
||||||
|
# compilation will be performed. Macro expansion can be done in a controlled
|
||||||
|
# way by setting EXPAND_ONLY_PREDEF to YES.
|
||||||
|
|
||||||
|
MACRO_EXPANSION = NO
|
||||||
|
|
||||||
|
# If the EXPAND_ONLY_PREDEF and MACRO_EXPANSION tags are both set to YES
|
||||||
|
# then the macro expansion is limited to the macros specified with the
|
||||||
|
# PREDEFINED and EXPAND_AS_PREDEFINED tags.
|
||||||
|
|
||||||
|
EXPAND_ONLY_PREDEF = NO
|
||||||
|
|
||||||
|
# If the SEARCH_INCLUDES tag is set to YES (the default) the includes files
|
||||||
|
# in the INCLUDE_PATH (see below) will be search if a #include is found.
|
||||||
|
|
||||||
|
SEARCH_INCLUDES = YES
|
||||||
|
|
||||||
|
# The INCLUDE_PATH tag can be used to specify one or more directories that
|
||||||
|
# contain include files that are not input files but should be processed by
|
||||||
|
# the preprocessor.
|
||||||
|
|
||||||
|
INCLUDE_PATH =
|
||||||
|
|
||||||
|
# You can use the INCLUDE_FILE_PATTERNS tag to specify one or more wildcard
|
||||||
|
# patterns (like *.h and *.hpp) to filter out the header-files in the
|
||||||
|
# directories. If left blank, the patterns specified with FILE_PATTERNS will
|
||||||
|
# be used.
|
||||||
|
|
||||||
|
INCLUDE_FILE_PATTERNS =
|
||||||
|
|
||||||
|
# The PREDEFINED tag can be used to specify one or more macro names that
|
||||||
|
# are defined before the preprocessor is started (similar to the -D option of
|
||||||
|
# gcc). The argument of the tag is a list of macros of the form: name
|
||||||
|
# or name=definition (no spaces). If the definition and the = are
|
||||||
|
# omitted =1 is assumed.
|
||||||
|
|
||||||
|
PREDEFINED = BUILD_DATE
|
||||||
|
|
||||||
|
# If the MACRO_EXPANSION and EXPAND_PREDEF_ONLY tags are set to YES then
|
||||||
|
# this tag can be used to specify a list of macro names that should be expanded.
|
||||||
|
# The macro definition that is found in the sources will be used.
|
||||||
|
# Use the PREDEFINED tag if you want to use a different macro definition.
|
||||||
|
|
||||||
|
EXPAND_AS_DEFINED =
|
||||||
|
|
||||||
|
# If the SKIP_FUNCTION_MACROS tag is set to YES (the default) then
|
||||||
|
# doxygen's preprocessor will remove all function-like macros that are alone
|
||||||
|
# on a line and do not end with a semicolon. Such function macros are typically
|
||||||
|
# used for boiler-plate code, and will confuse the parser if not removed.
|
||||||
|
|
||||||
|
SKIP_FUNCTION_MACROS = YES
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# Configuration::addtions related to external references
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# The TAGFILES tag can be used to specify one or more tagfiles.
|
||||||
|
|
||||||
|
TAGFILES =
|
||||||
|
|
||||||
|
# When a file name is specified after GENERATE_TAGFILE, doxygen will create
|
||||||
|
# a tag file that is based on the input files it reads.
|
||||||
|
|
||||||
|
GENERATE_TAGFILE =
|
||||||
|
|
||||||
|
# If the ALLEXTERNALS tag is set to YES all external classes will be listed
|
||||||
|
# in the class index. If set to NO only the inherited external classes
|
||||||
|
# will be listed.
|
||||||
|
|
||||||
|
ALLEXTERNALS = NO
|
||||||
|
|
||||||
|
# If the EXTERNAL_GROUPS tag is set to YES all external groups will be listed
|
||||||
|
# in the modules index. If set to NO, only the current project's groups will
|
||||||
|
# be listed.
|
||||||
|
|
||||||
|
EXTERNAL_GROUPS = YES
|
||||||
|
|
||||||
|
# The PERL_PATH should be the absolute path and name of the perl script
|
||||||
|
# interpreter (i.e. the result of `which perl').
|
||||||
|
|
||||||
|
PERL_PATH = /usr/bin/perl
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# Configuration options related to the dot tool
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# If the CLASS_DIAGRAMS tag is set to YES (the default) Doxygen will
|
||||||
|
# generate a inheritance diagram (in Html, RTF and LaTeX) for classes with base or
|
||||||
|
# super classes. Setting the tag to NO turns the diagrams off. Note that this
|
||||||
|
# option is superceded by the HAVE_DOT option below. This is only a fallback. It is
|
||||||
|
# recommended to install and use dot, since it yield more powerful graphs.
|
||||||
|
|
||||||
|
CLASS_DIAGRAMS = YES
|
||||||
|
|
||||||
|
# If you set the HAVE_DOT tag to YES then doxygen will assume the dot tool is
|
||||||
|
# available from the path. This tool is part of Graphviz, a graph visualization
|
||||||
|
# toolkit from AT&T and Lucent Bell Labs. The other options in this section
|
||||||
|
# have no effect if this option is set to NO (the default)
|
||||||
|
|
||||||
|
HAVE_DOT = NO
|
||||||
|
|
||||||
|
# If the CLASS_GRAPH and HAVE_DOT tags are set to YES then doxygen
|
||||||
|
# will generate a graph for each documented class showing the direct and
|
||||||
|
# indirect inheritance relations. Setting this tag to YES will force the
|
||||||
|
# the CLASS_DIAGRAMS tag to NO.
|
||||||
|
|
||||||
|
CLASS_GRAPH = YES
|
||||||
|
|
||||||
|
# If the COLLABORATION_GRAPH and HAVE_DOT tags are set to YES then doxygen
|
||||||
|
# will generate a graph for each documented class showing the direct and
|
||||||
|
# indirect implementation dependencies (inheritance, containment, and
|
||||||
|
# class references variables) of the class with other documented classes.
|
||||||
|
|
||||||
|
COLLABORATION_GRAPH = YES
|
||||||
|
|
||||||
|
# If set to YES, the inheritance and collaboration graphs will show the
|
||||||
|
# relations between templates and their instances.
|
||||||
|
|
||||||
|
TEMPLATE_RELATIONS = YES
|
||||||
|
|
||||||
|
# If set to YES, the inheritance and collaboration graphs will hide
|
||||||
|
# inheritance and usage relations if the target is undocumented
|
||||||
|
# or is not a class.
|
||||||
|
|
||||||
|
HIDE_UNDOC_RELATIONS = YES
|
||||||
|
|
||||||
|
# If the ENABLE_PREPROCESSING, SEARCH_INCLUDES, INCLUDE_GRAPH, and HAVE_DOT
|
||||||
|
# tags are set to YES then doxygen will generate a graph for each documented
|
||||||
|
# file showing the direct and indirect include dependencies of the file with
|
||||||
|
# other documented files.
|
||||||
|
|
||||||
|
INCLUDE_GRAPH = YES
|
||||||
|
|
||||||
|
# If the ENABLE_PREPROCESSING, SEARCH_INCLUDES, INCLUDED_BY_GRAPH, and
|
||||||
|
# HAVE_DOT tags are set to YES then doxygen will generate a graph for each
|
||||||
|
# documented header file showing the documented files that directly or
|
||||||
|
# indirectly include this file.
|
||||||
|
|
||||||
|
INCLUDED_BY_GRAPH = YES
|
||||||
|
|
||||||
|
# If the GRAPHICAL_HIERARCHY and HAVE_DOT tags are set to YES then doxygen
|
||||||
|
# will graphical hierarchy of all classes instead of a textual one.
|
||||||
|
|
||||||
|
GRAPHICAL_HIERARCHY = YES
|
||||||
|
|
||||||
|
# The DOT_IMAGE_FORMAT tag can be used to set the image format of the images
|
||||||
|
# generated by dot. Possible values are png, jpg, or gif
|
||||||
|
# If left blank png will be used.
|
||||||
|
|
||||||
|
DOT_IMAGE_FORMAT = png
|
||||||
|
|
||||||
|
# The tag DOT_PATH can be used to specify the path where the dot tool can be
|
||||||
|
# found. If left blank, it is assumed the dot tool can be found on the path.
|
||||||
|
|
||||||
|
DOT_PATH =
|
||||||
|
|
||||||
|
# The DOTFILE_DIRS tag can be used to specify one or more directories that
|
||||||
|
# contain dot files that are included in the documentation (see the
|
||||||
|
# \dotfile command).
|
||||||
|
|
||||||
|
DOTFILE_DIRS =
|
||||||
|
|
||||||
|
# The MAX_DOT_GRAPH_WIDTH tag can be used to set the maximum allowed width
|
||||||
|
# (in pixels) of the graphs generated by dot. If a graph becomes larger than
|
||||||
|
# this value, doxygen will try to truncate the graph, so that it fits within
|
||||||
|
# the specified constraint. Beware that most browsers cannot cope with very
|
||||||
|
# large images.
|
||||||
|
|
||||||
|
MAX_DOT_GRAPH_WIDTH = 1024
|
||||||
|
|
||||||
|
# The MAX_DOT_GRAPH_HEIGHT tag can be used to set the maximum allows height
|
||||||
|
# (in pixels) of the graphs generated by dot. If a graph becomes larger than
|
||||||
|
# this value, doxygen will try to truncate the graph, so that it fits within
|
||||||
|
# the specified constraint. Beware that most browsers cannot cope with very
|
||||||
|
# large images.
|
||||||
|
|
||||||
|
MAX_DOT_GRAPH_HEIGHT = 1024
|
||||||
|
|
||||||
|
# If the GENERATE_LEGEND tag is set to YES (the default) Doxygen will
|
||||||
|
# generate a legend page explaining the meaning of the various boxes and
|
||||||
|
# arrows in the dot generated graphs.
|
||||||
|
|
||||||
|
GENERATE_LEGEND = YES
|
||||||
|
|
||||||
|
# If the DOT_CLEANUP tag is set to YES (the default) Doxygen will
|
||||||
|
# remove the intermedate dot files that are used to generate
|
||||||
|
# the various graphs.
|
||||||
|
|
||||||
|
DOT_CLEANUP = YES
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# Configuration::addtions related to the search engine
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# The SEARCHENGINE tag specifies whether or not a search engine should be
|
||||||
|
# used. If set to NO the values of all tags below this one will be ignored.
|
||||||
|
|
||||||
|
SEARCHENGINE = NO
|
||||||
|
|
||||||
|
# The CGI_NAME tag should be the name of the CGI script that
|
||||||
|
# starts the search engine (doxysearch) with the correct parameters.
|
||||||
|
# A script with this name will be generated by doxygen.
|
||||||
|
|
||||||
|
CGI_NAME = search.cgi
|
||||||
|
|
||||||
|
# The CGI_URL tag should be the absolute URL to the directory where the
|
||||||
|
# cgi binaries are located. See the documentation of your http daemon for
|
||||||
|
# details.
|
||||||
|
|
||||||
|
CGI_URL =
|
||||||
|
|
||||||
|
# The DOC_URL tag should be the absolute URL to the directory where the
|
||||||
|
# documentation is located. If left blank the absolute path to the
|
||||||
|
# documentation, with file:// prepended to it, will be used.
|
||||||
|
|
||||||
|
DOC_URL =
|
||||||
|
|
||||||
|
# The DOC_ABSPATH tag should be the absolute path to the directory where the
|
||||||
|
# documentation is located. If left blank the directory on the local machine
|
||||||
|
# will be used.
|
||||||
|
|
||||||
|
DOC_ABSPATH =
|
||||||
|
|
||||||
|
# The BIN_ABSPATH tag must point to the directory where the doxysearch binary
|
||||||
|
# is installed.
|
||||||
|
|
||||||
|
BIN_ABSPATH = /usr/local/bin/
|
||||||
|
|
||||||
|
# The EXT_DOC_PATHS tag can be used to specify one or more paths to
|
||||||
|
# documentation generated for other projects. This allows doxysearch to search
|
||||||
|
# the documentation for these projects as well.
|
||||||
|
|
||||||
|
EXT_DOC_PATHS =
|
||||||
340
doc/GPL-license.txt
Normal file
340
doc/GPL-license.txt
Normal file
@@ -0,0 +1,340 @@
|
|||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
Version 2, June 1991
|
||||||
|
|
||||||
|
Copyright (C) 1989, 1991 Free Software Foundation, Inc.
|
||||||
|
59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
|
Preamble
|
||||||
|
|
||||||
|
The licenses for most software are designed to take away your
|
||||||
|
freedom to share and change it. By contrast, the GNU General Public
|
||||||
|
License is intended to guarantee your freedom to share and change free
|
||||||
|
software--to make sure the software is free for all its users. This
|
||||||
|
General Public License applies to most of the Free Software
|
||||||
|
Foundation's software and to any other program whose authors commit to
|
||||||
|
using it. (Some other Free Software Foundation software is covered by
|
||||||
|
the GNU Library General Public License instead.) You can apply it to
|
||||||
|
your programs, too.
|
||||||
|
|
||||||
|
When we speak of free software, we are referring to freedom, not
|
||||||
|
price. Our General Public Licenses are designed to make sure that you
|
||||||
|
have the freedom to distribute copies of free software (and charge for
|
||||||
|
this service if you wish), that you receive source code or can get it
|
||||||
|
if you want it, that you can change the software or use pieces of it
|
||||||
|
in new free programs; and that you know you can do these things.
|
||||||
|
|
||||||
|
To protect your rights, we need to make restrictions that forbid
|
||||||
|
anyone to deny you these rights or to ask you to surrender the rights.
|
||||||
|
These restrictions translate to certain responsibilities for you if you
|
||||||
|
distribute copies of the software, or if you modify it.
|
||||||
|
|
||||||
|
For example, if you distribute copies of such a program, whether
|
||||||
|
gratis or for a fee, you must give the recipients all the rights that
|
||||||
|
you have. You must make sure that they, too, receive or can get the
|
||||||
|
source code. And you must show them these terms so they know their
|
||||||
|
rights.
|
||||||
|
|
||||||
|
We protect your rights with two steps: (1) copyright the software, and
|
||||||
|
(2) offer you this license which gives you legal permission to copy,
|
||||||
|
distribute and/or modify the software.
|
||||||
|
|
||||||
|
Also, for each author's protection and ours, we want to make certain
|
||||||
|
that everyone understands that there is no warranty for this free
|
||||||
|
software. If the software is modified by someone else and passed on, we
|
||||||
|
want its recipients to know that what they have is not the original, so
|
||||||
|
that any problems introduced by others will not reflect on the original
|
||||||
|
authors' reputations.
|
||||||
|
|
||||||
|
Finally, any free program is threatened constantly by software
|
||||||
|
patents. We wish to avoid the danger that redistributors of a free
|
||||||
|
program will individually obtain patent licenses, in effect making the
|
||||||
|
program proprietary. To prevent this, we have made it clear that any
|
||||||
|
patent must be licensed for everyone's free use or not licensed at all.
|
||||||
|
|
||||||
|
The precise terms and conditions for copying, distribution and
|
||||||
|
modification follow.
|
||||||
|
|
||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||||
|
|
||||||
|
0. This License applies to any program or other work which contains
|
||||||
|
a notice placed by the copyright holder saying it may be distributed
|
||||||
|
under the terms of this General Public License. The "Program", below,
|
||||||
|
refers to any such program or work, and a "work based on the Program"
|
||||||
|
means either the Program or any derivative work under copyright law:
|
||||||
|
that is to say, a work containing the Program or a portion of it,
|
||||||
|
either verbatim or with modifications and/or translated into another
|
||||||
|
language. (Hereinafter, translation is included without limitation in
|
||||||
|
the term "modification".) Each licensee is addressed as "you".
|
||||||
|
|
||||||
|
Activities other than copying, distribution and modification are not
|
||||||
|
covered by this License; they are outside its scope. The act of
|
||||||
|
running the Program is not restricted, and the output from the Program
|
||||||
|
is covered only if its contents constitute a work based on the
|
||||||
|
Program (independent of having been made by running the Program).
|
||||||
|
Whether that is true depends on what the Program does.
|
||||||
|
|
||||||
|
1. You may copy and distribute verbatim copies of the Program's
|
||||||
|
source code as you receive it, in any medium, provided that you
|
||||||
|
conspicuously and appropriately publish on each copy an appropriate
|
||||||
|
copyright notice and disclaimer of warranty; keep intact all the
|
||||||
|
notices that refer to this License and to the absence of any warranty;
|
||||||
|
and give any other recipients of the Program a copy of this License
|
||||||
|
along with the Program.
|
||||||
|
|
||||||
|
You may charge a fee for the physical act of transferring a copy, and
|
||||||
|
you may at your option offer warranty protection in exchange for a fee.
|
||||||
|
|
||||||
|
2. You may modify your copy or copies of the Program or any portion
|
||||||
|
of it, thus forming a work based on the Program, and copy and
|
||||||
|
distribute such modifications or work under the terms of Section 1
|
||||||
|
above, provided that you also meet all of these conditions:
|
||||||
|
|
||||||
|
a) You must cause the modified files to carry prominent notices
|
||||||
|
stating that you changed the files and the date of any change.
|
||||||
|
|
||||||
|
b) You must cause any work that you distribute or publish, that in
|
||||||
|
whole or in part contains or is derived from the Program or any
|
||||||
|
part thereof, to be licensed as a whole at no charge to all third
|
||||||
|
parties under the terms of this License.
|
||||||
|
|
||||||
|
c) If the modified program normally reads commands interactively
|
||||||
|
when run, you must cause it, when started running for such
|
||||||
|
interactive use in the most ordinary way, to print or display an
|
||||||
|
announcement including an appropriate copyright notice and a
|
||||||
|
notice that there is no warranty (or else, saying that you provide
|
||||||
|
a warranty) and that users may redistribute the program under
|
||||||
|
these conditions, and telling the user how to view a copy of this
|
||||||
|
License. (Exception: if the Program itself is interactive but
|
||||||
|
does not normally print such an announcement, your work based on
|
||||||
|
the Program is not required to print an announcement.)
|
||||||
|
|
||||||
|
These requirements apply to the modified work as a whole. If
|
||||||
|
identifiable sections of that work are not derived from the Program,
|
||||||
|
and can be reasonably considered independent and separate works in
|
||||||
|
themselves, then this License, and its terms, do not apply to those
|
||||||
|
sections when you distribute them as separate works. But when you
|
||||||
|
distribute the same sections as part of a whole which is a work based
|
||||||
|
on the Program, the distribution of the whole must be on the terms of
|
||||||
|
this License, whose permissions for other licensees extend to the
|
||||||
|
entire whole, and thus to each and every part regardless of who wrote it.
|
||||||
|
|
||||||
|
Thus, it is not the intent of this section to claim rights or contest
|
||||||
|
your rights to work written entirely by you; rather, the intent is to
|
||||||
|
exercise the right to control the distribution of derivative or
|
||||||
|
collective works based on the Program.
|
||||||
|
|
||||||
|
In addition, mere aggregation of another work not based on the Program
|
||||||
|
with the Program (or with a work based on the Program) on a volume of
|
||||||
|
a storage or distribution medium does not bring the other work under
|
||||||
|
the scope of this License.
|
||||||
|
|
||||||
|
3. You may copy and distribute the Program (or a work based on it,
|
||||||
|
under Section 2) in object code or executable form under the terms of
|
||||||
|
Sections 1 and 2 above provided that you also do one of the following:
|
||||||
|
|
||||||
|
a) Accompany it with the complete corresponding machine-readable
|
||||||
|
source code, which must be distributed under the terms of Sections
|
||||||
|
1 and 2 above on a medium customarily used for software interchange; or,
|
||||||
|
|
||||||
|
b) Accompany it with a written offer, valid for at least three
|
||||||
|
years, to give any third party, for a charge no more than your
|
||||||
|
cost of physically performing source distribution, a complete
|
||||||
|
machine-readable copy of the corresponding source code, to be
|
||||||
|
distributed under the terms of Sections 1 and 2 above on a medium
|
||||||
|
customarily used for software interchange; or,
|
||||||
|
|
||||||
|
c) Accompany it with the information you received as to the offer
|
||||||
|
to distribute corresponding source code. (This alternative is
|
||||||
|
allowed only for noncommercial distribution and only if you
|
||||||
|
received the program in object code or executable form with such
|
||||||
|
an offer, in accord with Subsection b above.)
|
||||||
|
|
||||||
|
The source code for a work means the preferred form of the work for
|
||||||
|
making modifications to it. For an executable work, complete source
|
||||||
|
code means all the source code for all modules it contains, plus any
|
||||||
|
associated interface definition files, plus the scripts used to
|
||||||
|
control compilation and installation of the executable. However, as a
|
||||||
|
special exception, the source code distributed need not include
|
||||||
|
anything that is normally distributed (in either source or binary
|
||||||
|
form) with the major components (compiler, kernel, and so on) of the
|
||||||
|
operating system on which the executable runs, unless that component
|
||||||
|
itself accompanies the executable.
|
||||||
|
|
||||||
|
If distribution of executable or object code is made by offering
|
||||||
|
access to copy from a designated place, then offering equivalent
|
||||||
|
access to copy the source code from the same place counts as
|
||||||
|
distribution of the source code, even though third parties are not
|
||||||
|
compelled to copy the source along with the object code.
|
||||||
|
|
||||||
|
4. You may not copy, modify, sublicense, or distribute the Program
|
||||||
|
except as expressly provided under this License. Any attempt
|
||||||
|
otherwise to copy, modify, sublicense or distribute the Program is
|
||||||
|
void, and will automatically terminate your rights under this License.
|
||||||
|
However, parties who have received copies, or rights, from you under
|
||||||
|
this License will not have their licenses terminated so long as such
|
||||||
|
parties remain in full compliance.
|
||||||
|
|
||||||
|
5. You are not required to accept this License, since you have not
|
||||||
|
signed it. However, nothing else grants you permission to modify or
|
||||||
|
distribute the Program or its derivative works. These actions are
|
||||||
|
prohibited by law if you do not accept this License. Therefore, by
|
||||||
|
modifying or distributing the Program (or any work based on the
|
||||||
|
Program), you indicate your acceptance of this License to do so, and
|
||||||
|
all its terms and conditions for copying, distributing or modifying
|
||||||
|
the Program or works based on it.
|
||||||
|
|
||||||
|
6. Each time you redistribute the Program (or any work based on the
|
||||||
|
Program), the recipient automatically receives a license from the
|
||||||
|
original licensor to copy, distribute or modify the Program subject to
|
||||||
|
these terms and conditions. You may not impose any further
|
||||||
|
restrictions on the recipients' exercise of the rights granted herein.
|
||||||
|
You are not responsible for enforcing compliance by third parties to
|
||||||
|
this License.
|
||||||
|
|
||||||
|
7. If, as a consequence of a court judgment or allegation of patent
|
||||||
|
infringement or for any other reason (not limited to patent issues),
|
||||||
|
conditions are imposed on you (whether by court order, agreement or
|
||||||
|
otherwise) that contradict the conditions of this License, they do not
|
||||||
|
excuse you from the conditions of this License. If you cannot
|
||||||
|
distribute so as to satisfy simultaneously your obligations under this
|
||||||
|
License and any other pertinent obligations, then as a consequence you
|
||||||
|
may not distribute the Program at all. For example, if a patent
|
||||||
|
license would not permit royalty-free redistribution of the Program by
|
||||||
|
all those who receive copies directly or indirectly through you, then
|
||||||
|
the only way you could satisfy both it and this License would be to
|
||||||
|
refrain entirely from distribution of the Program.
|
||||||
|
|
||||||
|
If any portion of this section is held invalid or unenforceable under
|
||||||
|
any particular circumstance, the balance of the section is intended to
|
||||||
|
apply and the section as a whole is intended to apply in other
|
||||||
|
circumstances.
|
||||||
|
|
||||||
|
It is not the purpose of this section to induce you to infringe any
|
||||||
|
patents or other property right claims or to contest validity of any
|
||||||
|
such claims; this section has the sole purpose of protecting the
|
||||||
|
integrity of the free software distribution system, which is
|
||||||
|
implemented by public license practices. Many people have made
|
||||||
|
generous contributions to the wide range of software distributed
|
||||||
|
through that system in reliance on consistent application of that
|
||||||
|
system; it is up to the author/donor to decide if he or she is willing
|
||||||
|
to distribute software through any other system and a licensee cannot
|
||||||
|
impose that choice.
|
||||||
|
|
||||||
|
This section is intended to make thoroughly clear what is believed to
|
||||||
|
be a consequence of the rest of this License.
|
||||||
|
|
||||||
|
8. If the distribution and/or use of the Program is restricted in
|
||||||
|
certain countries either by patents or by copyrighted interfaces, the
|
||||||
|
original copyright holder who places the Program under this License
|
||||||
|
may add an explicit geographical distribution limitation excluding
|
||||||
|
those countries, so that distribution is permitted only in or among
|
||||||
|
countries not thus excluded. In such case, this License incorporates
|
||||||
|
the limitation as if written in the body of this License.
|
||||||
|
|
||||||
|
9. The Free Software Foundation may publish revised and/or new versions
|
||||||
|
of the General Public License from time to time. Such new versions will
|
||||||
|
be similar in spirit to the present version, but may differ in detail to
|
||||||
|
address new problems or concerns.
|
||||||
|
|
||||||
|
Each version is given a distinguishing version number. If the Program
|
||||||
|
specifies a version number of this License which applies to it and "any
|
||||||
|
later version", you have the option of following the terms and conditions
|
||||||
|
either of that version or of any later version published by the Free
|
||||||
|
Software Foundation. If the Program does not specify a version number of
|
||||||
|
this License, you may choose any version ever published by the Free Software
|
||||||
|
Foundation.
|
||||||
|
|
||||||
|
10. If you wish to incorporate parts of the Program into other free
|
||||||
|
programs whose distribution conditions are different, write to the author
|
||||||
|
to ask for permission. For software which is copyrighted by the Free
|
||||||
|
Software Foundation, write to the Free Software Foundation; we sometimes
|
||||||
|
make exceptions for this. Our decision will be guided by the two goals
|
||||||
|
of preserving the free status of all derivatives of our free software and
|
||||||
|
of promoting the sharing and reuse of software generally.
|
||||||
|
|
||||||
|
NO WARRANTY
|
||||||
|
|
||||||
|
11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
|
||||||
|
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
|
||||||
|
OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
|
||||||
|
PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
|
||||||
|
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
|
||||||
|
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
|
||||||
|
PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
|
||||||
|
REPAIR OR CORRECTION.
|
||||||
|
|
||||||
|
12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||||
|
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
|
||||||
|
REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
|
||||||
|
INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
|
||||||
|
OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
|
||||||
|
TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
|
||||||
|
YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
|
||||||
|
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGES.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
How to Apply These Terms to Your New Programs
|
||||||
|
|
||||||
|
If you develop a new program, and you want it to be of the greatest
|
||||||
|
possible use to the public, the best way to achieve this is to make it
|
||||||
|
free software which everyone can redistribute and change under these terms.
|
||||||
|
|
||||||
|
To do so, attach the following notices to the program. It is safest
|
||||||
|
to attach them to the start of each source file to most effectively
|
||||||
|
convey the exclusion of warranty; and each file should have at least
|
||||||
|
the "copyright" line and a pointer to where the full notice is found.
|
||||||
|
|
||||||
|
<one line to give the program's name and a brief idea of what it does.>
|
||||||
|
Copyright (C) <year> <name of author>
|
||||||
|
|
||||||
|
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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
|
||||||
|
|
||||||
|
Also add information on how to contact you by electronic and paper mail.
|
||||||
|
|
||||||
|
If the program is interactive, make it output a short notice like this
|
||||||
|
when it starts in an interactive mode:
|
||||||
|
|
||||||
|
Gnomovision version 69, Copyright (C) year name of author
|
||||||
|
Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||||
|
This is free software, and you are welcome to redistribute it
|
||||||
|
under certain conditions; type `show c' for details.
|
||||||
|
|
||||||
|
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||||
|
parts of the General Public License. Of course, the commands you use may
|
||||||
|
be called something other than `show w' and `show c'; they could even be
|
||||||
|
mouse-clicks or menu items--whatever suits your program.
|
||||||
|
|
||||||
|
You should also get your employer (if you work as a programmer) or your
|
||||||
|
school, if any, to sign a "copyright disclaimer" for the program, if
|
||||||
|
necessary. Here is a sample; alter the names:
|
||||||
|
|
||||||
|
Yoyodyne, Inc., hereby disclaims all copyright interest in the program
|
||||||
|
`Gnomovision' (which makes passes at compilers) written by James Hacker.
|
||||||
|
|
||||||
|
<signature of Ty Coon>, 1 April 1989
|
||||||
|
Ty Coon, President of Vice
|
||||||
|
|
||||||
|
This General Public License does not permit incorporating your program into
|
||||||
|
proprietary programs. If your program is a subroutine library, you may
|
||||||
|
consider it more useful to permit linking proprietary applications with the
|
||||||
|
library. If this is what you want to do, use the GNU Library General
|
||||||
|
Public License instead of this License.
|
||||||
123
doc/README.windows-gcc
Normal file
123
doc/README.windows-gcc
Normal file
@@ -0,0 +1,123 @@
|
|||||||
|
An updated version of this guide can be found at:
|
||||||
|
|
||||||
|
http://www.blender3d.org/cms/Building_with_Cygwin.524.0.html
|
||||||
|
|
||||||
|
Introduction
|
||||||
|
------------
|
||||||
|
|
||||||
|
Here are some basic instructions for building
|
||||||
|
blender for windows using gcc under cygwin.
|
||||||
|
Please note that the resulting executable does not
|
||||||
|
depend on cygwin and can be distrubuted to machines
|
||||||
|
that don't have cygwin installed.
|
||||||
|
|
||||||
|
The instructions are:
|
||||||
|
|
||||||
|
1. Download cygwin (www.cygwin.com) and use the setup program
|
||||||
|
to install packages for gcc, gcc-mingw, gcc-g++, w32api, make, cvs,
|
||||||
|
python, perl, gettext, and gettext-devel (and maybe others... the
|
||||||
|
dependency list is bound to change over time and hopefully these
|
||||||
|
instructions will keep up with the changes). All of the following
|
||||||
|
commands will be entered at the cygwin prompt so launch
|
||||||
|
cygwin now.
|
||||||
|
|
||||||
|
2. Create a directory to put your sources and then enter that
|
||||||
|
directory, e.g.:
|
||||||
|
mkdir bf-blender
|
||||||
|
cd bf-blender
|
||||||
|
|
||||||
|
*********WARNING: if the directory path you are in contains a space in
|
||||||
|
it you will get errors in trying to compile the code. Change directorys
|
||||||
|
to a one that does not contain a space in the path before creating the
|
||||||
|
above directory *********
|
||||||
|
|
||||||
|
|
||||||
|
Please note that a backslash at the end of a line in the following
|
||||||
|
means that the command spans two lines. If you wish to type the command as
|
||||||
|
one line, exclude the '\'.
|
||||||
|
|
||||||
|
3. Checkout the blender module from the bf-blender tree using cvs
|
||||||
|
(use password anonymous):
|
||||||
|
cvs -d:pserver:anonymous@cvs.blender.org:/cvsroot/bf-blender login
|
||||||
|
cvs -z3 -d:pserver:anonymous@cvs.blender.org:/cvsroot/bf-blender \
|
||||||
|
co blender
|
||||||
|
|
||||||
|
4. Checkout the lib/windows module from bf-blender using cvs:
|
||||||
|
cvs -z3 -d:pserver:anonymous@cvs.blender.org:/cvsroot/bf-blender \
|
||||||
|
co lib/windows
|
||||||
|
|
||||||
|
5. Enter the newly created blender directory:
|
||||||
|
cd blender
|
||||||
|
|
||||||
|
6. To prepare the build system to use only the free tools we must
|
||||||
|
set some environment variables. This is done by creating a
|
||||||
|
file called "user-def.mk" in the blender directory and
|
||||||
|
inserting the following line with notepad or your favorite
|
||||||
|
text editor:
|
||||||
|
export FREE_WINDOWS=true
|
||||||
|
|
||||||
|
The quickest way to do this though is to issue the following
|
||||||
|
command:
|
||||||
|
echo 'export FREE_WINDOWS=true' > user-def.mk
|
||||||
|
|
||||||
|
7. Time to build... issue the command:
|
||||||
|
make
|
||||||
|
|
||||||
|
8. Wait for it to finish (there is this mysterious place called
|
||||||
|
'outside' that I am told is nice to go to while waiting for a
|
||||||
|
compile to finish).
|
||||||
|
|
||||||
|
9. After it finishes compiling, if you would like to run your freshly compiled
|
||||||
|
blender, type make release. Then change directorys to obj/233.a/ and move
|
||||||
|
the zip file to where you want to use it, unzip the file, enter the directory
|
||||||
|
and run your brand new blender.
|
||||||
|
|
||||||
|
|
||||||
|
Getting Help
|
||||||
|
------------
|
||||||
|
If you have problems, come by #blendercompilers on irc.freenode.net
|
||||||
|
or post questions to the "Compiling, Libraries, Modules" forum
|
||||||
|
at www.blender.org. There is also the very useful bf-committers
|
||||||
|
mailing list, what you can subscribe to here:
|
||||||
|
|
||||||
|
http://www.blender.org/mailman/listinfo/bf-committers
|
||||||
|
(as a bonus you can get info about the most recent features that
|
||||||
|
are coming down the pipe ...)
|
||||||
|
|
||||||
|
This said, the most common fix to a problem will
|
||||||
|
probably involve installing an additional cygwin package,
|
||||||
|
so keep that cygwin setup program close by ...
|
||||||
|
|
||||||
|
Some final notes
|
||||||
|
----------------
|
||||||
|
|
||||||
|
- The build will take a long time, even on a fast machine
|
||||||
|
(a clean build takes almost an hour on my Athlon 1800+
|
||||||
|
based laptop).
|
||||||
|
- If the build is successful you will find it has created
|
||||||
|
the program obj/windows/bin/blender.exe
|
||||||
|
- The executable generated by gcc will generally be slower
|
||||||
|
that an msvc++ generated executable at rendering, but the
|
||||||
|
OpenGL speed should be about the same.
|
||||||
|
- Sound is disabled
|
||||||
|
- If you want to clean your sources issue a 'make clean'
|
||||||
|
in the top blender directory.
|
||||||
|
- If you want to update your sources when somebody has
|
||||||
|
added a new awesome feature, you will want to go to the
|
||||||
|
topmost blender directory and issue the following command:
|
||||||
|
cvs -z3 update -P -d
|
||||||
|
It would probably be best to clean your sources before
|
||||||
|
re-building (see previous note).
|
||||||
|
- This is a work in progress, so some things may not be working
|
||||||
|
right or it may not support all of the cutting edge features.
|
||||||
|
- Want to make a fancy zipped up blender package to give
|
||||||
|
to your buddies? Try "make release" ... read the output
|
||||||
|
to find out where the zip file was placed (note: you will
|
||||||
|
probably need the zip/unzip packages from cygwin to do
|
||||||
|
this).
|
||||||
|
- You can make a debug executable using 'make debug'. The
|
||||||
|
debug executable will be larger and slower that the
|
||||||
|
regular executable, but when used with the gnu debugger
|
||||||
|
(gdb) it can help debug a blender problem (for example,
|
||||||
|
it can locate the line of code that caused blender to
|
||||||
|
crash).
|
||||||
1393
doc/bf-members.txt
Normal file
1393
doc/bf-members.txt
Normal file
File diff suppressed because it is too large
Load Diff
156
doc/blender-cmake.txt
Normal file
156
doc/blender-cmake.txt
Normal file
@@ -0,0 +1,156 @@
|
|||||||
|
$Id$
|
||||||
|
|
||||||
|
Blender CMake build system
|
||||||
|
============================
|
||||||
|
|
||||||
|
Contents
|
||||||
|
---------------
|
||||||
|
|
||||||
|
1. Introduction
|
||||||
|
2. Obtaining CMake
|
||||||
|
3. Obtaining Dependencies
|
||||||
|
4. Deciding on a Build Environment
|
||||||
|
5. Configuring the build for the first time
|
||||||
|
6. Configuring the build after CVS updates
|
||||||
|
7. Specify alternate Python library versions and locations
|
||||||
|
|
||||||
|
|
||||||
|
1. Introduction
|
||||||
|
---------------
|
||||||
|
|
||||||
|
This document describes general usage of the new CMake scripts. The
|
||||||
|
inner workings will be described in blender-cmake-dev.txt (TODO).
|
||||||
|
|
||||||
|
2. Obtaining CMake
|
||||||
|
------------------
|
||||||
|
|
||||||
|
CMake for can either be downloaded using your favorite package manager
|
||||||
|
or is also available from the CMake website at http://www.cmake.org
|
||||||
|
The website also contains some documentation on CMake usage but I found
|
||||||
|
the man page alone pretty helpful.
|
||||||
|
|
||||||
|
3. Obtaining Dependencies
|
||||||
|
-------------------------
|
||||||
|
|
||||||
|
Check from the page
|
||||||
|
http://www.blender.org/cms/Getting_Dependencies.135.0.html that you
|
||||||
|
have all dependencies needed for building Blender. Note that for
|
||||||
|
windows many of these dependencies already come in the lib/windows
|
||||||
|
module from CVS.
|
||||||
|
|
||||||
|
4. Deciding on a Build Environment
|
||||||
|
----------------------------------
|
||||||
|
|
||||||
|
To build Blender with the CMake scripts you first need to decide which
|
||||||
|
build environment you feel comfortable with. This decision will also be
|
||||||
|
influenced by the platform you are developing on. The current implementation
|
||||||
|
have been successfully used to generate build files for the following
|
||||||
|
environments:
|
||||||
|
|
||||||
|
1. Microsoft Visual Studio 2005. There is a free version available
|
||||||
|
at http://msdn.microsoft.com/vstudio/express/visualc/.
|
||||||
|
|
||||||
|
2. Xcode on Mac OSX
|
||||||
|
|
||||||
|
3. Unix Makefiles (On Linux and Mac OSX): CMake actually creates make
|
||||||
|
files which generates nicely color coded output and a percentage
|
||||||
|
progress indicator.
|
||||||
|
|
||||||
|
|
||||||
|
5. Configuring the build for the first time
|
||||||
|
-------------------------------------------
|
||||||
|
|
||||||
|
CMake allows one to generate the build project files and binary objects
|
||||||
|
outside the source tree which can be pretty handy in working and experimenting
|
||||||
|
with different Blender configurations (Audio/NoAudio, GameEngine/NoGameEngine etc.)
|
||||||
|
while maintaining a clean source tree. It also makes it possible to generate files
|
||||||
|
for different build systems on the same source tree. This also has benefits for
|
||||||
|
general CVS management for the developer as patches and submit logs are much cleaner.
|
||||||
|
|
||||||
|
Create a directory outside the blender source tree where you would like to build
|
||||||
|
Blender (from now on called $BLENDERBUILD). On the commandline you can then run
|
||||||
|
the cmake command to generate your initial build files. First just run 'cmake' which
|
||||||
|
will inform you what the available generators are. Thn you can run
|
||||||
|
'cmake -G generator $BLENDERSOURCE' to generate the build files. Here is an example
|
||||||
|
of all this for Xcode:
|
||||||
|
|
||||||
|
% mkdir $BLENDERBUILD
|
||||||
|
% cd $BLENDERBUILD
|
||||||
|
% cmake
|
||||||
|
|
||||||
|
...
|
||||||
|
...
|
||||||
|
--version [file] = Show program name/version banner and exit.
|
||||||
|
|
||||||
|
Generators
|
||||||
|
|
||||||
|
The following generators are available on this platform:
|
||||||
|
KDevelop3 = Generates KDevelop 3 project files.
|
||||||
|
Unix Makefiles = Generates standard UNIX makefiles.
|
||||||
|
Xcode = Generate XCode project files.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
% cmake -G Xcode $BLENDERSOURCE
|
||||||
|
...
|
||||||
|
...
|
||||||
|
-- Configuring blender
|
||||||
|
-- Configuring blenderplayer
|
||||||
|
-- Configuring done
|
||||||
|
-- Generating done
|
||||||
|
-- Build files have been written to: $BLENDERBUILD
|
||||||
|
|
||||||
|
This will generate the build files with default values. Specific features can
|
||||||
|
be enabled or disabled by running the ccmake "GUI" from $BLENDERBUILD as follows:
|
||||||
|
|
||||||
|
% ccmake $BLENDERSOURCE
|
||||||
|
|
||||||
|
A number of options appear which can be changed depending on your needs and
|
||||||
|
available dependencies (e.g. setting WITH_OPENEXR to OFF will disable support
|
||||||
|
for OpenEXR). It will also allow you to override default and detected paths
|
||||||
|
(e.g. Python directories) and compile and link flags. When you are satisfied
|
||||||
|
used ccmake to re-configure the build files and exit.
|
||||||
|
|
||||||
|
It is also possible to use the commandline of 'cmake' to override certain
|
||||||
|
of these settings.
|
||||||
|
|
||||||
|
6. Configuring the build after CVS updates
|
||||||
|
------------------------------------------
|
||||||
|
|
||||||
|
The $BLENDERBUILD directory maintains a file called CMakeCache.txt which
|
||||||
|
remembers the initial run's settings for subsequent generation runs. After
|
||||||
|
every CVS update it may be a good idea to rerun the generation before building
|
||||||
|
Blender again. Just rerun the original 'cmake' run to do this, the settings
|
||||||
|
will be remembered. For the example above the following will do after every
|
||||||
|
'cvs up':
|
||||||
|
|
||||||
|
% cmake -G Xcode $BLENDERSOURCE
|
||||||
|
|
||||||
|
7. Specify alternate Python library versions and locations
|
||||||
|
----------------------------------------------------------
|
||||||
|
|
||||||
|
The commandline can be used to override detected/default settings, e.g:
|
||||||
|
|
||||||
|
On Unix:
|
||||||
|
cmake -D PYTHON_LIB=/usr/local/lib/python2.3/config/libpython2.3.so -D PYTHON_INC=/usr/local/include/python2.3 -D PYTHON_BINARY=/usr/local/bin/python2.3 -G "Unix Makefiles" ../blender
|
||||||
|
On Macs:
|
||||||
|
cmake -D PYTHON_INC=/System/Library/Frameworks/Python.framework/Versions/2.5/include/python2.5 -D PYTHON_LIBPATH=/System/Library/Frameworks/Python.framework/Versions/2.5/lib/python2.5/config -D PYTHON_BINARY=/System/Library/Frameworks/Python.framework/Versions/2.5/bin/python2.5 -G Xcode ../blender
|
||||||
|
|
||||||
|
Mote that this should only be needed once per build directory generation because it will keep the overrides in CMakeCache.txt for subsequent runs.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
To be continued...
|
||||||
|
|
||||||
|
TODO's
|
||||||
|
------
|
||||||
|
|
||||||
|
1. Get CMake to create proper distribution directories for the various platforms
|
||||||
|
like scons does.
|
||||||
|
2. Investigate the viability of using CPack to package installs automatically.
|
||||||
|
3. Refine this document and write detailed developer's document.
|
||||||
|
4. Make sure all options (ffmpeg, openexr, quicktime) has proper CMake support
|
||||||
|
on the various platforms.
|
||||||
|
|
||||||
|
/Jacques Beaurain (jbinto)
|
||||||
|
|
||||||
57
doc/blender-guardedalloc.txt
Normal file
57
doc/blender-guardedalloc.txt
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
MEMORY MANAGEMENT IN BLENDER (guardedalloc)
|
||||||
|
-------------------------------------------
|
||||||
|
|
||||||
|
NOTE: This file does not cover memutil and smart pointers and rerefence counted
|
||||||
|
garbage collection, which are contained in the memutil module.
|
||||||
|
|
||||||
|
Blender takes care of dynamic memory allocation using a set of own functions
|
||||||
|
which are recognizeable through their MEM_ prefix. All memory allocation and
|
||||||
|
deallocation in blender is done through these functions.
|
||||||
|
|
||||||
|
The following functions are available through MEM_guardedalloc.h:
|
||||||
|
|
||||||
|
For normal operation:
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
void *MEM_[mc]allocN(unsigned int len, char * str);
|
||||||
|
|
||||||
|
- nearest ANSI counterpart: malloc()
|
||||||
|
- str must be a static string describing the memory block (used for debugging
|
||||||
|
memory management problems)
|
||||||
|
- returns a memory block of length len
|
||||||
|
- MEM_callocN clears the memory block to 0
|
||||||
|
|
||||||
|
void *MEM_dupallocN(void *vmemh);
|
||||||
|
|
||||||
|
- nearest ANSI counterpart: combination malloc() and memcpy()
|
||||||
|
- returns a pointer to a copy of the given memory area
|
||||||
|
|
||||||
|
short MEM_freeN(void *vmemh);
|
||||||
|
|
||||||
|
- nearest ANSI counterpart: free()
|
||||||
|
- frees the memory area given by the pointer
|
||||||
|
- returns 0 on success and !=0 on error
|
||||||
|
|
||||||
|
int MEM_allocN_len(void *vmemh);
|
||||||
|
|
||||||
|
- nearest ANSI counterpart: none known
|
||||||
|
- returns the length of the given memory area
|
||||||
|
|
||||||
|
For debugging:
|
||||||
|
--------------
|
||||||
|
|
||||||
|
void MEM_set_error_stream(FILE*);
|
||||||
|
|
||||||
|
- this sets the file the memory manager should use to output debugging messages
|
||||||
|
- if the parameter is NULL the messages are suppressed
|
||||||
|
- default is that messages are suppressed
|
||||||
|
|
||||||
|
void MEM_printmemlist(void);
|
||||||
|
|
||||||
|
- if err_stream is set by MEM_set_error_stream() this function dumps a list of all
|
||||||
|
currently allocated memory blocks with length and name to the stream
|
||||||
|
|
||||||
|
int MEM_check_memory_integrity(void);
|
||||||
|
|
||||||
|
- this function tests if the internal structures of the memory manager are intact
|
||||||
|
- returns 0 on success and !=0 on error
|
||||||
194
doc/blender-scons-dev.txt
Normal file
194
doc/blender-scons-dev.txt
Normal file
@@ -0,0 +1,194 @@
|
|||||||
|
$Id$
|
||||||
|
|
||||||
|
|
||||||
|
Internals of Blenders SCons scripts
|
||||||
|
===================================
|
||||||
|
|
||||||
|
Scope
|
||||||
|
------
|
||||||
|
This document describes the architecture of the SCons scripts for
|
||||||
|
Blender. An overview of available functionality and how to modify,
|
||||||
|
extend and maintain the system.
|
||||||
|
|
||||||
|
Audience
|
||||||
|
--------
|
||||||
|
This document is for developers who need to modify the system,
|
||||||
|
ie. add or remove new libraries, add new arguments for SCons, etc.
|
||||||
|
|
||||||
|
Files and their meaning
|
||||||
|
-----------------------
|
||||||
|
|
||||||
|
The main entry point for the build system is the SConstruct-file in
|
||||||
|
$BLENDERHOME. This file creates the first BlenderEnvironment to work
|
||||||
|
with, reads in options, and sets up some directory structures. Further
|
||||||
|
it defines some targets.
|
||||||
|
|
||||||
|
Platform-specific configurations are in $BLENDERHOME/config. The
|
||||||
|
filenames have the form (platform)-config.py, where platform one of:
|
||||||
|
|
||||||
|
* darwin
|
||||||
|
* linux2
|
||||||
|
* win32-mingw
|
||||||
|
* win32-vc
|
||||||
|
|
||||||
|
The user can override options by creating a file
|
||||||
|
$BLENDERHOME/user-config.py. It can have any option from
|
||||||
|
(platform)-config.py. Options in this file will override the platform
|
||||||
|
defaults.
|
||||||
|
|
||||||
|
Much of the actual functionality can be found in the python scripts
|
||||||
|
in the directory $BLENDERHOME/tools, with Blender.py defining the
|
||||||
|
bulk of the functionality. btools.py has some helper functions, and
|
||||||
|
bcolors.py is for the terminal colours. mstoolkit.py and crossmingw.py
|
||||||
|
are modules which set up SCons for the MS VC++ 2003 toolkit and
|
||||||
|
the cross-compile toolset for compiling Windows binaries on Linux
|
||||||
|
respectively. Note: the cross-compile doesn't work yet for Blender,
|
||||||
|
but is added in preparation for having it work in the distant future.
|
||||||
|
|
||||||
|
BlenderEnvironment
|
||||||
|
------------------
|
||||||
|
|
||||||
|
The module Blender.py implements a BlenderEnvironment class, derived
|
||||||
|
from the SConsEnvironment of SCons. This is done to wrap some often
|
||||||
|
used functionality. The BlenderEnvironment offers two important
|
||||||
|
wrappers: BlenderProg() and BlenderLib(). The first one is used to
|
||||||
|
specify a binary to be built, the second one is used to specify what
|
||||||
|
static library is built from given sources.
|
||||||
|
|
||||||
|
Build a static library called "somelib". The system handles library
|
||||||
|
pre- and suffixes automatically, you don't need to bother yourself
|
||||||
|
with these details:
|
||||||
|
|
||||||
|
env = BlenderEnvironment(ENV = os.environ) # create an environment
|
||||||
|
env.BlenderLib(libname="somelib", sources=['list.c','with.c','sources.c'],
|
||||||
|
includes=['/list/with/include/paths', '.', '..'],
|
||||||
|
defines=['LIST_WITH', 'CPP_DEFINES', 'TO_USE'],
|
||||||
|
libtype=['blender', 'common'] # this is a list with libtypes. Normally you don't
|
||||||
|
# need to specify this, but if you encounter linking
|
||||||
|
# problems you may need this
|
||||||
|
priority=[10, 20] # Priorities, list as long as libtype, priority per type
|
||||||
|
compileflags=['/O2'] # List of compile flags needed for this particular library.
|
||||||
|
# used only in rare cases, like SOLID, qhull and Bullet
|
||||||
|
)
|
||||||
|
|
||||||
|
There should be no need to ever add an extra BlenderProg to the
|
||||||
|
existing ones in SConstruct, see that file for its use, and Blender.py
|
||||||
|
for its implementation.
|
||||||
|
|
||||||
|
The new system works so that using these wrappers, has all libraries
|
||||||
|
(and programs) register with a central repository. This means that
|
||||||
|
adding a new library is as easy as just creating the new SConscript
|
||||||
|
and making sure that it gets called properly. Linking and such will
|
||||||
|
then be handled automatically.
|
||||||
|
|
||||||
|
If you want that adding new source files for a certain library
|
||||||
|
is handled automatically, you can use the Glob() function from
|
||||||
|
the BlenderEnvironment to create lists of needed files. See
|
||||||
|
$BLENDERHOME/source/blender/src/SConscript for an example. Keep in
|
||||||
|
mind that this will add any new file that complies to the rule given
|
||||||
|
to the Glob() function. There are a few (external) libraries with
|
||||||
|
which this can't be used, because it'd take files that shouldn't be
|
||||||
|
compiled, and create subsequentially problems during the linking stage
|
||||||
|
(like SOLID, qhull, Bullet).
|
||||||
|
|
||||||
|
Linking order and priorities
|
||||||
|
----------------------------
|
||||||
|
|
||||||
|
As shown above, you can give a library a priority in a certain
|
||||||
|
group. If you need to make sure that a Blender library is linked
|
||||||
|
before or after another one, you can give it a priority. To debug
|
||||||
|
the priorities us BF_PRIORITYLIST=1 on the command-line while running
|
||||||
|
a build.
|
||||||
|
|
||||||
|
% scons BF_PRIORITYLIST=1
|
||||||
|
|
||||||
|
This will give a list with values suggested by the system. Make
|
||||||
|
changes to all SConscripts in question to reflect or change the
|
||||||
|
values given by this command. ALWAYS check this after adding a new
|
||||||
|
internal, external library or core library, and make sure there are
|
||||||
|
sane values. You can use large and negative numbers to test with,
|
||||||
|
but after you've got a working linking order, do change the system
|
||||||
|
to reflect BF_PRIORITYLIST values.
|
||||||
|
|
||||||
|
Also, if you find that a library needs to be given multiple times to
|
||||||
|
the linker, you can do that by giving a python list with the names
|
||||||
|
of the available library types. They are currently:
|
||||||
|
|
||||||
|
B.possible_types = ['core', 'common', 'blender', 'intern',
|
||||||
|
'international', 'game', 'game2',
|
||||||
|
'player', 'player2', 'system']
|
||||||
|
|
||||||
|
More groups can be added, but that should be carefully considered,
|
||||||
|
as it may lead to large-scale changes. The current amount of libraries
|
||||||
|
should suffice.
|
||||||
|
|
||||||
|
The central repository is utilised in the SConstruct in two
|
||||||
|
ways. Firstly, it is used to determine the order of all static
|
||||||
|
libraries to link into the main Blender executable. Secondly, it
|
||||||
|
is used to keep track of all built binaries and their location,
|
||||||
|
so that they can be properly copied to BF_INSTALLDIR.
|
||||||
|
|
||||||
|
The libraries can be fetched in their priority order with
|
||||||
|
create_blender_liblist from Blender.py, see the SConstruct on how
|
||||||
|
it is used.
|
||||||
|
|
||||||
|
The program repository is the global list program_list from
|
||||||
|
Blender.py. See SConstruct for its usage.
|
||||||
|
|
||||||
|
|
||||||
|
Adding a new option and libraries
|
||||||
|
---------------------------------
|
||||||
|
|
||||||
|
Lets say we want to add WITH_BF_NEWLIB, which will
|
||||||
|
enable or disable a new feature library with sources in
|
||||||
|
$BLENDERHOME/source/blender/newlib. This 'newlib' needs external
|
||||||
|
headers from a 3rd party library '3rdparty'. For this we want to
|
||||||
|
add a set of options BF_3RDPARTY, BF_3RDPARTY_INC, BF_3RDPARTY_LIB,
|
||||||
|
BF_3RDPARTY_LIBPATH:
|
||||||
|
|
||||||
|
1) Add all mentiond options to all (platform)-config.py
|
||||||
|
files. WITH_BF_NEWLIB is a boolean option ('true', 'false'),
|
||||||
|
the rest are strings with paths and library names. See the
|
||||||
|
OpenEXR options for example.
|
||||||
|
|
||||||
|
2) Add all options to the argument checking function
|
||||||
|
validate_arguments() in btools.py. See again OpenEXR options
|
||||||
|
for example.
|
||||||
|
|
||||||
|
3) Add all options to the option reading function read_opts()
|
||||||
|
in btools.py. See again OpenEXR options for example. All default
|
||||||
|
values can be empty, as the actual default values are in the
|
||||||
|
(platform)-config.py files.
|
||||||
|
|
||||||
|
4) Add BF_3RDPARTY_LIB to the function setup_syslibs()
|
||||||
|
and BF_3RDPARTY_LIBPATH to the function setup_staticlibs()
|
||||||
|
in Blender.py
|
||||||
|
|
||||||
|
At this stage we have prepared all option setting and linking needs,
|
||||||
|
but we still need to add in the compiling of the 'newlib'.
|
||||||
|
|
||||||
|
5) Create a SConscript in $BLENDERHOME/source/blender/newlib. Look
|
||||||
|
at ie. $BLENDERHOME/source/blender/src/SConscript for
|
||||||
|
template. The new SConscript will register the new library
|
||||||
|
like so:
|
||||||
|
|
||||||
|
env.BlenderLib(libname='newlib', sources=sourcefiles, includes=incs) # the rest of the arguments get defaults = empty lists and values
|
||||||
|
|
||||||
|
6) Edit $BLENDERHOME/source/blender/SConscript with the following
|
||||||
|
addition:
|
||||||
|
|
||||||
|
if env['WITH_BF_NEWLIB'] == 1:
|
||||||
|
SConscript(['newlib/SConscript'])
|
||||||
|
|
||||||
|
After this you can see if this works by trying to build:
|
||||||
|
|
||||||
|
% scons WITH_BF_NEWLIB=1 # build with newlib
|
||||||
|
% scons WITH_BF_NEWLIB=0 # disable newlib
|
||||||
|
|
||||||
|
This is all what should be needed. Changing the library name doesn't
|
||||||
|
need changes elsewhere in the system, as it is handled automatically
|
||||||
|
with the central library repository.
|
||||||
|
|
||||||
|
Enjoy the new system!
|
||||||
|
|
||||||
|
/Nathan Letwory (jesterKing)
|
||||||
236
doc/blender-scons.txt
Normal file
236
doc/blender-scons.txt
Normal file
@@ -0,0 +1,236 @@
|
|||||||
|
$Id$
|
||||||
|
|
||||||
|
Note: The current official release of SCons is 0.97
|
||||||
|
|
||||||
|
Blenders SCons build scripts
|
||||||
|
============================
|
||||||
|
|
||||||
|
Introduction
|
||||||
|
------------
|
||||||
|
|
||||||
|
Since the beginning of 2004 Blender has had the SCons system as a
|
||||||
|
build option. SCons is a Python-based, accurate build system. The
|
||||||
|
scripts that were implemented in the first iteration worked, but
|
||||||
|
the system grew quickly into such a state that maintaining it became
|
||||||
|
a nightmare, and adding new features was just horrible, leading to
|
||||||
|
many hacks without much sense in the overall structure.
|
||||||
|
|
||||||
|
The rewrite has been waiting for a long time. Jonathan Jacobs provided
|
||||||
|
a first overhaul of the scripts, which I used in the first phase of
|
||||||
|
the rewrite. To make the system as maintainable as possible I made
|
||||||
|
some radical changes, but thanks go to Jonathan for providing me
|
||||||
|
with the patch to get started.
|
||||||
|
|
||||||
|
This document describes the usage of the new SCons scripts. The
|
||||||
|
inner workings are described in blender-scons-dev.txt.
|
||||||
|
|
||||||
|
Building Blender
|
||||||
|
----------------
|
||||||
|
|
||||||
|
To build Blender with the SCons scripts you need a full Python
|
||||||
|
install, version 2.4 or later (http://www.python.org) and a SCons
|
||||||
|
installation, version v0.97 (http://www.scons.org).
|
||||||
|
|
||||||
|
Check from the page
|
||||||
|
http://www.blender.org/development/building-blender/getting-dependencies/
|
||||||
|
that you have all dependencies needed for building Blender. Note that for
|
||||||
|
windows many of these dependencies already come in the lib/windows module
|
||||||
|
from CVS.
|
||||||
|
|
||||||
|
In the base directory of the sources (from now on called $BLENDERHOME)
|
||||||
|
you'll see a file named SConstruct. This is the entry point for the
|
||||||
|
SCons build system. In a terminal, change to this directory. To just
|
||||||
|
build, issue the command 'scons':
|
||||||
|
|
||||||
|
% scons
|
||||||
|
|
||||||
|
This will start the build process with default values. Depending
|
||||||
|
on your platform you may see colour in your output (non-Windows
|
||||||
|
machines). In the the beginning an overview of targets and arguments
|
||||||
|
from the command-line is given, then all libraries and binaries to
|
||||||
|
build are configured.
|
||||||
|
|
||||||
|
The build uses BF_BUILDDIR to build into and BF_INSTALLDIR to
|
||||||
|
finally copy all needed files to get a proper setup. These
|
||||||
|
variabbles have default values for every platform in
|
||||||
|
$BLENDERHOME/config/(platform)-config.py. After the build successfully
|
||||||
|
completes, you can find everything you need in BF_INSTALLDIR.
|
||||||
|
|
||||||
|
|
||||||
|
Configuring the build
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
The default values for your platform can be found in the directory
|
||||||
|
$BLENDERHOME/config. Your platform specific defaults are in
|
||||||
|
(platform)-config.py, where platform is one of:
|
||||||
|
|
||||||
|
- linux2, for machines running Linux
|
||||||
|
- win32-vc, for Windows machines, compiling with a Microsoft compiler
|
||||||
|
- win32-mingw, for Windows machines, compiling with the MingW compiler
|
||||||
|
- darwin, for OS X machines
|
||||||
|
(TBD: add cygwin, solaris and freebsd support)
|
||||||
|
|
||||||
|
These files you will normally not change. If you need to override
|
||||||
|
a default value, make a copy of the proper configuration to
|
||||||
|
$BLENDERHOME/user-config.py. This file you can modify to your
|
||||||
|
likings. Any value set here will override the ones from the
|
||||||
|
(platform)-config.py.
|
||||||
|
|
||||||
|
If you want to quickly test a new setting, you can give the option
|
||||||
|
also on the command-line:
|
||||||
|
|
||||||
|
% scons BF_BUILDDIR=../mybuilddir WITH_BF_OPENEXR=0
|
||||||
|
|
||||||
|
This command sets the build directory to BF_BUILDDIR and disables
|
||||||
|
OpenEXR support.
|
||||||
|
|
||||||
|
If you need to know what can be set through the command-line, run
|
||||||
|
scons with -h:
|
||||||
|
|
||||||
|
% scons -h
|
||||||
|
|
||||||
|
This command will print a long list with settable options and what
|
||||||
|
every option means. Many of the default values will be empty, and
|
||||||
|
from a fresh checkout without a user-config.py the actual values
|
||||||
|
are the defaults as per $BLENDERHOME/config/(platform)-config.py
|
||||||
|
(unless you have overridden any of them in your
|
||||||
|
$BLENDERHOME/user-config.py).
|
||||||
|
|
||||||
|
NOTE: The best way to avoid confusion is the
|
||||||
|
copy $BLENDERHOME/config/(platform)-config.py to
|
||||||
|
$BLENDERHOME/user-config.py. You should NEVER have to modify
|
||||||
|
$BLENDERHOME/config/(platform)-config.py
|
||||||
|
|
||||||
|
Configuring the output
|
||||||
|
----------------------
|
||||||
|
|
||||||
|
This rewrite features a cleaner output during the build process. If
|
||||||
|
you need to see the full command-line for compiles, then you can
|
||||||
|
change that behaviour. Also the use of colours can be changed:
|
||||||
|
|
||||||
|
% scons BF_FANCY=0
|
||||||
|
|
||||||
|
This will disable the use of colours.
|
||||||
|
|
||||||
|
% scons BF_QUIET=0
|
||||||
|
|
||||||
|
This will give the old, noisy output. Every command-line per
|
||||||
|
compile is printed out in its full glory. This is very useful when
|
||||||
|
debugging problems with compiling, because you can see what the
|
||||||
|
included paths are, what defines are given on the command-line,
|
||||||
|
what compiler switches are used, etc.
|
||||||
|
|
||||||
|
Compiling Only Some Libraries
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
Scons now has support for specifying a list of libraries that are
|
||||||
|
exclusively compiled, ignoring all other libraries. This is invoked
|
||||||
|
with the BF_QUICK arguments; for example:
|
||||||
|
|
||||||
|
% scons BF_QUICK=src,bf_blenkernel
|
||||||
|
|
||||||
|
Note that this not the same as passing a list of folders as in the
|
||||||
|
makefile's "quicky" command. In Scons, all of Blender's code modules
|
||||||
|
are in their own static library; this corresponds to one-lib-per-folder
|
||||||
|
in some cases (especially in blender/source/blender).
|
||||||
|
|
||||||
|
To obtain a list of the libraries, simple fire up scons and CTRL-C out once
|
||||||
|
it finishes configuring (and printing to the console) the library list.
|
||||||
|
|
||||||
|
Compiling Libraries With Debug Profiling
|
||||||
|
----------------------------------------
|
||||||
|
|
||||||
|
Scons has support for specifying a list of libraries that are compiled
|
||||||
|
with debug profiling enabled. This is implemented in two commands:
|
||||||
|
BF_QUICKDEBUG which is a command-line argument and BF_DEBUG_LIBS, which goes
|
||||||
|
in your user-config.py
|
||||||
|
|
||||||
|
BF_QUICKDEBUG is similar to BF_QUICK:
|
||||||
|
|
||||||
|
% scons BF_QUICKDEBUG=src,bf_blenkernel,some-other-lib
|
||||||
|
|
||||||
|
To use BF_DEBUG_LIBS, put something like the following in you user-config.py:
|
||||||
|
|
||||||
|
BF_DEBUG_LIBS = ['bf_blenlib', 'src', 'some_lib']
|
||||||
|
|
||||||
|
For instructions on how to find the names of the libraries (folders) you
|
||||||
|
wish to use, see the above section. Note that the command BF_DEBUG
|
||||||
|
(see below) will override these settings and compile ALL of Blender with
|
||||||
|
debug symbols. Also note that BF_QUICKDEBUG and BF_DEBUG_LIBS are combined;
|
||||||
|
for example, setting BF_QUICKDEBUG won't overwrite the contents of BF_DEBUG_LIBS.
|
||||||
|
|
||||||
|
|
||||||
|
Not installing
|
||||||
|
--------------
|
||||||
|
|
||||||
|
If you dont want to install the build result, you can use the following option either
|
||||||
|
on the commandline or in your user-config.py :
|
||||||
|
|
||||||
|
WITHOUT_BF_INSTALL='true'
|
||||||
|
|
||||||
|
by default, this is set to 'false', and so the build is installed
|
||||||
|
|
||||||
|
|
||||||
|
Supported toolset
|
||||||
|
-----------------
|
||||||
|
|
||||||
|
WINDOWS
|
||||||
|
|
||||||
|
* msvc, this is a full install of Microsoft Visual C++. You'll
|
||||||
|
likely have the .NET Framework SDK, Platform SDK and DX9 SDK
|
||||||
|
installed * mstoolkit, this is the free MS VC++ 2003 Toolkit. You
|
||||||
|
need to verify you have also the SDKs installed as mentioned
|
||||||
|
for msvc. * mingw, this is a minimal MingW install. TBD: write
|
||||||
|
proper instructions on getting needed packages.
|
||||||
|
|
||||||
|
On Windows with all of the three toolset installed you need to
|
||||||
|
specify what toolset to use
|
||||||
|
|
||||||
|
% scons BF_TOOLSET=msvc
|
||||||
|
% scons BF_TOOLSET=mstoolkit
|
||||||
|
% scons BF_TOOLSET=mingw
|
||||||
|
|
||||||
|
If you have only the toolkit installed, you will also need to give
|
||||||
|
BF_TOOLSET=mstoolkit on the command-line, to make sure everything is
|
||||||
|
setup properly. Currently there is no good mechanism to automatically
|
||||||
|
determine wether the found 'cl.exe' is from the toolkit or from a
|
||||||
|
complete install.
|
||||||
|
|
||||||
|
LINUX and OS X
|
||||||
|
|
||||||
|
Currently only the default toolsets are supported for these platforms,
|
||||||
|
so nothing special needs to be told to SCons when building. The
|
||||||
|
defaults should work fine in most cases.
|
||||||
|
|
||||||
|
Examples
|
||||||
|
--------
|
||||||
|
|
||||||
|
Build Blender with the defaults:
|
||||||
|
|
||||||
|
% scons
|
||||||
|
|
||||||
|
Build Blender, but disable OpenEXR support:
|
||||||
|
|
||||||
|
% scons WITH_BF_OPENEXR=0
|
||||||
|
|
||||||
|
Build Blender, enable debug symbols:
|
||||||
|
|
||||||
|
% scons BF_DEBUG=1
|
||||||
|
|
||||||
|
Build Blender, install to different directory:
|
||||||
|
|
||||||
|
% scons BF_INSTALLDIR=/tmp/testbuild
|
||||||
|
|
||||||
|
Build Blender in /tmp/obj and install to /usr/local:
|
||||||
|
|
||||||
|
% scons BF_BUILDDIR=/tmp/obj BF_INSTALLDIR=/usr/local
|
||||||
|
|
||||||
|
Clean BF_BUILDDIR:
|
||||||
|
|
||||||
|
% scons clean
|
||||||
|
|
||||||
|
Clean out the installed files:
|
||||||
|
|
||||||
|
% scons -c
|
||||||
|
|
||||||
|
/Nathan Letwory (jesterKing)
|
||||||
63
doc/doxygen.main
Normal file
63
doc/doxygen.main
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
/** \mainpage Blender
|
||||||
|
*
|
||||||
|
* \section intro Introduction
|
||||||
|
*
|
||||||
|
* Blender is an integrated 3d package, which features:
|
||||||
|
* - modeling
|
||||||
|
* - animation
|
||||||
|
* - texturing
|
||||||
|
* - compositing
|
||||||
|
* - rendering
|
||||||
|
* - scripting
|
||||||
|
* - game creation
|
||||||
|
*
|
||||||
|
* These pages document the source code of blender.
|
||||||
|
*
|
||||||
|
* \section sects Main sections of the blender code
|
||||||
|
*
|
||||||
|
* The following sections are the broad categories into which the various modules
|
||||||
|
* belong.
|
||||||
|
*
|
||||||
|
* - \ref mainmodule
|
||||||
|
* - \ref render
|
||||||
|
* - \ref meshedit
|
||||||
|
* - \ref texture
|
||||||
|
* - \ref compositor
|
||||||
|
* - \ref scripts
|
||||||
|
* - \ref gameengine
|
||||||
|
*
|
||||||
|
* \section GUI
|
||||||
|
* - \ref gui
|
||||||
|
* - \ref hotkeys
|
||||||
|
* - \ref toolbox
|
||||||
|
*
|
||||||
|
* \section Libraries and Wrappers
|
||||||
|
* - GHOST API: \ref GHOST_C-api.h
|
||||||
|
* - \ref imbuf
|
||||||
|
*
|
||||||
|
* \section Miscellaneous
|
||||||
|
* - \ref undoc
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** \defgroup mainmodule Main Module */
|
||||||
|
/** \defgroup defaultconfig Default and Configuration
|
||||||
|
* \ingroup mainmodule
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** \defgroup render Rendering Module */
|
||||||
|
/** \defgroup meshedit Mesh Editing Module */
|
||||||
|
/** \defgroup texture Textureing */
|
||||||
|
/** \defgroup compositor Compositing */
|
||||||
|
/** \defgroup scripts Scripting */
|
||||||
|
/** \defgroup gameengine Game Engine */
|
||||||
|
|
||||||
|
/** \defgroup gui GUI */
|
||||||
|
/** \defgroup hotkeys Hotkeys
|
||||||
|
* \ingroup gui
|
||||||
|
*/
|
||||||
|
/** \defgroup toolbox Toolbox
|
||||||
|
* \ingroup gui
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** \defgroup imbuf IMage Buffer */
|
||||||
|
/** \defgroup undoc Undocumented */
|
||||||
515
doc/interface_API.txt
Normal file
515
doc/interface_API.txt
Normal file
@@ -0,0 +1,515 @@
|
|||||||
|
---------------------------------------------------
|
||||||
|
Blender interface.c API toolkit notes
|
||||||
|
(july 2003, Ton Roosendaal)
|
||||||
|
---------------------------------------------------
|
||||||
|
|
||||||
|
Contents
|
||||||
|
|
||||||
|
1 General notes
|
||||||
|
1.1 C and H files
|
||||||
|
|
||||||
|
2. Windows & Blocks
|
||||||
|
2.1 Memory allocation
|
||||||
|
2.2 And how it works internally
|
||||||
|
|
||||||
|
3. API for uiBlock
|
||||||
|
3.1 uiBlock Controlling functions
|
||||||
|
3.2 Internal function to know
|
||||||
|
|
||||||
|
4. API for uiButton
|
||||||
|
4.1 UiDefBut
|
||||||
|
1. BUT
|
||||||
|
2. TOG or TOGN or TOGR
|
||||||
|
TOG|BIT|<nr>
|
||||||
|
3. TOG3|BIT|<nr>
|
||||||
|
4. ROW
|
||||||
|
5. SLI or NUMSLI or HSVSLI
|
||||||
|
6. NUM
|
||||||
|
7. TEX
|
||||||
|
8. LABEL
|
||||||
|
9 SEPR
|
||||||
|
10. MENU
|
||||||
|
11. COL
|
||||||
|
4.2 Icon buttons
|
||||||
|
12. ICONROW
|
||||||
|
13. ICONTEXTROW
|
||||||
|
4.3 pulldown menus / block buttons
|
||||||
|
14. BLOCK
|
||||||
|
4.4 specials
|
||||||
|
15. KEYEVT
|
||||||
|
16. LINK and INLINK
|
||||||
|
17. IDPOIN
|
||||||
|
4.5 uiButton control fuctions
|
||||||
|
|
||||||
|
|
||||||
|
----------------1. General notes
|
||||||
|
|
||||||
|
- The API is built with Blender in mind, with some buttons acting on lists of Blender data.
|
||||||
|
It was not meant to be available as a separate SDK, nor to be used for other applications.
|
||||||
|
|
||||||
|
- It works with only OpenGL calls, for the full 100%. This means that it has some quirks
|
||||||
|
built-in to work with all OS's and OpenGL versions. Especially frontbuffer drawing is
|
||||||
|
a continuous point of attention. Buttons can be drawn with any window matrix. However,
|
||||||
|
errors can still occor when buttons are created in windows with non-standard glViewports.
|
||||||
|
|
||||||
|
- The code was written to replace the old 1.8 button system, but under high pressure. Quite
|
||||||
|
some button methods from the old system were copied for that reason.
|
||||||
|
|
||||||
|
- I tried to design a unified GUI system, which equally works for pulldown menus, pop up menus,
|
||||||
|
and normal button layouts. Although it gives nice features and freedom in design, the code
|
||||||
|
looks quite hard to understand for that reason. Not all 'normal' pulldown menu features
|
||||||
|
could be hacked in easily, they just differ too much from other UI elements. Could be
|
||||||
|
looked at once...
|
||||||
|
|
||||||
|
- During the past period of NaN (beginning of 2002) someone tried to make a more 'high' level
|
||||||
|
API for it, with less low level defines and structure info needed in calling code. I am not
|
||||||
|
really sure if this was done well... or even finished. In the bottom of interface.c you can
|
||||||
|
see the 'new' API which is now used in Blender code. It used to be so much more simple!
|
||||||
|
Nevertheless, I will use that convention in this doc.
|
||||||
|
|
||||||
|
- Unfinished stuff: the code was scheduled to be expanded with 'floating blocks' which can
|
||||||
|
serve as permanent little button-fields in Blender windows. Think for example of having
|
||||||
|
an (optional) extra field in the 3d window displaying object loc/rot/size.
|
||||||
|
After that, the existing button windows can be reorganized in such blocks as well, allowing
|
||||||
|
a user to configure the genereal buttons layout (make vertical for example).
|
||||||
|
|
||||||
|
|
||||||
|
--------------1.1 C and H files
|
||||||
|
|
||||||
|
blender/source/blender/src/interface.c /* almost all code */
|
||||||
|
blender/source/blender/include/interface.h /* internals for previous code */
|
||||||
|
blender/source/blender/include/BIF_interface.h /* externals for previous code */
|
||||||
|
|
||||||
|
(the previous 2 include files have not been separated fully yet)
|
||||||
|
|
||||||
|
Color and icons stuff has been put in: (unfinished code, under development)
|
||||||
|
blender/source/blender/src/resources.c
|
||||||
|
blender/source/blender/include/BIF_resources.h
|
||||||
|
|
||||||
|
Related code:
|
||||||
|
blender/source/blender/src/toolbox.c (extra GUI elements built on top of this API)
|
||||||
|
|
||||||
|
|
||||||
|
--------------2. Windows & Blocks
|
||||||
|
|
||||||
|
All GUI elements are collected in uiBlocks, which in turn are linked together in a list that's
|
||||||
|
part of a Blender Area-window.
|
||||||
|
|
||||||
|
uiBlock *block= uiNewBlock(&curarea->uiblocks, "stuff", UI_EMBOSSX, UI_HELV, curarea->win);
|
||||||
|
|
||||||
|
The next code example makes a new block, and puts it in the list of blocks of the current active
|
||||||
|
Area:
|
||||||
|
|
||||||
|
uiDoBlocks(&curarea->uiblocks, event);
|
||||||
|
|
||||||
|
This code is usually available in each area-window event queue handler. You give uiDoBlocks
|
||||||
|
an event code, and the uiDoBlocks handles whatever is to be handled. Blocks can be
|
||||||
|
standard buttons or pull down menus. Can return immediately, or jump to an internal handling
|
||||||
|
loop.
|
||||||
|
|
||||||
|
2.1 Memory allocation
|
||||||
|
|
||||||
|
Important to know is that for this toolkit there's no difference in "creating blocks" or
|
||||||
|
"drawing blocks". In fact, for each window redraw all blocks are created again. Constructing
|
||||||
|
button interfaces in Blender always happens in the main drawing function itself.
|
||||||
|
|
||||||
|
Memory allocation is handled as follows:
|
||||||
|
- if in this window a uiBlock with the same name existed, it is freed
|
||||||
|
- when you close a window (or blender) the uiBlocks get freed.
|
||||||
|
- when you duplicate (split) a window, the uiBlocks get copied
|
||||||
|
|
||||||
|
2.2 And how it works internally
|
||||||
|
|
||||||
|
With a call to uiDoblocks, all blocks in the current active window are evaluated.
|
||||||
|
It walks through the lists in a rather complex manner:
|
||||||
|
|
||||||
|
- while(looping)
|
||||||
|
|
||||||
|
/* the normal buttons handling */
|
||||||
|
- for each block
|
||||||
|
- call uiDoBlock (handles buttons for single block)
|
||||||
|
- (end for)
|
||||||
|
|
||||||
|
/* at this moment, a new block can be created, for a menu */
|
||||||
|
/* so we create a 2nd loop for it */
|
||||||
|
- while first block is a menu
|
||||||
|
- if block is a menu and not initialized:
|
||||||
|
- initalize 'saveunder'
|
||||||
|
- draw it
|
||||||
|
- get event from queue
|
||||||
|
- call uiDoBlock (handles buttons for single block)
|
||||||
|
/* here, a new block again can be created, for a sub menu */
|
||||||
|
- if return "end" from uiDoBlock
|
||||||
|
restore 'saveunder's
|
||||||
|
free all menu blocks
|
||||||
|
exit from loop
|
||||||
|
- do tooltip if nothing has happened
|
||||||
|
- (end while)
|
||||||
|
|
||||||
|
- if there was menu, it does this loop once more
|
||||||
|
(when you click outside a menu, at another button)
|
||||||
|
|
||||||
|
- (end while)
|
||||||
|
|
||||||
|
- do tooltip if nothing has happened
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
-------------3. API for uiBlock
|
||||||
|
|
||||||
|
Create a new buttons block, and link it to the window:
|
||||||
|
|
||||||
|
uiBlock *uiNewBlock(ListBase *lb, char *name, short dt, short font, short win)
|
||||||
|
ListBase *lb pointer to list basis, where the block will be appended to (blenlib)
|
||||||
|
char *name unique name to identify the block. When the name exists in the list,
|
||||||
|
the old uiBlock gets freed.
|
||||||
|
short dt drawtype. See below
|
||||||
|
short font font id number
|
||||||
|
short win blender area-window id
|
||||||
|
|
||||||
|
drawtype:
|
||||||
|
UI_EMBOSSX 0 /* Rounded embossed button (standard in Blender) */
|
||||||
|
UI_EMBOSSW 1 /* Simpler embossed button */
|
||||||
|
UI_EMBOSSN 2 /* Button with no border */
|
||||||
|
UI_EMBOSSF 3 /* Square embossed button (file select) */
|
||||||
|
UI_EMBOSSM 4 /* Colored, for pulldown menus */
|
||||||
|
UI_EMBOSSP 5 /* Simple borderless coloured button (like blender sensors) */
|
||||||
|
|
||||||
|
font:
|
||||||
|
UI_HELV 0 /* normal font */
|
||||||
|
UI_HELVB 1 /* bold font */
|
||||||
|
With the new truetype option in Blender, this is used for all font families
|
||||||
|
|
||||||
|
When a uiBlock is created, each uiButton that is defined gets the uiBlock properties.
|
||||||
|
Changing Block properties inbetween will affact uiButtons defined thereafter.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
----------3.1 uiBlock Controlling functions:
|
||||||
|
|
||||||
|
void uiDrawBlock(block)
|
||||||
|
draws the block
|
||||||
|
|
||||||
|
void uiBlockSetCol(uiBlock *block, int col)
|
||||||
|
|
||||||
|
col:
|
||||||
|
BUTGREY,
|
||||||
|
BUTGREEN,
|
||||||
|
BUTBLUE,
|
||||||
|
BUTSALMON,
|
||||||
|
MIDGREY,
|
||||||
|
BUTPURPLE,
|
||||||
|
|
||||||
|
void uiBlockSetEmboss(uiBlock *block, int emboss)
|
||||||
|
changes drawtype
|
||||||
|
|
||||||
|
void uiBlockSetDirection(uiBlock *block, int direction)
|
||||||
|
for pop-up and pulldown menus:
|
||||||
|
|
||||||
|
direction:
|
||||||
|
UI_TOP
|
||||||
|
UI_DOWN
|
||||||
|
UI_LEFT
|
||||||
|
UI_RIGHT
|
||||||
|
|
||||||
|
void uiBlockSetXOfs(uiBlock *block, int xofs)
|
||||||
|
for menus, offset from parent
|
||||||
|
|
||||||
|
void uiBlockSetButmFunc(uiBlock *block, void (*menufunc)(void *arg, int event), void *arg)
|
||||||
|
sets function to be handled when a menu-block is marked "OK"
|
||||||
|
|
||||||
|
void uiAutoBlock(uiBlock *block, float minx, float miny, float sizex, float sizey, UI_BLOCK_ROWS)
|
||||||
|
|
||||||
|
Sets the buttons in this block to automatically align, and fit within boundaries.
|
||||||
|
Internally it allows multiple collums or rows as well. Only 'row order' has been implemented.
|
||||||
|
The uiDefBut definitions don't need coordinates as input here, but instead:
|
||||||
|
- first value (x1) to indicate row number
|
||||||
|
- width and height values (if filled in) will be used to define a relative width/height.
|
||||||
|
A call to uiDrawBlock will invoke the calculus to fit in all buttons.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
---------- 3.2 Internal function to know:
|
||||||
|
|
||||||
|
These flags used to be accessible from outside of interface.c. Currently it is only
|
||||||
|
used elsewhere by toolbox.c, so it can be considered 'internal' somewhat.
|
||||||
|
|
||||||
|
void uiBlockSetFlag(uiBlock *block, int flag) /* block types, can be 'OR'ed */
|
||||||
|
UI_BLOCK_LOOP 1 a sublooping block, drawn in frontbuffer, i.e. menus
|
||||||
|
UI_BLOCK_REDRAW 2 block needs a redraw
|
||||||
|
UI_BLOCK_RET_1 4 block is closed when an event happens with value '1' (press key, not for mouse)
|
||||||
|
UI_BLOCK_BUSY 8 internal
|
||||||
|
UI_BLOCK_NUMSELECT 16 keys 1-2-...-9-0 can be used to select items
|
||||||
|
UI_BLOCK_ENTER_OK 32 enter key closes block with "OK"
|
||||||
|
|
||||||
|
(these values are being set within the interface.c and toolbox.c code.)
|
||||||
|
|
||||||
|
|
||||||
|
-------------4. API for uiButton
|
||||||
|
|
||||||
|
In Blender a button can do four things:
|
||||||
|
|
||||||
|
- directly visualize data, and write to it.
|
||||||
|
- put event codes (shorts) back in the queue, to be handled
|
||||||
|
- call a user-defined function pointer (while being pressed, etc)
|
||||||
|
- create and call another block (i.e. menu)
|
||||||
|
|
||||||
|
Internally, each button or menu item is a 'uiButton', with a generic API and handling:
|
||||||
|
ui_def_but(block, type, retval, str, x1, y1, x2, y2, poin, min, max, a1, a2, tip);
|
||||||
|
|
||||||
|
Beacause a lot of obscure generic (re-use) happens here, translation calls have been made
|
||||||
|
for each most button types individually.
|
||||||
|
|
||||||
|
|
||||||
|
-----------4.1 UiDefBut
|
||||||
|
|
||||||
|
uiBut *UiDefBut[CSIF]( uiBlock *block, int type, int retval, char *str,
|
||||||
|
short x1, short y1, short x2, short y2, xxxx *poin,
|
||||||
|
float min, float max, float a1, float a2, char *tip)
|
||||||
|
|
||||||
|
UiDefButC operatates on char
|
||||||
|
UiDefButS operatates on short
|
||||||
|
UiDefButI operatates on int
|
||||||
|
UiDefButF operatates on float
|
||||||
|
|
||||||
|
*block: current uiBlock pointer
|
||||||
|
type: see below
|
||||||
|
retval: return value, which is put back in queue
|
||||||
|
*str: button name
|
||||||
|
x1, y1: coordinates of left-lower corner
|
||||||
|
x2, y2: width, height
|
||||||
|
*poin: pointer to char, short, int, float
|
||||||
|
min, max used for slider buttons
|
||||||
|
a1, a2 extra info for some buttons
|
||||||
|
*tip: tooltip string
|
||||||
|
|
||||||
|
type:
|
||||||
|
|
||||||
|
1. BUT
|
||||||
|
Activation button. (like "Render")
|
||||||
|
Passing on a pointer is not needed
|
||||||
|
|
||||||
|
2. TOG or TOGN or TOGR
|
||||||
|
Toggle button (like "Lock")
|
||||||
|
The pointer value is set either at 0 or 1
|
||||||
|
If pressed, it calls the optional function with arguments provided.
|
||||||
|
Type TOGN: works negative, when pressed it sets at 0
|
||||||
|
Type TOGR: is part of a row, redraws automatically all buttons with same *poin
|
||||||
|
|
||||||
|
"|BIT|<nr>"
|
||||||
|
When added to type, it works on a single bit <nr> (lowest order bit: nr = '0')
|
||||||
|
|
||||||
|
3. TOG3|BIT|<nr>
|
||||||
|
A toggle with 3 values!
|
||||||
|
Can be only used for short *poin.
|
||||||
|
In the third toggle setting, the bit <nr> of *( poin+1) is set.
|
||||||
|
|
||||||
|
4. ROW
|
||||||
|
Button that's part of a row.
|
||||||
|
in "min" you set a row-id number, in "max" the value you want *poin to be
|
||||||
|
assigned when you press the button. Always pass on these values as floats.
|
||||||
|
When this button is pressed, it sets the "max" value to *poin, and redraws
|
||||||
|
all buttons with the same row-id number.
|
||||||
|
|
||||||
|
5. SLI or NUMSLI or HSVSLI
|
||||||
|
Slider, number-slider or hsv-slider button.
|
||||||
|
"min" and "max" are to clamp the value to.
|
||||||
|
If you want a button type "Col" to be updated, make 'a1' equal to 'retval'
|
||||||
|
from the COL button.
|
||||||
|
|
||||||
|
6. NUM
|
||||||
|
Number button
|
||||||
|
Set the clamping values 'min' and 'max' always as float.
|
||||||
|
For UiDefButF, set a 'step' in 'a1', in 1/100's. The step value is the increment or
|
||||||
|
decrement when you click once on the right or left side of a button.
|
||||||
|
The optional button function is additionally called for each change of the *poin value.
|
||||||
|
|
||||||
|
7. TEX
|
||||||
|
Text string button.
|
||||||
|
Pointertype is standard a char. Value 'max' is length of string (pass as float).
|
||||||
|
When button is left with ESC, it doesn't put the 'retval' at the queue.
|
||||||
|
|
||||||
|
8. LABEL
|
||||||
|
Label button.
|
||||||
|
Only displays text.
|
||||||
|
If 'min' is set at 1.0, the text is printed in white.
|
||||||
|
|
||||||
|
9 SEPR
|
||||||
|
A separator line, typically used within pulldown menus.
|
||||||
|
|
||||||
|
10. MENU
|
||||||
|
Menu button.
|
||||||
|
The syntax of the string in *name defines the menu items:
|
||||||
|
- %t means the previous text becomes the title
|
||||||
|
- item separator is '|'
|
||||||
|
- return values are indicated with %x[nr] (i.e: %x12).
|
||||||
|
without returnvalues, the first item gets value 0 (incl. title!)
|
||||||
|
Example: "Do something %t| turn left %2| turn right %1| nothing %0"
|
||||||
|
|
||||||
|
11. COL
|
||||||
|
A special button that only visualizes a RGB value
|
||||||
|
In 'retval' you can put a code, which is used to identify for sliders if it needs
|
||||||
|
redraws while using the sliders. Check button '5'.
|
||||||
|
As *poin you input the pointer to the 'r' value, 'g' and 'b' are supposed to be
|
||||||
|
next to that.
|
||||||
|
|
||||||
|
|
||||||
|
------------4.2 Icon buttons
|
||||||
|
|
||||||
|
Instead of a 'name', all buttons as described for uiDefBut also can have an icon:
|
||||||
|
|
||||||
|
uiBut *uiDefIconBut(uiBlock *block, int type, int retval, int icon,
|
||||||
|
short x1, short y1, short x2, short y2, void *poin,
|
||||||
|
float min, float max, float a1, float a2, char *tip)
|
||||||
|
|
||||||
|
Same syntax and types available as previous uiDefBut, but now with an icon code
|
||||||
|
instead of a name. THe icons are numbered in resources.c
|
||||||
|
|
||||||
|
uiBut *uiDefIconTextButF(uiBlock *block, int type, int retval, int icon, char *str,
|
||||||
|
short x1, short y1, short x2, short y2, float *poin,
|
||||||
|
float min, float max, float a1, float a2, char *tip)
|
||||||
|
|
||||||
|
Same again, but now with an icon and string as button name.
|
||||||
|
|
||||||
|
Two special icon buttons are available in Blender:
|
||||||
|
|
||||||
|
12. ICONROW
|
||||||
|
(uiDefIconBut)
|
||||||
|
This button pops up a vertical menu with a row of icons to choose from.
|
||||||
|
'max' = amount of icons. The icons are supposed to be ordered in a sequence
|
||||||
|
It writes in *poin which item in the menu was choosen (starting with 0).
|
||||||
|
|
||||||
|
13. ICONTEXTROW
|
||||||
|
(uiDefIconTextBut)
|
||||||
|
Same as previous, but with the texts next to it.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
-----------4.3 pulldown menus / block buttons
|
||||||
|
|
||||||
|
14. BLOCK
|
||||||
|
void uiDefBlockBut(uiBlock *block, uiBlockFuncFP func, void *arg, char *str,
|
||||||
|
short x1, short y1, short x2, short y2, char *tip)
|
||||||
|
|
||||||
|
This button creates a new block when pressed. The function argument 'func' is called
|
||||||
|
to take care of this. An example func:
|
||||||
|
|
||||||
|
static uiBlock *info_file_importmenu(void *arg_unused)
|
||||||
|
{
|
||||||
|
uiBlock *block;
|
||||||
|
short yco= 0, xco = 20;
|
||||||
|
|
||||||
|
block= uiNewBlock(&curarea->uiblocks, "importmenu", UI_EMBOSSW, UI_HELV, G.curscreen->mainwin);
|
||||||
|
uiBlockSetXOfs(block, -40); // offset to parent button
|
||||||
|
|
||||||
|
/* flags are defines */
|
||||||
|
uiDefBut(block, LABEL, 0, "VRML 2.0 options", xco, yco, 125, 19, NULL, 0.0, 0.0, 0, 0, "");
|
||||||
|
uiDefButS(block, TOG|BIT|0, 0, "SepLayers", xco, yco-=20, 75, 19, &U.vrmlflag, 0.0, 0.0, 0, 0, "");
|
||||||
|
uiDefButS(block, TOG|BIT|1, 0, "Scale 1/100", xco, yco-=20, 75, 19, &U.vrmlflag, 0.0, 0.0, 0, 0, "");
|
||||||
|
uiDefButS(block, TOG|BIT|2, 0, "Two Sided", xco, yco-=20, 75, 19, &U.vrmlflag, 0.0, 0.0, 0, 0, "");
|
||||||
|
|
||||||
|
uiBlockSetDirection(block, UI_RIGHT);
|
||||||
|
uiTextBoundsBlock(block, 50); // checks for fontsize
|
||||||
|
|
||||||
|
return block;
|
||||||
|
}
|
||||||
|
|
||||||
|
The uiDef coordinates here are only relative. When this function is called, the interface
|
||||||
|
code automatically makes sure the buttons fit in the menu nicely.
|
||||||
|
|
||||||
|
Inside a menu uiBlock, other uiBlocks can be invoked to make a hierarchical menu.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
-----------4.4 specials
|
||||||
|
|
||||||
|
15. KEYEVT
|
||||||
|
|
||||||
|
void uiDefKeyevtButS(uiBlock *block, int retval, char *str,
|
||||||
|
short x1, short y1, short x2, short y2, short *spoin, char *tip)
|
||||||
|
|
||||||
|
A special button, which stores a keyvalue in *spoin. When the button is pressed,
|
||||||
|
it displays the text 'Press any Key'. A keypress then stores the value.
|
||||||
|
|
||||||
|
16. LINK and INLINK
|
||||||
|
|
||||||
|
These button present a method of linking data in Blender, by drawing a line from one
|
||||||
|
icon to another. It consists of two button types:
|
||||||
|
|
||||||
|
LINK, the 'linking from' part, can be:
|
||||||
|
- a single pointer to data (only one line allowed)
|
||||||
|
- an array of pointers to data. The LINK buttons system keeps track of allocating
|
||||||
|
space for the array, and set the correct pointers in it.
|
||||||
|
|
||||||
|
INLINK, the 'linking to' part activates creating a link, when a user releases the mouse
|
||||||
|
cursor over it, while dragging a line from the LINK button.
|
||||||
|
|
||||||
|
These buttons are defined as follows:
|
||||||
|
|
||||||
|
|
||||||
|
uiBut but= uiDefIconBut(block, LINK, 0, ICON_LINK, x1, y1, w, h, NULL, 0, 0, 0, 0, "");
|
||||||
|
/* create the LINK icon */
|
||||||
|
|
||||||
|
uiSetButLink(but, void **pt, void ***ppt, short *totlink, short fromcode, short tocode);
|
||||||
|
**pt: pointer to pointer (only one link allowed)
|
||||||
|
***ppt: pointer to pointerpointer (an array of pointers)
|
||||||
|
(Either one of these values should be NULL)
|
||||||
|
|
||||||
|
fromcode: (currently unused)
|
||||||
|
tocode: a short indicating which blocks it can link to.
|
||||||
|
|
||||||
|
|
||||||
|
uiDefIconBut(block, INLINK, 0, ICON_INLINK, x1, y1, w, h, void *poin, short fromcode, 0, 0, 0, "");
|
||||||
|
poin: the pointer of the datablock you want to create links to
|
||||||
|
fromcode: a short identifying which LINK buttons can connect to it
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
17. IDPOIN
|
||||||
|
void uiDefIDPoinBut(uiBlock *block, uiIDPoinFuncFP func, int retval, char *str,
|
||||||
|
short x1, short y1, short x2, short y2, void *idpp, char *tip)
|
||||||
|
|
||||||
|
The ID struct is a generic part in structs like Object, Material, Mesh, etc.
|
||||||
|
Most linking options in Blender happens using ID's. (Mesh -> Material).
|
||||||
|
|
||||||
|
This special button in Blender visualizes an ID pointer with its name. Typing in
|
||||||
|
a new name, changes the pointer. For most ID types in Blender functions have been
|
||||||
|
written already, needed by this button, to check validity of names, and assign the pointer.
|
||||||
|
|
||||||
|
(BTW: the 'void *idpp' has to be a pointer to the ID pointer!)
|
||||||
|
|
||||||
|
Example function that can be put in 'func':
|
||||||
|
|
||||||
|
void test_scriptpoin_but(char *name, ID **idpp)
|
||||||
|
{
|
||||||
|
ID *id;
|
||||||
|
|
||||||
|
id= G.main->text.first;
|
||||||
|
while(id) {
|
||||||
|
if( strcmp(name, id->name+2)==0 ) {
|
||||||
|
*idpp= id;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
id= id->next;
|
||||||
|
}
|
||||||
|
*idpp= 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
------------- 4.5 uiButton control fuctions
|
||||||
|
|
||||||
|
|
||||||
|
void uiButSetFunc(uiBut *but, void (*func)(void *arg1, void *arg2), void *arg1, void *arg2)
|
||||||
|
When the button is pressed and released, it calls this function, with the 2 arguments.
|
||||||
|
|
||||||
|
void uiButSetFlag(uiBut *but, int flag)
|
||||||
|
set a flag for further control of button behaviour:
|
||||||
|
flag:
|
||||||
|
UI_TEXT_LEFT
|
||||||
|
|
||||||
|
int uiButGetRetVal(uiBut *but)
|
||||||
|
gives return value
|
||||||
|
|
||||||
|
|
||||||
|
</body>
|
||||||
|
<br><br><br>
|
||||||
45
extern/CMakeLists.txt
vendored
Normal file
45
extern/CMakeLists.txt
vendored
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
# $Id$
|
||||||
|
# ***** BEGIN GPL/BL DUAL 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. The Blender
|
||||||
|
# Foundation also sells licenses for use in proprietary software under
|
||||||
|
# the Blender License. See http://www.blender.org/BL/ for information
|
||||||
|
# about this.
|
||||||
|
#
|
||||||
|
# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
#
|
||||||
|
# The Original Code is Copyright (C) 2006, Blender Foundation
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# The Original Code is: all of this file.
|
||||||
|
#
|
||||||
|
# Contributor(s): Jacques Beaurain.
|
||||||
|
#
|
||||||
|
# ***** END GPL/BL DUAL LICENSE BLOCK *****
|
||||||
|
|
||||||
|
IF(WITH_GAMEENGINE)
|
||||||
|
SUBDIRS(qhull solid)
|
||||||
|
|
||||||
|
IF(WITH_BULLET)
|
||||||
|
SUBDIRS(bullet2)
|
||||||
|
ENDIF(WITH_BULLET)
|
||||||
|
ENDIF(WITH_GAMEENGINE)
|
||||||
|
|
||||||
|
IF(WITH_INTERNATIONAL)
|
||||||
|
SUBDIRS(bFTGL)
|
||||||
|
ENDIF(WITH_INTERNATIONAL)
|
||||||
|
|
||||||
|
IF(WITH_VERSE)
|
||||||
|
SUBDIRS(verse)
|
||||||
|
ENDIF(WITH_VERSE)
|
||||||
|
|
||||||
76
extern/Makefile
vendored
Normal file
76
extern/Makefile
vendored
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
# $Id$
|
||||||
|
#
|
||||||
|
# ***** BEGIN GPL/BL DUAL 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. The Blender
|
||||||
|
# Foundation also sells licenses for use in proprietary software under
|
||||||
|
# the Blender License. See http://www.blender.org/BL/ for information
|
||||||
|
# about this.
|
||||||
|
#
|
||||||
|
# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
#
|
||||||
|
# The Original Code is Copyright (C) 2002 by Hans Lambermont
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# The Original Code is: all of this file.
|
||||||
|
#
|
||||||
|
# Contributor(s): none yet.
|
||||||
|
#
|
||||||
|
# ***** END GPL/BL DUAL LICENSE BLOCK *****
|
||||||
|
# Bounces make to subdirectories. Also installs after succesful all target.
|
||||||
|
|
||||||
|
include nan_definitions.mk
|
||||||
|
|
||||||
|
SOURCEDIR = extern
|
||||||
|
DIR = $(OCGDIR)/extern
|
||||||
|
DIRS = qhull/src solid
|
||||||
|
|
||||||
|
ifeq ($(WITH_FREETYPE2), true)
|
||||||
|
DIRS += bFTGL/src
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq ($(WITH_FFMPEG), true)
|
||||||
|
ifeq ($(NAN_FFMPEG), $(LCGDIR)/ffmpeg)
|
||||||
|
DIRS += ffmpeg
|
||||||
|
endif
|
||||||
|
ifeq ($(NAN_FFMPEG), $(LCGDIR)/gcc/ffmpeg)
|
||||||
|
DIRS += ffmpeg
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq ($(WITH_VERSE), true)
|
||||||
|
DIRS += verse
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq ($(NAN_NO_KETSJI), true)
|
||||||
|
DIRS += bullet2
|
||||||
|
endif
|
||||||
|
|
||||||
|
TARGET =
|
||||||
|
ifneq ($(OS),irix)
|
||||||
|
TARGET=solid
|
||||||
|
endif
|
||||||
|
|
||||||
|
all::
|
||||||
|
@[ -d $(OCGDIR)/extern ] || mkdir -p $(OCGDIR)/extern
|
||||||
|
@for i in $(DIRS); do \
|
||||||
|
echo "====> $(MAKE) $@ in $(SOURCEDIR)/$$i" ;\
|
||||||
|
$(MAKE) -C $$i install || exit 1; \
|
||||||
|
done
|
||||||
|
|
||||||
|
clean test debug::
|
||||||
|
@[ -d $(OCGDIR)/extern ] || mkdir -p $(OCGDIR)/extern
|
||||||
|
@for i in $(DIRS); do \
|
||||||
|
echo "====> $(MAKE) $@ in $(SOURCEDIR)/$$i" ;\
|
||||||
|
$(MAKE) -C $$i $@ || exit 1; \
|
||||||
|
done
|
||||||
18
extern/SConscript
vendored
Normal file
18
extern/SConscript
vendored
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
#!/usr/bin/python
|
||||||
|
|
||||||
|
Import('env')
|
||||||
|
|
||||||
|
if env['WITH_BF_GAMEENGINE']:
|
||||||
|
SConscript(['qhull/SConscript',
|
||||||
|
'solid/SConscript'])
|
||||||
|
if env['WITH_BF_BULLET']:
|
||||||
|
SConscript(['bullet2/src/SConscript'])
|
||||||
|
|
||||||
|
if env['WITH_BF_INTERNATIONAL']:
|
||||||
|
SConscript(['bFTGL/SConscript'])
|
||||||
|
|
||||||
|
if env['WITH_BF_VERSE']:
|
||||||
|
SConscript(['verse/dist/SConstruct'])
|
||||||
|
|
||||||
|
if env['WITH_BF_FFMPEG'] and env['BF_FFMPEG_LIB'] == '':
|
||||||
|
SConscript(['ffmpeg/SConscript']);
|
||||||
35
extern/bFTGL/CMakeLists.txt
vendored
Normal file
35
extern/bFTGL/CMakeLists.txt
vendored
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
# $Id$
|
||||||
|
# ***** BEGIN GPL/BL DUAL 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. The Blender
|
||||||
|
# Foundation also sells licenses for use in proprietary software under
|
||||||
|
# the Blender License. See http://www.blender.org/BL/ for information
|
||||||
|
# about this.
|
||||||
|
#
|
||||||
|
# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
#
|
||||||
|
# The Original Code is Copyright (C) 2006, Blender Foundation
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# The Original Code is: all of this file.
|
||||||
|
#
|
||||||
|
# Contributor(s): Jacques Beaurain.
|
||||||
|
#
|
||||||
|
# ***** END GPL/BL DUAL LICENSE BLOCK *****
|
||||||
|
|
||||||
|
SET(INC include src ${FREETYPE_INC})
|
||||||
|
|
||||||
|
FILE(GLOB SRC src/*.cpp)
|
||||||
|
ADD_DEFINITIONS(-DFTGL_LIBRARY_STATIC)
|
||||||
|
BLENDERLIB(extern_ftgl "${SRC}" "${INC}")
|
||||||
|
#, libtype=['international','player'], priority=[5, 210])
|
||||||
481
extern/bFTGL/COPYING.txt
vendored
Normal file
481
extern/bFTGL/COPYING.txt
vendored
Normal file
@@ -0,0 +1,481 @@
|
|||||||
|
GNU LIBRARY GENERAL PUBLIC LICENSE
|
||||||
|
Version 2, June 1991
|
||||||
|
|
||||||
|
Copyright (C) 1991 Free Software Foundation, Inc.
|
||||||
|
59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
|
[This is the first released version of the library GPL. It is
|
||||||
|
numbered 2 because it goes with version 2 of the ordinary GPL.]
|
||||||
|
|
||||||
|
Preamble
|
||||||
|
|
||||||
|
The licenses for most software are designed to take away your
|
||||||
|
freedom to share and change it. By contrast, the GNU General Public
|
||||||
|
Licenses are intended to guarantee your freedom to share and change
|
||||||
|
free software--to make sure the software is free for all its users.
|
||||||
|
|
||||||
|
This license, the Library General Public License, applies to some
|
||||||
|
specially designated Free Software Foundation software, and to any
|
||||||
|
other libraries whose authors decide to use it. You can use it for
|
||||||
|
your libraries, too.
|
||||||
|
|
||||||
|
When we speak of free software, we are referring to freedom, not
|
||||||
|
price. Our General Public Licenses are designed to make sure that you
|
||||||
|
have the freedom to distribute copies of free software (and charge for
|
||||||
|
this service if you wish), that you receive source code or can get it
|
||||||
|
if you want it, that you can change the software or use pieces of it
|
||||||
|
in new free programs; and that you know you can do these things.
|
||||||
|
|
||||||
|
To protect your rights, we need to make restrictions that forbid
|
||||||
|
anyone to deny you these rights or to ask you to surrender the rights.
|
||||||
|
These restrictions translate to certain responsibilities for you if
|
||||||
|
you distribute copies of the library, or if you modify it.
|
||||||
|
|
||||||
|
For example, if you distribute copies of the library, whether gratis
|
||||||
|
or for a fee, you must give the recipients all the rights that we gave
|
||||||
|
you. You must make sure that they, too, receive or can get the source
|
||||||
|
code. If you link a program with the library, you must provide
|
||||||
|
complete object files to the recipients so that they can relink them
|
||||||
|
with the library, after making changes to the library and recompiling
|
||||||
|
it. And you must show them these terms so they know their rights.
|
||||||
|
|
||||||
|
Our method of protecting your rights has two steps: (1) copyright
|
||||||
|
the library, and (2) offer you this license which gives you legal
|
||||||
|
permission to copy, distribute and/or modify the library.
|
||||||
|
|
||||||
|
Also, for each distributor's protection, we want to make certain
|
||||||
|
that everyone understands that there is no warranty for this free
|
||||||
|
library. If the library is modified by someone else and passed on, we
|
||||||
|
want its recipients to know that what they have is not the original
|
||||||
|
version, so that any problems introduced by others will not reflect on
|
||||||
|
the original authors' reputations.
|
||||||
|
|
||||||
|
Finally, any free program is threatened constantly by software
|
||||||
|
patents. We wish to avoid the danger that companies distributing free
|
||||||
|
software will individually obtain patent licenses, thus in effect
|
||||||
|
transforming the program into proprietary software. To prevent this,
|
||||||
|
we have made it clear that any patent must be licensed for everyone's
|
||||||
|
free use or not licensed at all.
|
||||||
|
|
||||||
|
Most GNU software, including some libraries, is covered by the ordinary
|
||||||
|
GNU General Public License, which was designed for utility programs. This
|
||||||
|
license, the GNU Library General Public License, applies to certain
|
||||||
|
designated libraries. This license is quite different from the ordinary
|
||||||
|
one; be sure to read it in full, and don't assume that anything in it is
|
||||||
|
the same as in the ordinary license.
|
||||||
|
|
||||||
|
The reason we have a separate public license for some libraries is that
|
||||||
|
they blur the distinction we usually make between modifying or adding to a
|
||||||
|
program and simply using it. Linking a program with a library, without
|
||||||
|
changing the library, is in some sense simply using the library, and is
|
||||||
|
analogous to running a utility program or application program. However, in
|
||||||
|
a textual and legal sense, the linked executable is a combined work, a
|
||||||
|
derivative of the original library, and the ordinary General Public License
|
||||||
|
treats it as such.
|
||||||
|
|
||||||
|
Because of this blurred distinction, using the ordinary General
|
||||||
|
Public License for libraries did not effectively promote software
|
||||||
|
sharing, because most developers did not use the libraries. We
|
||||||
|
concluded that weaker conditions might promote sharing better.
|
||||||
|
|
||||||
|
However, unrestricted linking of non-free programs would deprive the
|
||||||
|
users of those programs of all benefit from the free status of the
|
||||||
|
libraries themselves. This Library General Public License is intended to
|
||||||
|
permit developers of non-free programs to use free libraries, while
|
||||||
|
preserving your freedom as a user of such programs to change the free
|
||||||
|
libraries that are incorporated in them. (We have not seen how to achieve
|
||||||
|
this as regards changes in header files, but we have achieved it as regards
|
||||||
|
changes in the actual functions of the Library.) The hope is that this
|
||||||
|
will lead to faster development of free libraries.
|
||||||
|
|
||||||
|
The precise terms and conditions for copying, distribution and
|
||||||
|
modification follow. Pay close attention to the difference between a
|
||||||
|
"work based on the library" and a "work that uses the library". The
|
||||||
|
former contains code derived from the library, while the latter only
|
||||||
|
works together with the library.
|
||||||
|
|
||||||
|
Note that it is possible for a library to be covered by the ordinary
|
||||||
|
General Public License rather than by this special one.
|
||||||
|
|
||||||
|
GNU LIBRARY GENERAL PUBLIC LICENSE
|
||||||
|
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||||
|
|
||||||
|
0. This License Agreement applies to any software library which
|
||||||
|
contains a notice placed by the copyright holder or other authorized
|
||||||
|
party saying it may be distributed under the terms of this Library
|
||||||
|
General Public License (also called "this License"). Each licensee is
|
||||||
|
addressed as "you".
|
||||||
|
|
||||||
|
A "library" means a collection of software functions and/or data
|
||||||
|
prepared so as to be conveniently linked with application programs
|
||||||
|
(which use some of those functions and data) to form executables.
|
||||||
|
|
||||||
|
The "Library", below, refers to any such software library or work
|
||||||
|
which has been distributed under these terms. A "work based on the
|
||||||
|
Library" means either the Library or any derivative work under
|
||||||
|
copyright law: that is to say, a work containing the Library or a
|
||||||
|
portion of it, either verbatim or with modifications and/or translated
|
||||||
|
straightforwardly into another language. (Hereinafter, translation is
|
||||||
|
included without limitation in the term "modification".)
|
||||||
|
|
||||||
|
"Source code" for a work means the preferred form of the work for
|
||||||
|
making modifications to it. For a library, complete source code means
|
||||||
|
all the source code for all modules it contains, plus any associated
|
||||||
|
interface definition files, plus the scripts used to control compilation
|
||||||
|
and installation of the library.
|
||||||
|
|
||||||
|
Activities other than copying, distribution and modification are not
|
||||||
|
covered by this License; they are outside its scope. The act of
|
||||||
|
running a program using the Library is not restricted, and output from
|
||||||
|
such a program is covered only if its contents constitute a work based
|
||||||
|
on the Library (independent of the use of the Library in a tool for
|
||||||
|
writing it). Whether that is true depends on what the Library does
|
||||||
|
and what the program that uses the Library does.
|
||||||
|
|
||||||
|
1. You may copy and distribute verbatim copies of the Library's
|
||||||
|
complete source code as you receive it, in any medium, provided that
|
||||||
|
you conspicuously and appropriately publish on each copy an
|
||||||
|
appropriate copyright notice and disclaimer of warranty; keep intact
|
||||||
|
all the notices that refer to this License and to the absence of any
|
||||||
|
warranty; and distribute a copy of this License along with the
|
||||||
|
Library.
|
||||||
|
|
||||||
|
You may charge a fee for the physical act of transferring a copy,
|
||||||
|
and you may at your option offer warranty protection in exchange for a
|
||||||
|
fee.
|
||||||
|
|
||||||
|
2. You may modify your copy or copies of the Library or any portion
|
||||||
|
of it, thus forming a work based on the Library, and copy and
|
||||||
|
distribute such modifications or work under the terms of Section 1
|
||||||
|
above, provided that you also meet all of these conditions:
|
||||||
|
|
||||||
|
a) The modified work must itself be a software library.
|
||||||
|
|
||||||
|
b) You must cause the files modified to carry prominent notices
|
||||||
|
stating that you changed the files and the date of any change.
|
||||||
|
|
||||||
|
c) You must cause the whole of the work to be licensed at no
|
||||||
|
charge to all third parties under the terms of this License.
|
||||||
|
|
||||||
|
d) If a facility in the modified Library refers to a function or a
|
||||||
|
table of data to be supplied by an application program that uses
|
||||||
|
the facility, other than as an argument passed when the facility
|
||||||
|
is invoked, then you must make a good faith effort to ensure that,
|
||||||
|
in the event an application does not supply such function or
|
||||||
|
table, the facility still operates, and performs whatever part of
|
||||||
|
its purpose remains meaningful.
|
||||||
|
|
||||||
|
(For example, a function in a library to compute square roots has
|
||||||
|
a purpose that is entirely well-defined independent of the
|
||||||
|
application. Therefore, Subsection 2d requires that any
|
||||||
|
application-supplied function or table used by this function must
|
||||||
|
be optional: if the application does not supply it, the square
|
||||||
|
root function must still compute square roots.)
|
||||||
|
|
||||||
|
These requirements apply to the modified work as a whole. If
|
||||||
|
identifiable sections of that work are not derived from the Library,
|
||||||
|
and can be reasonably considered independent and separate works in
|
||||||
|
themselves, then this License, and its terms, do not apply to those
|
||||||
|
sections when you distribute them as separate works. But when you
|
||||||
|
distribute the same sections as part of a whole which is a work based
|
||||||
|
on the Library, the distribution of the whole must be on the terms of
|
||||||
|
this License, whose permissions for other licensees extend to the
|
||||||
|
entire whole, and thus to each and every part regardless of who wrote
|
||||||
|
it.
|
||||||
|
|
||||||
|
Thus, it is not the intent of this section to claim rights or contest
|
||||||
|
your rights to work written entirely by you; rather, the intent is to
|
||||||
|
exercise the right to control the distribution of derivative or
|
||||||
|
collective works based on the Library.
|
||||||
|
|
||||||
|
In addition, mere aggregation of another work not based on the Library
|
||||||
|
with the Library (or with a work based on the Library) on a volume of
|
||||||
|
a storage or distribution medium does not bring the other work under
|
||||||
|
the scope of this License.
|
||||||
|
|
||||||
|
3. You may opt to apply the terms of the ordinary GNU General Public
|
||||||
|
License instead of this License to a given copy of the Library. To do
|
||||||
|
this, you must alter all the notices that refer to this License, so
|
||||||
|
that they refer to the ordinary GNU General Public License, version 2,
|
||||||
|
instead of to this License. (If a newer version than version 2 of the
|
||||||
|
ordinary GNU General Public License has appeared, then you can specify
|
||||||
|
that version instead if you wish.) Do not make any other change in
|
||||||
|
these notices.
|
||||||
|
|
||||||
|
Once this change is made in a given copy, it is irreversible for
|
||||||
|
that copy, so the ordinary GNU General Public License applies to all
|
||||||
|
subsequent copies and derivative works made from that copy.
|
||||||
|
|
||||||
|
This option is useful when you wish to copy part of the code of
|
||||||
|
the Library into a program that is not a library.
|
||||||
|
|
||||||
|
4. You may copy and distribute the Library (or a portion or
|
||||||
|
derivative of it, under Section 2) in object code or executable form
|
||||||
|
under the terms of Sections 1 and 2 above provided that you accompany
|
||||||
|
it with the complete corresponding machine-readable source code, which
|
||||||
|
must be distributed under the terms of Sections 1 and 2 above on a
|
||||||
|
medium customarily used for software interchange.
|
||||||
|
|
||||||
|
If distribution of object code is made by offering access to copy
|
||||||
|
from a designated place, then offering equivalent access to copy the
|
||||||
|
source code from the same place satisfies the requirement to
|
||||||
|
distribute the source code, even though third parties are not
|
||||||
|
compelled to copy the source along with the object code.
|
||||||
|
|
||||||
|
5. A program that contains no derivative of any portion of the
|
||||||
|
Library, but is designed to work with the Library by being compiled or
|
||||||
|
linked with it, is called a "work that uses the Library". Such a
|
||||||
|
work, in isolation, is not a derivative work of the Library, and
|
||||||
|
therefore falls outside the scope of this License.
|
||||||
|
|
||||||
|
However, linking a "work that uses the Library" with the Library
|
||||||
|
creates an executable that is a derivative of the Library (because it
|
||||||
|
contains portions of the Library), rather than a "work that uses the
|
||||||
|
library". The executable is therefore covered by this License.
|
||||||
|
Section 6 states terms for distribution of such executables.
|
||||||
|
|
||||||
|
When a "work that uses the Library" uses material from a header file
|
||||||
|
that is part of the Library, the object code for the work may be a
|
||||||
|
derivative work of the Library even though the source code is not.
|
||||||
|
Whether this is true is especially significant if the work can be
|
||||||
|
linked without the Library, or if the work is itself a library. The
|
||||||
|
threshold for this to be true is not precisely defined by law.
|
||||||
|
|
||||||
|
If such an object file uses only numerical parameters, data
|
||||||
|
structure layouts and accessors, and small macros and small inline
|
||||||
|
functions (ten lines or less in length), then the use of the object
|
||||||
|
file is unrestricted, regardless of whether it is legally a derivative
|
||||||
|
work. (Executables containing this object code plus portions of the
|
||||||
|
Library will still fall under Section 6.)
|
||||||
|
|
||||||
|
Otherwise, if the work is a derivative of the Library, you may
|
||||||
|
distribute the object code for the work under the terms of Section 6.
|
||||||
|
Any executables containing that work also fall under Section 6,
|
||||||
|
whether or not they are linked directly with the Library itself.
|
||||||
|
|
||||||
|
6. As an exception to the Sections above, you may also compile or
|
||||||
|
link a "work that uses the Library" with the Library to produce a
|
||||||
|
work containing portions of the Library, and distribute that work
|
||||||
|
under terms of your choice, provided that the terms permit
|
||||||
|
modification of the work for the customer's own use and reverse
|
||||||
|
engineering for debugging such modifications.
|
||||||
|
|
||||||
|
You must give prominent notice with each copy of the work that the
|
||||||
|
Library is used in it and that the Library and its use are covered by
|
||||||
|
this License. You must supply a copy of this License. If the work
|
||||||
|
during execution displays copyright notices, you must include the
|
||||||
|
copyright notice for the Library among them, as well as a reference
|
||||||
|
directing the user to the copy of this License. Also, you must do one
|
||||||
|
of these things:
|
||||||
|
|
||||||
|
a) Accompany the work with the complete corresponding
|
||||||
|
machine-readable source code for the Library including whatever
|
||||||
|
changes were used in the work (which must be distributed under
|
||||||
|
Sections 1 and 2 above); and, if the work is an executable linked
|
||||||
|
with the Library, with the complete machine-readable "work that
|
||||||
|
uses the Library", as object code and/or source code, so that the
|
||||||
|
user can modify the Library and then relink to produce a modified
|
||||||
|
executable containing the modified Library. (It is understood
|
||||||
|
that the user who changes the contents of definitions files in the
|
||||||
|
Library will not necessarily be able to recompile the application
|
||||||
|
to use the modified definitions.)
|
||||||
|
|
||||||
|
b) Accompany the work with a written offer, valid for at
|
||||||
|
least three years, to give the same user the materials
|
||||||
|
specified in Subsection 6a, above, for a charge no more
|
||||||
|
than the cost of performing this distribution.
|
||||||
|
|
||||||
|
c) If distribution of the work is made by offering access to copy
|
||||||
|
from a designated place, offer equivalent access to copy the above
|
||||||
|
specified materials from the same place.
|
||||||
|
|
||||||
|
d) Verify that the user has already received a copy of these
|
||||||
|
materials or that you have already sent this user a copy.
|
||||||
|
|
||||||
|
For an executable, the required form of the "work that uses the
|
||||||
|
Library" must include any data and utility programs needed for
|
||||||
|
reproducing the executable from it. However, as a special exception,
|
||||||
|
the source code distributed need not include anything that is normally
|
||||||
|
distributed (in either source or binary form) with the major
|
||||||
|
components (compiler, kernel, and so on) of the operating system on
|
||||||
|
which the executable runs, unless that component itself accompanies
|
||||||
|
the executable.
|
||||||
|
|
||||||
|
It may happen that this requirement contradicts the license
|
||||||
|
restrictions of other proprietary libraries that do not normally
|
||||||
|
accompany the operating system. Such a contradiction means you cannot
|
||||||
|
use both them and the Library together in an executable that you
|
||||||
|
distribute.
|
||||||
|
|
||||||
|
7. You may place library facilities that are a work based on the
|
||||||
|
Library side-by-side in a single library together with other library
|
||||||
|
facilities not covered by this License, and distribute such a combined
|
||||||
|
library, provided that the separate distribution of the work based on
|
||||||
|
the Library and of the other library facilities is otherwise
|
||||||
|
permitted, and provided that you do these two things:
|
||||||
|
|
||||||
|
a) Accompany the combined library with a copy of the same work
|
||||||
|
based on the Library, uncombined with any other library
|
||||||
|
facilities. This must be distributed under the terms of the
|
||||||
|
Sections above.
|
||||||
|
|
||||||
|
b) Give prominent notice with the combined library of the fact
|
||||||
|
that part of it is a work based on the Library, and explaining
|
||||||
|
where to find the accompanying uncombined form of the same work.
|
||||||
|
|
||||||
|
8. You may not copy, modify, sublicense, link with, or distribute
|
||||||
|
the Library except as expressly provided under this License. Any
|
||||||
|
attempt otherwise to copy, modify, sublicense, link with, or
|
||||||
|
distribute the Library is void, and will automatically terminate your
|
||||||
|
rights under this License. However, parties who have received copies,
|
||||||
|
or rights, from you under this License will not have their licenses
|
||||||
|
terminated so long as such parties remain in full compliance.
|
||||||
|
|
||||||
|
9. You are not required to accept this License, since you have not
|
||||||
|
signed it. However, nothing else grants you permission to modify or
|
||||||
|
distribute the Library or its derivative works. These actions are
|
||||||
|
prohibited by law if you do not accept this License. Therefore, by
|
||||||
|
modifying or distributing the Library (or any work based on the
|
||||||
|
Library), you indicate your acceptance of this License to do so, and
|
||||||
|
all its terms and conditions for copying, distributing or modifying
|
||||||
|
the Library or works based on it.
|
||||||
|
|
||||||
|
10. Each time you redistribute the Library (or any work based on the
|
||||||
|
Library), the recipient automatically receives a license from the
|
||||||
|
original licensor to copy, distribute, link with or modify the Library
|
||||||
|
subject to these terms and conditions. You may not impose any further
|
||||||
|
restrictions on the recipients' exercise of the rights granted herein.
|
||||||
|
You are not responsible for enforcing compliance by third parties to
|
||||||
|
this License.
|
||||||
|
|
||||||
|
11. If, as a consequence of a court judgment or allegation of patent
|
||||||
|
infringement or for any other reason (not limited to patent issues),
|
||||||
|
conditions are imposed on you (whether by court order, agreement or
|
||||||
|
otherwise) that contradict the conditions of this License, they do not
|
||||||
|
excuse you from the conditions of this License. If you cannot
|
||||||
|
distribute so as to satisfy simultaneously your obligations under this
|
||||||
|
License and any other pertinent obligations, then as a consequence you
|
||||||
|
may not distribute the Library at all. For example, if a patent
|
||||||
|
license would not permit royalty-free redistribution of the Library by
|
||||||
|
all those who receive copies directly or indirectly through you, then
|
||||||
|
the only way you could satisfy both it and this License would be to
|
||||||
|
refrain entirely from distribution of the Library.
|
||||||
|
|
||||||
|
If any portion of this section is held invalid or unenforceable under any
|
||||||
|
particular circumstance, the balance of the section is intended to apply,
|
||||||
|
and the section as a whole is intended to apply in other circumstances.
|
||||||
|
|
||||||
|
It is not the purpose of this section to induce you to infringe any
|
||||||
|
patents or other property right claims or to contest validity of any
|
||||||
|
such claims; this section has the sole purpose of protecting the
|
||||||
|
integrity of the free software distribution system which is
|
||||||
|
implemented by public license practices. Many people have made
|
||||||
|
generous contributions to the wide range of software distributed
|
||||||
|
through that system in reliance on consistent application of that
|
||||||
|
system; it is up to the author/donor to decide if he or she is willing
|
||||||
|
to distribute software through any other system and a licensee cannot
|
||||||
|
impose that choice.
|
||||||
|
|
||||||
|
This section is intended to make thoroughly clear what is believed to
|
||||||
|
be a consequence of the rest of this License.
|
||||||
|
|
||||||
|
12. If the distribution and/or use of the Library is restricted in
|
||||||
|
certain countries either by patents or by copyrighted interfaces, the
|
||||||
|
original copyright holder who places the Library under this License may add
|
||||||
|
an explicit geographical distribution limitation excluding those countries,
|
||||||
|
so that distribution is permitted only in or among countries not thus
|
||||||
|
excluded. In such case, this License incorporates the limitation as if
|
||||||
|
written in the body of this License.
|
||||||
|
|
||||||
|
13. The Free Software Foundation may publish revised and/or new
|
||||||
|
versions of the Library General Public License from time to time.
|
||||||
|
Such new versions will be similar in spirit to the present version,
|
||||||
|
but may differ in detail to address new problems or concerns.
|
||||||
|
|
||||||
|
Each version is given a distinguishing version number. If the Library
|
||||||
|
specifies a version number of this License which applies to it and
|
||||||
|
"any later version", you have the option of following the terms and
|
||||||
|
conditions either of that version or of any later version published by
|
||||||
|
the Free Software Foundation. If the Library does not specify a
|
||||||
|
license version number, you may choose any version ever published by
|
||||||
|
the Free Software Foundation.
|
||||||
|
|
||||||
|
14. If you wish to incorporate parts of the Library into other free
|
||||||
|
programs whose distribution conditions are incompatible with these,
|
||||||
|
write to the author to ask for permission. For software which is
|
||||||
|
copyrighted by the Free Software Foundation, write to the Free
|
||||||
|
Software Foundation; we sometimes make exceptions for this. Our
|
||||||
|
decision will be guided by the two goals of preserving the free status
|
||||||
|
of all derivatives of our free software and of promoting the sharing
|
||||||
|
and reuse of software generally.
|
||||||
|
|
||||||
|
NO WARRANTY
|
||||||
|
|
||||||
|
15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
|
||||||
|
WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
|
||||||
|
EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
|
||||||
|
OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY
|
||||||
|
KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||||
|
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
|
||||||
|
LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME
|
||||||
|
THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
|
||||||
|
|
||||||
|
16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN
|
||||||
|
WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY
|
||||||
|
AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU
|
||||||
|
FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR
|
||||||
|
CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE
|
||||||
|
LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
|
||||||
|
RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
|
||||||
|
FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
|
||||||
|
SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
|
||||||
|
DAMAGES.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
How to Apply These Terms to Your New Libraries
|
||||||
|
|
||||||
|
If you develop a new library, and you want it to be of the greatest
|
||||||
|
possible use to the public, we recommend making it free software that
|
||||||
|
everyone can redistribute and change. You can do so by permitting
|
||||||
|
redistribution under these terms (or, alternatively, under the terms of the
|
||||||
|
ordinary General Public License).
|
||||||
|
|
||||||
|
To apply these terms, attach the following notices to the library. It is
|
||||||
|
safest to attach them to the start of each source file to most effectively
|
||||||
|
convey the exclusion of warranty; and each file should have at least the
|
||||||
|
"copyright" line and a pointer to where the full notice is found.
|
||||||
|
|
||||||
|
<one line to give the library's name and a brief idea of what it does.>
|
||||||
|
Copyright (C) <year> <name of author>
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Library General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
This library 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
|
||||||
|
Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public
|
||||||
|
License along with this library; if not, write to the Free
|
||||||
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
|
||||||
|
Also add information on how to contact you by electronic and paper mail.
|
||||||
|
|
||||||
|
You should also get your employer (if you work as a programmer) or your
|
||||||
|
school, if any, to sign a "copyright disclaimer" for the library, if
|
||||||
|
necessary. Here is a sample; alter the names:
|
||||||
|
|
||||||
|
Yoyodyne, Inc., hereby disclaims all copyright interest in the
|
||||||
|
library `Frob' (a library for tweaking knobs) written by James Random Hacker.
|
||||||
|
|
||||||
|
<signature of Ty Coon>, 1 April 1990
|
||||||
|
Ty Coon, President of Vice
|
||||||
|
|
||||||
|
That's all there is to it!
|
||||||
51
extern/bFTGL/README.txt
vendored
Normal file
51
extern/bFTGL/README.txt
vendored
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
FTGL 2.0.11
|
||||||
|
16 August 2004
|
||||||
|
|
||||||
|
DESCRIPTION:
|
||||||
|
|
||||||
|
FTGL is a free open source library to enable developers to use arbitrary
|
||||||
|
fonts in their OpenGL (www.opengl.org) applications.
|
||||||
|
Unlike other OpenGL font libraries FTGL uses standard font file formats
|
||||||
|
so doesn't need a preprocessing step to convert the high quality font data
|
||||||
|
into a lesser quality, proprietary format.
|
||||||
|
FTGL uses the Freetype (www.freetype.org) font library to open and 'decode'
|
||||||
|
the fonts. It then takes that output and stores it in a format most efficient
|
||||||
|
for OpenGL rendering.
|
||||||
|
|
||||||
|
Rendering modes supported are
|
||||||
|
- Bit maps
|
||||||
|
- Antialiased Pix maps
|
||||||
|
- Texture maps
|
||||||
|
- Outlines
|
||||||
|
- Polygon meshes
|
||||||
|
- Extruded polygon meshes
|
||||||
|
|
||||||
|
FTGL is designed to be used in commercial quality software. It has been
|
||||||
|
written with performance, robustness and simplicity in mind.
|
||||||
|
|
||||||
|
USAGE:
|
||||||
|
|
||||||
|
FTGLPixmapFont font( "Fonts:Arial");
|
||||||
|
|
||||||
|
font.FaceSize( 72);
|
||||||
|
|
||||||
|
font.render( "Hello World!");
|
||||||
|
|
||||||
|
This library was inspired by gltt, Copyright (C) 1998-1999 Stephane Rehel
|
||||||
|
(http://gltt.sourceforge.net)
|
||||||
|
Bezier curve code contributed by Jed Soane.
|
||||||
|
Demo, Linux port, extrusion code and gltt maintainance by Gerard Lanois
|
||||||
|
Linux port by Matthias Kretz
|
||||||
|
Windows port by Andrew Ellerton & Max Rheiner
|
||||||
|
Bug fixes by Robert Osfield, Marcelo E. Magallon, Markku Rontu, Mark A. Fox,
|
||||||
|
Patrick Rogers
|
||||||
|
Containers and optimisations by Sebastien Barre
|
||||||
|
Autoconf Marcelo E. Magallon.
|
||||||
|
|
||||||
|
|
||||||
|
Please contact me if you have any suggestions, feature requests, or problems.
|
||||||
|
|
||||||
|
Henry Maddocks
|
||||||
|
ftgl@opengl.geek.nz
|
||||||
|
http://homepages.paradise.net.nz/henryj/
|
||||||
|
|
||||||
30
extern/bFTGL/SConscript
vendored
Normal file
30
extern/bFTGL/SConscript
vendored
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
#!/usr/bin/python
|
||||||
|
import sys
|
||||||
|
import os
|
||||||
|
|
||||||
|
Import('env')
|
||||||
|
|
||||||
|
# Import the C flags set in the SConstruct file
|
||||||
|
#Import ('cflags')
|
||||||
|
#Import ('defines')
|
||||||
|
#Import ('user_options_dict')
|
||||||
|
|
||||||
|
#if sys.platform=='linux2' or sys.platform=='linux-i386':
|
||||||
|
# ftgl_env.Append (CCFLAGS = ['-O2', '-ansi'])
|
||||||
|
#elif sys.platform=='win32':
|
||||||
|
#ftgl_env.Append (CCFLAGS = ['/O2'])
|
||||||
|
#elif sys.platform=='sunos':
|
||||||
|
# ftgl_env.Append (CCFLAGS = ['Xc', '-v', '-fast'])
|
||||||
|
#elif sys.platform=='darwin':
|
||||||
|
# ftgl_env.Append (CCFLAGS = ['-O2', '-pipe', '-fPIC', '-funsigned-char', '-ffast-math'])
|
||||||
|
#else:
|
||||||
|
# ftgl_env.Append (CCFLAGS = cflags)
|
||||||
|
|
||||||
|
#ftgl_env.Append (CPPDEFINES = defines)
|
||||||
|
|
||||||
|
incs = 'include src ' + env['BF_FREETYPE_INC']
|
||||||
|
defs = ''
|
||||||
|
|
||||||
|
sources = env.Glob('src/*.cpp')
|
||||||
|
|
||||||
|
env.BlenderLib ( 'extern_ftgl', sources, Split(incs), Split(defs), libtype=['international','player'], priority=[5, 210])
|
||||||
4
extern/bFTGL/cleanup
vendored
Executable file
4
extern/bFTGL/cleanup
vendored
Executable file
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/sh -fx
|
||||||
|
# script to get rid of the grabage that MAC OSX drops in all the directories
|
||||||
|
|
||||||
|
find . -name .DS_Store -print -exec rm {} \;
|
||||||
124
extern/bFTGL/include/FTBBox.h
vendored
Normal file
124
extern/bFTGL/include/FTBBox.h
vendored
Normal file
@@ -0,0 +1,124 @@
|
|||||||
|
#ifndef __FTBBox__
|
||||||
|
#define __FTBBox__
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
//#include FT_GLYPH_H
|
||||||
|
#include FT_OUTLINE_H
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
#include "FTPoint.h"
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTBBox is a convenience class for handling bounding boxes.
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTBBox
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Default constructor. Bounding box is set to zero.
|
||||||
|
*/
|
||||||
|
FTBBox()
|
||||||
|
: lowerX(0.0f),
|
||||||
|
lowerY(0.0f),
|
||||||
|
lowerZ(0.0f),
|
||||||
|
upperX(0.0f),
|
||||||
|
upperY(0.0f),
|
||||||
|
upperZ(0.0f)
|
||||||
|
{}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
FTBBox( float lx, float ly, float lz, float ux, float uy, float uz)
|
||||||
|
: lowerX(lx),
|
||||||
|
lowerY(ly),
|
||||||
|
lowerZ(lz),
|
||||||
|
upperX(ux),
|
||||||
|
upperY(uy),
|
||||||
|
upperZ(uz)
|
||||||
|
{}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor. Extracts a bounding box from a freetype glyph. Uses
|
||||||
|
* the control box for the glyph. <code>FT_Glyph_Get_CBox()</code>
|
||||||
|
*
|
||||||
|
* @param glyph A freetype glyph
|
||||||
|
*/
|
||||||
|
FTBBox( FT_GlyphSlot glyph)
|
||||||
|
: lowerX(0.0f),
|
||||||
|
lowerY(0.0f),
|
||||||
|
lowerZ(0.0f),
|
||||||
|
upperX(0.0f),
|
||||||
|
upperY(0.0f),
|
||||||
|
upperZ(0.0f)
|
||||||
|
{
|
||||||
|
FT_BBox bbox;
|
||||||
|
FT_Outline_Get_CBox( &(glyph->outline), &bbox);
|
||||||
|
|
||||||
|
lowerX = static_cast<float>( bbox.xMin) / 64.0f;
|
||||||
|
lowerY = static_cast<float>( bbox.yMin) / 64.0f;
|
||||||
|
lowerZ = 0.0f;
|
||||||
|
upperX = static_cast<float>( bbox.xMax) / 64.0f;
|
||||||
|
upperY = static_cast<float>( bbox.yMax) / 64.0f;
|
||||||
|
upperZ = 0.0f;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
~FTBBox()
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Move the Bounding Box by a vector.
|
||||||
|
*
|
||||||
|
* @param distance The distance to move the bbox in 3D space.
|
||||||
|
*/
|
||||||
|
FTBBox& Move( FTPoint distance)
|
||||||
|
{
|
||||||
|
lowerX += distance.x;
|
||||||
|
lowerY += distance.y;
|
||||||
|
lowerZ += distance.z;
|
||||||
|
upperX += distance.x;
|
||||||
|
upperY += distance.y;
|
||||||
|
upperZ += distance.z;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
FTBBox& operator += ( const FTBBox& bbox)
|
||||||
|
{
|
||||||
|
lowerX = bbox.lowerX < lowerX? bbox.lowerX: lowerX;
|
||||||
|
lowerY = bbox.lowerY < lowerY? bbox.lowerY: lowerY;
|
||||||
|
lowerZ = bbox.lowerZ < lowerZ? bbox.lowerZ: lowerZ;
|
||||||
|
upperX = bbox.upperX > upperX? bbox.upperX: upperX;
|
||||||
|
upperY = bbox.upperY > upperY? bbox.upperY: upperY;
|
||||||
|
upperZ = bbox.upperZ > upperZ? bbox.upperZ: upperZ;
|
||||||
|
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetDepth( float depth)
|
||||||
|
{
|
||||||
|
upperZ = lowerZ + depth;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The bounds of the box
|
||||||
|
*/
|
||||||
|
// Make these ftPoints & private
|
||||||
|
float lowerX, lowerY, lowerZ, upperX, upperY, upperZ;
|
||||||
|
protected:
|
||||||
|
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTBBox__
|
||||||
|
|
||||||
76
extern/bFTGL/include/FTBitmapGlyph.h
vendored
Normal file
76
extern/bFTGL/include/FTBitmapGlyph.h
vendored
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
#ifndef __FTBitmapGlyph__
|
||||||
|
#define __FTBitmapGlyph__
|
||||||
|
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
#include FT_GLYPH_H
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
#include "FTGlyph.h"
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTBitmapGlyph is a specialisation of FTGlyph for creating bitmaps.
|
||||||
|
*
|
||||||
|
* It provides the interface between Freetype glyphs and their openGL
|
||||||
|
* Renderable counterparts. This is an abstract class and derived classes
|
||||||
|
* must implement the <code>Render</code> function.
|
||||||
|
*
|
||||||
|
* @see FTGlyphContainer
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTBitmapGlyph : public FTGlyph
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*
|
||||||
|
* @param glyph The Freetype glyph to be processed
|
||||||
|
*/
|
||||||
|
FTBitmapGlyph( FT_GlyphSlot glyph);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FTBitmapGlyph();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders this glyph at the current pen position.
|
||||||
|
*
|
||||||
|
* @param pen The current pen position.
|
||||||
|
* @return The advance distance for this glyph.
|
||||||
|
*/
|
||||||
|
virtual float Render( const FTPoint& pen);
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* The width of the glyph 'image'
|
||||||
|
*/
|
||||||
|
unsigned int destWidth;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The height of the glyph 'image'
|
||||||
|
*/
|
||||||
|
unsigned int destHeight;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The pitch of the glyph 'image'
|
||||||
|
*/
|
||||||
|
unsigned int destPitch;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Vector from the pen position to the topleft corner of the bitmap
|
||||||
|
*/
|
||||||
|
FTPoint pos;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pointer to the 'image' data
|
||||||
|
*/
|
||||||
|
unsigned char* data;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTBitmapGlyph__
|
||||||
|
|
||||||
76
extern/bFTGL/include/FTBufferGlyph.h
vendored
Normal file
76
extern/bFTGL/include/FTBufferGlyph.h
vendored
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
#ifndef __FTBufferGlyph__
|
||||||
|
#define __FTBufferGlyph__
|
||||||
|
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
#include FT_GLYPH_H
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
#include "FTGlyph.h"
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTBufferGlyph is a specialisation of FTGlyph for creating pixmaps.
|
||||||
|
*
|
||||||
|
* @see FTGlyphContainer
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTBufferGlyph : public FTGlyph
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*
|
||||||
|
* @param glyph The Freetype glyph to be processed
|
||||||
|
*/
|
||||||
|
FTBufferGlyph( FT_GlyphSlot glyph, unsigned char* clientBuffer);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FTBufferGlyph();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders this glyph at the current pen position.
|
||||||
|
*
|
||||||
|
* @param pen The current pen position.
|
||||||
|
* @return The advance distance for this glyph.
|
||||||
|
*/
|
||||||
|
virtual float Render( const FTPoint& pen);
|
||||||
|
|
||||||
|
// attributes
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* The width of the glyph 'image'
|
||||||
|
*/
|
||||||
|
int destWidth;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The height of the glyph 'image'
|
||||||
|
*/
|
||||||
|
int destHeight;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The pitch of the glyph 'image'
|
||||||
|
*/
|
||||||
|
unsigned int destPitch;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Vector from the pen position to the topleft corner of the pixmap
|
||||||
|
*/
|
||||||
|
FTPoint pos;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pointer to the 'image' data
|
||||||
|
*/
|
||||||
|
unsigned char* data;
|
||||||
|
|
||||||
|
|
||||||
|
unsigned char* buffer;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTBufferGlyph__
|
||||||
130
extern/bFTGL/include/FTCharToGlyphIndexMap.h
vendored
Normal file
130
extern/bFTGL/include/FTCharToGlyphIndexMap.h
vendored
Normal file
@@ -0,0 +1,130 @@
|
|||||||
|
#ifndef __FTCharToGlyphIndexMap__
|
||||||
|
#define __FTCharToGlyphIndexMap__
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provides a non-STL alternative to the STL map<unsigned long, unsigned long>
|
||||||
|
* which maps character codes to glyph indices inside FTCharmap.
|
||||||
|
*
|
||||||
|
* Implementation:
|
||||||
|
* - NumberOfBuckets buckets are considered.
|
||||||
|
* - Each bucket has BucketSize entries.
|
||||||
|
* - When the glyph index for the character code C has to be stored, the
|
||||||
|
* bucket this character belongs to is found using 'C div BucketSize'.
|
||||||
|
* If this bucket has not been allocated yet, do it now.
|
||||||
|
* The entry in the bucked is found using 'C mod BucketSize'.
|
||||||
|
* If it is set to IndexNotFound, then the glyph entry has not been set.
|
||||||
|
* - Try to mimic the calls made to the STL map API.
|
||||||
|
*
|
||||||
|
* Caveats:
|
||||||
|
* - The glyph index is now a signed long instead of unsigned long, so
|
||||||
|
* the special value IndexNotFound (= -1) can be used to specify that the
|
||||||
|
* glyph index has not been stored yet.
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTCharToGlyphIndexMap
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
typedef unsigned long CharacterCode;
|
||||||
|
typedef signed long GlyphIndex;
|
||||||
|
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
NumberOfBuckets = 256,
|
||||||
|
BucketSize = 256,
|
||||||
|
IndexNotFound = -1
|
||||||
|
};
|
||||||
|
|
||||||
|
FTCharToGlyphIndexMap()
|
||||||
|
{
|
||||||
|
this->Indices = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual ~FTCharToGlyphIndexMap()
|
||||||
|
{
|
||||||
|
if( this->Indices)
|
||||||
|
{
|
||||||
|
// Free all buckets
|
||||||
|
this->clear();
|
||||||
|
|
||||||
|
// Free main structure
|
||||||
|
delete [] this->Indices;
|
||||||
|
this->Indices = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void clear()
|
||||||
|
{
|
||||||
|
if(this->Indices)
|
||||||
|
{
|
||||||
|
for( int i = 0; i < FTCharToGlyphIndexMap::NumberOfBuckets; i++)
|
||||||
|
{
|
||||||
|
if( this->Indices[i])
|
||||||
|
{
|
||||||
|
delete [] this->Indices[i];
|
||||||
|
this->Indices[i] = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const GlyphIndex find( CharacterCode c)
|
||||||
|
{
|
||||||
|
if( !this->Indices)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Find position of char code in buckets
|
||||||
|
div_t pos = div( c, FTCharToGlyphIndexMap::BucketSize);
|
||||||
|
|
||||||
|
if( !this->Indices[pos.quot])
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
const FTCharToGlyphIndexMap::GlyphIndex *ptr = &this->Indices[pos.quot][pos.rem];
|
||||||
|
if( *ptr == FTCharToGlyphIndexMap::IndexNotFound)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return *ptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
void insert( CharacterCode c, GlyphIndex g)
|
||||||
|
{
|
||||||
|
if( !this->Indices)
|
||||||
|
{
|
||||||
|
this->Indices = new GlyphIndex* [FTCharToGlyphIndexMap::NumberOfBuckets];
|
||||||
|
for( int i = 0; i < FTCharToGlyphIndexMap::NumberOfBuckets; i++)
|
||||||
|
{
|
||||||
|
this->Indices[i] = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Find position of char code in buckets
|
||||||
|
div_t pos = div(c, FTCharToGlyphIndexMap::BucketSize);
|
||||||
|
|
||||||
|
// Allocate bucket if does not exist yet
|
||||||
|
if( !this->Indices[pos.quot])
|
||||||
|
{
|
||||||
|
this->Indices[pos.quot] = new GlyphIndex [FTCharToGlyphIndexMap::BucketSize];
|
||||||
|
for( int i = 0; i < FTCharToGlyphIndexMap::BucketSize; i++)
|
||||||
|
{
|
||||||
|
this->Indices[pos.quot][i] = FTCharToGlyphIndexMap::IndexNotFound;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
this->Indices[pos.quot][pos.rem] = g;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
GlyphIndex** Indices;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTCharToGlyphIndexMap__
|
||||||
136
extern/bFTGL/include/FTCharmap.h
vendored
Normal file
136
extern/bFTGL/include/FTCharmap.h
vendored
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
#ifndef __FTCharmap__
|
||||||
|
#define __FTCharmap__
|
||||||
|
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
#include FT_GLYPH_H
|
||||||
|
|
||||||
|
#include "FTCharToGlyphIndexMap.h"
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTCharmap takes care of specifying the encoding for a font and mapping
|
||||||
|
* character codes to glyph indices.
|
||||||
|
*
|
||||||
|
* It doesn't preprocess all indices, only on an as needed basis. This may
|
||||||
|
* seem like a performance penalty but it is quicker than using the 'raw'
|
||||||
|
* freetype calls and will save significant amounts of memory when dealing
|
||||||
|
* with unicode encoding
|
||||||
|
*
|
||||||
|
* @see "Freetype 2 Documentation"
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
class FTFace;
|
||||||
|
|
||||||
|
class FTGL_EXPORT FTCharmap
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*/
|
||||||
|
FTCharmap( FTFace* face);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FTCharmap();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Queries for the current character map code.
|
||||||
|
*
|
||||||
|
* @return The current character map code.
|
||||||
|
*/
|
||||||
|
FT_Encoding Encoding() const { return ftEncoding;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the character map for the face.
|
||||||
|
* Valid encodings as at Freetype 2.0.4
|
||||||
|
* ft_encoding_none
|
||||||
|
* ft_encoding_symbol
|
||||||
|
* ft_encoding_unicode
|
||||||
|
* ft_encoding_latin_2
|
||||||
|
* ft_encoding_sjis
|
||||||
|
* ft_encoding_gb2312
|
||||||
|
* ft_encoding_big5
|
||||||
|
* ft_encoding_wansung
|
||||||
|
* ft_encoding_johab
|
||||||
|
* ft_encoding_adobe_standard
|
||||||
|
* ft_encoding_adobe_expert
|
||||||
|
* ft_encoding_adobe_custom
|
||||||
|
* ft_encoding_apple_roman
|
||||||
|
*
|
||||||
|
* @param encoding the Freetype encoding symbol. See above.
|
||||||
|
* @return <code>true</code> if charmap was valid and set
|
||||||
|
* correctly. If the requested encoding is
|
||||||
|
* unavailable it will be set to ft_encoding_none.
|
||||||
|
*/
|
||||||
|
bool CharMap( FT_Encoding encoding);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the FTGlyphContainer index of the input character.
|
||||||
|
*
|
||||||
|
* @param characterCode The character code of the requested glyph in
|
||||||
|
* the current encoding eg apple roman.
|
||||||
|
* @return The FTGlyphContainer index for the character or zero
|
||||||
|
* if it wasn't found
|
||||||
|
*/
|
||||||
|
unsigned int GlyphListIndex( const unsigned int characterCode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the font glyph index of the input character.
|
||||||
|
*
|
||||||
|
* @param characterCode The character code of the requested glyph in
|
||||||
|
* the current encoding eg apple roman.
|
||||||
|
* @return The glyph index for the character.
|
||||||
|
*/
|
||||||
|
unsigned int FontIndex( const unsigned int characterCode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the FTGlyphContainer index of the character code.
|
||||||
|
*
|
||||||
|
* @param characterCode The character code of the requested glyph in
|
||||||
|
* the current encoding eg apple roman.
|
||||||
|
* @param containerIndex The index into the FTGlyphContainer of the
|
||||||
|
* character code.
|
||||||
|
*/
|
||||||
|
void InsertIndex( const unsigned int characterCode, const unsigned int containerIndex);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Queries for errors.
|
||||||
|
*
|
||||||
|
* @return The current error code. Zero means no error.
|
||||||
|
*/
|
||||||
|
FT_Error Error() const { return err;}
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Current character map code.
|
||||||
|
*/
|
||||||
|
FT_Encoding ftEncoding;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The current Freetype face.
|
||||||
|
*/
|
||||||
|
const FT_Face ftFace;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A structure that maps glyph indices to character codes
|
||||||
|
*
|
||||||
|
* < character code, face glyph index>
|
||||||
|
*/
|
||||||
|
typedef FTCharToGlyphIndexMap CharacterMap;
|
||||||
|
CharacterMap charMap;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current error code.
|
||||||
|
*/
|
||||||
|
FT_Error err;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTCharmap__
|
||||||
88
extern/bFTGL/include/FTContour.h
vendored
Normal file
88
extern/bFTGL/include/FTContour.h
vendored
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
#ifndef __FTContour__
|
||||||
|
#define __FTContour__
|
||||||
|
|
||||||
|
#include "FTPoint.h"
|
||||||
|
#include "FTVector.h"
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTContour class is a container of points that describe a vector font
|
||||||
|
* outline. It is used as a container for the output of the bezier curve
|
||||||
|
* evaluator in FTVectoriser.
|
||||||
|
*
|
||||||
|
* @see FTOutlineGlyph
|
||||||
|
* @see FTPolyGlyph
|
||||||
|
* @see FTPoint
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTContour
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*
|
||||||
|
* @param contour
|
||||||
|
* @param pointTags
|
||||||
|
* @param numberOfPoints
|
||||||
|
*/
|
||||||
|
FTContour( FT_Vector* contour, char* pointTags, unsigned int numberOfPoints);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
~FTContour()
|
||||||
|
{
|
||||||
|
pointList.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return a point at index.
|
||||||
|
*
|
||||||
|
* @param index of the point in the curve.
|
||||||
|
* @return const point reference
|
||||||
|
*/
|
||||||
|
const FTPoint& Point( unsigned int index) const { return pointList[index];}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* How many points define this contour
|
||||||
|
*
|
||||||
|
* @return the number of points in this contour
|
||||||
|
*/
|
||||||
|
size_t PointCount() const { return pointList.size();}
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Add a point to this contour. This function tests for duplicate
|
||||||
|
* points.
|
||||||
|
*
|
||||||
|
* @param point The point to be added to the contour.
|
||||||
|
*/
|
||||||
|
inline void AddPoint( FTPoint point);
|
||||||
|
|
||||||
|
inline void AddPoint( float x, float y);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* De Casteljau (bezier) algorithm contributed by Jed Soane
|
||||||
|
* Evaluates a quadratic or conic (second degree) curve
|
||||||
|
*/
|
||||||
|
inline void evaluateQuadraticCurve();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* De Casteljau (bezier) algorithm contributed by Jed Soane
|
||||||
|
* Evaluates a cubic (third degree) curve
|
||||||
|
*/
|
||||||
|
inline void evaluateCubicCurve();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The list of points in this contour
|
||||||
|
*/
|
||||||
|
typedef FTVector<FTPoint> PointVector;
|
||||||
|
PointVector pointList;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 2D array storing values of de Casteljau algorithm.
|
||||||
|
*/
|
||||||
|
float controlPoints[4][2];
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // __FTContour__
|
||||||
71
extern/bFTGL/include/FTExtrdGlyph.h
vendored
Normal file
71
extern/bFTGL/include/FTExtrdGlyph.h
vendored
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
#ifndef __FTExtrdGlyph__
|
||||||
|
#define __FTExtrdGlyph__
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
#include FT_GLYPH_H
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
#include "FTGlyph.h"
|
||||||
|
|
||||||
|
class FTVectoriser;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTExtrdGlyph is a specialisation of FTGlyph for creating tessellated
|
||||||
|
* extruded polygon glyphs.
|
||||||
|
*
|
||||||
|
* @see FTGlyphContainer
|
||||||
|
* @see FTVectoriser
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTExtrdGlyph : public FTGlyph
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor. Sets the Error to Invalid_Outline if the glyphs isn't an outline.
|
||||||
|
*
|
||||||
|
* @param glyph The Freetype glyph to be processed
|
||||||
|
* @param depth The distance along the z axis to extrude the glyph
|
||||||
|
*/
|
||||||
|
FTExtrdGlyph( FT_GlyphSlot glyph, float depth);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FTExtrdGlyph();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders this glyph at the current pen position.
|
||||||
|
*
|
||||||
|
* @param pen The current pen position.
|
||||||
|
* @return The advance distance for this glyph.
|
||||||
|
*/
|
||||||
|
virtual float Render( const FTPoint& pen);
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Calculate the normal vector to 2 points. This is 2D and ignores
|
||||||
|
* the z component. The normal will be normalised
|
||||||
|
*
|
||||||
|
* @param a
|
||||||
|
* @param b
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
FTPoint GetNormal( const FTPoint &a, const FTPoint &b);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* OpenGL display list
|
||||||
|
*/
|
||||||
|
GLuint glList;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Distance to extrude the glyph
|
||||||
|
*/
|
||||||
|
float depth;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTExtrdGlyph__
|
||||||
|
|
||||||
149
extern/bFTGL/include/FTFace.h
vendored
Normal file
149
extern/bFTGL/include/FTFace.h
vendored
Normal file
@@ -0,0 +1,149 @@
|
|||||||
|
#ifndef __FTFace__
|
||||||
|
#define __FTFace__
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
#include FT_GLYPH_H
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
#include "FTPoint.h"
|
||||||
|
#include "FTSize.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTFace class provides an abstraction layer for the Freetype Face.
|
||||||
|
*
|
||||||
|
* @see "Freetype 2 Documentation"
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTFace
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Opens and reads a face file. Error is set.
|
||||||
|
*
|
||||||
|
* @param filename font file name.
|
||||||
|
*/
|
||||||
|
FTFace( const char* filename);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Read face data from an in-memory buffer. Error is set.
|
||||||
|
*
|
||||||
|
* @param pBufferBytes the in-memory buffer
|
||||||
|
* @param bufferSizeInBytes the length of the buffer in bytes
|
||||||
|
*/
|
||||||
|
FTFace( const unsigned char *pBufferBytes, size_t bufferSizeInBytes );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*
|
||||||
|
* Disposes of the current Freetype Face.
|
||||||
|
*/
|
||||||
|
virtual ~FTFace();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Attach auxilliary file to font (e.g., font metrics).
|
||||||
|
*
|
||||||
|
* @param filename auxilliary font file name.
|
||||||
|
* @return <code>true</code> if file has opened
|
||||||
|
* successfully.
|
||||||
|
*/
|
||||||
|
bool Attach( const char* filename);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Attach auxilliary data to font (e.g., font metrics) from memory
|
||||||
|
*
|
||||||
|
* @param pBufferBytes the in-memory buffer
|
||||||
|
* @param bufferSizeInBytes the length of the buffer in bytes
|
||||||
|
* @return <code>true</code> if file has opened
|
||||||
|
* successfully.
|
||||||
|
*/
|
||||||
|
bool Attach( const unsigned char *pBufferBytes, size_t bufferSizeInBytes);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Disposes of the face
|
||||||
|
*/
|
||||||
|
void Close();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the freetype face object..
|
||||||
|
*
|
||||||
|
* @return pointer to an FT_Face.
|
||||||
|
*/
|
||||||
|
FT_Face* Face() const { return ftFace;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the char size for the current face.
|
||||||
|
*
|
||||||
|
* This doesn't guarantee that the size was set correctly. Clients
|
||||||
|
* should check errors.
|
||||||
|
*
|
||||||
|
* @param size the face size in points (1/72 inch)
|
||||||
|
* @param res the resolution of the target device.
|
||||||
|
* @return <code>FTSize</code> object
|
||||||
|
*/
|
||||||
|
const FTSize& Size( const unsigned int size, const unsigned int res);
|
||||||
|
|
||||||
|
unsigned int UnitsPerEM() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the number of character maps in this face.
|
||||||
|
*
|
||||||
|
* @return character map count.
|
||||||
|
*/
|
||||||
|
unsigned int CharMapCount();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a list of character maps in this face.
|
||||||
|
*
|
||||||
|
* @return pointer to the first encoding.
|
||||||
|
*/
|
||||||
|
FT_Encoding* CharMapList();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the kerning vector between two glyphs
|
||||||
|
*/
|
||||||
|
FTPoint KernAdvance( unsigned int index1, unsigned int index2);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Loads and creates a Freetype glyph.
|
||||||
|
*/
|
||||||
|
FT_GlyphSlot Glyph( unsigned int index, FT_Int load_flags);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the number of glyphs in the current face.
|
||||||
|
*/
|
||||||
|
unsigned int GlyphCount() const { return numGlyphs;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Queries for errors.
|
||||||
|
*
|
||||||
|
* @return The current error code.
|
||||||
|
*/
|
||||||
|
FT_Error Error() const { return err; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* The Freetype face
|
||||||
|
*/
|
||||||
|
FT_Face* ftFace;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The size object associated with this face
|
||||||
|
*/
|
||||||
|
FTSize charSize;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The number of glyphs in this face
|
||||||
|
*/
|
||||||
|
int numGlyphs;
|
||||||
|
|
||||||
|
FT_Encoding* fontEncodingList;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current error code. Zero means no error.
|
||||||
|
*/
|
||||||
|
FT_Error err;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTFace__
|
||||||
260
extern/bFTGL/include/FTFont.h
vendored
Normal file
260
extern/bFTGL/include/FTFont.h
vendored
Normal file
@@ -0,0 +1,260 @@
|
|||||||
|
#ifndef __FTFont__
|
||||||
|
#define __FTFont__
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
|
||||||
|
#include "FTFace.h"
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
class FTGlyphContainer;
|
||||||
|
class FTGlyph;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTFont is the public interface for the FTGL library.
|
||||||
|
*
|
||||||
|
* Specific font classes are derived from this class. It uses the helper
|
||||||
|
* classes FTFace and FTSize to access the Freetype library. This class
|
||||||
|
* is abstract and deriving classes must implement the protected
|
||||||
|
* <code>MakeGlyph</code> function to create glyphs of the
|
||||||
|
* appropriate type.
|
||||||
|
*
|
||||||
|
* It is good practice after using these functions to test the error
|
||||||
|
* code returned. <code>FT_Error Error()</code>
|
||||||
|
*
|
||||||
|
* @see FTFace
|
||||||
|
* @see FTSize
|
||||||
|
* @see FTGlyphContainer
|
||||||
|
* @see FTGlyph
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTFont
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Open and read a font file. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param fontname font file name.
|
||||||
|
*/
|
||||||
|
FTFont( const char* fontname);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Open and read a font from a buffer in memory. Sets Error flag.
|
||||||
|
* The buffer is owned by the client and is NOT copied by FTGL. The
|
||||||
|
* pointer must be valid while using FTGL.
|
||||||
|
*
|
||||||
|
* @param pBufferBytes the in-memory buffer
|
||||||
|
* @param bufferSizeInBytes the length of the buffer in bytes
|
||||||
|
*/
|
||||||
|
FTFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FTFont();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Attach auxilliary file to font e.g font metrics.
|
||||||
|
*
|
||||||
|
* Note: not all font formats implement this function.
|
||||||
|
*
|
||||||
|
* @param filename auxilliary font file name.
|
||||||
|
* @return <code>true</code> if file has been attached
|
||||||
|
* successfully.
|
||||||
|
*/
|
||||||
|
bool Attach( const char* filename);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Attach auxilliary data to font e.g font metrics, from memory
|
||||||
|
*
|
||||||
|
* Note: not all font formats implement this function.
|
||||||
|
*
|
||||||
|
* @param pBufferBytes the in-memory buffer
|
||||||
|
* @param bufferSizeInBytes the length of the buffer in bytes
|
||||||
|
* @return <code>true</code> if file has been attached
|
||||||
|
* successfully.
|
||||||
|
*/
|
||||||
|
bool Attach( const unsigned char *pBufferBytes, size_t bufferSizeInBytes);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the character map for the face.
|
||||||
|
*
|
||||||
|
* @param encoding Freetype enumerate for char map code.
|
||||||
|
* @return <code>true</code> if charmap was valid and
|
||||||
|
* set correctly
|
||||||
|
*/
|
||||||
|
bool CharMap( FT_Encoding encoding );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the number of character maps in this face.
|
||||||
|
*
|
||||||
|
* @return character map count.
|
||||||
|
*/
|
||||||
|
unsigned int CharMapCount();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a list of character maps in this face.
|
||||||
|
*
|
||||||
|
* @return pointer to the first encoding.
|
||||||
|
*/
|
||||||
|
FT_Encoding* CharMapList();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the char size for the current face.
|
||||||
|
*
|
||||||
|
* @param size the face size in points (1/72 inch)
|
||||||
|
* @param res the resolution of the target device.
|
||||||
|
* @return <code>true</code> if size was set correctly
|
||||||
|
*/
|
||||||
|
virtual bool FaceSize( const unsigned int size, const unsigned int res = 72);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the current face size in points.
|
||||||
|
*
|
||||||
|
* @return face size
|
||||||
|
*/
|
||||||
|
unsigned int FaceSize() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the extrusion distance for the font. Only implemented by
|
||||||
|
* FTGLExtrdFont
|
||||||
|
*
|
||||||
|
* @param d The extrusion distance.
|
||||||
|
*/
|
||||||
|
virtual void Depth( float d){}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the global ascender height for the face.
|
||||||
|
*
|
||||||
|
* @return Ascender height
|
||||||
|
*/
|
||||||
|
float Ascender() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the global descender height for the face.
|
||||||
|
*
|
||||||
|
* @return Descender height
|
||||||
|
*/
|
||||||
|
float Descender() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the bounding box for a string.
|
||||||
|
*
|
||||||
|
* @param string a char string
|
||||||
|
* @param llx lower left near x coord
|
||||||
|
* @param lly lower left near y coord
|
||||||
|
* @param llz lower left near z coord
|
||||||
|
* @param urx upper right far x coord
|
||||||
|
* @param ury upper right far y coord
|
||||||
|
* @param urz upper right far z coord
|
||||||
|
*/
|
||||||
|
void BBox( const char* string, float& llx, float& lly, float& llz, float& urx, float& ury, float& urz);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the bounding box for a string.
|
||||||
|
*
|
||||||
|
* @param string a wchar_t string
|
||||||
|
* @param llx lower left near x coord
|
||||||
|
* @param lly lower left near y coord
|
||||||
|
* @param llz lower left near z coord
|
||||||
|
* @param urx upper right far x coord
|
||||||
|
* @param ury upper right far y coord
|
||||||
|
* @param urz upper right far z coord
|
||||||
|
*/
|
||||||
|
void BBox( const wchar_t* string, float& llx, float& lly, float& llz, float& urx, float& ury, float& urz);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the advance width for a string.
|
||||||
|
*
|
||||||
|
* @param string a wchar_t string
|
||||||
|
* @return advance width
|
||||||
|
*/
|
||||||
|
float Advance( const wchar_t* string);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the advance width for a string.
|
||||||
|
*
|
||||||
|
* @param string a char string
|
||||||
|
* @return advance width
|
||||||
|
*/
|
||||||
|
float Advance( const char* string);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Render a string of characters
|
||||||
|
*
|
||||||
|
* @param string 'C' style string to be output.
|
||||||
|
*/
|
||||||
|
virtual void Render( const char* string );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Render a string of characters
|
||||||
|
*
|
||||||
|
* @param string wchar_t string to be output.
|
||||||
|
*/
|
||||||
|
virtual void Render( const wchar_t* string );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Queries the Font for errors.
|
||||||
|
*
|
||||||
|
* @return The current error code.
|
||||||
|
*/
|
||||||
|
FT_Error Error() const { return err;}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
/**
|
||||||
|
* Construct a glyph of the correct type.
|
||||||
|
*
|
||||||
|
* Clients must overide the function and return their specialised
|
||||||
|
* FTGlyph.
|
||||||
|
*
|
||||||
|
* @param g The glyph index NOT the char code.
|
||||||
|
* @return An FT****Glyph or <code>null</code> on failure.
|
||||||
|
*/
|
||||||
|
virtual FTGlyph* MakeGlyph( unsigned int g) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current face object
|
||||||
|
*/
|
||||||
|
FTFace face;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current size object
|
||||||
|
*/
|
||||||
|
FTSize charSize;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current error code. Zero means no error.
|
||||||
|
*/
|
||||||
|
FT_Error err;
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Render a character
|
||||||
|
* This function does an implicit conversion on it's arguments.
|
||||||
|
*
|
||||||
|
* @param chr current character
|
||||||
|
* @param nextChr next character
|
||||||
|
*/
|
||||||
|
inline void DoRender( const unsigned int chr, const unsigned int nextChr);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check that the glyph at <code>chr</code> exist. If not load it.
|
||||||
|
*
|
||||||
|
* @param chr character index
|
||||||
|
*/
|
||||||
|
inline void CheckGlyph( const unsigned int chr);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An object that holds a list of glyphs
|
||||||
|
*/
|
||||||
|
FTGlyphContainer* glyphList;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current pen or cursor position;
|
||||||
|
*/
|
||||||
|
FTPoint pen;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTFont__
|
||||||
|
|
||||||
96
extern/bFTGL/include/FTGL.h
vendored
Normal file
96
extern/bFTGL/include/FTGL.h
vendored
Normal file
@@ -0,0 +1,96 @@
|
|||||||
|
#ifndef __FTGL__
|
||||||
|
#define __FTGL__
|
||||||
|
|
||||||
|
|
||||||
|
typedef double FTGL_DOUBLE;
|
||||||
|
typedef float FTGL_FLOAT;
|
||||||
|
|
||||||
|
// Fixes for deprecated identifiers in 2.1.5
|
||||||
|
#ifndef FT_OPEN_MEMORY
|
||||||
|
#define FT_OPEN_MEMORY (FT_Open_Flags)1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef FT_RENDER_MODE_MONO
|
||||||
|
#define FT_RENDER_MODE_MONO ft_render_mode_mono
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef FT_RENDER_MODE_NORMAL
|
||||||
|
#define FT_RENDER_MODE_NORMAL ft_render_mode_normal
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef WIN32
|
||||||
|
|
||||||
|
// Under windows avoid including <windows.h> is overrated.
|
||||||
|
// Sure, it can be avoided and "name space pollution" can be
|
||||||
|
// avoided, but why? It really doesn't make that much difference
|
||||||
|
// these days.
|
||||||
|
#define WIN32_LEAN_AND_MEAN
|
||||||
|
#include <windows.h>
|
||||||
|
|
||||||
|
#ifndef __gl_h_
|
||||||
|
#include <GL/gl.h>
|
||||||
|
#include <GL/glu.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
// Non windows platforms - don't require nonsense as seen above :-)
|
||||||
|
#ifndef __gl_h_
|
||||||
|
#ifdef __APPLE_CC__
|
||||||
|
#include <OpenGL/gl.h>
|
||||||
|
#include <OpenGL/glu.h>
|
||||||
|
#else
|
||||||
|
#include <GL/gl.h>
|
||||||
|
#include <GL/glu.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// Required for compatibility with glext.h style function definitions of
|
||||||
|
// OpenGL extensions, such as in src/osg/Point.cpp.
|
||||||
|
#ifndef APIENTRY
|
||||||
|
#define APIENTRY
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// Compiler-specific conditional compilation
|
||||||
|
#ifdef _MSC_VER // MS Visual C++
|
||||||
|
|
||||||
|
// Disable various warning.
|
||||||
|
// 4786: template name too long
|
||||||
|
#pragma warning( disable : 4251 )
|
||||||
|
#pragma warning( disable : 4275 )
|
||||||
|
#pragma warning( disable : 4786 )
|
||||||
|
|
||||||
|
// The following definitions control how symbols are exported.
|
||||||
|
// If the target is a static library ensure that FTGL_LIBRARY_STATIC
|
||||||
|
// is defined. If building a dynamic library (ie DLL) ensure the
|
||||||
|
// FTGL_LIBRARY macro is defined, as it will mark symbols for
|
||||||
|
// export. If compiling a project to _use_ the _dynamic_ library
|
||||||
|
// version of the library, no definition is required.
|
||||||
|
#ifdef FTGL_LIBRARY_STATIC // static lib - no special export required
|
||||||
|
# define FTGL_EXPORT
|
||||||
|
#elif FTGL_LIBRARY // dynamic lib - must export/import symbols appropriately.
|
||||||
|
# define FTGL_EXPORT __declspec(dllexport)
|
||||||
|
#else
|
||||||
|
# define FTGL_EXPORT __declspec(dllimport)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#else
|
||||||
|
// Compiler that is not MS Visual C++.
|
||||||
|
// Ensure that the export symbol is defined (and blank)
|
||||||
|
#define FTGL_EXPORT
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
// lifted from glext.h, to remove dependancy on glext.h
|
||||||
|
#ifndef GL_EXT_texture_object
|
||||||
|
#define GL_TEXTURE_PRIORITY_EXT 0x8066
|
||||||
|
#define GL_TEXTURE_RESIDENT_EXT 0x8067
|
||||||
|
#define GL_TEXTURE_1D_BINDING_EXT 0x8068
|
||||||
|
#define GL_TEXTURE_2D_BINDING_EXT 0x8069
|
||||||
|
#define GL_TEXTURE_3D_BINDING_EXT 0x806A
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // __FTGL__
|
||||||
65
extern/bFTGL/include/FTGLBitmapFont.h
vendored
Normal file
65
extern/bFTGL/include/FTGLBitmapFont.h
vendored
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
#ifndef __FTGLBitmapFont__
|
||||||
|
#define __FTGLBitmapFont__
|
||||||
|
|
||||||
|
#include "FTFont.h"
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
|
||||||
|
class FTGlyph;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTGLBitmapFont is a specialisation of the FTFont class for handling
|
||||||
|
* Bitmap fonts
|
||||||
|
*
|
||||||
|
* @see FTFont
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTGLBitmapFont : public FTFont
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Open and read a font file. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param fontname font file name.
|
||||||
|
*/
|
||||||
|
FTGLBitmapFont( const char* fontname);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Open and read a font from a buffer in memory. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param pBufferBytes the in-memory buffer
|
||||||
|
* @param bufferSizeInBytes the length of the buffer in bytes
|
||||||
|
*/
|
||||||
|
FTGLBitmapFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
~FTGLBitmapFont();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders a string of characters
|
||||||
|
*
|
||||||
|
* @param string 'C' style string to be output.
|
||||||
|
*/
|
||||||
|
void Render( const char* string);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders a string of characters
|
||||||
|
*
|
||||||
|
* @param string 'C' style wide string to be output.
|
||||||
|
*/
|
||||||
|
void Render( const wchar_t* string);
|
||||||
|
|
||||||
|
// attributes
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Construct a FTBitmapGlyph.
|
||||||
|
*
|
||||||
|
* @param g The glyph index NOT the char code.
|
||||||
|
* @return An FTBitmapGlyph or <code>null</code> on failure.
|
||||||
|
*/
|
||||||
|
inline virtual FTGlyph* MakeGlyph( unsigned int g);
|
||||||
|
|
||||||
|
};
|
||||||
|
#endif // __FTGLBitmapFont__
|
||||||
76
extern/bFTGL/include/FTGLBufferFont.h
vendored
Normal file
76
extern/bFTGL/include/FTGLBufferFont.h
vendored
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
#ifndef __FTGLBufferFont__
|
||||||
|
#define __FTGLBufferFont__
|
||||||
|
|
||||||
|
|
||||||
|
#include "FTFont.h"
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
|
||||||
|
class FTGlyph;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTGLBufferFont is a specialisation of the FTFont class for handling
|
||||||
|
* Pixmap (Grey Scale) fonts
|
||||||
|
*
|
||||||
|
* @see FTFont
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTGLBufferFont : public FTFont
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Open and read a font file. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param fontname font file name.
|
||||||
|
*/
|
||||||
|
FTGLBufferFont( const char* fontname);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Open and read a font from a buffer in memory. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param pBufferBytes the in-memory buffer
|
||||||
|
* @param bufferSizeInBytes the length of the buffer in bytes
|
||||||
|
*/
|
||||||
|
FTGLBufferFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes);
|
||||||
|
|
||||||
|
|
||||||
|
void SetClientBuffer( unsigned char* b)
|
||||||
|
{
|
||||||
|
buffer = b;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
~FTGLBufferFont();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders a string of characters
|
||||||
|
*
|
||||||
|
* @param string 'C' style string to be output.
|
||||||
|
*/
|
||||||
|
void Render( const char* string);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders a string of characters
|
||||||
|
*
|
||||||
|
* @param string wchar_t string to be output.
|
||||||
|
*/
|
||||||
|
void Render( const wchar_t* string);
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Construct a FTBufferGlyph.
|
||||||
|
*
|
||||||
|
* @param g The glyph index NOT the char code.
|
||||||
|
* @return An FTBufferGlyph or <code>null</code> on failure.
|
||||||
|
*/
|
||||||
|
inline virtual FTGlyph* MakeGlyph( unsigned int g);
|
||||||
|
|
||||||
|
unsigned char* buffer;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTGLBufferFont__
|
||||||
|
|
||||||
55
extern/bFTGL/include/FTGLExtrdFont.h
vendored
Normal file
55
extern/bFTGL/include/FTGLExtrdFont.h
vendored
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
#ifndef __FTGLExtrdFont__
|
||||||
|
#define __FTGLExtrdFont__
|
||||||
|
|
||||||
|
#include "FTFont.h"
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
class FTGlyph;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTGLExtrdFont is a specialisation of the FTFont class for handling
|
||||||
|
* extruded Polygon fonts
|
||||||
|
*
|
||||||
|
* @see FTFont
|
||||||
|
* @see FTGLPolygonFont
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTGLExtrdFont : public FTFont
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Open and read a font file. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param fontname font file name.
|
||||||
|
*/
|
||||||
|
FTGLExtrdFont( const char* fontname);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Open and read a font from a buffer in memory. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param pBufferBytes the in-memory buffer
|
||||||
|
* @param bufferSizeInBytes the length of the buffer in bytes
|
||||||
|
*/
|
||||||
|
FTGLExtrdFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
~FTGLExtrdFont();
|
||||||
|
|
||||||
|
void Depth( float d) { depth = d;}
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Construct a FTPolyGlyph.
|
||||||
|
*
|
||||||
|
* @param glyphIndex The glyph index NOT the char code.
|
||||||
|
* @return An FTExtrdGlyph or <code>null</code> on failure.
|
||||||
|
*/
|
||||||
|
inline virtual FTGlyph* MakeGlyph( unsigned int glyphIndex);
|
||||||
|
|
||||||
|
float depth;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTGLExtrdFont__
|
||||||
|
|
||||||
64
extern/bFTGL/include/FTGLOutlineFont.h
vendored
Normal file
64
extern/bFTGL/include/FTGLOutlineFont.h
vendored
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
#ifndef __FTGLOutlineFont__
|
||||||
|
#define __FTGLOutlineFont__
|
||||||
|
|
||||||
|
|
||||||
|
#include "FTFont.h"
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
class FTGlyph;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTGLOutlineFont is a specialisation of the FTFont class for handling
|
||||||
|
* Vector Outline fonts
|
||||||
|
*
|
||||||
|
* @see FTFont
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTGLOutlineFont : public FTFont
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Open and read a font file. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param fontname font file name.
|
||||||
|
*/
|
||||||
|
FTGLOutlineFont( const char* fontname);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Open and read a font from a buffer in memory. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param pBufferBytes the in-memory buffer
|
||||||
|
* @param bufferSizeInBytes the length of the buffer in bytes
|
||||||
|
*/
|
||||||
|
FTGLOutlineFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
~FTGLOutlineFont();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders a string of characters
|
||||||
|
*
|
||||||
|
* @param string 'C' style string to be output.
|
||||||
|
*/
|
||||||
|
void Render( const char* string);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders a string of characters
|
||||||
|
*
|
||||||
|
* @param string wchar_t string to be output.
|
||||||
|
*/
|
||||||
|
void Render( const wchar_t* string);
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Construct a FTOutlineGlyph.
|
||||||
|
*
|
||||||
|
* @param g The glyph index NOT the char code.
|
||||||
|
* @return An FTOutlineGlyph or <code>null</code> on failure.
|
||||||
|
*/
|
||||||
|
inline virtual FTGlyph* MakeGlyph( unsigned int g);
|
||||||
|
|
||||||
|
};
|
||||||
|
#endif // __FTGLOutlineFont__
|
||||||
68
extern/bFTGL/include/FTGLPixmapFont.h
vendored
Normal file
68
extern/bFTGL/include/FTGLPixmapFont.h
vendored
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
#ifndef __FTGLPixmapFont__
|
||||||
|
#define __FTGLPixmapFont__
|
||||||
|
|
||||||
|
|
||||||
|
#include "FTFont.h"
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
|
||||||
|
class FTGlyph;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTGLPixmapFont is a specialisation of the FTFont class for handling
|
||||||
|
* Pixmap (Grey Scale) fonts
|
||||||
|
*
|
||||||
|
* @see FTFont
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTGLPixmapFont : public FTFont
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Open and read a font file. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param fontname font file name.
|
||||||
|
*/
|
||||||
|
FTGLPixmapFont( const char* fontname);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Open and read a font from a buffer in memory. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param pBufferBytes the in-memory buffer
|
||||||
|
* @param bufferSizeInBytes the length of the buffer in bytes
|
||||||
|
*/
|
||||||
|
FTGLPixmapFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
~FTGLPixmapFont();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders a string of characters
|
||||||
|
*
|
||||||
|
* @param string 'C' style string to be output.
|
||||||
|
*/
|
||||||
|
void Render( const char* string);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders a string of characters
|
||||||
|
*
|
||||||
|
* @param string wchar_t string to be output.
|
||||||
|
*/
|
||||||
|
void Render( const wchar_t* string);
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Construct a FTPixmapGlyph.
|
||||||
|
*
|
||||||
|
* @param g The glyph index NOT the char code.
|
||||||
|
* @return An FTPixmapGlyph or <code>null</code> on failure.
|
||||||
|
*/
|
||||||
|
inline virtual FTGlyph* MakeGlyph( unsigned int g);
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTGLPixmapFont__
|
||||||
|
|
||||||
53
extern/bFTGL/include/FTGLPolygonFont.h
vendored
Normal file
53
extern/bFTGL/include/FTGLPolygonFont.h
vendored
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
#ifndef __FTGLPolygonFont__
|
||||||
|
#define __FTGLPolygonFont__
|
||||||
|
|
||||||
|
|
||||||
|
#include "FTFont.h"
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
class FTGlyph;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTGLPolygonFont is a specialisation of the FTFont class for handling
|
||||||
|
* tesselated Polygon Mesh fonts
|
||||||
|
*
|
||||||
|
* @see FTFont
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTGLPolygonFont : public FTFont
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Open and read a font file. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param fontname font file name.
|
||||||
|
*/
|
||||||
|
FTGLPolygonFont( const char* fontname);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Open and read a font from a buffer in memory. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param pBufferBytes the in-memory buffer
|
||||||
|
* @param bufferSizeInBytes the length of the buffer in bytes
|
||||||
|
*/
|
||||||
|
FTGLPolygonFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
~FTGLPolygonFont();
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Construct a FTPolyGlyph.
|
||||||
|
*
|
||||||
|
* @param g The glyph index NOT the char code.
|
||||||
|
* @return An FTPolyGlyph or <code>null</code> on failure.
|
||||||
|
*/
|
||||||
|
inline virtual FTGlyph* MakeGlyph( unsigned int g);
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTGLPolygonFont__
|
||||||
|
|
||||||
151
extern/bFTGL/include/FTGLTextureFont.h
vendored
Normal file
151
extern/bFTGL/include/FTGLTextureFont.h
vendored
Normal file
@@ -0,0 +1,151 @@
|
|||||||
|
#ifndef __FTGLTextureFont__
|
||||||
|
#define __FTGLTextureFont__
|
||||||
|
|
||||||
|
#include "FTFont.h"
|
||||||
|
#include "FTVector.h"
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
class FTTextureGlyph;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTGLTextureFont is a specialisation of the FTFont class for handling
|
||||||
|
* Texture mapped fonts
|
||||||
|
*
|
||||||
|
* @see FTFont
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTGLTextureFont : public FTFont
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Open and read a font file. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param fontname font file name.
|
||||||
|
*/
|
||||||
|
FTGLTextureFont( const char* fontname);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Open and read a font from a buffer in memory. Sets Error flag.
|
||||||
|
*
|
||||||
|
* @param pBufferBytes the in-memory buffer
|
||||||
|
* @param bufferSizeInBytes the length of the buffer in bytes
|
||||||
|
*/
|
||||||
|
FTGLTextureFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FTGLTextureFont();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the char size for the current face.
|
||||||
|
*
|
||||||
|
* @param size the face size in points (1/72 inch)
|
||||||
|
* @param res the resolution of the target device.
|
||||||
|
* @return <code>true</code> if size was set correctly
|
||||||
|
*/
|
||||||
|
virtual bool FaceSize( const unsigned int size, const unsigned int res = 72);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders a string of characters
|
||||||
|
*
|
||||||
|
* @param string 'C' style string to be output.
|
||||||
|
*/
|
||||||
|
virtual void Render( const char* string);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders a string of characters
|
||||||
|
*
|
||||||
|
* @param string wchar_t string to be output.
|
||||||
|
*/
|
||||||
|
virtual void Render( const wchar_t* string);
|
||||||
|
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Construct a FTTextureGlyph.
|
||||||
|
*
|
||||||
|
* @param glyphIndex The glyph index NOT the char code.
|
||||||
|
* @return An FTTextureGlyph or <code>null</code> on failure.
|
||||||
|
*/
|
||||||
|
inline virtual FTGlyph* MakeGlyph( unsigned int glyphIndex);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the size of a block of memory required to layout the glyphs
|
||||||
|
*
|
||||||
|
* Calculates a width and height based on the glyph sizes and the
|
||||||
|
* number of glyphs. It over estimates.
|
||||||
|
*/
|
||||||
|
inline void CalculateTextureSize();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a 'blank' OpenGL texture object.
|
||||||
|
*
|
||||||
|
* The format is GL_ALPHA and the params are
|
||||||
|
* GL_TEXTURE_WRAP_S = GL_CLAMP
|
||||||
|
* GL_TEXTURE_WRAP_T = GL_CLAMP
|
||||||
|
* GL_TEXTURE_MAG_FILTER = GL_LINEAR
|
||||||
|
* GL_TEXTURE_MIN_FILTER = GL_LINEAR
|
||||||
|
* Note that mipmapping is NOT used
|
||||||
|
*/
|
||||||
|
inline GLuint CreateTexture();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The maximum texture dimension on this OpenGL implemetation
|
||||||
|
*/
|
||||||
|
GLsizei maxTextSize;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The minimum texture width required to hold the glyphs
|
||||||
|
*/
|
||||||
|
GLsizei textureWidth;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The minimum texture height required to hold the glyphs
|
||||||
|
*/
|
||||||
|
GLsizei textureHeight;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*An array of texture ids
|
||||||
|
*/
|
||||||
|
FTVector<GLuint> textureIDList;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The max height for glyphs in the current font
|
||||||
|
*/
|
||||||
|
int glyphHeight;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The max width for glyphs in the current font
|
||||||
|
*/
|
||||||
|
int glyphWidth;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A value to be added to the height and width to ensure that
|
||||||
|
* glyphs don't overlap in the texture
|
||||||
|
*/
|
||||||
|
unsigned int padding;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
unsigned int numGlyphs;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*/
|
||||||
|
unsigned int remGlyphs;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*/
|
||||||
|
int xOffset;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*/
|
||||||
|
int yOffset;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTGLTextureFont__
|
||||||
|
|
||||||
|
|
||||||
89
extern/bFTGL/include/FTGlyph.h
vendored
Normal file
89
extern/bFTGL/include/FTGlyph.h
vendored
Normal file
@@ -0,0 +1,89 @@
|
|||||||
|
#ifndef __FTGlyph__
|
||||||
|
#define __FTGlyph__
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
#include FT_GLYPH_H
|
||||||
|
|
||||||
|
#include "FTBBox.h"
|
||||||
|
#include "FTPoint.h"
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTGlyph is the base class for FTGL glyphs.
|
||||||
|
*
|
||||||
|
* It provides the interface between Freetype glyphs and their openGL
|
||||||
|
* renderable counterparts. This is an abstract class and derived classes
|
||||||
|
* must implement the <code>render</code> function.
|
||||||
|
*
|
||||||
|
* @see FTGlyphContainer
|
||||||
|
* @see FTBBox
|
||||||
|
* @see FTPoint
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTGlyph
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*/
|
||||||
|
FTGlyph( FT_GlyphSlot glyph);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FTGlyph();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders this glyph at the current pen position.
|
||||||
|
*
|
||||||
|
* @param pen The current pen position.
|
||||||
|
* @return The advance distance for this glyph.
|
||||||
|
*/
|
||||||
|
virtual float Render( const FTPoint& pen) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the advance width for this glyph.
|
||||||
|
*
|
||||||
|
* @return advance width.
|
||||||
|
*/
|
||||||
|
float Advance() const { return advance;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the bounding box for this glyph.
|
||||||
|
*
|
||||||
|
* @return bounding box.
|
||||||
|
*/
|
||||||
|
const FTBBox& BBox() const { return bBox;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Queries for errors.
|
||||||
|
*
|
||||||
|
* @return The current error code.
|
||||||
|
*/
|
||||||
|
FT_Error Error() const { return err;}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
/**
|
||||||
|
* The advance distance for this glyph
|
||||||
|
*/
|
||||||
|
float advance;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The bounding box of this glyph.
|
||||||
|
*/
|
||||||
|
FTBBox bBox;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current error code. Zero means no error.
|
||||||
|
*/
|
||||||
|
FT_Error err;
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTGlyph__
|
||||||
|
|
||||||
127
extern/bFTGL/include/FTGlyphContainer.h
vendored
Normal file
127
extern/bFTGL/include/FTGlyphContainer.h
vendored
Normal file
@@ -0,0 +1,127 @@
|
|||||||
|
#ifndef __FTGlyphContainer__
|
||||||
|
#define __FTGlyphContainer__
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
#include FT_GLYPH_H
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
#include "FTBBox.h"
|
||||||
|
#include "FTPoint.h"
|
||||||
|
#include "FTVector.h"
|
||||||
|
|
||||||
|
class FTFace;
|
||||||
|
class FTGlyph;
|
||||||
|
class FTCharmap;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTGlyphContainer holds the post processed FTGlyph objects.
|
||||||
|
*
|
||||||
|
* @see FTGlyph
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTGlyphContainer
|
||||||
|
{
|
||||||
|
typedef FTVector<FTGlyph*> GlyphVector;
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*
|
||||||
|
* @param face The Freetype face
|
||||||
|
*/
|
||||||
|
FTGlyphContainer( FTFace* face);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
~FTGlyphContainer();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the character map for the face.
|
||||||
|
*
|
||||||
|
* @param encoding the Freetype encoding symbol. See above.
|
||||||
|
* @return <code>true</code> if charmap was valid
|
||||||
|
* and set correctly
|
||||||
|
*/
|
||||||
|
bool CharMap( FT_Encoding encoding);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the font index of the input character.
|
||||||
|
*
|
||||||
|
* @param characterCode The character code of the requested glyph in the
|
||||||
|
* current encoding eg apple roman.
|
||||||
|
* @return The font index for the character.
|
||||||
|
*/
|
||||||
|
unsigned int FontIndex( const unsigned int characterCode ) const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds a glyph to this glyph list.
|
||||||
|
*
|
||||||
|
* @param glyph The FTGlyph to be inserted into the container
|
||||||
|
* @param characterCode The char code of the glyph NOT the glyph index.
|
||||||
|
*/
|
||||||
|
void Add( FTGlyph* glyph, const unsigned int characterCode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a glyph from the glyph list
|
||||||
|
*
|
||||||
|
* @param characterCode The char code of the glyph NOT the glyph index
|
||||||
|
* @return An FTGlyph or <code>null</code> is it hasn't been
|
||||||
|
* loaded.
|
||||||
|
*/
|
||||||
|
const FTGlyph* const Glyph( const unsigned int characterCode) const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the bounding box for a character.
|
||||||
|
* @param characterCode The char code of the glyph NOT the glyph index
|
||||||
|
*/
|
||||||
|
FTBBox BBox( const unsigned int characterCode) const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the kerned advance width for a glyph.
|
||||||
|
*
|
||||||
|
* @param characterCode glyph index of the character
|
||||||
|
* @param nextCharacterCode the next glyph in a string
|
||||||
|
* @return advance width
|
||||||
|
*/
|
||||||
|
float Advance( const unsigned int characterCode, const unsigned int nextCharacterCode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders a character
|
||||||
|
* @param characterCode the glyph to be Rendered
|
||||||
|
* @param nextCharacterCode the next glyph in the string. Used for kerning.
|
||||||
|
* @param penPosition the position to Render the glyph
|
||||||
|
* @return The distance to advance the pen position after Rendering
|
||||||
|
*/
|
||||||
|
FTPoint Render( const unsigned int characterCode, const unsigned int nextCharacterCode, FTPoint penPosition);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Queries the Font for errors.
|
||||||
|
*
|
||||||
|
* @return The current error code.
|
||||||
|
*/
|
||||||
|
FT_Error Error() const { return err;}
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* The FTGL face
|
||||||
|
*/
|
||||||
|
FTFace* face;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Character Map object associated with the current face
|
||||||
|
*/
|
||||||
|
FTCharmap* charMap;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A structure to hold the glyphs
|
||||||
|
*/
|
||||||
|
GlyphVector glyphs;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current error code. Zero means no error.
|
||||||
|
*/
|
||||||
|
FT_Error err;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTGlyphContainer__
|
||||||
97
extern/bFTGL/include/FTLibrary.h
vendored
Normal file
97
extern/bFTGL/include/FTLibrary.h
vendored
Normal file
@@ -0,0 +1,97 @@
|
|||||||
|
#ifndef __FTLibrary__
|
||||||
|
#define __FTLibrary__
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
//#include FT_CACHE_H
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTLibrary class is the global accessor for the Freetype library.
|
||||||
|
*
|
||||||
|
* This class encapsulates the Freetype Library. This is a singleton class
|
||||||
|
* and ensures that only one FT_Library is in existence at any one time.
|
||||||
|
* All constructors are private therefore clients cannot create or
|
||||||
|
* instantiate this class themselves and must access it's methods via the
|
||||||
|
* static <code>FTLibrary::Instance()</code> function.
|
||||||
|
*
|
||||||
|
* Just because this class returns a valid <code>FTLibrary</code> object
|
||||||
|
* doesn't mean that the Freetype Library has been successfully initialised.
|
||||||
|
* Clients should check for errors. You can initialse the library AND check
|
||||||
|
* for errors using the following code...
|
||||||
|
* <code>err = FTLibrary::Instance().Error();</code>
|
||||||
|
*
|
||||||
|
* @see "Freetype 2 Documentation"
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTLibrary
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Global acces point to the single FTLibrary object.
|
||||||
|
*
|
||||||
|
* @return The global <code>FTLibrary</code> object.
|
||||||
|
*/
|
||||||
|
static FTLibrary& Instance();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets a pointer to the native Freetype library.
|
||||||
|
*
|
||||||
|
* @return A handle to a FreeType library instance.
|
||||||
|
*/
|
||||||
|
const FT_Library* const GetLibrary() const { return library;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Queries the library for errors.
|
||||||
|
*
|
||||||
|
* @return The current error code.
|
||||||
|
*/
|
||||||
|
FT_Error Error() const { return err;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*
|
||||||
|
* Disposes of the Freetype library
|
||||||
|
*/
|
||||||
|
~FTLibrary();
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Default constructors.
|
||||||
|
*
|
||||||
|
* Made private to stop clients creating there own FTLibrary
|
||||||
|
* objects.
|
||||||
|
*/
|
||||||
|
FTLibrary();
|
||||||
|
FTLibrary( const FT_Library&){}
|
||||||
|
FTLibrary& operator=( const FT_Library&) { return *this; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialises the Freetype library
|
||||||
|
*
|
||||||
|
* Even though this function indicates success via the return value,
|
||||||
|
* clients can't see this so must check the error codes. This function
|
||||||
|
* is only ever called by the default c_stor
|
||||||
|
*
|
||||||
|
* @return <code>true</code> if the Freetype library was
|
||||||
|
* successfully initialised, <code>false</code>
|
||||||
|
* otherwise.
|
||||||
|
*/
|
||||||
|
bool Initialise();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Freetype library handle.
|
||||||
|
*/
|
||||||
|
FT_Library* library;
|
||||||
|
// FTC_Manager* manager;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current error code. Zero means no error.
|
||||||
|
*/
|
||||||
|
FT_Error err;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // __FTLibrary__
|
||||||
112
extern/bFTGL/include/FTList.h
vendored
Normal file
112
extern/bFTGL/include/FTList.h
vendored
Normal file
@@ -0,0 +1,112 @@
|
|||||||
|
#ifndef __FTList__
|
||||||
|
#define __FTList__
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provides a non-STL alternative to the STL list
|
||||||
|
*/
|
||||||
|
template <typename FT_LIST_ITEM_TYPE>
|
||||||
|
class FTGL_EXPORT FTList
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
typedef FT_LIST_ITEM_TYPE value_type;
|
||||||
|
typedef value_type& reference;
|
||||||
|
typedef const value_type& const_reference;
|
||||||
|
typedef size_t size_type;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*/
|
||||||
|
FTList()
|
||||||
|
: listSize(0),
|
||||||
|
tail(0)
|
||||||
|
{
|
||||||
|
tail = NULL;
|
||||||
|
head = new Node;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
~FTList()
|
||||||
|
{
|
||||||
|
Node* next;
|
||||||
|
|
||||||
|
for( Node *walk = head; walk; walk = next)
|
||||||
|
{
|
||||||
|
next = walk->next;
|
||||||
|
delete walk;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the number of items in the list
|
||||||
|
*/
|
||||||
|
size_type size() const
|
||||||
|
{
|
||||||
|
return listSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add an item to the end of the list
|
||||||
|
*/
|
||||||
|
void push_back( const value_type& item)
|
||||||
|
{
|
||||||
|
Node* node = new Node( item);
|
||||||
|
|
||||||
|
if( head->next == NULL)
|
||||||
|
{
|
||||||
|
head->next = node;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( tail)
|
||||||
|
{
|
||||||
|
tail->next = node;
|
||||||
|
}
|
||||||
|
tail = node;
|
||||||
|
++listSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the item at the front of the list
|
||||||
|
*/
|
||||||
|
reference front() const
|
||||||
|
{
|
||||||
|
return head->next->payload;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the item at the end of the list
|
||||||
|
*/
|
||||||
|
reference back() const
|
||||||
|
{
|
||||||
|
return tail->payload;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
struct Node
|
||||||
|
{
|
||||||
|
Node()
|
||||||
|
: next(NULL)
|
||||||
|
{}
|
||||||
|
|
||||||
|
Node( const value_type& item)
|
||||||
|
: next(NULL)
|
||||||
|
{
|
||||||
|
payload = item;
|
||||||
|
}
|
||||||
|
|
||||||
|
Node* next;
|
||||||
|
|
||||||
|
value_type payload;
|
||||||
|
};
|
||||||
|
|
||||||
|
size_type listSize;
|
||||||
|
|
||||||
|
Node* head;
|
||||||
|
Node* tail;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // __FTList__
|
||||||
|
|
||||||
54
extern/bFTGL/include/FTOutlineGlyph.h
vendored
Normal file
54
extern/bFTGL/include/FTOutlineGlyph.h
vendored
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
#ifndef __FTOutlineGlyph__
|
||||||
|
#define __FTOutlineGlyph__
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
#include FT_GLYPH_H
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
#include "FTGlyph.h"
|
||||||
|
|
||||||
|
class FTVectoriser;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTOutlineGlyph is a specialisation of FTGlyph for creating outlines.
|
||||||
|
*
|
||||||
|
* @see FTGlyphContainer
|
||||||
|
* @see FTVectoriser
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTOutlineGlyph : public FTGlyph
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor. Sets the Error to Invalid_Outline if the glyphs isn't an outline.
|
||||||
|
*
|
||||||
|
* @param glyph The Freetype glyph to be processed
|
||||||
|
*/
|
||||||
|
FTOutlineGlyph( FT_GlyphSlot glyph);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FTOutlineGlyph();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders this glyph at the current pen position.
|
||||||
|
*
|
||||||
|
* @param pen The current pen position.
|
||||||
|
* @return The advance distance for this glyph.
|
||||||
|
*/
|
||||||
|
virtual float Render( const FTPoint& pen);
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* OpenGL display list
|
||||||
|
*/
|
||||||
|
GLuint glList;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTOutlineGlyph__
|
||||||
|
|
||||||
68
extern/bFTGL/include/FTPixmapGlyph.h
vendored
Normal file
68
extern/bFTGL/include/FTPixmapGlyph.h
vendored
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
#ifndef __FTPixmapGlyph__
|
||||||
|
#define __FTPixmapGlyph__
|
||||||
|
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
#include FT_GLYPH_H
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
#include "FTGlyph.h"
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTPixmapGlyph is a specialisation of FTGlyph for creating pixmaps.
|
||||||
|
*
|
||||||
|
* @see FTGlyphContainer
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTPixmapGlyph : public FTGlyph
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*
|
||||||
|
* @param glyph The Freetype glyph to be processed
|
||||||
|
*/
|
||||||
|
FTPixmapGlyph( FT_GlyphSlot glyph);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FTPixmapGlyph();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders this glyph at the current pen position.
|
||||||
|
*
|
||||||
|
* @param pen The current pen position.
|
||||||
|
* @return The advance distance for this glyph.
|
||||||
|
*/
|
||||||
|
virtual float Render( const FTPoint& pen);
|
||||||
|
|
||||||
|
// attributes
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* The width of the glyph 'image'
|
||||||
|
*/
|
||||||
|
int destWidth;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The height of the glyph 'image'
|
||||||
|
*/
|
||||||
|
int destHeight;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Vector from the pen position to the topleft corner of the pixmap
|
||||||
|
*/
|
||||||
|
FTPoint pos;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pointer to the 'image' data
|
||||||
|
*/
|
||||||
|
unsigned char* data;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTPixmapGlyph__
|
||||||
85
extern/bFTGL/include/FTPoint.h
vendored
Normal file
85
extern/bFTGL/include/FTPoint.h
vendored
Normal file
@@ -0,0 +1,85 @@
|
|||||||
|
#ifndef __FTPoint__
|
||||||
|
#define __FTPoint__
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
#include FT_GLYPH_H
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTPoint class is a basic 3 dimensional point or vector.
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTPoint
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Default constructor. Point is set to zero.
|
||||||
|
*/
|
||||||
|
FTPoint()
|
||||||
|
: x(0), y(0), z(0)
|
||||||
|
{}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*
|
||||||
|
* @param X
|
||||||
|
* @param Y
|
||||||
|
* @param Z
|
||||||
|
*/
|
||||||
|
FTPoint( const FTGL_DOUBLE X, const FTGL_DOUBLE Y, const FTGL_DOUBLE Z)
|
||||||
|
: x(X), y(Y), z(Z)
|
||||||
|
{}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor. This converts an FT_Vector to an FT_Point
|
||||||
|
*
|
||||||
|
* @param ft_vector A freetype vector
|
||||||
|
*/
|
||||||
|
FTPoint( const FT_Vector& ft_vector)
|
||||||
|
: x(ft_vector.x), y(ft_vector.y), z(0)
|
||||||
|
{}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Operator +=
|
||||||
|
*
|
||||||
|
* @param point
|
||||||
|
* @return this plus point.
|
||||||
|
*/
|
||||||
|
FTPoint& operator += ( const FTPoint& point)
|
||||||
|
{
|
||||||
|
x += point.x;
|
||||||
|
y += point.y;
|
||||||
|
z += point.z;
|
||||||
|
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Operator == Tests for eqaulity
|
||||||
|
*
|
||||||
|
* @param a
|
||||||
|
* @param b
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
friend bool operator == ( const FTPoint &a, const FTPoint &b);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Operator != Tests for non equality
|
||||||
|
*
|
||||||
|
* @param a
|
||||||
|
* @param b
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
friend bool operator != ( const FTPoint &a, const FTPoint &b);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The point data
|
||||||
|
*/
|
||||||
|
FTGL_DOUBLE x, y, z; // FIXME make private
|
||||||
|
|
||||||
|
private:
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // __FTPoint__
|
||||||
|
|
||||||
55
extern/bFTGL/include/FTPolyGlyph.h
vendored
Normal file
55
extern/bFTGL/include/FTPolyGlyph.h
vendored
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
#ifndef __FTPolyGlyph__
|
||||||
|
#define __FTPolyGlyph__
|
||||||
|
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
#include FT_GLYPH_H
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
#include "FTGlyph.h"
|
||||||
|
|
||||||
|
class FTVectoriser;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTPolyGlyph is a specialisation of FTGlyph for creating tessellated
|
||||||
|
* polygon glyphs.
|
||||||
|
*
|
||||||
|
* @see FTGlyphContainer
|
||||||
|
* @see FTVectoriser
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTPolyGlyph : public FTGlyph
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor. Sets the Error to Invalid_Outline if the glyphs isn't an outline.
|
||||||
|
*
|
||||||
|
* @param glyph The Freetype glyph to be processed
|
||||||
|
*/
|
||||||
|
FTPolyGlyph( FT_GlyphSlot glyph);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FTPolyGlyph();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders this glyph at the current pen position.
|
||||||
|
*
|
||||||
|
* @param pen The current pen position.
|
||||||
|
* @return The advance distance for this glyph.
|
||||||
|
*/
|
||||||
|
virtual float Render( const FTPoint& pen);
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* OpenGL display list
|
||||||
|
*/
|
||||||
|
GLuint glList;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTPolyGlyph__
|
||||||
|
|
||||||
132
extern/bFTGL/include/FTSize.h
vendored
Normal file
132
extern/bFTGL/include/FTSize.h
vendored
Normal file
@@ -0,0 +1,132 @@
|
|||||||
|
#ifndef __FTSize__
|
||||||
|
#define __FTSize__
|
||||||
|
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTSize class provides an abstraction layer for the Freetype Size.
|
||||||
|
*
|
||||||
|
* @see "Freetype 2 Documentation"
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTSize
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Default Constructor
|
||||||
|
*/
|
||||||
|
FTSize();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FTSize();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the char size for the current face.
|
||||||
|
*
|
||||||
|
* This doesn't guarantee that the size was set correctly. Clients
|
||||||
|
* should check errors.
|
||||||
|
*
|
||||||
|
* @param face Parent face for this size object
|
||||||
|
* @param point_size the face size in points (1/72 inch)
|
||||||
|
* @param x_resolution the horizontal resolution of the target device.
|
||||||
|
* @param y_resolution the vertical resolution of the target device.
|
||||||
|
* @return <code>true</code> if the size has been set. Clients should check Error() for more information if this function returns false()
|
||||||
|
*/
|
||||||
|
bool CharSize( FT_Face* face, unsigned int point_size, unsigned int x_resolution, unsigned int y_resolution);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* get the char size for the current face.
|
||||||
|
*
|
||||||
|
* @return The char size in points
|
||||||
|
*/
|
||||||
|
unsigned int CharSize() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the global ascender height for the face in pixels.
|
||||||
|
*
|
||||||
|
* @return Ascender height
|
||||||
|
*/
|
||||||
|
float Ascender() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the global descender height for the face in pixels.
|
||||||
|
*
|
||||||
|
* @return Ascender height
|
||||||
|
*/
|
||||||
|
float Descender() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the global face height for the face.
|
||||||
|
*
|
||||||
|
* If the face is scalable this returns the height of the global
|
||||||
|
* bounding box which ensures that any glyph will be less than or
|
||||||
|
* equal to this height. If the font isn't scalable there is no
|
||||||
|
* guarantee that glyphs will not be taller than this value.
|
||||||
|
*
|
||||||
|
* @return height in pixels.
|
||||||
|
*/
|
||||||
|
float Height() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the global face width for the face.
|
||||||
|
*
|
||||||
|
* If the face is scalable this returns the width of the global
|
||||||
|
* bounding box which ensures that any glyph will be less than or
|
||||||
|
* equal to this width. If the font isn't scalable this value is
|
||||||
|
* the max_advance for the face.
|
||||||
|
*
|
||||||
|
* @return width in pixels.
|
||||||
|
*/
|
||||||
|
float Width() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the underline position for the face.
|
||||||
|
*
|
||||||
|
* @return underline position in pixels
|
||||||
|
*/
|
||||||
|
float Underline() const;
|
||||||
|
|
||||||
|
unsigned int XPixelsPerEm() const;
|
||||||
|
|
||||||
|
unsigned int YPixelsPerEm() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Queries for errors.
|
||||||
|
*
|
||||||
|
* @return The current error code.
|
||||||
|
*/
|
||||||
|
FT_Error Error() const { return err; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* The current Freetype face that this FTSize object relates to.
|
||||||
|
*/
|
||||||
|
FT_Face* ftFace;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Freetype size.
|
||||||
|
*/
|
||||||
|
FT_Size ftSize;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The size in points.
|
||||||
|
*/
|
||||||
|
unsigned int size;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current error code. Zero means no error.
|
||||||
|
*/
|
||||||
|
FT_Error err;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // __FTSize__
|
||||||
|
|
||||||
89
extern/bFTGL/include/FTTextureGlyph.h
vendored
Normal file
89
extern/bFTGL/include/FTTextureGlyph.h
vendored
Normal file
@@ -0,0 +1,89 @@
|
|||||||
|
#ifndef __FTTextureGlyph__
|
||||||
|
#define __FTTextureGlyph__
|
||||||
|
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
#include FT_GLYPH_H
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
#include "FTGlyph.h"
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTTextureGlyph is a specialisation of FTGlyph for creating texture
|
||||||
|
* glyphs.
|
||||||
|
*
|
||||||
|
* @see FTGlyphContainer
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTTextureGlyph : public FTGlyph
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*
|
||||||
|
* @param glyph The Freetype glyph to be processed
|
||||||
|
* @param id The id of the texture that this glyph will be
|
||||||
|
* drawn in
|
||||||
|
* @param xOffset The x offset into the parent texture to draw
|
||||||
|
* this glyph
|
||||||
|
* @param yOffset The y offset into the parent texture to draw
|
||||||
|
* this glyph
|
||||||
|
* @param width The width of the parent texture
|
||||||
|
* @param height The height (number of rows) of the parent texture
|
||||||
|
*/
|
||||||
|
FTTextureGlyph( FT_GlyphSlot glyph, int id, int xOffset, int yOffset, GLsizei width, GLsizei height);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FTTextureGlyph();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders this glyph at the current pen position.
|
||||||
|
*
|
||||||
|
* @param pen The current pen position.
|
||||||
|
* @return The advance distance for this glyph.
|
||||||
|
*/
|
||||||
|
virtual float Render( const FTPoint& pen);
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* The width of the glyph 'image'
|
||||||
|
*/
|
||||||
|
int destWidth;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The height of the glyph 'image'
|
||||||
|
*/
|
||||||
|
int destHeight;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Vector from the pen position to the topleft corner of the pixmap
|
||||||
|
*/
|
||||||
|
FTPoint pos;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The texture co-ords of this glyph within the texture.
|
||||||
|
*/
|
||||||
|
FTPoint uv[2];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The texture index that this glyph is contained in.
|
||||||
|
*/
|
||||||
|
int glTextureID;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The texture index of the currently active texture
|
||||||
|
*
|
||||||
|
* We call glGetIntegerv( GL_TEXTURE_2D_BINDING, activeTextureID);
|
||||||
|
* to get the currently active texture to try to reduce the number
|
||||||
|
* of texture bind operations
|
||||||
|
*/
|
||||||
|
GLint activeTextureID;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTTextureGlyph__
|
||||||
190
extern/bFTGL/include/FTVector.h
vendored
Normal file
190
extern/bFTGL/include/FTVector.h
vendored
Normal file
@@ -0,0 +1,190 @@
|
|||||||
|
#ifndef __FTVector__
|
||||||
|
#define __FTVector__
|
||||||
|
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provides a non-STL alternative to the STL vector
|
||||||
|
*/
|
||||||
|
template <typename FT_VECTOR_ITEM_TYPE>
|
||||||
|
class FTGL_EXPORT FTVector
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
typedef FT_VECTOR_ITEM_TYPE value_type;
|
||||||
|
typedef value_type& reference;
|
||||||
|
typedef const value_type& const_reference;
|
||||||
|
typedef value_type* iterator;
|
||||||
|
typedef const value_type* const_iterator;
|
||||||
|
typedef size_t size_type;
|
||||||
|
|
||||||
|
FTVector()
|
||||||
|
{
|
||||||
|
Capacity = Size = 0;
|
||||||
|
Items = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
virtual ~FTVector()
|
||||||
|
{
|
||||||
|
clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
FTVector& operator =(const FTVector& v)
|
||||||
|
{
|
||||||
|
reserve(v.capacity());
|
||||||
|
|
||||||
|
iterator ptr = begin();
|
||||||
|
const_iterator vbegin = v.begin();
|
||||||
|
const_iterator vend = v.end();
|
||||||
|
|
||||||
|
while( vbegin != vend)
|
||||||
|
{
|
||||||
|
*ptr++ = *vbegin++;
|
||||||
|
}
|
||||||
|
|
||||||
|
Size = v.size();
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_type size() const
|
||||||
|
{
|
||||||
|
return Size;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_type capacity() const
|
||||||
|
{
|
||||||
|
return Capacity;
|
||||||
|
}
|
||||||
|
|
||||||
|
iterator begin()
|
||||||
|
{
|
||||||
|
return Items;
|
||||||
|
}
|
||||||
|
|
||||||
|
const_iterator begin() const
|
||||||
|
{
|
||||||
|
return Items;
|
||||||
|
}
|
||||||
|
|
||||||
|
iterator end()
|
||||||
|
{
|
||||||
|
return begin() + size();
|
||||||
|
}
|
||||||
|
|
||||||
|
const_iterator end() const
|
||||||
|
{
|
||||||
|
return begin() + size();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool empty() const
|
||||||
|
{
|
||||||
|
return size() == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
reference operator [](size_type pos)
|
||||||
|
{
|
||||||
|
return( *(begin() + pos));
|
||||||
|
}
|
||||||
|
|
||||||
|
const_reference operator []( size_type pos) const
|
||||||
|
{
|
||||||
|
return( *(begin() + pos));
|
||||||
|
}
|
||||||
|
|
||||||
|
void clear()
|
||||||
|
{
|
||||||
|
if( Capacity)
|
||||||
|
{
|
||||||
|
delete [] Items;
|
||||||
|
Capacity = Size = 0;
|
||||||
|
Items = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void reserve( size_type n)
|
||||||
|
{
|
||||||
|
if( capacity() < n)
|
||||||
|
{
|
||||||
|
expand(n);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void push_back(const value_type& x)
|
||||||
|
{
|
||||||
|
if( size() == capacity())
|
||||||
|
{
|
||||||
|
expand();
|
||||||
|
}
|
||||||
|
|
||||||
|
( *this)[size()] = x;
|
||||||
|
++Size;
|
||||||
|
}
|
||||||
|
|
||||||
|
void resize(size_type n, value_type x)
|
||||||
|
{
|
||||||
|
if( n == size())
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
reserve(n);
|
||||||
|
iterator begin, end;
|
||||||
|
|
||||||
|
if( n >= Size)
|
||||||
|
{
|
||||||
|
begin = this->end();
|
||||||
|
end = this->begin() + n;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
begin = this->begin() + n;
|
||||||
|
end = this->end();
|
||||||
|
}
|
||||||
|
|
||||||
|
while( begin != end)
|
||||||
|
{
|
||||||
|
*begin++ = x;
|
||||||
|
}
|
||||||
|
|
||||||
|
Size = n;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private:
|
||||||
|
void expand(size_type capacity_hint = 0)
|
||||||
|
{
|
||||||
|
size_type new_capacity =( capacity() == 0) ? 256 : capacity()* 2;
|
||||||
|
if( capacity_hint)
|
||||||
|
{
|
||||||
|
while( new_capacity < capacity_hint)
|
||||||
|
{
|
||||||
|
new_capacity *= 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
value_type *new_items = new value_type[new_capacity];
|
||||||
|
|
||||||
|
iterator begin = this->begin();
|
||||||
|
iterator end = this->end();
|
||||||
|
value_type *ptr = new_items;
|
||||||
|
|
||||||
|
while( begin != end)
|
||||||
|
{
|
||||||
|
*ptr++ = *begin++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( Capacity)
|
||||||
|
{
|
||||||
|
delete [] Items;
|
||||||
|
}
|
||||||
|
|
||||||
|
Items = new_items;
|
||||||
|
Capacity = new_capacity;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_type Capacity;
|
||||||
|
size_type Size;
|
||||||
|
value_type* Items;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // __FTVector__
|
||||||
275
extern/bFTGL/include/FTVectoriser.h
vendored
Normal file
275
extern/bFTGL/include/FTVectoriser.h
vendored
Normal file
@@ -0,0 +1,275 @@
|
|||||||
|
#ifndef __FTVectoriser__
|
||||||
|
#define __FTVectoriser__
|
||||||
|
|
||||||
|
|
||||||
|
#include "FTContour.h"
|
||||||
|
#include "FTList.h"
|
||||||
|
#include "FTPoint.h"
|
||||||
|
#include "FTVector.h"
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef CALLBACK
|
||||||
|
#define CALLBACK
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTTesselation captures points that are output by OpenGL's gluTesselator.
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTTesselation
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Default constructor
|
||||||
|
*/
|
||||||
|
FTTesselation( GLenum m)
|
||||||
|
: meshType(m)
|
||||||
|
{
|
||||||
|
pointList.reserve( 128);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
~FTTesselation()
|
||||||
|
{
|
||||||
|
pointList.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add a point to the mesh.
|
||||||
|
*/
|
||||||
|
void AddPoint( const FTGL_DOUBLE x, const FTGL_DOUBLE y, const FTGL_DOUBLE z)
|
||||||
|
{
|
||||||
|
pointList.push_back( FTPoint( x, y, z));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The number of points in this mesh
|
||||||
|
*/
|
||||||
|
size_t PointCount() const { return pointList.size();}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
const FTPoint& Point( unsigned int index) const { return pointList[index];}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the OpenGL polygon type.
|
||||||
|
*/
|
||||||
|
GLenum PolygonType() const { return meshType;}
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Points generated by gluTesselator.
|
||||||
|
*/
|
||||||
|
typedef FTVector<FTPoint> PointVector;
|
||||||
|
PointVector pointList;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* OpenGL primitive type from gluTesselator.
|
||||||
|
*/
|
||||||
|
GLenum meshType;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTMesh is a container of FTTesselation's that make up a polygon glyph
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTMesh
|
||||||
|
{
|
||||||
|
typedef FTVector<FTTesselation*> TesselationVector;
|
||||||
|
typedef FTList<FTPoint> PointList;
|
||||||
|
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Default constructor
|
||||||
|
*/
|
||||||
|
FTMesh();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
~FTMesh();
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
void AddPoint( const FTGL_DOUBLE x, const FTGL_DOUBLE y, const FTGL_DOUBLE z);
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FTGL_DOUBLE* Combine( const FTGL_DOUBLE x, const FTGL_DOUBLE y, const FTGL_DOUBLE z);
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
void Begin( GLenum meshType);
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
void End();
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
void Error( GLenum e) { err = e;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
unsigned int TesselationCount() const { return tesselationList.size();}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
const FTTesselation* const Tesselation( unsigned int index) const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
const PointList& TempPointList() const { return tempPointList;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the GL ERROR returned by the glu tesselator
|
||||||
|
*/
|
||||||
|
GLenum Error() const { return err;}
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* The current sub mesh that we are constructing.
|
||||||
|
*/
|
||||||
|
FTTesselation* currentTesselation;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Holds each sub mesh that comprises this glyph.
|
||||||
|
*/
|
||||||
|
TesselationVector tesselationList;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Holds extra points created by gluTesselator. See ftglCombine.
|
||||||
|
*/
|
||||||
|
PointList tempPointList;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GL ERROR returned by the glu tesselator
|
||||||
|
*/
|
||||||
|
GLenum err;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
const FTGL_DOUBLE FTGL_FRONT_FACING = 1.0;
|
||||||
|
const FTGL_DOUBLE FTGL_BACK_FACING = -1.0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FTVectoriser class is a helper class that converts font outlines into
|
||||||
|
* point data.
|
||||||
|
*
|
||||||
|
* @see FTExtrdGlyph
|
||||||
|
* @see FTOutlineGlyph
|
||||||
|
* @see FTPolyGlyph
|
||||||
|
* @see FTContour
|
||||||
|
* @see FTPoint
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class FTGL_EXPORT FTVectoriser
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*
|
||||||
|
* @param glyph The freetype glyph to be processed
|
||||||
|
*/
|
||||||
|
FTVectoriser( const FT_GlyphSlot glyph);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FTVectoriser();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Build an FTMesh from the vector outline data.
|
||||||
|
*
|
||||||
|
* @param zNormal The direction of the z axis of the normal
|
||||||
|
* for this mesh
|
||||||
|
*/
|
||||||
|
void MakeMesh( FTGL_DOUBLE zNormal = FTGL_FRONT_FACING);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the current mesh.
|
||||||
|
*/
|
||||||
|
const FTMesh* const GetMesh() const { return mesh;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the total count of points in this outline
|
||||||
|
*
|
||||||
|
* @return the number of points
|
||||||
|
*/
|
||||||
|
size_t PointCount();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the count of contours in this outline
|
||||||
|
*
|
||||||
|
* @return the number of contours
|
||||||
|
*/
|
||||||
|
size_t ContourCount() const { return ftContourCount;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return a contour at index
|
||||||
|
*
|
||||||
|
* @return the number of contours
|
||||||
|
*/
|
||||||
|
const FTContour* const Contour( unsigned int index) const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the number of points in a specific contour in this outline
|
||||||
|
*
|
||||||
|
* @param c The contour index
|
||||||
|
* @return the number of points in contour[c]
|
||||||
|
*/
|
||||||
|
size_t ContourSize( int c) const { return contourList[c]->PointCount();}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the flag for the tesselation rule for this outline
|
||||||
|
*
|
||||||
|
* @return The contour flag
|
||||||
|
*/
|
||||||
|
int ContourFlag() const { return contourFlag;}
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* Process the freetype outline data into contours of points
|
||||||
|
*/
|
||||||
|
void ProcessContours();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The list of contours in the glyph
|
||||||
|
*/
|
||||||
|
FTContour** contourList;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A Mesh for tesselations
|
||||||
|
*/
|
||||||
|
FTMesh* mesh;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The number of contours reported by Freetype
|
||||||
|
*/
|
||||||
|
short ftContourCount;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A flag indicating the tesselation rule for the glyph
|
||||||
|
*/
|
||||||
|
int contourFlag;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A Freetype outline
|
||||||
|
*/
|
||||||
|
FT_Outline outline;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __FTVectoriser__
|
||||||
27
extern/bFTGL/license.txt
vendored
Normal file
27
extern/bFTGL/license.txt
vendored
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
FTGL
|
||||||
|
|
||||||
|
Herewith is a license. I've also chucked in a gnu (see COPYING.txt) license
|
||||||
|
for those that are that way inclined. Basically I want you to use this
|
||||||
|
software and if you think this license is preventing you from doing so
|
||||||
|
let me know.
|
||||||
|
|
||||||
|
Copyright (C) 2001-3 Henry Maddocks
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
a copy of this software and associated documentation files (the
|
||||||
|
"Software"), to deal in the Software without restriction, including
|
||||||
|
without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||||
|
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
||||||
|
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
||||||
|
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
406
extern/bFTGL/make/msvc_7_0/ftgl_static_lib.vcproj
vendored
Normal file
406
extern/bFTGL/make/msvc_7_0/ftgl_static_lib.vcproj
vendored
Normal file
@@ -0,0 +1,406 @@
|
|||||||
|
<?xml version="1.0" encoding="Windows-1252"?>
|
||||||
|
<VisualStudioProject
|
||||||
|
ProjectType="Visual C++"
|
||||||
|
Version="7.10"
|
||||||
|
Name="ftgl_static_lib"
|
||||||
|
ProjectGUID="{F9850C15-FF0A-429E-9D47-89FB433C9BD8}"
|
||||||
|
SccProjectName=""
|
||||||
|
SccLocalPath="">
|
||||||
|
<Platforms>
|
||||||
|
<Platform
|
||||||
|
Name="Win32"/>
|
||||||
|
</Platforms>
|
||||||
|
<Configurations>
|
||||||
|
<Configuration
|
||||||
|
Name="Blender Debug|Win32"
|
||||||
|
OutputDirectory="..\..\..\..\..\build\msvc_7\extern\ftgl\debug"
|
||||||
|
IntermediateDirectory="..\..\..\..\..\build\msvc_7\extern\ftgl\debug"
|
||||||
|
ConfigurationType="4"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="FALSE"
|
||||||
|
CharacterSet="2">
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\include;..\..\..\..\..\lib\windows\freetype\include"
|
||||||
|
PreprocessorDefinitions="_DEBUG;WIN32;_LIB;FTGL_LIBRARY_STATIC"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
UsePrecompiledHeader="2"
|
||||||
|
PrecompiledHeaderFile="..\..\..\..\..\build\msvc_7\extern\ftgl\debug\ftgl_static_lib.pch"
|
||||||
|
AssemblerListingLocation="..\..\..\..\..\build\msvc_7\extern\ftgl\debug\"
|
||||||
|
ObjectFile="..\..\..\..\..\build\msvc_7\extern\ftgl\debug\"
|
||||||
|
ProgramDataBaseFileName="..\..\..\..\..\build\msvc_7\extern\ftgl\debug\"
|
||||||
|
WarningLevel="2"
|
||||||
|
SuppressStartupBanner="TRUE"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="0"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
OutputFile="..\..\..\..\..\build\msvc_7\libs\extern\debug\ftgl_static.lib"
|
||||||
|
SuppressStartupBanner="TRUE"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
Description="Copying FTGL files library (debug target) to lib tree."
|
||||||
|
CommandLine="ECHO Copying header files
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\ftgl\include\ MKDIR ..\..\..\..\..\build\msvc_7\extern\ftgl\include
|
||||||
|
XCOPY /Y ..\..\include\*.h ..\..\..\..\..\build\msvc_7\extern\ftgl\include
|
||||||
|
ECHO Done
|
||||||
|
"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="_DEBUG"
|
||||||
|
Culture="1033"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedWrapperGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Blender Release|Win32"
|
||||||
|
OutputDirectory="..\..\..\..\..\build\msvc_7\extern\ftgl"
|
||||||
|
IntermediateDirectory="..\..\..\..\..\build\msvc_7\extern\ftgl"
|
||||||
|
ConfigurationType="4"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="FALSE"
|
||||||
|
CharacterSet="2">
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="1"
|
||||||
|
AdditionalIncludeDirectories="..\..\include;..\..\..\..\..\lib\windows\freetype\include"
|
||||||
|
PreprocessorDefinitions="NDEBUG;WIN32;_LIB;FTGL_LIBRARY_STATIC"
|
||||||
|
StringPooling="TRUE"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="TRUE"
|
||||||
|
UsePrecompiledHeader="2"
|
||||||
|
PrecompiledHeaderFile="..\..\..\..\..\build\msvc_7\extern\ftgl\ftgl_static_lib.pch"
|
||||||
|
AssemblerListingLocation="..\..\..\..\..\build\msvc_7\extern\ftgl\"
|
||||||
|
ObjectFile="..\..\..\..\..\build\msvc_7\extern\ftgl\"
|
||||||
|
ProgramDataBaseFileName="..\..\..\..\..\build\msvc_7\extern\ftgl\"
|
||||||
|
WarningLevel="2"
|
||||||
|
SuppressStartupBanner="TRUE"
|
||||||
|
CompileAs="0"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
OutputFile="..\..\..\..\..\build\msvc_7\libs\extern\ftgl_static.lib"
|
||||||
|
SuppressStartupBanner="TRUE"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
Description="Copying FTGL files library to lib tree."
|
||||||
|
CommandLine="ECHO Copying header files
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\ftgl\include\ MKDIR ..\..\..\..\..\build\msvc_7\extern\ftgl\include
|
||||||
|
XCOPY /Y ..\..\include\*.h ..\..\..\..\..\build\msvc_7\extern\ftgl\include
|
||||||
|
ECHO Done
|
||||||
|
"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="NDEBUG"
|
||||||
|
Culture="1033"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedWrapperGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="3D Plugin Release|Win32"
|
||||||
|
OutputDirectory="..\..\..\..\..\build\msvc_7\extern\ftgl\mtdll"
|
||||||
|
IntermediateDirectory="..\..\..\..\..\build\msvc_7\extern\ftgl\mtdll"
|
||||||
|
ConfigurationType="4"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="FALSE"
|
||||||
|
CharacterSet="2">
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="1"
|
||||||
|
AdditionalIncludeDirectories="..\..\include;..\..\..\..\..\lib\windows\freetype\include"
|
||||||
|
PreprocessorDefinitions="NDEBUG;WIN32;_LIB;FTGL_LIBRARY_STATIC"
|
||||||
|
StringPooling="TRUE"
|
||||||
|
RuntimeLibrary="2"
|
||||||
|
EnableFunctionLevelLinking="TRUE"
|
||||||
|
UsePrecompiledHeader="2"
|
||||||
|
PrecompiledHeaderFile="..\..\..\..\..\build\msvc_7\extern\ftgl\mtdll\ftgl_static_lib.pch"
|
||||||
|
AssemblerListingLocation="..\..\..\..\..\build\msvc_7\extern\ftgl\mtdll\"
|
||||||
|
ObjectFile="..\..\..\..\..\build\msvc_7\extern\ftgl\mtdll\"
|
||||||
|
ProgramDataBaseFileName="..\..\..\..\..\build\msvc_7\extern\ftgl\mtdll\"
|
||||||
|
WarningLevel="2"
|
||||||
|
SuppressStartupBanner="TRUE"
|
||||||
|
CompileAs="0"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
OutputFile="..\..\..\..\..\build\msvc_7\libs\extern\mtdll\ftgl_static.lib"
|
||||||
|
SuppressStartupBanner="TRUE"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
Description="Copying FTGL files library to lib tree."
|
||||||
|
CommandLine="ECHO Copying header files
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\ftgl\include\ MKDIR ..\..\..\..\..\build\msvc_7\extern\ftgl\include
|
||||||
|
XCOPY /Y ..\..\include\*.h ..\..\..\..\..\build\msvc_7\extern\ftgl\include
|
||||||
|
ECHO Done
|
||||||
|
"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="NDEBUG"
|
||||||
|
Culture="1033"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedWrapperGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="3D Plugin Debug|Win32"
|
||||||
|
OutputDirectory="..\..\..\..\..\build\msvc_7\extern\ftgl\mtdll\debug"
|
||||||
|
IntermediateDirectory="..\..\..\..\..\build\msvc_7\extern\ftgl\mtdll\debug"
|
||||||
|
ConfigurationType="4"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="FALSE"
|
||||||
|
CharacterSet="2">
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\include;..\..\..\..\..\lib\windows\freetype\include"
|
||||||
|
PreprocessorDefinitions="_DEBUG;WIN32;_LIB;FTGL_LIBRARY_STATIC"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="3"
|
||||||
|
UsePrecompiledHeader="2"
|
||||||
|
PrecompiledHeaderFile="..\..\..\..\..\build\msvc_7\extern\ftgl\mtdll\debug\ftgl_static_lib.pch"
|
||||||
|
AssemblerListingLocation="..\..\..\..\..\build\msvc_7\extern\ftgl\mtdll\debug\"
|
||||||
|
ObjectFile="..\..\..\..\..\build\msvc_7\extern\ftgl\mtdll\debug\"
|
||||||
|
ProgramDataBaseFileName="..\..\..\..\..\build\msvc_7\extern\ftgl\mtdll\debug\"
|
||||||
|
WarningLevel="2"
|
||||||
|
SuppressStartupBanner="TRUE"
|
||||||
|
DebugInformationFormat="3"
|
||||||
|
CompileAs="0"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
OutputFile="..\..\..\..\..\build\msvc_7\libs\extern\mtdll\debug\ftgl_static.lib"
|
||||||
|
SuppressStartupBanner="TRUE"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
Description="Copying FTGL files library (debug target) to lib tree."
|
||||||
|
CommandLine="ECHO Copying header files
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\ftgl\include\ MKDIR ..\..\..\..\..\build\msvc_7\extern\ftgl\include
|
||||||
|
XCOPY /Y ..\..\include\*.h ..\..\..\..\..\build\msvc_7\extern\ftgl\include
|
||||||
|
ECHO Done
|
||||||
|
"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="_DEBUG"
|
||||||
|
Culture="1033"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedWrapperGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
||||||
|
</Configuration>
|
||||||
|
</Configurations>
|
||||||
|
<References>
|
||||||
|
</References>
|
||||||
|
<Files>
|
||||||
|
<Filter
|
||||||
|
Name="Source Files"
|
||||||
|
Filter="cpp;c;cxx;rc;def;r;odl;idl;hpj;bat">
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTBitmapGlyph.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTCharmap.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTContour.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTExtrdGlyph.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTFace.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTFont.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTGLBitmapFont.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTGLExtrdFont.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTGLOutlineFont.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTGLPixmapFont.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTGLPolygonFont.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTGLTextureFont.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTGlyph.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTGlyphContainer.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTLibrary.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTOutlineGlyph.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTPixmapGlyph.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTPoint.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTPolyGlyph.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTSize.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTTextureGlyph.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\FTVectoriser.cpp">
|
||||||
|
</File>
|
||||||
|
</Filter>
|
||||||
|
<Filter
|
||||||
|
Name="Header Files"
|
||||||
|
Filter="h;hpp;hxx;hm;inl">
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTBBox.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTBitmapGlyph.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTCharmap.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTCharToGlyphIndexMap.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTContour.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTExtrdGlyph.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTFace.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTFont.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTGL.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTGLBitmapFont.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTGLExtrdFont.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTGLOutlineFont.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTGLPixmapFont.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTGLPolygonFont.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTGLTextureFont.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTGlyph.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTGlyphContainer.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTLibrary.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTList.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTOutlineGlyph.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTPixmapGlyph.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTPoint.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTPolyGlyph.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTSize.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTTextureGlyph.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTVector.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\FTVectoriser.h">
|
||||||
|
</File>
|
||||||
|
</Filter>
|
||||||
|
</Files>
|
||||||
|
<Globals>
|
||||||
|
</Globals>
|
||||||
|
</VisualStudioProject>
|
||||||
66
extern/bFTGL/src/FTBitmapGlyph.cpp
vendored
Normal file
66
extern/bFTGL/src/FTBitmapGlyph.cpp
vendored
Normal file
@@ -0,0 +1,66 @@
|
|||||||
|
#include <string>
|
||||||
|
|
||||||
|
#include "FTBitmapGlyph.h"
|
||||||
|
|
||||||
|
FTBitmapGlyph::FTBitmapGlyph( FT_GlyphSlot glyph)
|
||||||
|
: FTGlyph( glyph),
|
||||||
|
destWidth(0),
|
||||||
|
destHeight(0),
|
||||||
|
data(0)
|
||||||
|
{
|
||||||
|
err = FT_Render_Glyph( glyph, FT_RENDER_MODE_MONO);
|
||||||
|
if( err || ft_glyph_format_bitmap != glyph->format)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
FT_Bitmap bitmap = glyph->bitmap;
|
||||||
|
|
||||||
|
unsigned int srcWidth = bitmap.width;
|
||||||
|
unsigned int srcHeight = bitmap.rows;
|
||||||
|
unsigned int srcPitch = bitmap.pitch;
|
||||||
|
|
||||||
|
destWidth = srcWidth;
|
||||||
|
destHeight = srcHeight;
|
||||||
|
destPitch = srcPitch;
|
||||||
|
|
||||||
|
if( destWidth && destHeight)
|
||||||
|
{
|
||||||
|
data = new unsigned char[destPitch * destHeight];
|
||||||
|
unsigned char* dest = data + (( destHeight - 1) * destPitch);
|
||||||
|
|
||||||
|
unsigned char* src = bitmap.buffer;
|
||||||
|
|
||||||
|
for( unsigned int y = 0; y < srcHeight; ++y)
|
||||||
|
{
|
||||||
|
memcpy( dest, src, srcPitch);
|
||||||
|
dest -= destPitch;
|
||||||
|
src += srcPitch;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pos.x = glyph->bitmap_left;
|
||||||
|
pos.y = static_cast<int>(srcHeight) - glyph->bitmap_top;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTBitmapGlyph::~FTBitmapGlyph()
|
||||||
|
{
|
||||||
|
delete [] data;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTBitmapGlyph::Render( const FTPoint& pen)
|
||||||
|
{
|
||||||
|
if( data)
|
||||||
|
{
|
||||||
|
glBitmap( 0, 0, 0.0, 0.0, pen.x + pos.x, pen.y - pos.y, (const GLubyte*)0 );
|
||||||
|
|
||||||
|
glPixelStorei( GL_UNPACK_ROW_LENGTH, destPitch * 8);
|
||||||
|
glBitmap( destWidth, destHeight, 0.0f, 0.0, 0.0, 0.0, (const GLubyte*)data);
|
||||||
|
|
||||||
|
glBitmap( 0, 0, 0.0, 0.0, -pen.x - pos.x, -pen.y + pos.y, (const GLubyte*)0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
return advance;
|
||||||
|
}
|
||||||
59
extern/bFTGL/src/FTBufferGlyph.cpp
vendored
Normal file
59
extern/bFTGL/src/FTBufferGlyph.cpp
vendored
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
#include "FTBufferGlyph.h"
|
||||||
|
|
||||||
|
FTBufferGlyph::FTBufferGlyph( FT_GlyphSlot glyph, unsigned char* b)
|
||||||
|
: FTGlyph( glyph),
|
||||||
|
destWidth(0),
|
||||||
|
destHeight(0),
|
||||||
|
data(0),
|
||||||
|
buffer(b)
|
||||||
|
{
|
||||||
|
err = FT_Render_Glyph( glyph, FT_RENDER_MODE_NORMAL);
|
||||||
|
if( err || ft_glyph_format_bitmap != glyph->format)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
FT_Bitmap bitmap = glyph->bitmap;
|
||||||
|
|
||||||
|
unsigned int srcWidth = bitmap.width;
|
||||||
|
unsigned int srcHeight = bitmap.rows;
|
||||||
|
unsigned int srcPitch = bitmap.pitch;
|
||||||
|
|
||||||
|
destWidth = srcWidth;
|
||||||
|
destHeight = srcHeight;
|
||||||
|
destPitch = srcPitch;
|
||||||
|
|
||||||
|
if( destWidth && destHeight)
|
||||||
|
{
|
||||||
|
data = new unsigned char[destPitch * destHeight];
|
||||||
|
unsigned char* dest = data + (( destHeight - 1) * destPitch);
|
||||||
|
|
||||||
|
unsigned char* src = bitmap.buffer;
|
||||||
|
|
||||||
|
for( unsigned int y = 0; y < srcHeight; ++y)
|
||||||
|
{
|
||||||
|
memcpy( dest, src, srcPitch);
|
||||||
|
dest -= destPitch;
|
||||||
|
src += srcPitch;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pos.x = glyph->bitmap_left;
|
||||||
|
pos.y = srcHeight - glyph->bitmap_top;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTBufferGlyph::~FTBufferGlyph()
|
||||||
|
{
|
||||||
|
delete [] data;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTBufferGlyph::Render( const FTPoint& pen)
|
||||||
|
{
|
||||||
|
if( data && buffer)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
return advance;
|
||||||
|
}
|
||||||
62
extern/bFTGL/src/FTCharmap.cpp
vendored
Normal file
62
extern/bFTGL/src/FTCharmap.cpp
vendored
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
#include "FTFace.h"
|
||||||
|
#include "FTCharmap.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTCharmap::FTCharmap( FTFace* face)
|
||||||
|
: ftFace( *(face->Face())),
|
||||||
|
err(0)
|
||||||
|
{
|
||||||
|
if( !ftFace->charmap)
|
||||||
|
{
|
||||||
|
err = FT_Set_Charmap( ftFace, ftFace->charmaps[0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
ftEncoding = ftFace->charmap->encoding;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTCharmap::~FTCharmap()
|
||||||
|
{
|
||||||
|
charMap.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool FTCharmap::CharMap( FT_Encoding encoding)
|
||||||
|
{
|
||||||
|
if( ftEncoding == encoding)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
err = FT_Select_Charmap( ftFace, encoding );
|
||||||
|
|
||||||
|
if( !err)
|
||||||
|
{
|
||||||
|
ftEncoding = encoding;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ftEncoding = ft_encoding_none;
|
||||||
|
}
|
||||||
|
|
||||||
|
charMap.clear();
|
||||||
|
return !err;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
unsigned int FTCharmap::GlyphListIndex( const unsigned int characterCode )
|
||||||
|
{
|
||||||
|
return charMap.find( characterCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
unsigned int FTCharmap::FontIndex( const unsigned int characterCode )
|
||||||
|
{
|
||||||
|
return FT_Get_Char_Index( ftFace, characterCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTCharmap::InsertIndex( const unsigned int characterCode, const unsigned int containerIndex)
|
||||||
|
{
|
||||||
|
charMap.insert( characterCode, containerIndex);
|
||||||
|
}
|
||||||
149
extern/bFTGL/src/FTContour.cpp
vendored
Normal file
149
extern/bFTGL/src/FTContour.cpp
vendored
Normal file
@@ -0,0 +1,149 @@
|
|||||||
|
#include "FTContour.h"
|
||||||
|
|
||||||
|
static const float BEZIER_STEP_SIZE = 0.2f;
|
||||||
|
|
||||||
|
|
||||||
|
void FTContour::AddPoint( FTPoint point)
|
||||||
|
{
|
||||||
|
if( pointList.empty() || point != pointList[pointList.size() - 1])
|
||||||
|
{
|
||||||
|
pointList.push_back( point);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTContour::AddPoint( float x, float y)
|
||||||
|
{
|
||||||
|
AddPoint( FTPoint( x, y, 0.0f));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTContour::evaluateQuadraticCurve()
|
||||||
|
{
|
||||||
|
for( unsigned int i = 0; i <= ( 1.0f / BEZIER_STEP_SIZE); i++)
|
||||||
|
{
|
||||||
|
float bezierValues[2][2];
|
||||||
|
|
||||||
|
float t = static_cast<float>(i) * BEZIER_STEP_SIZE;
|
||||||
|
|
||||||
|
bezierValues[0][0] = (1.0f - t) * controlPoints[0][0] + t * controlPoints[1][0];
|
||||||
|
bezierValues[0][1] = (1.0f - t) * controlPoints[0][1] + t * controlPoints[1][1];
|
||||||
|
|
||||||
|
bezierValues[1][0] = (1.0f - t) * controlPoints[1][0] + t * controlPoints[2][0];
|
||||||
|
bezierValues[1][1] = (1.0f - t) * controlPoints[1][1] + t * controlPoints[2][1];
|
||||||
|
|
||||||
|
bezierValues[0][0] = (1.0f - t) * bezierValues[0][0] + t * bezierValues[1][0];
|
||||||
|
bezierValues[0][1] = (1.0f - t) * bezierValues[0][1] + t * bezierValues[1][1];
|
||||||
|
|
||||||
|
AddPoint( bezierValues[0][0], bezierValues[0][1]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void FTContour::evaluateCubicCurve()
|
||||||
|
{
|
||||||
|
for( unsigned int i = 0; i <= ( 1.0f / BEZIER_STEP_SIZE); i++)
|
||||||
|
{
|
||||||
|
float bezierValues[3][2];
|
||||||
|
|
||||||
|
float t = static_cast<float>(i) * BEZIER_STEP_SIZE;
|
||||||
|
|
||||||
|
bezierValues[0][0] = (1.0f - t) * controlPoints[0][0] + t * controlPoints[1][0];
|
||||||
|
bezierValues[0][1] = (1.0f - t) * controlPoints[0][1] + t * controlPoints[1][1];
|
||||||
|
|
||||||
|
bezierValues[1][0] = (1.0f - t) * controlPoints[1][0] + t * controlPoints[2][0];
|
||||||
|
bezierValues[1][1] = (1.0f - t) * controlPoints[1][1] + t * controlPoints[2][1];
|
||||||
|
|
||||||
|
bezierValues[2][0] = (1.0f - t) * controlPoints[2][0] + t * controlPoints[3][0];
|
||||||
|
bezierValues[2][1] = (1.0f - t) * controlPoints[2][1] + t * controlPoints[3][1];
|
||||||
|
|
||||||
|
bezierValues[0][0] = (1.0f - t) * bezierValues[0][0] + t * bezierValues[1][0];
|
||||||
|
bezierValues[0][1] = (1.0f - t) * bezierValues[0][1] + t * bezierValues[1][1];
|
||||||
|
|
||||||
|
bezierValues[1][0] = (1.0f - t) * bezierValues[1][0] + t * bezierValues[2][0];
|
||||||
|
bezierValues[1][1] = (1.0f - t) * bezierValues[1][1] + t * bezierValues[2][1];
|
||||||
|
|
||||||
|
bezierValues[0][0] = (1.0f - t) * bezierValues[0][0] + t * bezierValues[1][0];
|
||||||
|
bezierValues[0][1] = (1.0f - t) * bezierValues[0][1] + t * bezierValues[1][1];
|
||||||
|
|
||||||
|
AddPoint( bezierValues[0][0], bezierValues[0][1]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTContour::FTContour( FT_Vector* contour, char* pointTags, unsigned int numberOfPoints)
|
||||||
|
{
|
||||||
|
for( unsigned int pointIndex = 0; pointIndex < numberOfPoints; ++ pointIndex)
|
||||||
|
{
|
||||||
|
char pointTag = pointTags[pointIndex];
|
||||||
|
|
||||||
|
if( pointTag == FT_Curve_Tag_On || numberOfPoints < 2)
|
||||||
|
{
|
||||||
|
AddPoint( contour[pointIndex].x, contour[pointIndex].y);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
FTPoint controlPoint( contour[pointIndex]);
|
||||||
|
FTPoint previousPoint = ( 0 == pointIndex)
|
||||||
|
? FTPoint( contour[numberOfPoints - 1])
|
||||||
|
: pointList[pointList.size() - 1];
|
||||||
|
|
||||||
|
FTPoint nextPoint = ( pointIndex == numberOfPoints - 1)
|
||||||
|
? pointList[0]
|
||||||
|
: FTPoint( contour[pointIndex + 1]);
|
||||||
|
|
||||||
|
if( pointTag == FT_Curve_Tag_Conic)
|
||||||
|
{
|
||||||
|
char nextPointTag = ( pointIndex == numberOfPoints - 1)
|
||||||
|
? pointTags[0]
|
||||||
|
: pointTags[pointIndex + 1];
|
||||||
|
|
||||||
|
while( nextPointTag == FT_Curve_Tag_Conic)
|
||||||
|
{
|
||||||
|
nextPoint = FTPoint( static_cast<float>( controlPoint.x + nextPoint.x) * 0.5f,
|
||||||
|
static_cast<float>( controlPoint.y + nextPoint.y) * 0.5f,
|
||||||
|
0);
|
||||||
|
|
||||||
|
controlPoints[0][0] = previousPoint.x; controlPoints[0][1] = previousPoint.y;
|
||||||
|
controlPoints[1][0] = controlPoint.x; controlPoints[1][1] = controlPoint.y;
|
||||||
|
controlPoints[2][0] = nextPoint.x; controlPoints[2][1] = nextPoint.y;
|
||||||
|
|
||||||
|
evaluateQuadraticCurve();
|
||||||
|
++pointIndex;
|
||||||
|
|
||||||
|
previousPoint = nextPoint;
|
||||||
|
controlPoint = FTPoint( contour[pointIndex]);
|
||||||
|
nextPoint = ( pointIndex == numberOfPoints - 1)
|
||||||
|
? pointList[0]
|
||||||
|
: FTPoint( contour[pointIndex + 1]);
|
||||||
|
nextPointTag = ( pointIndex == numberOfPoints - 1)
|
||||||
|
? pointTags[0]
|
||||||
|
: pointTags[pointIndex + 1];
|
||||||
|
}
|
||||||
|
|
||||||
|
controlPoints[0][0] = previousPoint.x; controlPoints[0][1] = previousPoint.y;
|
||||||
|
controlPoints[1][0] = controlPoint.x; controlPoints[1][1] = controlPoint.y;
|
||||||
|
controlPoints[2][0] = nextPoint.x; controlPoints[2][1] = nextPoint.y;
|
||||||
|
|
||||||
|
evaluateQuadraticCurve();
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( pointTag == FT_Curve_Tag_Cubic)
|
||||||
|
{
|
||||||
|
FTPoint controlPoint2 = nextPoint;
|
||||||
|
|
||||||
|
FTPoint nextPoint = ( pointIndex == numberOfPoints - 2)
|
||||||
|
? pointList[0]
|
||||||
|
: FTPoint( contour[pointIndex + 2]);
|
||||||
|
|
||||||
|
controlPoints[0][0] = previousPoint.x; controlPoints[0][1] = previousPoint.y;
|
||||||
|
controlPoints[1][0] = controlPoint.x; controlPoints[1][1] = controlPoint.y;
|
||||||
|
controlPoints[2][0] = controlPoint2.x; controlPoints[2][1] = controlPoint2.y;
|
||||||
|
controlPoints[3][0] = nextPoint.x; controlPoints[3][1] = nextPoint.y;
|
||||||
|
|
||||||
|
evaluateCubicCurve();
|
||||||
|
++pointIndex;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
141
extern/bFTGL/src/FTExtrdGlyph.cpp
vendored
Normal file
141
extern/bFTGL/src/FTExtrdGlyph.cpp
vendored
Normal file
@@ -0,0 +1,141 @@
|
|||||||
|
#include <math.h>
|
||||||
|
|
||||||
|
#include "FTExtrdGlyph.h"
|
||||||
|
#include "FTVectoriser.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTExtrdGlyph::FTExtrdGlyph( FT_GlyphSlot glyph, float d)
|
||||||
|
: FTGlyph( glyph),
|
||||||
|
glList(0),
|
||||||
|
depth(d)
|
||||||
|
{
|
||||||
|
bBox.SetDepth( -depth);
|
||||||
|
|
||||||
|
if( ft_glyph_format_outline != glyph->format)
|
||||||
|
{
|
||||||
|
err = 0x14; // Invalid_Outline
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
FTVectoriser vectoriser( glyph);
|
||||||
|
if ( ( vectoriser.ContourCount() < 1) || ( vectoriser.PointCount() < 3))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned int tesselationIndex;
|
||||||
|
glList = glGenLists(1);
|
||||||
|
glNewList( glList, GL_COMPILE);
|
||||||
|
|
||||||
|
vectoriser.MakeMesh( 1.0);
|
||||||
|
glNormal3d(0.0, 0.0, 1.0);
|
||||||
|
|
||||||
|
const FTMesh* mesh = vectoriser.GetMesh();
|
||||||
|
for( tesselationIndex = 0; tesselationIndex < mesh->TesselationCount(); ++tesselationIndex)
|
||||||
|
{
|
||||||
|
const FTTesselation* subMesh = mesh->Tesselation( tesselationIndex);
|
||||||
|
unsigned int polyonType = subMesh->PolygonType();
|
||||||
|
|
||||||
|
glBegin( polyonType);
|
||||||
|
for( unsigned int pointIndex = 0; pointIndex < subMesh->PointCount(); ++pointIndex)
|
||||||
|
{
|
||||||
|
glVertex3f( subMesh->Point( pointIndex).x / 64.0f,
|
||||||
|
subMesh->Point( pointIndex).y / 64.0f,
|
||||||
|
0.0f);
|
||||||
|
}
|
||||||
|
glEnd();
|
||||||
|
}
|
||||||
|
|
||||||
|
vectoriser.MakeMesh( -1.0);
|
||||||
|
glNormal3d(0.0, 0.0, -1.0);
|
||||||
|
|
||||||
|
mesh = vectoriser.GetMesh();
|
||||||
|
for( tesselationIndex = 0; tesselationIndex < mesh->TesselationCount(); ++tesselationIndex)
|
||||||
|
{
|
||||||
|
const FTTesselation* subMesh = mesh->Tesselation( tesselationIndex);
|
||||||
|
unsigned int polyonType = subMesh->PolygonType();
|
||||||
|
|
||||||
|
glBegin( polyonType);
|
||||||
|
for( unsigned int pointIndex = 0; pointIndex < subMesh->PointCount(); ++pointIndex)
|
||||||
|
{
|
||||||
|
glVertex3f( subMesh->Point( pointIndex).x / 64.0f,
|
||||||
|
subMesh->Point( pointIndex).y / 64.0f,
|
||||||
|
-depth);
|
||||||
|
}
|
||||||
|
glEnd();
|
||||||
|
}
|
||||||
|
|
||||||
|
int contourFlag = vectoriser.ContourFlag();
|
||||||
|
|
||||||
|
for( size_t c = 0; c < vectoriser.ContourCount(); ++c)
|
||||||
|
{
|
||||||
|
const FTContour* contour = vectoriser.Contour(c);
|
||||||
|
unsigned int numberOfPoints = contour->PointCount();
|
||||||
|
|
||||||
|
glBegin( GL_QUAD_STRIP);
|
||||||
|
for( unsigned int j = 0; j <= numberOfPoints; ++j)
|
||||||
|
{
|
||||||
|
unsigned int index = ( j == numberOfPoints) ? 0 : j;
|
||||||
|
unsigned int nextIndex = ( index == numberOfPoints - 1) ? 0 : index + 1;
|
||||||
|
|
||||||
|
FTPoint normal = GetNormal( contour->Point(index), contour->Point(nextIndex));
|
||||||
|
glNormal3f( normal.x, normal.y, 0.0f);
|
||||||
|
|
||||||
|
if( contourFlag & ft_outline_reverse_fill)
|
||||||
|
{
|
||||||
|
glVertex3f( contour->Point(index).x / 64.0f, contour->Point(index).y / 64.0f, 0.0f);
|
||||||
|
glVertex3f( contour->Point(index).x / 64.0f, contour->Point(index).y / 64.0f, -depth);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
glVertex3f( contour->Point(index).x / 64.0f, contour->Point(index).y / 64.0f, -depth);
|
||||||
|
glVertex3f( contour->Point(index).x / 64.0f, contour->Point(index).y / 64.0f, 0.0f);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
glEnd();
|
||||||
|
}
|
||||||
|
|
||||||
|
glEndList();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTExtrdGlyph::~FTExtrdGlyph()
|
||||||
|
{
|
||||||
|
glDeleteLists( glList, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTExtrdGlyph::Render( const FTPoint& pen)
|
||||||
|
{
|
||||||
|
if( glList)
|
||||||
|
{
|
||||||
|
glTranslatef( pen.x, pen.y, 0);
|
||||||
|
glCallList( glList);
|
||||||
|
glTranslatef( -pen.x, -pen.y, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return advance;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTPoint FTExtrdGlyph::GetNormal( const FTPoint &a, const FTPoint &b)
|
||||||
|
{
|
||||||
|
float vectorX = a.x - b.x;
|
||||||
|
float vectorY = a.y - b.y;
|
||||||
|
|
||||||
|
float length = sqrt( vectorX * vectorX + vectorY * vectorY );
|
||||||
|
|
||||||
|
if( length > 0.0f)
|
||||||
|
{
|
||||||
|
length = 1 / length;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
length = 0.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
return FTPoint( -vectorY * length,
|
||||||
|
vectorX * length,
|
||||||
|
0.0f);
|
||||||
|
}
|
||||||
|
|
||||||
154
extern/bFTGL/src/FTFace.cpp
vendored
Normal file
154
extern/bFTGL/src/FTFace.cpp
vendored
Normal file
@@ -0,0 +1,154 @@
|
|||||||
|
#include "FTFace.h"
|
||||||
|
#include "FTLibrary.h"
|
||||||
|
|
||||||
|
#include FT_TRUETYPE_TABLES_H
|
||||||
|
|
||||||
|
FTFace::FTFace( const char* filename)
|
||||||
|
: numGlyphs(0),
|
||||||
|
fontEncodingList(0),
|
||||||
|
err(0)
|
||||||
|
{
|
||||||
|
const FT_Long DEFAULT_FACE_INDEX = 0;
|
||||||
|
ftFace = new FT_Face;
|
||||||
|
|
||||||
|
err = FT_New_Face( *FTLibrary::Instance().GetLibrary(), filename, DEFAULT_FACE_INDEX, ftFace);
|
||||||
|
|
||||||
|
if( err)
|
||||||
|
{
|
||||||
|
delete ftFace;
|
||||||
|
ftFace = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
numGlyphs = (*ftFace)->num_glyphs;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTFace::FTFace( const unsigned char *pBufferBytes, size_t bufferSizeInBytes)
|
||||||
|
: numGlyphs(0),
|
||||||
|
err(0)
|
||||||
|
{
|
||||||
|
const FT_Long DEFAULT_FACE_INDEX = 0;
|
||||||
|
ftFace = new FT_Face;
|
||||||
|
|
||||||
|
err = FT_New_Memory_Face( *FTLibrary::Instance().GetLibrary(), (FT_Byte *)pBufferBytes, bufferSizeInBytes, DEFAULT_FACE_INDEX, ftFace);
|
||||||
|
|
||||||
|
if( err)
|
||||||
|
{
|
||||||
|
delete ftFace;
|
||||||
|
ftFace = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
numGlyphs = (*ftFace)->num_glyphs;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTFace::~FTFace()
|
||||||
|
{
|
||||||
|
Close();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool FTFace::Attach( const char* filename)
|
||||||
|
{
|
||||||
|
err = FT_Attach_File( *ftFace, filename);
|
||||||
|
return !err;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool FTFace::Attach( const unsigned char *pBufferBytes, size_t bufferSizeInBytes)
|
||||||
|
{
|
||||||
|
FT_Open_Args open;
|
||||||
|
|
||||||
|
open.flags = FT_OPEN_MEMORY;
|
||||||
|
open.memory_base = (FT_Byte *)pBufferBytes;
|
||||||
|
open.memory_size = bufferSizeInBytes;
|
||||||
|
|
||||||
|
err = FT_Attach_Stream( *ftFace, &open);
|
||||||
|
return !err;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTFace::Close()
|
||||||
|
{
|
||||||
|
if( ftFace)
|
||||||
|
{
|
||||||
|
FT_Done_Face( *ftFace);
|
||||||
|
delete ftFace;
|
||||||
|
ftFace = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const FTSize& FTFace::Size( const unsigned int size, const unsigned int res)
|
||||||
|
{
|
||||||
|
charSize.CharSize( ftFace, size, res, res);
|
||||||
|
err = charSize.Error();
|
||||||
|
|
||||||
|
return charSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
unsigned int FTFace::CharMapCount()
|
||||||
|
{
|
||||||
|
return (*ftFace)->num_charmaps;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_Encoding* FTFace::CharMapList()
|
||||||
|
{
|
||||||
|
if( 0 == fontEncodingList)
|
||||||
|
{
|
||||||
|
fontEncodingList = new FT_Encoding[CharMapCount()];
|
||||||
|
for( size_t encodingIndex = 0; encodingIndex < CharMapCount(); ++encodingIndex)
|
||||||
|
{
|
||||||
|
fontEncodingList[encodingIndex] = (*ftFace)->charmaps[encodingIndex]->encoding;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return fontEncodingList;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
unsigned int FTFace::UnitsPerEM() const
|
||||||
|
{
|
||||||
|
return (*ftFace)->units_per_EM;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTPoint FTFace::KernAdvance( unsigned int index1, unsigned int index2)
|
||||||
|
{
|
||||||
|
float x, y;
|
||||||
|
x = y = 0.0f;
|
||||||
|
|
||||||
|
if( FT_HAS_KERNING((*ftFace)) && index1 && index2)
|
||||||
|
{
|
||||||
|
FT_Vector kernAdvance;
|
||||||
|
kernAdvance.x = kernAdvance.y = 0;
|
||||||
|
|
||||||
|
err = FT_Get_Kerning( *ftFace, index1, index2, ft_kerning_unfitted, &kernAdvance);
|
||||||
|
if( !err)
|
||||||
|
{
|
||||||
|
x = static_cast<float>( kernAdvance.x) / 64.0f;
|
||||||
|
y = static_cast<float>( kernAdvance.y) / 64.0f;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return FTPoint( x, y, 0.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_GlyphSlot FTFace::Glyph( unsigned int index, FT_Int load_flags)
|
||||||
|
{
|
||||||
|
err = FT_Load_Glyph( *ftFace, index, load_flags);
|
||||||
|
if( err)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (*ftFace)->glyph;
|
||||||
|
}
|
||||||
|
|
||||||
271
extern/bFTGL/src/FTFont.cpp
vendored
Normal file
271
extern/bFTGL/src/FTFont.cpp
vendored
Normal file
@@ -0,0 +1,271 @@
|
|||||||
|
#include "FTFace.h"
|
||||||
|
#include "FTFont.h"
|
||||||
|
#include "FTGlyphContainer.h"
|
||||||
|
#include "FTBBox.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTFont::FTFont( const char* fontname)
|
||||||
|
: face( fontname),
|
||||||
|
glyphList(0)
|
||||||
|
{
|
||||||
|
err = face.Error();
|
||||||
|
if( err == 0)
|
||||||
|
{
|
||||||
|
glyphList = new FTGlyphContainer( &face);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTFont::FTFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes)
|
||||||
|
: face( pBufferBytes, bufferSizeInBytes),
|
||||||
|
glyphList(0)
|
||||||
|
{
|
||||||
|
err = face.Error();
|
||||||
|
if( err == 0)
|
||||||
|
{
|
||||||
|
glyphList = new FTGlyphContainer( &face);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTFont::~FTFont()
|
||||||
|
{
|
||||||
|
delete glyphList;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool FTFont::Attach( const char* filename)
|
||||||
|
{
|
||||||
|
if( face.Attach( filename))
|
||||||
|
{
|
||||||
|
err = 0;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
err = face.Error();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool FTFont::Attach( const unsigned char *pBufferBytes, size_t bufferSizeInBytes)
|
||||||
|
{
|
||||||
|
if( face.Attach( pBufferBytes, bufferSizeInBytes))
|
||||||
|
{
|
||||||
|
err = 0;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
err = face.Error();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool FTFont::FaceSize( const unsigned int size, const unsigned int res )
|
||||||
|
{
|
||||||
|
charSize = face.Size( size, res);
|
||||||
|
|
||||||
|
if( face.Error())
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( glyphList != NULL)
|
||||||
|
{
|
||||||
|
delete glyphList;
|
||||||
|
}
|
||||||
|
|
||||||
|
glyphList = new FTGlyphContainer( &face);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
unsigned int FTFont::FaceSize() const
|
||||||
|
{
|
||||||
|
return charSize.CharSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool FTFont::CharMap( FT_Encoding encoding)
|
||||||
|
{
|
||||||
|
bool result = glyphList->CharMap( encoding);
|
||||||
|
err = glyphList->Error();
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
unsigned int FTFont::CharMapCount()
|
||||||
|
{
|
||||||
|
return face.CharMapCount();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_Encoding* FTFont::CharMapList()
|
||||||
|
{
|
||||||
|
return face.CharMapList();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTFont::Ascender() const
|
||||||
|
{
|
||||||
|
return charSize.Ascender();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTFont::Descender() const
|
||||||
|
{
|
||||||
|
return charSize.Descender();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTFont::BBox( const char* string,
|
||||||
|
float& llx, float& lly, float& llz, float& urx, float& ury, float& urz)
|
||||||
|
{
|
||||||
|
FTBBox totalBBox;
|
||||||
|
|
||||||
|
if((NULL != string) && ('\0' != *string))
|
||||||
|
{
|
||||||
|
const unsigned char* c = (unsigned char*)string;
|
||||||
|
|
||||||
|
CheckGlyph( *c);
|
||||||
|
|
||||||
|
totalBBox = glyphList->BBox( *c);
|
||||||
|
float advance = glyphList->Advance( *c, *(c + 1));
|
||||||
|
++c;
|
||||||
|
|
||||||
|
while( *c)
|
||||||
|
{
|
||||||
|
CheckGlyph( *c);
|
||||||
|
FTBBox tempBBox = glyphList->BBox( *c);
|
||||||
|
tempBBox.Move( FTPoint( advance, 0.0f, 0.0f));
|
||||||
|
totalBBox += tempBBox;
|
||||||
|
advance += glyphList->Advance( *c, *(c + 1));
|
||||||
|
++c;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
llx = totalBBox.lowerX;
|
||||||
|
lly = totalBBox.lowerY;
|
||||||
|
llz = totalBBox.lowerZ;
|
||||||
|
urx = totalBBox.upperX;
|
||||||
|
ury = totalBBox.upperY;
|
||||||
|
urz = totalBBox.upperZ;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTFont::BBox( const wchar_t* string,
|
||||||
|
float& llx, float& lly, float& llz, float& urx, float& ury, float& urz)
|
||||||
|
{
|
||||||
|
FTBBox totalBBox;
|
||||||
|
|
||||||
|
if((NULL != string) && ('\0' != *string))
|
||||||
|
{
|
||||||
|
const wchar_t* c = string;
|
||||||
|
|
||||||
|
CheckGlyph( *c);
|
||||||
|
|
||||||
|
totalBBox = glyphList->BBox( *c);
|
||||||
|
float advance = glyphList->Advance( *c, *(c + 1));
|
||||||
|
++c;
|
||||||
|
|
||||||
|
while( *c)
|
||||||
|
{
|
||||||
|
CheckGlyph( *c);
|
||||||
|
FTBBox tempBBox = glyphList->BBox( *c);
|
||||||
|
tempBBox.Move( FTPoint( advance, 0.0f, 0.0f));
|
||||||
|
totalBBox += tempBBox;
|
||||||
|
advance += glyphList->Advance( *c, *(c + 1));
|
||||||
|
++c;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
llx = totalBBox.lowerX;
|
||||||
|
lly = totalBBox.lowerY;
|
||||||
|
llz = totalBBox.lowerZ;
|
||||||
|
urx = totalBBox.upperX;
|
||||||
|
ury = totalBBox.upperY;
|
||||||
|
urz = totalBBox.upperZ;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTFont::Advance( const wchar_t* string)
|
||||||
|
{
|
||||||
|
const wchar_t* c = string;
|
||||||
|
float width = 0.0f;
|
||||||
|
|
||||||
|
while( *c)
|
||||||
|
{
|
||||||
|
CheckGlyph( *c);
|
||||||
|
width += glyphList->Advance( *c, *(c + 1));
|
||||||
|
++c;
|
||||||
|
}
|
||||||
|
|
||||||
|
return width;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTFont::Advance( const char* string)
|
||||||
|
{
|
||||||
|
const unsigned char* c = (unsigned char*)string;
|
||||||
|
float width = 0.0f;
|
||||||
|
|
||||||
|
while( *c)
|
||||||
|
{
|
||||||
|
CheckGlyph( *c);
|
||||||
|
width += glyphList->Advance( *c, *(c + 1));
|
||||||
|
++c;
|
||||||
|
}
|
||||||
|
|
||||||
|
return width;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTFont::Render( const char* string )
|
||||||
|
{
|
||||||
|
const unsigned char* c = (unsigned char*)string;
|
||||||
|
pen.x = 0; pen.y = 0;
|
||||||
|
|
||||||
|
while( *c)
|
||||||
|
{
|
||||||
|
DoRender( *c, *(c + 1));
|
||||||
|
++c;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTFont::Render( const wchar_t* string )
|
||||||
|
{
|
||||||
|
const wchar_t* c = string;
|
||||||
|
pen.x = 0; pen.y = 0;
|
||||||
|
|
||||||
|
while( *c)
|
||||||
|
{
|
||||||
|
DoRender( *c, *(c + 1));
|
||||||
|
++c;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTFont::DoRender( const unsigned int chr, const unsigned int nextChr)
|
||||||
|
{
|
||||||
|
CheckGlyph( chr);
|
||||||
|
|
||||||
|
FTPoint kernAdvance = glyphList->Render( chr, nextChr, pen);
|
||||||
|
|
||||||
|
pen.x += kernAdvance.x;
|
||||||
|
pen.y += kernAdvance.y;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTFont::CheckGlyph( const unsigned int characterCode)
|
||||||
|
{
|
||||||
|
if( NULL == glyphList->Glyph( characterCode))
|
||||||
|
{
|
||||||
|
unsigned int glyphIndex = glyphList->FontIndex( characterCode);
|
||||||
|
glyphList->Add( MakeGlyph( glyphIndex), characterCode);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
66
extern/bFTGL/src/FTGLBitmapFont.cpp
vendored
Normal file
66
extern/bFTGL/src/FTGLBitmapFont.cpp
vendored
Normal file
@@ -0,0 +1,66 @@
|
|||||||
|
#include "FTGLBitmapFont.h"
|
||||||
|
#include "FTBitmapGlyph.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTGLBitmapFont::FTGLBitmapFont( const char* fontname)
|
||||||
|
: FTFont( fontname)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLBitmapFont::FTGLBitmapFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes)
|
||||||
|
: FTFont( pBufferBytes, bufferSizeInBytes)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLBitmapFont::~FTGLBitmapFont()
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGlyph* FTGLBitmapFont::MakeGlyph( unsigned int g)
|
||||||
|
{
|
||||||
|
FT_GlyphSlot ftGlyph = face.Glyph( g, FT_LOAD_DEFAULT);
|
||||||
|
|
||||||
|
if( ftGlyph)
|
||||||
|
{
|
||||||
|
FTBitmapGlyph* tempGlyph = new FTBitmapGlyph( ftGlyph);
|
||||||
|
return tempGlyph;
|
||||||
|
}
|
||||||
|
|
||||||
|
err = face.Error();
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTGLBitmapFont::Render( const char* string)
|
||||||
|
{
|
||||||
|
glPushClientAttrib( GL_CLIENT_PIXEL_STORE_BIT);
|
||||||
|
glPushAttrib( GL_ENABLE_BIT);
|
||||||
|
|
||||||
|
glPixelStorei( GL_UNPACK_LSB_FIRST, GL_FALSE);
|
||||||
|
glPixelStorei( GL_UNPACK_ALIGNMENT, 1);
|
||||||
|
|
||||||
|
glDisable( GL_BLEND);
|
||||||
|
|
||||||
|
FTFont::Render( string);
|
||||||
|
|
||||||
|
glPopAttrib();
|
||||||
|
glPopClientAttrib();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTGLBitmapFont::Render( const wchar_t* string)
|
||||||
|
{
|
||||||
|
glPushClientAttrib( GL_CLIENT_PIXEL_STORE_BIT);
|
||||||
|
glPushAttrib( GL_ENABLE_BIT);
|
||||||
|
|
||||||
|
glPixelStorei( GL_UNPACK_LSB_FIRST, GL_FALSE);
|
||||||
|
glPixelStorei( GL_UNPACK_ALIGNMENT, 1);
|
||||||
|
|
||||||
|
glDisable( GL_BLEND);
|
||||||
|
|
||||||
|
FTFont::Render( string);
|
||||||
|
|
||||||
|
glPopAttrib();
|
||||||
|
glPopClientAttrib();
|
||||||
|
}
|
||||||
|
|
||||||
53
extern/bFTGL/src/FTGLBufferFont.cpp
vendored
Normal file
53
extern/bFTGL/src/FTGLBufferFont.cpp
vendored
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
#include "FTGLBufferFont.h"
|
||||||
|
#include "FTBufferGlyph.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTGLBufferFont::FTGLBufferFont( const char* fontname)
|
||||||
|
: FTFont( fontname),
|
||||||
|
buffer(0)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLBufferFont::FTGLBufferFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes)
|
||||||
|
: FTFont( pBufferBytes, bufferSizeInBytes),
|
||||||
|
buffer(0)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLBufferFont::~FTGLBufferFont()
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGlyph* FTGLBufferFont::MakeGlyph( unsigned int g)
|
||||||
|
{
|
||||||
|
FT_GlyphSlot ftGlyph = face.Glyph( g, FT_LOAD_NO_HINTING);
|
||||||
|
|
||||||
|
if( ftGlyph)
|
||||||
|
{
|
||||||
|
FTBufferGlyph* tempGlyph = new FTBufferGlyph( ftGlyph, buffer);
|
||||||
|
return tempGlyph;
|
||||||
|
}
|
||||||
|
|
||||||
|
err = face.Error();
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTGLBufferFont::Render( const char* string)
|
||||||
|
{
|
||||||
|
if( NULL != buffer)
|
||||||
|
{
|
||||||
|
FTFont::Render( string);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTGLBufferFont::Render( const wchar_t* string)
|
||||||
|
{
|
||||||
|
if( NULL != buffer)
|
||||||
|
{
|
||||||
|
FTFont::Render( string);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
35
extern/bFTGL/src/FTGLExtrdFont.cpp
vendored
Normal file
35
extern/bFTGL/src/FTGLExtrdFont.cpp
vendored
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
#include "FTGLExtrdFont.h"
|
||||||
|
#include "FTExtrdGlyph.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTGLExtrdFont::FTGLExtrdFont( const char* fontname)
|
||||||
|
: FTFont( fontname),
|
||||||
|
depth( 0.0f)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLExtrdFont::FTGLExtrdFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes)
|
||||||
|
: FTFont( pBufferBytes, bufferSizeInBytes),
|
||||||
|
depth( 0.0f)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLExtrdFont::~FTGLExtrdFont()
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGlyph* FTGLExtrdFont::MakeGlyph( unsigned int glyphIndex)
|
||||||
|
{
|
||||||
|
FT_GlyphSlot ftGlyph = face.Glyph( glyphIndex, FT_LOAD_NO_HINTING);
|
||||||
|
|
||||||
|
if( ftGlyph)
|
||||||
|
{
|
||||||
|
FTExtrdGlyph* tempGlyph = new FTExtrdGlyph( ftGlyph, depth);
|
||||||
|
return tempGlyph;
|
||||||
|
}
|
||||||
|
|
||||||
|
err = face.Error();
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
66
extern/bFTGL/src/FTGLOutlineFont.cpp
vendored
Normal file
66
extern/bFTGL/src/FTGLOutlineFont.cpp
vendored
Normal file
@@ -0,0 +1,66 @@
|
|||||||
|
#include "FTGLOutlineFont.h"
|
||||||
|
#include "FTOutlineGlyph.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTGLOutlineFont::FTGLOutlineFont( const char* fontname)
|
||||||
|
: FTFont( fontname)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLOutlineFont::FTGLOutlineFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes)
|
||||||
|
: FTFont( pBufferBytes, bufferSizeInBytes)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLOutlineFont::~FTGLOutlineFont()
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGlyph* FTGLOutlineFont::MakeGlyph( unsigned int g)
|
||||||
|
{
|
||||||
|
FT_GlyphSlot ftGlyph = face.Glyph( g, FT_LOAD_NO_HINTING);
|
||||||
|
|
||||||
|
if( ftGlyph)
|
||||||
|
{
|
||||||
|
FTOutlineGlyph* tempGlyph = new FTOutlineGlyph( ftGlyph);
|
||||||
|
return tempGlyph;
|
||||||
|
}
|
||||||
|
|
||||||
|
err = face.Error();
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTGLOutlineFont::Render( const char* string)
|
||||||
|
{
|
||||||
|
glPushAttrib( GL_ENABLE_BIT | GL_HINT_BIT | GL_LINE_BIT | GL_COLOR_BUFFER_BIT);
|
||||||
|
|
||||||
|
glDisable( GL_TEXTURE_2D);
|
||||||
|
|
||||||
|
glEnable( GL_LINE_SMOOTH);
|
||||||
|
glHint( GL_LINE_SMOOTH_HINT, GL_DONT_CARE);
|
||||||
|
glEnable(GL_BLEND);
|
||||||
|
glBlendFunc( GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); // GL_ONE
|
||||||
|
|
||||||
|
FTFont::Render( string);
|
||||||
|
|
||||||
|
glPopAttrib();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTGLOutlineFont::Render( const wchar_t* string)
|
||||||
|
{
|
||||||
|
glPushAttrib( GL_ENABLE_BIT | GL_HINT_BIT | GL_LINE_BIT | GL_COLOR_BUFFER_BIT);
|
||||||
|
|
||||||
|
glDisable( GL_TEXTURE_2D);
|
||||||
|
|
||||||
|
glEnable( GL_LINE_SMOOTH);
|
||||||
|
glHint( GL_LINE_SMOOTH_HINT, GL_DONT_CARE);
|
||||||
|
glEnable(GL_BLEND);
|
||||||
|
glBlendFunc( GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); // GL_ONE
|
||||||
|
|
||||||
|
FTFont::Render( string);
|
||||||
|
|
||||||
|
glPopAttrib();
|
||||||
|
}
|
||||||
|
|
||||||
68
extern/bFTGL/src/FTGLPixmapFont.cpp
vendored
Normal file
68
extern/bFTGL/src/FTGLPixmapFont.cpp
vendored
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
#include "FTGLPixmapFont.h"
|
||||||
|
#include "FTPixmapGlyph.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTGLPixmapFont::FTGLPixmapFont( const char* fontname)
|
||||||
|
: FTFont( fontname)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLPixmapFont::FTGLPixmapFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes)
|
||||||
|
: FTFont( pBufferBytes, bufferSizeInBytes)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLPixmapFont::~FTGLPixmapFont()
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGlyph* FTGLPixmapFont::MakeGlyph( unsigned int g)
|
||||||
|
{
|
||||||
|
FT_GlyphSlot ftGlyph = face.Glyph( g, FT_LOAD_NO_HINTING | FT_LOAD_NO_BITMAP);
|
||||||
|
|
||||||
|
if( ftGlyph)
|
||||||
|
{
|
||||||
|
FTPixmapGlyph* tempGlyph = new FTPixmapGlyph( ftGlyph);
|
||||||
|
return tempGlyph;
|
||||||
|
}
|
||||||
|
|
||||||
|
err = face.Error();
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTGLPixmapFont::Render( const char* string)
|
||||||
|
{
|
||||||
|
glPushAttrib( GL_ENABLE_BIT | GL_PIXEL_MODE_BIT | GL_COLOR_BUFFER_BIT);
|
||||||
|
glPushClientAttrib( GL_CLIENT_PIXEL_STORE_BIT);
|
||||||
|
|
||||||
|
glEnable(GL_BLEND);
|
||||||
|
glBlendFunc( GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
||||||
|
|
||||||
|
glDisable( GL_TEXTURE_2D);
|
||||||
|
|
||||||
|
FTFont::Render( string);
|
||||||
|
|
||||||
|
glPopClientAttrib();
|
||||||
|
glPopAttrib();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTGLPixmapFont::Render( const wchar_t* string)
|
||||||
|
{
|
||||||
|
//glPushAttrib( GL_ENABLE_BIT | GL_PIXEL_MODE_BIT | GL_COLOR_BUFFER_BIT);
|
||||||
|
// glPushClientAttrib( GL_CLIENT_PIXEL_STORE_BIT);
|
||||||
|
|
||||||
|
glEnable(GL_BLEND);
|
||||||
|
glBlendFunc( GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
||||||
|
|
||||||
|
glDisable( GL_TEXTURE_2D);
|
||||||
|
|
||||||
|
FTFont::Render( string);
|
||||||
|
|
||||||
|
glDisable(GL_BLEND);
|
||||||
|
// glPopClientAttrib();
|
||||||
|
// glPopAttrib();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
33
extern/bFTGL/src/FTGLPolygonFont.cpp
vendored
Normal file
33
extern/bFTGL/src/FTGLPolygonFont.cpp
vendored
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
#include "FTGLPolygonFont.h"
|
||||||
|
#include "FTPolyGlyph.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTGLPolygonFont::FTGLPolygonFont( const char* fontname)
|
||||||
|
: FTFont( fontname)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLPolygonFont::FTGLPolygonFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes)
|
||||||
|
: FTFont( pBufferBytes, bufferSizeInBytes)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLPolygonFont::~FTGLPolygonFont()
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTGlyph* FTGLPolygonFont::MakeGlyph( unsigned int g)
|
||||||
|
{
|
||||||
|
FT_GlyphSlot ftGlyph = face.Glyph( g, FT_LOAD_NO_HINTING);
|
||||||
|
|
||||||
|
if( ftGlyph)
|
||||||
|
{
|
||||||
|
FTPolyGlyph* tempGlyph = new FTPolyGlyph( ftGlyph);
|
||||||
|
return tempGlyph;
|
||||||
|
}
|
||||||
|
|
||||||
|
err = face.Error();
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
178
extern/bFTGL/src/FTGLTextureFont.cpp
vendored
Normal file
178
extern/bFTGL/src/FTGLTextureFont.cpp
vendored
Normal file
@@ -0,0 +1,178 @@
|
|||||||
|
#include <string> // For memset
|
||||||
|
|
||||||
|
#include "FTGLTextureFont.h"
|
||||||
|
#include "FTTextureGlyph.h"
|
||||||
|
|
||||||
|
|
||||||
|
inline GLuint NextPowerOf2( GLuint in)
|
||||||
|
{
|
||||||
|
in -= 1;
|
||||||
|
|
||||||
|
in |= in >> 16;
|
||||||
|
in |= in >> 8;
|
||||||
|
in |= in >> 4;
|
||||||
|
in |= in >> 2;
|
||||||
|
in |= in >> 1;
|
||||||
|
|
||||||
|
return in + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLTextureFont::FTGLTextureFont( const char* fontname)
|
||||||
|
: FTFont( fontname),
|
||||||
|
maxTextSize(0),
|
||||||
|
textureWidth(0),
|
||||||
|
textureHeight(0),
|
||||||
|
glyphHeight(0),
|
||||||
|
glyphWidth(0),
|
||||||
|
padding(3),
|
||||||
|
xOffset(0),
|
||||||
|
yOffset(0)
|
||||||
|
{
|
||||||
|
remGlyphs = numGlyphs = face.GlyphCount();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLTextureFont::FTGLTextureFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes)
|
||||||
|
: FTFont( pBufferBytes, bufferSizeInBytes),
|
||||||
|
maxTextSize(0),
|
||||||
|
textureWidth(0),
|
||||||
|
textureHeight(0),
|
||||||
|
glyphHeight(0),
|
||||||
|
glyphWidth(0),
|
||||||
|
padding(3),
|
||||||
|
xOffset(0),
|
||||||
|
yOffset(0)
|
||||||
|
{
|
||||||
|
remGlyphs = numGlyphs = face.GlyphCount();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTGLTextureFont::~FTGLTextureFont()
|
||||||
|
{
|
||||||
|
glDeleteTextures( textureIDList.size(), (const GLuint*)&textureIDList[0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTGlyph* FTGLTextureFont::MakeGlyph( unsigned int glyphIndex)
|
||||||
|
{
|
||||||
|
FT_GlyphSlot ftGlyph = face.Glyph( glyphIndex, FT_LOAD_NO_HINTING | FT_LOAD_NO_BITMAP);
|
||||||
|
|
||||||
|
if( ftGlyph)
|
||||||
|
{
|
||||||
|
glyphHeight = static_cast<int>( charSize.Height());
|
||||||
|
glyphWidth = static_cast<int>( charSize.Width());
|
||||||
|
|
||||||
|
if( textureIDList.empty())
|
||||||
|
{
|
||||||
|
textureIDList.push_back( CreateTexture());
|
||||||
|
xOffset = yOffset = padding;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( xOffset > ( textureWidth - glyphWidth))
|
||||||
|
{
|
||||||
|
xOffset = padding;
|
||||||
|
yOffset += glyphHeight;
|
||||||
|
|
||||||
|
if( yOffset > ( textureHeight - glyphHeight))
|
||||||
|
{
|
||||||
|
textureIDList.push_back( CreateTexture());
|
||||||
|
yOffset = padding;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
FTTextureGlyph* tempGlyph = new FTTextureGlyph( ftGlyph, textureIDList[textureIDList.size() - 1],
|
||||||
|
xOffset, yOffset, textureWidth, textureHeight);
|
||||||
|
xOffset += static_cast<int>( tempGlyph->BBox().upperX - tempGlyph->BBox().lowerX + padding);
|
||||||
|
|
||||||
|
--remGlyphs;
|
||||||
|
return tempGlyph;
|
||||||
|
}
|
||||||
|
|
||||||
|
err = face.Error();
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTGLTextureFont::CalculateTextureSize()
|
||||||
|
{
|
||||||
|
if( !maxTextSize)
|
||||||
|
{
|
||||||
|
glGetIntegerv( GL_MAX_TEXTURE_SIZE, (GLint*)&maxTextSize);
|
||||||
|
}
|
||||||
|
|
||||||
|
textureWidth = NextPowerOf2( (remGlyphs * glyphWidth) + ( padding * 2));
|
||||||
|
if( textureWidth > maxTextSize)
|
||||||
|
{
|
||||||
|
textureWidth = maxTextSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
int h = static_cast<int>( (textureWidth - ( padding * 2)) / glyphWidth);
|
||||||
|
|
||||||
|
textureHeight = NextPowerOf2( (( numGlyphs / h) + 1) * glyphHeight);
|
||||||
|
textureHeight = textureHeight > maxTextSize ? maxTextSize : textureHeight;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
GLuint FTGLTextureFont::CreateTexture()
|
||||||
|
{
|
||||||
|
CalculateTextureSize();
|
||||||
|
|
||||||
|
int totalMemory = textureWidth * textureHeight;
|
||||||
|
unsigned char* textureMemory = new unsigned char[totalMemory];
|
||||||
|
memset( textureMemory, 0, totalMemory);
|
||||||
|
|
||||||
|
GLuint textID;
|
||||||
|
glGenTextures( 1, (GLuint*)&textID);
|
||||||
|
|
||||||
|
glBindTexture( GL_TEXTURE_2D, textID);
|
||||||
|
glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP);
|
||||||
|
glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP);
|
||||||
|
glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
|
||||||
|
glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
|
||||||
|
|
||||||
|
glTexImage2D( GL_TEXTURE_2D, 0, GL_ALPHA, textureWidth, textureHeight, 0, GL_ALPHA, GL_UNSIGNED_BYTE, textureMemory);
|
||||||
|
|
||||||
|
delete [] textureMemory;
|
||||||
|
|
||||||
|
return textID;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool FTGLTextureFont::FaceSize( const unsigned int size, const unsigned int res)
|
||||||
|
{
|
||||||
|
if( !textureIDList.empty())
|
||||||
|
{
|
||||||
|
glDeleteTextures( textureIDList.size(), (const GLuint*)&textureIDList[0]);
|
||||||
|
remGlyphs = numGlyphs = face.GlyphCount();
|
||||||
|
}
|
||||||
|
|
||||||
|
return FTFont::FaceSize( size, res);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTGLTextureFont::Render( const char* string)
|
||||||
|
{
|
||||||
|
// glPushAttrib( GL_ENABLE_BIT | GL_COLOR_BUFFER_BIT);
|
||||||
|
|
||||||
|
glEnable(GL_BLEND);
|
||||||
|
glBlendFunc( GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); // GL_ONE
|
||||||
|
|
||||||
|
FTFont::Render( string);
|
||||||
|
|
||||||
|
// glPopAttrib();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTGLTextureFont::Render( const wchar_t* string)
|
||||||
|
{
|
||||||
|
// glPushAttrib( GL_ENABLE_BIT | GL_COLOR_BUFFER_BIT);
|
||||||
|
|
||||||
|
glEnable(GL_BLEND);
|
||||||
|
glBlendFunc( GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); // GL_ONE
|
||||||
|
|
||||||
|
FTFont::Render( string);
|
||||||
|
|
||||||
|
// glPopAttrib();
|
||||||
|
}
|
||||||
|
|
||||||
17
extern/bFTGL/src/FTGlyph.cpp
vendored
Normal file
17
extern/bFTGL/src/FTGlyph.cpp
vendored
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
#include "FTGlyph.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTGlyph::FTGlyph( FT_GlyphSlot glyph)
|
||||||
|
: advance(0.0f),
|
||||||
|
err(0)
|
||||||
|
{
|
||||||
|
if( glyph)
|
||||||
|
{
|
||||||
|
bBox = FTBBox( glyph);
|
||||||
|
advance = static_cast<float>( glyph->advance.x) / 64.0f;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTGlyph::~FTGlyph()
|
||||||
|
{}
|
||||||
93
extern/bFTGL/src/FTGlyphContainer.cpp
vendored
Normal file
93
extern/bFTGL/src/FTGlyphContainer.cpp
vendored
Normal file
@@ -0,0 +1,93 @@
|
|||||||
|
#include "FTGlyphContainer.h"
|
||||||
|
#include "FTGlyph.h"
|
||||||
|
#include "FTFace.h"
|
||||||
|
#include "FTCharmap.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTGlyphContainer::FTGlyphContainer( FTFace* f)
|
||||||
|
: face(f),
|
||||||
|
err(0)
|
||||||
|
{
|
||||||
|
glyphs.push_back( NULL);
|
||||||
|
charMap = new FTCharmap( face);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTGlyphContainer::~FTGlyphContainer()
|
||||||
|
{
|
||||||
|
GlyphVector::iterator glyphIterator;
|
||||||
|
for( glyphIterator = glyphs.begin(); glyphIterator != glyphs.end(); ++glyphIterator)
|
||||||
|
{
|
||||||
|
delete *glyphIterator;
|
||||||
|
}
|
||||||
|
|
||||||
|
glyphs.clear();
|
||||||
|
delete charMap;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool FTGlyphContainer::CharMap( FT_Encoding encoding)
|
||||||
|
{
|
||||||
|
bool result = charMap->CharMap( encoding);
|
||||||
|
err = charMap->Error();
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
unsigned int FTGlyphContainer::FontIndex( const unsigned int characterCode) const
|
||||||
|
{
|
||||||
|
return charMap->FontIndex( characterCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTGlyphContainer::Add( FTGlyph* tempGlyph, const unsigned int characterCode)
|
||||||
|
{
|
||||||
|
charMap->InsertIndex( characterCode, glyphs.size());
|
||||||
|
glyphs.push_back( tempGlyph);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const FTGlyph* const FTGlyphContainer::Glyph( const unsigned int characterCode) const
|
||||||
|
{
|
||||||
|
signed int index = charMap->GlyphListIndex( characterCode);
|
||||||
|
return glyphs[index];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTBBox FTGlyphContainer::BBox( const unsigned int characterCode) const
|
||||||
|
{
|
||||||
|
return glyphs[charMap->GlyphListIndex( characterCode)]->BBox();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTGlyphContainer::Advance( const unsigned int characterCode, const unsigned int nextCharacterCode)
|
||||||
|
{
|
||||||
|
unsigned int left = charMap->FontIndex( characterCode);
|
||||||
|
unsigned int right = charMap->FontIndex( nextCharacterCode);
|
||||||
|
|
||||||
|
float width = face->KernAdvance( left, right).x;
|
||||||
|
width += glyphs[charMap->GlyphListIndex( characterCode)]->Advance();
|
||||||
|
|
||||||
|
return width;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTPoint FTGlyphContainer::Render( const unsigned int characterCode, const unsigned int nextCharacterCode, FTPoint penPosition)
|
||||||
|
{
|
||||||
|
FTPoint kernAdvance;
|
||||||
|
float advance = 0;
|
||||||
|
|
||||||
|
unsigned int left = charMap->FontIndex( characterCode);
|
||||||
|
unsigned int right = charMap->FontIndex( nextCharacterCode);
|
||||||
|
|
||||||
|
kernAdvance = face->KernAdvance( left, right);
|
||||||
|
|
||||||
|
if( !face->Error())
|
||||||
|
{
|
||||||
|
advance = glyphs[charMap->GlyphListIndex( characterCode)]->Render( penPosition);
|
||||||
|
}
|
||||||
|
|
||||||
|
kernAdvance.x = advance + kernAdvance.x;
|
||||||
|
// kernAdvance.y = advance.y + kernAdvance.y;
|
||||||
|
return kernAdvance;
|
||||||
|
}
|
||||||
64
extern/bFTGL/src/FTLibrary.cpp
vendored
Normal file
64
extern/bFTGL/src/FTLibrary.cpp
vendored
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
#include "FTLibrary.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTLibrary& FTLibrary::Instance()
|
||||||
|
{
|
||||||
|
static FTLibrary ftlib;
|
||||||
|
return ftlib;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTLibrary::~FTLibrary()
|
||||||
|
{
|
||||||
|
if( library != 0)
|
||||||
|
{
|
||||||
|
FT_Done_FreeType( *library);
|
||||||
|
|
||||||
|
delete library;
|
||||||
|
library= 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// if( manager != 0)
|
||||||
|
// {
|
||||||
|
// FTC_Manager_Done( manager );
|
||||||
|
//
|
||||||
|
// delete manager;
|
||||||
|
// manager= 0;
|
||||||
|
// }
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTLibrary::FTLibrary()
|
||||||
|
: library(0),
|
||||||
|
err(0)
|
||||||
|
{
|
||||||
|
Initialise();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool FTLibrary::Initialise()
|
||||||
|
{
|
||||||
|
if( library != 0)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
library = new FT_Library;
|
||||||
|
|
||||||
|
err = FT_Init_FreeType( library);
|
||||||
|
if( err)
|
||||||
|
{
|
||||||
|
delete library;
|
||||||
|
library = 0;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// FTC_Manager* manager;
|
||||||
|
//
|
||||||
|
// if( FTC_Manager_New( lib, 0, 0, 0, my_face_requester, 0, manager )
|
||||||
|
// {
|
||||||
|
// delete manager;
|
||||||
|
// manager= 0;
|
||||||
|
// return false;
|
||||||
|
// }
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
57
extern/bFTGL/src/FTOutlineGlyph.cpp
vendored
Normal file
57
extern/bFTGL/src/FTOutlineGlyph.cpp
vendored
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
#include "FTOutlineGlyph.h"
|
||||||
|
#include "FTVectoriser.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTOutlineGlyph::FTOutlineGlyph( FT_GlyphSlot glyph)
|
||||||
|
: FTGlyph( glyph),
|
||||||
|
glList(0)
|
||||||
|
{
|
||||||
|
if( ft_glyph_format_outline != glyph->format)
|
||||||
|
{
|
||||||
|
err = 0x14; // Invalid_Outline
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
FTVectoriser vectoriser( glyph);
|
||||||
|
|
||||||
|
size_t numContours = vectoriser.ContourCount();
|
||||||
|
if ( ( numContours < 1) || ( vectoriser.PointCount() < 3))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
glList = glGenLists(1);
|
||||||
|
glNewList( glList, GL_COMPILE);
|
||||||
|
for( unsigned int c = 0; c < numContours; ++c)
|
||||||
|
{
|
||||||
|
const FTContour* contour = vectoriser.Contour(c);
|
||||||
|
|
||||||
|
glBegin( GL_LINE_LOOP);
|
||||||
|
for( unsigned int p = 0; p < contour->PointCount(); ++p)
|
||||||
|
{
|
||||||
|
glVertex2f( contour->Point(p).x / 64.0f, contour->Point(p).y / 64.0f);
|
||||||
|
}
|
||||||
|
glEnd();
|
||||||
|
}
|
||||||
|
glEndList();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTOutlineGlyph::~FTOutlineGlyph()
|
||||||
|
{
|
||||||
|
glDeleteLists( glList, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTOutlineGlyph::Render( const FTPoint& pen)
|
||||||
|
{
|
||||||
|
if( glList)
|
||||||
|
{
|
||||||
|
glTranslatef( pen.x, pen.y, 0);
|
||||||
|
glCallList( glList);
|
||||||
|
glTranslatef( -pen.x, -pen.y, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return advance;
|
||||||
|
}
|
||||||
|
|
||||||
109
extern/bFTGL/src/FTPixmapGlyph.cpp
vendored
Normal file
109
extern/bFTGL/src/FTPixmapGlyph.cpp
vendored
Normal file
@@ -0,0 +1,109 @@
|
|||||||
|
#include "FTPixmapGlyph.h"
|
||||||
|
|
||||||
|
FTPixmapGlyph::FTPixmapGlyph( FT_GlyphSlot glyph)
|
||||||
|
: FTGlyph( glyph),
|
||||||
|
destWidth(0),
|
||||||
|
destHeight(0),
|
||||||
|
data(0)
|
||||||
|
{
|
||||||
|
err = FT_Render_Glyph( glyph, FT_RENDER_MODE_NORMAL);
|
||||||
|
if( err || ft_glyph_format_bitmap != glyph->format)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
FT_Bitmap bitmap = glyph->bitmap;
|
||||||
|
|
||||||
|
//check the pixel mode
|
||||||
|
//ft_pixel_mode_grays
|
||||||
|
|
||||||
|
int srcWidth = bitmap.width;
|
||||||
|
int srcHeight = bitmap.rows;
|
||||||
|
|
||||||
|
// FIXME What about dest alignment?
|
||||||
|
destWidth = srcWidth;
|
||||||
|
destHeight = srcHeight;
|
||||||
|
|
||||||
|
if( destWidth && destHeight)
|
||||||
|
{
|
||||||
|
data = new unsigned char[destWidth * destHeight * 4];
|
||||||
|
|
||||||
|
// Get the current glColor.
|
||||||
|
float ftglColour[4];
|
||||||
|
// glGetFloatv( GL_CURRENT_COLOR, ftglColour);
|
||||||
|
ftglColour[0] = ftglColour[1] = ftglColour[2] = ftglColour[3] = 1.0;
|
||||||
|
|
||||||
|
unsigned char redComponent = static_cast<unsigned char>( ftglColour[0] * 255.0f);
|
||||||
|
unsigned char greenComponent = static_cast<unsigned char>( ftglColour[1] * 255.0f);
|
||||||
|
unsigned char blueComponent = static_cast<unsigned char>( ftglColour[2] * 255.0f);
|
||||||
|
|
||||||
|
unsigned char* src = bitmap.buffer;
|
||||||
|
|
||||||
|
unsigned char* dest = data + ((destHeight - 1) * destWidth) * 4;
|
||||||
|
size_t destStep = destWidth * 4 * 2;
|
||||||
|
|
||||||
|
if( ftglColour[3] == 1.0f)
|
||||||
|
{
|
||||||
|
for( int y = 0; y < srcHeight; ++y)
|
||||||
|
{
|
||||||
|
for( int x = 0; x < srcWidth; ++x)
|
||||||
|
{
|
||||||
|
*dest++ = redComponent;
|
||||||
|
*dest++ = greenComponent;
|
||||||
|
*dest++ = blueComponent;
|
||||||
|
*dest++ = *src++;
|
||||||
|
}
|
||||||
|
dest -= destStep;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for( int y = 0; y < srcHeight; ++y)
|
||||||
|
{
|
||||||
|
for( int x = 0; x < srcWidth; ++x)
|
||||||
|
{
|
||||||
|
*dest++ = redComponent;
|
||||||
|
*dest++ = greenComponent;
|
||||||
|
*dest++ = blueComponent;
|
||||||
|
*dest++ = static_cast<unsigned char>(ftglColour[3] * *src++);
|
||||||
|
}
|
||||||
|
dest -= destStep;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
destHeight = srcHeight;
|
||||||
|
}
|
||||||
|
|
||||||
|
pos.x = glyph->bitmap_left;
|
||||||
|
pos.y = srcHeight - glyph->bitmap_top;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTPixmapGlyph::~FTPixmapGlyph()
|
||||||
|
{
|
||||||
|
delete [] data;
|
||||||
|
}
|
||||||
|
|
||||||
|
#include <math.h>
|
||||||
|
float FTPixmapGlyph::Render( const FTPoint& pen)
|
||||||
|
{
|
||||||
|
if( data)
|
||||||
|
{
|
||||||
|
float dx, dy;
|
||||||
|
|
||||||
|
dx= floor( (pen.x + pos.x ) );
|
||||||
|
dy= ( (pen.y - pos.y ) );
|
||||||
|
|
||||||
|
// Move the glyph origin
|
||||||
|
glBitmap( 0, 0, 0.0f, 0.0f, dx, dy, (const GLubyte*)0);
|
||||||
|
|
||||||
|
glPixelStorei( GL_UNPACK_ROW_LENGTH, 0);
|
||||||
|
|
||||||
|
glDrawPixels( destWidth, destHeight, GL_RGBA, GL_UNSIGNED_BYTE, (const GLvoid*)data);
|
||||||
|
|
||||||
|
// Restore the glyph origin
|
||||||
|
glBitmap( 0, 0, 0.0f, 0.0f, -dx, -dy, (const GLubyte*)0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return advance;
|
||||||
|
}
|
||||||
14
extern/bFTGL/src/FTPoint.cpp
vendored
Normal file
14
extern/bFTGL/src/FTPoint.cpp
vendored
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
#include "FTPoint.h"
|
||||||
|
|
||||||
|
|
||||||
|
bool operator == ( const FTPoint &a, const FTPoint &b)
|
||||||
|
{
|
||||||
|
return((a.x == b.x) && (a.y == b.y) && (a.z == b.z));
|
||||||
|
}
|
||||||
|
|
||||||
|
bool operator != ( const FTPoint &a, const FTPoint &b)
|
||||||
|
{
|
||||||
|
return((a.x != b.x) || (a.y != b.y) || (a.z != b.z));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
62
extern/bFTGL/src/FTPolyGlyph.cpp
vendored
Normal file
62
extern/bFTGL/src/FTPolyGlyph.cpp
vendored
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
#include "FTPolyGlyph.h"
|
||||||
|
#include "FTVectoriser.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTPolyGlyph::FTPolyGlyph( FT_GlyphSlot glyph)
|
||||||
|
: FTGlyph( glyph),
|
||||||
|
glList(0)
|
||||||
|
{
|
||||||
|
if( ft_glyph_format_outline != glyph->format)
|
||||||
|
{
|
||||||
|
err = 0x14; // Invalid_Outline
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
FTVectoriser vectoriser( glyph);
|
||||||
|
|
||||||
|
if(( vectoriser.ContourCount() < 1) || ( vectoriser.PointCount() < 3))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
vectoriser.MakeMesh( 1.0);
|
||||||
|
|
||||||
|
glList = glGenLists( 1);
|
||||||
|
glNewList( glList, GL_COMPILE);
|
||||||
|
|
||||||
|
const FTMesh* mesh = vectoriser.GetMesh();
|
||||||
|
for( unsigned int index = 0; index < mesh->TesselationCount(); ++index)
|
||||||
|
{
|
||||||
|
const FTTesselation* subMesh = mesh->Tesselation( index);
|
||||||
|
unsigned int polyonType = subMesh->PolygonType();
|
||||||
|
|
||||||
|
glBegin( polyonType);
|
||||||
|
for( unsigned int x = 0; x < subMesh->PointCount(); ++x)
|
||||||
|
{
|
||||||
|
glVertex3f( subMesh->Point(x).x / 64.0f,
|
||||||
|
subMesh->Point(x).y / 64.0f,
|
||||||
|
0.0f);
|
||||||
|
}
|
||||||
|
glEnd();
|
||||||
|
}
|
||||||
|
glEndList();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTPolyGlyph::~FTPolyGlyph()
|
||||||
|
{
|
||||||
|
glDeleteLists( glList, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTPolyGlyph::Render( const FTPoint& pen)
|
||||||
|
{
|
||||||
|
if( glList)
|
||||||
|
{
|
||||||
|
glTranslatef( pen.x, pen.y, 0);
|
||||||
|
glCallList( glList);
|
||||||
|
glTranslatef( -pen.x, -pen.y, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return advance;
|
||||||
|
}
|
||||||
105
extern/bFTGL/src/FTSize.cpp
vendored
Normal file
105
extern/bFTGL/src/FTSize.cpp
vendored
Normal file
@@ -0,0 +1,105 @@
|
|||||||
|
#include "FTSize.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTSize::FTSize()
|
||||||
|
: ftFace(0),
|
||||||
|
ftSize(0),
|
||||||
|
size(0),
|
||||||
|
err(0)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
FTSize::~FTSize()
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
bool FTSize::CharSize( FT_Face* face, unsigned int point_size, unsigned int x_resolution, unsigned int y_resolution )
|
||||||
|
{
|
||||||
|
err = FT_Set_Char_Size( *face, 0L, point_size * 64, x_resolution, y_resolution);
|
||||||
|
|
||||||
|
if( !err)
|
||||||
|
{
|
||||||
|
ftFace = face;
|
||||||
|
size = point_size;
|
||||||
|
ftSize = (*ftFace)->size;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ftFace = 0;
|
||||||
|
size = 0;
|
||||||
|
ftSize = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return !err;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
unsigned int FTSize::CharSize() const
|
||||||
|
{
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTSize::Ascender() const
|
||||||
|
{
|
||||||
|
return ftSize == 0 ? 0.0f : static_cast<float>( ftSize->metrics.ascender) / 64.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTSize::Descender() const
|
||||||
|
{
|
||||||
|
return ftSize == 0 ? 0.0f : static_cast<float>( ftSize->metrics.descender) / 64.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTSize::Height() const
|
||||||
|
{
|
||||||
|
if( 0 == ftSize)
|
||||||
|
{
|
||||||
|
return 0.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( FT_IS_SCALABLE((*ftFace)))
|
||||||
|
{
|
||||||
|
return ( (*ftFace)->bbox.yMax - (*ftFace)->bbox.yMin) * ( (float)ftSize->metrics.y_ppem / (float)(*ftFace)->units_per_EM);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return static_cast<float>( ftSize->metrics.height) / 64.0f;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTSize::Width() const
|
||||||
|
{
|
||||||
|
if( 0 == ftSize)
|
||||||
|
{
|
||||||
|
return 0.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( FT_IS_SCALABLE((*ftFace)))
|
||||||
|
{
|
||||||
|
return ( (*ftFace)->bbox.xMax - (*ftFace)->bbox.xMin) * ( static_cast<float>(ftSize->metrics.x_ppem) / static_cast<float>((*ftFace)->units_per_EM));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return static_cast<float>( ftSize->metrics.max_advance) / 64.0f;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float FTSize::Underline() const
|
||||||
|
{
|
||||||
|
return 0.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned int FTSize::XPixelsPerEm() const
|
||||||
|
{
|
||||||
|
return ftSize == 0 ? 0 : ftSize->metrics.x_ppem;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned int FTSize::YPixelsPerEm() const
|
||||||
|
{
|
||||||
|
return ftSize == 0 ? 0 : ftSize->metrics.y_ppem;
|
||||||
|
}
|
||||||
|
|
||||||
87
extern/bFTGL/src/FTTextureGlyph.cpp
vendored
Normal file
87
extern/bFTGL/src/FTTextureGlyph.cpp
vendored
Normal file
@@ -0,0 +1,87 @@
|
|||||||
|
#include "FTTextureGlyph.h"
|
||||||
|
|
||||||
|
|
||||||
|
FTTextureGlyph::FTTextureGlyph( FT_GlyphSlot glyph, int id, int xOffset, int yOffset, GLsizei width, GLsizei height)
|
||||||
|
: FTGlyph( glyph),
|
||||||
|
destWidth(0),
|
||||||
|
destHeight(0),
|
||||||
|
glTextureID(id),
|
||||||
|
activeTextureID(0)
|
||||||
|
{
|
||||||
|
err = FT_Render_Glyph( glyph, FT_RENDER_MODE_NORMAL);
|
||||||
|
if( err || glyph->format != ft_glyph_format_bitmap)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
FT_Bitmap bitmap = glyph->bitmap;
|
||||||
|
|
||||||
|
destWidth = bitmap.width;
|
||||||
|
destHeight = bitmap.rows;
|
||||||
|
|
||||||
|
if( destWidth && destHeight)
|
||||||
|
{
|
||||||
|
glPushClientAttrib( GL_CLIENT_PIXEL_STORE_BIT);
|
||||||
|
glPixelStorei( GL_UNPACK_LSB_FIRST, GL_FALSE);
|
||||||
|
glPixelStorei( GL_UNPACK_ROW_LENGTH, 0);
|
||||||
|
glPixelStorei( GL_UNPACK_ALIGNMENT, 1);
|
||||||
|
|
||||||
|
glBindTexture( GL_TEXTURE_2D, glTextureID);
|
||||||
|
glTexSubImage2D( GL_TEXTURE_2D, 0, xOffset, yOffset, destWidth, destHeight, GL_ALPHA, GL_UNSIGNED_BYTE, bitmap.buffer);
|
||||||
|
|
||||||
|
glPopClientAttrib();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// 0
|
||||||
|
// +----+
|
||||||
|
// | |
|
||||||
|
// | |
|
||||||
|
// | |
|
||||||
|
// +----+
|
||||||
|
// 1
|
||||||
|
|
||||||
|
uv[0].x = static_cast<float>(xOffset) / static_cast<float>(width);
|
||||||
|
uv[0].y = static_cast<float>(yOffset) / static_cast<float>(height);
|
||||||
|
uv[1].x = static_cast<float>( xOffset + destWidth) / static_cast<float>(width);
|
||||||
|
uv[1].y = static_cast<float>( yOffset + destHeight) / static_cast<float>(height);
|
||||||
|
|
||||||
|
pos.x = glyph->bitmap_left;
|
||||||
|
pos.y = glyph->bitmap_top;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTTextureGlyph::~FTTextureGlyph()
|
||||||
|
{}
|
||||||
|
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
|
float FTTextureGlyph::Render( const FTPoint& pen)
|
||||||
|
{
|
||||||
|
float dx;
|
||||||
|
|
||||||
|
glGetIntegerv( GL_TEXTURE_2D_BINDING_EXT, &activeTextureID);
|
||||||
|
if( activeTextureID != glTextureID)
|
||||||
|
{
|
||||||
|
glBindTexture( GL_TEXTURE_2D, (GLuint)glTextureID);
|
||||||
|
}
|
||||||
|
|
||||||
|
dx= floor( (pen.x + pos.x ) );
|
||||||
|
|
||||||
|
glBegin( GL_QUADS);
|
||||||
|
glTexCoord2f( uv[0].x, uv[0].y);
|
||||||
|
glVertex2f( dx, pen.y + pos.y);
|
||||||
|
|
||||||
|
glTexCoord2f( uv[0].x, uv[1].y);
|
||||||
|
glVertex2f( dx, pen.y + pos.y - destHeight);
|
||||||
|
|
||||||
|
glTexCoord2f( uv[1].x, uv[1].y);
|
||||||
|
glVertex2f( dx + destWidth, pen.y + pos.y - destHeight);
|
||||||
|
|
||||||
|
glTexCoord2f( uv[1].x, uv[0].y);
|
||||||
|
glVertex2f( dx + destWidth, pen.y + pos.y);
|
||||||
|
glEnd();
|
||||||
|
|
||||||
|
return advance;
|
||||||
|
}
|
||||||
|
|
||||||
229
extern/bFTGL/src/FTVectoriser.cpp
vendored
Normal file
229
extern/bFTGL/src/FTVectoriser.cpp
vendored
Normal file
@@ -0,0 +1,229 @@
|
|||||||
|
#include "FTVectoriser.h"
|
||||||
|
#include "FTGL.h"
|
||||||
|
|
||||||
|
#ifndef CALLBACK
|
||||||
|
#define CALLBACK
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__APPLE_CC__)
|
||||||
|
#if __APPLE_CC__ >= 5465
|
||||||
|
typedef GLvoid (*GLUTesselatorFunction)();
|
||||||
|
#else
|
||||||
|
typedef GLvoid (*GLUTesselatorFunction)(...);
|
||||||
|
#endif
|
||||||
|
#elif defined( __mips ) || defined( __linux__ ) || defined( __FreeBSD__ ) || defined( __OpenBSD__ ) || defined( __sun ) || defined (__CYGWIN__)
|
||||||
|
typedef GLvoid (*GLUTesselatorFunction)();
|
||||||
|
#elif defined ( WIN32)
|
||||||
|
typedef GLvoid (CALLBACK *GLUTesselatorFunction)( );
|
||||||
|
#else
|
||||||
|
#error "Error - need to define type GLUTesselatorFunction for this platform/compiler"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
void CALLBACK ftglError( GLenum errCode, FTMesh* mesh)
|
||||||
|
{
|
||||||
|
mesh->Error( errCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void CALLBACK ftglVertex( void* data, FTMesh* mesh)
|
||||||
|
{
|
||||||
|
FTGL_DOUBLE* vertex = static_cast<FTGL_DOUBLE*>(data);
|
||||||
|
mesh->AddPoint( vertex[0], vertex[1], vertex[2]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void CALLBACK ftglCombine( FTGL_DOUBLE coords[3], void* vertex_data[4], GLfloat weight[4], void** outData, FTMesh* mesh)
|
||||||
|
{
|
||||||
|
FTGL_DOUBLE* vertex = static_cast<FTGL_DOUBLE*>(coords);
|
||||||
|
*outData = mesh->Combine( vertex[0], vertex[1], vertex[2]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void CALLBACK ftglBegin( GLenum type, FTMesh* mesh)
|
||||||
|
{
|
||||||
|
mesh->Begin( type);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void CALLBACK ftglEnd( FTMesh* mesh)
|
||||||
|
{
|
||||||
|
mesh->End();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTMesh::FTMesh()
|
||||||
|
: currentTesselation(0),
|
||||||
|
err(0)
|
||||||
|
{
|
||||||
|
tesselationList.reserve( 16);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTMesh::~FTMesh()
|
||||||
|
{
|
||||||
|
for( size_t t = 0; t < tesselationList.size(); ++t)
|
||||||
|
{
|
||||||
|
delete tesselationList[t];
|
||||||
|
}
|
||||||
|
|
||||||
|
tesselationList.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTMesh::AddPoint( const FTGL_DOUBLE x, const FTGL_DOUBLE y, const FTGL_DOUBLE z)
|
||||||
|
{
|
||||||
|
currentTesselation->AddPoint( x, y, z);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTGL_DOUBLE* FTMesh::Combine( const FTGL_DOUBLE x, const FTGL_DOUBLE y, const FTGL_DOUBLE z)
|
||||||
|
{
|
||||||
|
tempPointList.push_back( FTPoint( x, y,z));
|
||||||
|
return &tempPointList.back().x;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTMesh::Begin( GLenum meshType)
|
||||||
|
{
|
||||||
|
currentTesselation = new FTTesselation( meshType);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTMesh::End()
|
||||||
|
{
|
||||||
|
tesselationList.push_back( currentTesselation);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const FTTesselation* const FTMesh::Tesselation( unsigned int index) const
|
||||||
|
{
|
||||||
|
return ( index < tesselationList.size()) ? tesselationList[index] : NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTVectoriser::FTVectoriser( const FT_GlyphSlot glyph)
|
||||||
|
: contourList(0),
|
||||||
|
mesh(0),
|
||||||
|
ftContourCount(0),
|
||||||
|
contourFlag(0)
|
||||||
|
{
|
||||||
|
if( glyph)
|
||||||
|
{
|
||||||
|
outline = glyph->outline;
|
||||||
|
|
||||||
|
ftContourCount = outline.n_contours;;
|
||||||
|
contourList = 0;
|
||||||
|
contourFlag = outline.flags;
|
||||||
|
|
||||||
|
ProcessContours();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FTVectoriser::~FTVectoriser()
|
||||||
|
{
|
||||||
|
for( size_t c = 0; c < ContourCount(); ++c)
|
||||||
|
{
|
||||||
|
delete contourList[c];
|
||||||
|
}
|
||||||
|
|
||||||
|
delete [] contourList;
|
||||||
|
delete mesh;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTVectoriser::ProcessContours()
|
||||||
|
{
|
||||||
|
short contourLength = 0;
|
||||||
|
short startIndex = 0;
|
||||||
|
short endIndex = 0;
|
||||||
|
|
||||||
|
contourList = new FTContour*[ftContourCount];
|
||||||
|
|
||||||
|
for( short contourIndex = 0; contourIndex < ftContourCount; ++contourIndex)
|
||||||
|
{
|
||||||
|
FT_Vector* pointList = &outline.points[startIndex];
|
||||||
|
char* tagList = &outline.tags[startIndex];
|
||||||
|
|
||||||
|
endIndex = outline.contours[contourIndex];
|
||||||
|
contourLength = ( endIndex - startIndex) + 1;
|
||||||
|
|
||||||
|
FTContour* contour = new FTContour( pointList, tagList, contourLength);
|
||||||
|
|
||||||
|
contourList[contourIndex] = contour;
|
||||||
|
|
||||||
|
startIndex = endIndex + 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
size_t FTVectoriser::PointCount()
|
||||||
|
{
|
||||||
|
size_t s = 0;
|
||||||
|
for( size_t c = 0; c < ContourCount(); ++c)
|
||||||
|
{
|
||||||
|
s += contourList[c]->PointCount();
|
||||||
|
}
|
||||||
|
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const FTContour* const FTVectoriser::Contour( unsigned int index) const
|
||||||
|
{
|
||||||
|
return ( index < ContourCount()) ? contourList[index] : NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FTVectoriser::MakeMesh( FTGL_DOUBLE zNormal)
|
||||||
|
{
|
||||||
|
if( mesh)
|
||||||
|
{
|
||||||
|
delete mesh;
|
||||||
|
}
|
||||||
|
|
||||||
|
mesh = new FTMesh;
|
||||||
|
|
||||||
|
GLUtesselator* tobj = gluNewTess();
|
||||||
|
|
||||||
|
gluTessCallback( tobj, GLU_TESS_BEGIN_DATA, (GLUTesselatorFunction)ftglBegin);
|
||||||
|
gluTessCallback( tobj, GLU_TESS_VERTEX_DATA, (GLUTesselatorFunction)ftglVertex);
|
||||||
|
gluTessCallback( tobj, GLU_TESS_COMBINE_DATA, (GLUTesselatorFunction)ftglCombine);
|
||||||
|
gluTessCallback( tobj, GLU_TESS_END_DATA, (GLUTesselatorFunction)ftglEnd);
|
||||||
|
gluTessCallback( tobj, GLU_TESS_ERROR_DATA, (GLUTesselatorFunction)ftglError);
|
||||||
|
|
||||||
|
if( contourFlag & ft_outline_even_odd_fill) // ft_outline_reverse_fill
|
||||||
|
{
|
||||||
|
gluTessProperty( tobj, GLU_TESS_WINDING_RULE, GLU_TESS_WINDING_ODD);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
gluTessProperty( tobj, GLU_TESS_WINDING_RULE, GLU_TESS_WINDING_NONZERO);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
gluTessProperty( tobj, GLU_TESS_TOLERANCE, 0);
|
||||||
|
gluTessNormal( tobj, 0.0f, 0.0f, zNormal);
|
||||||
|
gluTessBeginPolygon( tobj, mesh);
|
||||||
|
|
||||||
|
for( size_t c = 0; c < ContourCount(); ++c)
|
||||||
|
{
|
||||||
|
const FTContour* contour = contourList[c];
|
||||||
|
|
||||||
|
gluTessBeginContour( tobj);
|
||||||
|
|
||||||
|
for( size_t p = 0; p < contour->PointCount(); ++p)
|
||||||
|
{
|
||||||
|
FTGL_DOUBLE* d = const_cast<FTGL_DOUBLE*>(&contour->Point(p).x);
|
||||||
|
gluTessVertex( tobj, d, d);
|
||||||
|
}
|
||||||
|
|
||||||
|
gluTessEndContour( tobj);
|
||||||
|
}
|
||||||
|
|
||||||
|
gluTessEndPolygon( tobj);
|
||||||
|
|
||||||
|
gluDeleteTess( tobj);
|
||||||
|
}
|
||||||
|
|
||||||
62
extern/bFTGL/src/Makefile
vendored
Normal file
62
extern/bFTGL/src/Makefile
vendored
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
#
|
||||||
|
# $Id$
|
||||||
|
#
|
||||||
|
# ***** BEGIN GPL/BL DUAL 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. The Blender
|
||||||
|
# Foundation also sells licenses for use in proprietary software under
|
||||||
|
# the Blender License. See http://www.blender.org/BL/ for information
|
||||||
|
# about this.
|
||||||
|
#
|
||||||
|
# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, 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/BL DUAL LICENSE BLOCK *****
|
||||||
|
#
|
||||||
|
#
|
||||||
|
|
||||||
|
LIBNAME = ftgl
|
||||||
|
DIR = $(OCGDIR)/extern/$(LIBNAME)
|
||||||
|
|
||||||
|
CCFLAGS += $(LEVEL_1_CPP_WARNINGS)
|
||||||
|
|
||||||
|
CSRCS =
|
||||||
|
CCSRCS = FTBitmapGlyph.cpp FTCharmap.cpp FTContour.cpp FTExtrdGlyph.cpp \
|
||||||
|
FTFace.cpp FTFont.cpp FTGLBitmapFont.cpp FTGLExtrdFont.cpp \
|
||||||
|
FTGLOutlineFont.cpp FTGLPixmapFont.cpp FTGLPolygonFont.cpp \
|
||||||
|
FTGLTextureFont.cpp FTGlyph.cpp FTGlyphContainer.cpp FTLibrary.cpp \
|
||||||
|
FTOutlineGlyph.cpp FTPixmapGlyph.cpp FTPoint.cpp FTPolyGlyph.cpp \
|
||||||
|
FTSize.cpp FTTextureGlyph.cpp FTVectoriser.cpp
|
||||||
|
|
||||||
|
include nan_compile.mk
|
||||||
|
CPPFLAGS += -I../include
|
||||||
|
CPPFLAGS += -I$(NAN_FREETYPE)/include -I$(NAN_FREETYPE)/include/freetype2
|
||||||
|
|
||||||
|
install: all debug
|
||||||
|
@[ -d $(NAN_FTGL) ] || mkdir -p $(NAN_FTGL)
|
||||||
|
@[ -d $(NAN_FTGL)/include ] || mkdir -p $(NAN_FTGL)/include
|
||||||
|
@[ -d $(NAN_FTGL)/lib ] || mkdir -p $(NAN_FTGL)/lib
|
||||||
|
@[ -d $(NAN_FTGL)/lib/debug ] || mkdir -p $(NAN_FTGL)/lib/debug
|
||||||
|
@$(NANBLENDERHOME)/intern/tools/cpifdiff.sh $(DIR)/lib$(LIBNAME).a $(NAN_FTGL)/lib/
|
||||||
|
# @$(NANBLENDERHOME)/intern/tools/cpifdiff.sh $(DIR)/debug/lib$(LIBNAME).a $(NAN_FTGL)/lib/debug/
|
||||||
|
ifeq ($(OS),darwin)
|
||||||
|
ranlib $(NAN_FTGL)/lib/lib$(LIBNAME).a
|
||||||
|
endif
|
||||||
|
@$(NANBLENDERHOME)/intern/tools/cpifdiff.sh ../include/*.h $(NAN_FTGL)/include/
|
||||||
|
|
||||||
206
extern/bFTGL/win32_vcpp/README_WIN32.txt
vendored
Normal file
206
extern/bFTGL/win32_vcpp/README_WIN32.txt
vendored
Normal file
@@ -0,0 +1,206 @@
|
|||||||
|
FTGL 1.31
|
||||||
|
|
||||||
|
NOTES FOR COMPILING ON WINDOWS
|
||||||
|
|
||||||
|
14 Feb 2002
|
||||||
|
|
||||||
|
Ellers, ellers@iinet.net.au
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
SUPPORTED COMPILERS
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
I have rebuilt the FTGL project files for Visual C++ (version 6). There are
|
||||||
|
|
||||||
|
presently no other compilers or environments supported but feel free to
|
||||||
|
|
||||||
|
contribute them.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
QUICK GUIDE: COMPILING FTGL
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
- Start up MSVC++ with ftgl.dsw.
|
||||||
|
|
||||||
|
- Tell MSVC++ where FreeType is. You'll need to do something like this:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
* select Project>Settings
|
||||||
|
|
||||||
|
* select ftgl_static (for a start)
|
||||||
|
|
||||||
|
* select "All Configurations"
|
||||||
|
|
||||||
|
* go to the tab C++ > PreProcessor
|
||||||
|
|
||||||
|
* Set additional include directories appropriately. For me it is:
|
||||||
|
|
||||||
|
D:\cots\freetype-2.0.5\include
|
||||||
|
|
||||||
|
* repeat for all configurations of ftgl_dll
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
QUICK GUIDE: COMPILING/RUNNING SUPPLIED DEMO PROGRAM
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
- The program expects the first argument to be the name of a truetype file.
|
||||||
|
|
||||||
|
I copied timesbi.ttf from the windows directory to C:\TEMP and then edit
|
||||||
|
|
||||||
|
the settings of the project:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
* select Project>Settings
|
||||||
|
|
||||||
|
* select Demo project
|
||||||
|
|
||||||
|
* select panel Debug>General
|
||||||
|
|
||||||
|
* set Program Arguments to be "C:\TEMP\timesbi.ttf"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
QUICK GUIDE: COMPILING YOUR PROGRAM TO USE FTGL
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
- Choose dynamic or static library linkage
|
||||||
|
|
||||||
|
* if you want to link to a static FTGL library ensure that
|
||||||
|
|
||||||
|
FTGL_LIBRARY_STATIC is defined in the preprocessor section
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
CONFIGURATION / CODE GENERATION / C LIBRARIES
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
FTGL can be built in various configurations (inspired by Freetype and libpng):
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
- static library (.lib)
|
||||||
|
|
||||||
|
- dynamic library (.dll)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
MSVC++ requires selection of "code generation" option, which seems to be
|
||||||
|
|
||||||
|
mostly to do with which version of the Standard C library is linked with the
|
||||||
|
|
||||||
|
library.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
The following modes are supported:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
- static/dynamic
|
||||||
|
|
||||||
|
- single threaded (ST) or multithreaded (MT)
|
||||||
|
|
||||||
|
NOTE: the multithreaded DLL (MD) mode was NOT included, as freetype itself
|
||||||
|
|
||||||
|
doesn't support that mode so I figure there's no point yet.
|
||||||
|
|
||||||
|
- debug/release (debug has _d suffix)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
So the static multithreaded release library is:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
ftgl_static_MT.lib
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
The same library built in DEBUG mode:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
ftgl_static_MT_d.lib
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
If you're not sure which one is appropriate (and if you're a novice don't
|
||||||
|
|
||||||
|
been too put off...) start with making the decision about debug or release.
|
||||||
|
|
||||||
|
This should be easy because if you're building the debug version of your
|
||||||
|
|
||||||
|
app its probably a good idea to link with the debug version of FTGL (but
|
||||||
|
|
||||||
|
not compulsory). Once thats done, you may get errors like:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
LIBCMTD.lib(crt0init.obj) : warning LNK4098: defaultlib "libcmt.lib" conflicts with use of other libs; use /NODEFAULTLIB:library
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
This will happen, for example, when you link a glut app with an FTGL library
|
||||||
|
|
||||||
|
compiled with different codegen options than the GLUT library.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
MSVC++ "sort of"
|
||||||
|
|
||||||
|
requires that all libs be linked with the same codegen option. GLUT is built
|
||||||
|
|
||||||
|
in XXX mode, so if you're linking with GLUT, you can get rid of the warning
|
||||||
|
|
||||||
|
by linking with the XXX version of FTGL. The various versions are particularly
|
||||||
|
|
||||||
|
useful if you're doing std C stuff, like printf etc.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
FAQ
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Q: "But... do I HAVE to use all these DIFFERENT build modes, like multi-
|
||||||
|
|
||||||
|
threaded, debug single threaded, etc?"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
A: No. Sometimes library makers only generate one style anyway. It depends
|
||||||
|
|
||||||
|
on your needs. Unless you're linking with standard C stuff (e.g. printf)
|
||||||
|
|
||||||
|
then it probably won't make a great deal of difference. If you get
|
||||||
|
|
||||||
|
warnings about "default lib libcmt.lib conflicts" etc, then you can make
|
||||||
|
|
||||||
|
use of the different libraries.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
92
extern/bFTGL/win32_vcpp/ftgl.dsw
vendored
Normal file
92
extern/bFTGL/win32_vcpp/ftgl.dsw
vendored
Normal file
@@ -0,0 +1,92 @@
|
|||||||
|
Microsoft Developer Studio Workspace File, Format Version 6.00
|
||||||
|
# WARNING: DO NOT EDIT OR DELETE THIS WORKSPACE FILE!
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Project: "ftgl_demo"=".\ftgl_demo\ftgl_demo.dsp" - Package Owner=<4>
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<4>
|
||||||
|
{{{
|
||||||
|
Begin Project Dependency
|
||||||
|
Project_Dep_Name ftgl_dll
|
||||||
|
End Project Dependency
|
||||||
|
Begin Project Dependency
|
||||||
|
Project_Dep_Name ftgl_static_lib
|
||||||
|
End Project Dependency
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Project: "ftgl_demo_2"=".\ftgl_demo\ftgl_demo_2.dsp" - Package Owner=<4>
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<4>
|
||||||
|
{{{
|
||||||
|
Begin Project Dependency
|
||||||
|
Project_Dep_Name ftgl_dll
|
||||||
|
End Project Dependency
|
||||||
|
Begin Project Dependency
|
||||||
|
Project_Dep_Name ftgl_static_lib
|
||||||
|
End Project Dependency
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Project: "ftgl_dll"=".\ftgl_dll\ftgl_dll.dsp" - Package Owner=<4>
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<4>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Project: "ftgl_static_lib"=".\ftgl_static_lib\ftgl_static_lib.dsp" - Package Owner=<4>
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<4>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Project: "unit_tests"=".\unit_tests\unit_tests.dsp" - Package Owner=<4>
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<4>
|
||||||
|
{{{
|
||||||
|
Begin Project Dependency
|
||||||
|
Project_Dep_Name ftgl_static_lib
|
||||||
|
End Project Dependency
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Global:
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<3>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
357
extern/bFTGL/win32_vcpp/ftgl_dll/ftgl_dll.dsp
vendored
Normal file
357
extern/bFTGL/win32_vcpp/ftgl_dll/ftgl_dll.dsp
vendored
Normal file
@@ -0,0 +1,357 @@
|
|||||||
|
# Microsoft Developer Studio Project File - Name="ftgl_dll" - Package Owner=<4>
|
||||||
|
# Microsoft Developer Studio Generated Build File, Format Version 6.00
|
||||||
|
# ** DO NOT EDIT **
|
||||||
|
|
||||||
|
# TARGTYPE "Win32 (x86) Dynamic-Link Library" 0x0102
|
||||||
|
|
||||||
|
CFG=ftgl_dll - Win32 Debug
|
||||||
|
!MESSAGE This is not a valid makefile. To build this project using NMAKE,
|
||||||
|
!MESSAGE use the Export Makefile command and run
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE NMAKE /f "ftgl_dll.mak".
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE You can specify a configuration when running NMAKE
|
||||||
|
!MESSAGE by defining the macro CFG on the command line. For example:
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE NMAKE /f "ftgl_dll.mak" CFG="ftgl_dll - Win32 Debug"
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE Possible choices for configuration are:
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE "ftgl_dll - Win32 Release" (based on "Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE "ftgl_dll - Win32 Debug" (based on "Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE "ftgl_dll - Win32 Release MT" (based on "Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE "ftgl_dll - Win32 Debug MT" (based on "Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE
|
||||||
|
|
||||||
|
# Begin Project
|
||||||
|
# PROP AllowPerConfigDependencies 0
|
||||||
|
# PROP Scc_ProjName ""
|
||||||
|
# PROP Scc_LocalPath ""
|
||||||
|
CPP=cl.exe
|
||||||
|
MTL=midl.exe
|
||||||
|
RSC=rc.exe
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "ftgl_dll - Win32 Release"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir "Release_ST"
|
||||||
|
# PROP BASE Intermediate_Dir "Release_ST"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir "../Build"
|
||||||
|
# PROP Intermediate_Dir "Release_ST"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir "../Build"
|
||||||
|
# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "FTGL_DLL_EXPORTS" /YX /FD /c
|
||||||
|
# ADD CPP /nologo /MT /W3 /GX /O2 /I "D:\cots\freetype-2.0.5\include" /I "..\..\include" /D "NDEBUG" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "FTGL_LIBRARY" /YX /FD /c
|
||||||
|
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
# ADD BASE RSC /l 0x409 /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x409 /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /machine:I386
|
||||||
|
# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib opengl32.lib glu32.lib freetype204.lib /nologo /dll /machine:I386 /out:"../Build/ftgl_dynamic_MT.dll" /libpath:"D:\cots\freetype-2.0.5\objs"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "ftgl_dll - Win32 Debug"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 1
|
||||||
|
# PROP BASE Output_Dir "Debug_ST"
|
||||||
|
# PROP BASE Intermediate_Dir "Debug_ST"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 1
|
||||||
|
# PROP Output_Dir "../Build"
|
||||||
|
# PROP Intermediate_Dir "Debug_ST"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir "../Build"
|
||||||
|
# ADD BASE CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "FTGL_DLL_EXPORTS" /YX /FD /GZ /c
|
||||||
|
# ADD CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /I "D:\cots\freetype-2.0.5\include" /I "..\..\include" /D "_DEBUG" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "FTGL_LIBRARY" /YX /FD /GZ /c
|
||||||
|
# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
|
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
|
# ADD BASE RSC /l 0x409 /d "_DEBUG"
|
||||||
|
# ADD RSC /l 0x409 /d "_DEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /debug /machine:I386 /pdbtype:sept
|
||||||
|
# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib opengl32.lib glu32.lib freetype204_D.lib /nologo /dll /pdb:"Debug_ST/ftgl_dynamic_ST_d.pdb" /debug /machine:I386 /out:"../Build/ftgl_dynamic_MT_d.dll" /pdbtype:sept /libpath:"D:\cots\freetype-2.0.5\objs"
|
||||||
|
# SUBTRACT LINK32 /pdb:none
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "ftgl_dll - Win32 Release MT"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir "Release_MT"
|
||||||
|
# PROP BASE Intermediate_Dir "Release_MT"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir "../Build"
|
||||||
|
# PROP Intermediate_Dir "Release_MT"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir "../Build"
|
||||||
|
# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "FTGL_DLL_EXPORTS" /YX /FD /c
|
||||||
|
# ADD CPP /nologo /MD /W3 /GX /O2 /I "D:\cots\freetype-2.0.5\include" /I "..\..\include" /D "NDEBUG" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "FTGL_LIBRARY" /YX /FD /c
|
||||||
|
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
# ADD BASE RSC /l 0x409 /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x409 /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /machine:I386
|
||||||
|
# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib opengl32.lib glu32.lib freetype204MT.lib /nologo /dll /machine:I386 /out:"../Build/ftgl_dynamic_MTD.dll" /libpath:"D:\cots\freetype-2.0.5\objs"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "ftgl_dll - Win32 Debug MT"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 1
|
||||||
|
# PROP BASE Output_Dir "Debug_MT"
|
||||||
|
# PROP BASE Intermediate_Dir "Debug_MT"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 1
|
||||||
|
# PROP Output_Dir "../Build"
|
||||||
|
# PROP Intermediate_Dir "Debug_MT"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir "../Build"
|
||||||
|
# ADD BASE CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "FTGL_DLL_EXPORTS" /YX /FD /GZ /c
|
||||||
|
# ADD CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /I "D:\cots\freetype-2.0.5\include" /I "..\..\include" /D "_DEBUG" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "FTGL_LIBRARY" /YX /FD /GZ /c
|
||||||
|
# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
|
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
|
# ADD BASE RSC /l 0x409 /d "_DEBUG"
|
||||||
|
# ADD RSC /l 0x409 /d "_DEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /debug /machine:I386 /pdbtype:sept
|
||||||
|
# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib opengl32.lib glu32.lib freetype204MT_D.lib /nologo /dll /pdb:"Debug_ST/ftgl_dynamic_MT_d.pdb" /debug /machine:I386 /out:"../Build/ftgl_dynamic_MTD_d.dll" /pdbtype:sept /libpath:"D:\cots\freetype-2.0.5\objs"
|
||||||
|
# SUBTRACT LINK32 /pdb:none
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# Begin Target
|
||||||
|
|
||||||
|
# Name "ftgl_dll - Win32 Release"
|
||||||
|
# Name "ftgl_dll - Win32 Debug"
|
||||||
|
# Name "ftgl_dll - Win32 Release MT"
|
||||||
|
# Name "ftgl_dll - Win32 Debug MT"
|
||||||
|
# Begin Group "Source Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTBitmapGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTCharmap.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTContour.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTExtrdGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTFace.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGLBitmapFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGLExtrdFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGLOutlineFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGLPixmapFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGLPolygonFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGLTextureFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGlyphContainer.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTLibrary.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTOutlineGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTPixmapGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTPoint.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTPolyGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTSize.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTTextureGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTVectoriser.cpp
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# Begin Group "Header Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "h;hpp;hxx;hm;inl"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTBBox.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTBitmapGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTCharmap.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTCharToGlyphIndexMap.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTContour.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTExtrdGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTFace.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGL.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGLBitmapFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGLExtrdFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGLOutlineFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGLPixmapFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGLPolygonFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGLTextureFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGlyphContainer.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTLibrary.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTList.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTOutlineGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTPixmapGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTPoint.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTPolyGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTSize.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTTextureGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTVector.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTVectoriser.h
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# Begin Group "Resource Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe"
|
||||||
|
# End Group
|
||||||
|
# End Target
|
||||||
|
# End Project
|
||||||
342
extern/bFTGL/win32_vcpp/ftgl_static_lib/ftgl_static_lib.dsp
vendored
Normal file
342
extern/bFTGL/win32_vcpp/ftgl_static_lib/ftgl_static_lib.dsp
vendored
Normal file
@@ -0,0 +1,342 @@
|
|||||||
|
# Microsoft Developer Studio Project File - Name="ftgl_static_lib" - Package Owner=<4>
|
||||||
|
# Microsoft Developer Studio Generated Build File, Format Version 6.00
|
||||||
|
# ** DO NOT EDIT **
|
||||||
|
|
||||||
|
# TARGTYPE "Win32 (x86) Static Library" 0x0104
|
||||||
|
|
||||||
|
CFG=ftgl_static_lib - Win32 Debug MT
|
||||||
|
!MESSAGE This is not a valid makefile. To build this project using NMAKE,
|
||||||
|
!MESSAGE use the Export Makefile command and run
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE NMAKE /f "ftgl_static_lib.mak".
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE You can specify a configuration when running NMAKE
|
||||||
|
!MESSAGE by defining the macro CFG on the command line. For example:
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE NMAKE /f "ftgl_static_lib.mak" CFG="ftgl_static_lib - Win32 Debug MT"
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE Possible choices for configuration are:
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE "ftgl_static_lib - Win32 Release" (based on "Win32 (x86) Static Library")
|
||||||
|
!MESSAGE "ftgl_static_lib - Win32 Debug" (based on "Win32 (x86) Static Library")
|
||||||
|
!MESSAGE "ftgl_static_lib - Win32 Debug MT" (based on "Win32 (x86) Static Library")
|
||||||
|
!MESSAGE "ftgl_static_lib - Win32 Release MT" (based on "Win32 (x86) Static Library")
|
||||||
|
!MESSAGE
|
||||||
|
|
||||||
|
# Begin Project
|
||||||
|
# PROP AllowPerConfigDependencies 0
|
||||||
|
# PROP Scc_ProjName ""
|
||||||
|
# PROP Scc_LocalPath ""
|
||||||
|
CPP=cl.exe
|
||||||
|
RSC=rc.exe
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "ftgl_static_lib - Win32 Release"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir "Release_ST"
|
||||||
|
# PROP BASE Intermediate_Dir "Release_ST"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir "Release_ST"
|
||||||
|
# PROP Intermediate_Dir "Release_ST"
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /YX /FD /c
|
||||||
|
# ADD CPP /nologo /MT /W3 /GX /O2 /I "..\..\..\..\lib\windows\freetype\include" /I "..\..\include" /I "..\..\..\..\..\lib\windows\freetype\include" /D "NDEBUG" /D "WIN32" /D "_MBCS" /D "_LIB" /D "FTGL_LIBRARY_STATIC" /YX /FD /c
|
||||||
|
# ADD BASE RSC /l 0x409 /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x409 /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LIB32=link.exe -lib
|
||||||
|
# ADD BASE LIB32 /nologo
|
||||||
|
# ADD LIB32 /nologo /out:"..\Build\ftgl_static_ST.lib"
|
||||||
|
# Begin Special Build Tool
|
||||||
|
SOURCE="$(InputPath)"
|
||||||
|
PostBuild_Cmds=ECHO Copying lib to lib\windows\ftgl\lib XCOPY /Y ..\Build\*lib ..\..\..\..\..\lib\windows\ftgl\lib
|
||||||
|
# End Special Build Tool
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "ftgl_static_lib - Win32 Debug"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 1
|
||||||
|
# PROP BASE Output_Dir "Debug_ST"
|
||||||
|
# PROP BASE Intermediate_Dir "Debug_ST"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 1
|
||||||
|
# PROP Output_Dir "Debug_ST"
|
||||||
|
# PROP Intermediate_Dir "Debug_ST"
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
# ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /YX /FD /GZ /c
|
||||||
|
# ADD CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /I "D:\cots\freetype-2.0.5\include" /I "..\..\include" /D "_DEBUG" /D "WIN32" /D "_MBCS" /D "_LIB" /D "FTGL_LIBRARY_STATIC" /YX /FD /GZ /c
|
||||||
|
# ADD BASE RSC /l 0x409 /d "_DEBUG"
|
||||||
|
# ADD RSC /l 0x409 /d "_DEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LIB32=link.exe -lib
|
||||||
|
# ADD BASE LIB32 /nologo
|
||||||
|
# ADD LIB32 /nologo /out:"..\Build\ftgl_static_MT_d.lib"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "ftgl_static_lib - Win32 Debug MT"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 1
|
||||||
|
# PROP BASE Output_Dir "Debug_MT"
|
||||||
|
# PROP BASE Intermediate_Dir "Debug_MT"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 1
|
||||||
|
# PROP Output_Dir "Debug_MT"
|
||||||
|
# PROP Intermediate_Dir "Debug_MT"
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
# ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /I "D:\cots\freetype-2.0.5\include" /D "_DEBUG" /D "WIN32" /D "_MBCS" /D "_LIB" /D "FTGL_LIBRARY_STATIC" /YX /FD /GZ /c
|
||||||
|
# ADD CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /I "D:\cots\freetype-2.0.5\include" /I "..\..\include" /D "_DEBUG" /D "WIN32" /D "_MBCS" /D "_LIB" /D "FTGL_LIBRARY_STATIC" /YX /FD /GZ /c
|
||||||
|
# ADD BASE RSC /l 0x409 /d "_DEBUG"
|
||||||
|
# ADD RSC /l 0x409 /d "_DEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LIB32=link.exe -lib
|
||||||
|
# ADD BASE LIB32 /nologo
|
||||||
|
# ADD LIB32 /nologo /out:"..\Build\ftgl_static_MTD_d.lib"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "ftgl_static_lib - Win32 Release MT"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir "Release_MT"
|
||||||
|
# PROP BASE Intermediate_Dir "Release_MT"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir "Release_MT"
|
||||||
|
# PROP Intermediate_Dir "Release_MT"
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
# ADD BASE CPP /nologo /W3 /GX /O2 /D "NDEBUG" /D "WIN32" /D "_MBCS" /D "_LIB" /D "FTGL_LIBRARY_STATIC" /YX /FD /c
|
||||||
|
# ADD CPP /nologo /MD /W3 /GX /O2 /I "D:\cots\freetype-2.0.5\include" /I "..\..\include" /D "NDEBUG" /D "WIN32" /D "_MBCS" /D "_LIB" /D "FTGL_LIBRARY_STATIC" /YX /FD /c
|
||||||
|
# ADD BASE RSC /l 0x409 /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x409 /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LIB32=link.exe -lib
|
||||||
|
# ADD BASE LIB32 /nologo
|
||||||
|
# ADD LIB32 /nologo /out:"..\Build\ftgl_static_MTD.lib"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# Begin Target
|
||||||
|
|
||||||
|
# Name "ftgl_static_lib - Win32 Release"
|
||||||
|
# Name "ftgl_static_lib - Win32 Debug"
|
||||||
|
# Name "ftgl_static_lib - Win32 Debug MT"
|
||||||
|
# Name "ftgl_static_lib - Win32 Release MT"
|
||||||
|
# Begin Group "Source Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTBitmapGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTCharmap.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTContour.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTExtrdGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTFace.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGLBitmapFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGLExtrdFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGLOutlineFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGLPixmapFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGLPolygonFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGLTextureFont.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTGlyphContainer.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTLibrary.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTOutlineGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTPixmapGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTPoint.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTPolyGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTSize.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTTextureGlyph.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\FTVectoriser.cpp
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# Begin Group "Header Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "h;hpp;hxx;hm;inl"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTBBox.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTBitmapGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTCharmap.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTCharToGlyphIndexMap.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTContour.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTExtrdGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTFace.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGL.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGLBitmapFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGLExtrdFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGLOutlineFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGLPixmapFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGLPolygonFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGLTextureFont.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTGlyphContainer.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTLibrary.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTList.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTOutlineGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTPixmapGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTPoint.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTPolyGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTSize.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTTextureGlyph.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTVector.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\FTVectoriser.h
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# End Target
|
||||||
|
# End Project
|
||||||
168
extern/bFTGL/win32_vcpp/unit_tests/unit_tests.dsp
vendored
Normal file
168
extern/bFTGL/win32_vcpp/unit_tests/unit_tests.dsp
vendored
Normal file
@@ -0,0 +1,168 @@
|
|||||||
|
# Microsoft Developer Studio Project File - Name="unit_tests" - Package Owner=<4>
|
||||||
|
# Microsoft Developer Studio Generated Build File, Format Version 6.00
|
||||||
|
# ** DO NOT EDIT **
|
||||||
|
|
||||||
|
# TARGTYPE "Win32 (x86) Console Application" 0x0103
|
||||||
|
|
||||||
|
CFG=unit_tests - Win32 Debug
|
||||||
|
!MESSAGE This is not a valid makefile. To build this project using NMAKE,
|
||||||
|
!MESSAGE use the Export Makefile command and run
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE NMAKE /f "unit_tests.mak".
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE You can specify a configuration when running NMAKE
|
||||||
|
!MESSAGE by defining the macro CFG on the command line. For example:
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE NMAKE /f "unit_tests.mak" CFG="unit_tests - Win32 Debug"
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE Possible choices for configuration are:
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE "unit_tests - Win32 Release" (based on "Win32 (x86) Console Application")
|
||||||
|
!MESSAGE "unit_tests - Win32 Debug" (based on "Win32 (x86) Console Application")
|
||||||
|
!MESSAGE
|
||||||
|
|
||||||
|
# Begin Project
|
||||||
|
# PROP AllowPerConfigDependencies 0
|
||||||
|
# PROP Scc_ProjName ""
|
||||||
|
# PROP Scc_LocalPath ""
|
||||||
|
CPP=cl.exe
|
||||||
|
RSC=rc.exe
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "unit_tests - Win32 Release"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir "Release"
|
||||||
|
# PROP BASE Intermediate_Dir "Release"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir "Release"
|
||||||
|
# PROP Intermediate_Dir "Release"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /D "_MBCS" /Yu"stdafx.h" /FD /c
|
||||||
|
# ADD CPP /nologo /MD /W3 /GX /O2 /I "$(MIC_COTS_CPPUNIT_DIR)/include" /I "../../include" /I "../../extras" /I "D:\cots\freetype-2.0.5\include" /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /D "_MBCS" /D "FTGL_LIBRARY_STATIC" /FD /c
|
||||||
|
# SUBTRACT CPP /YX /Yc /Yu
|
||||||
|
# ADD BASE RSC /l 0x409 /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x409 /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /machine:I386
|
||||||
|
# ADD LINK32 freetype204MT.lib ftgl_static_MT.lib cppunit.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib opengl32.lib glu32.lib /nologo /subsystem:console /machine:I386 /libpath:"..\Build" /libpath:"D:\cots\freetype-2.0.5\objs" /libpath:"D:\cots\cppunit-1.9.8\lib"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "unit_tests - Win32 Debug"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 1
|
||||||
|
# PROP BASE Output_Dir "Debug"
|
||||||
|
# PROP BASE Intermediate_Dir "Debug"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 1
|
||||||
|
# PROP Output_Dir "Debug"
|
||||||
|
# PROP Intermediate_Dir "Debug"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
# ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_CONSOLE" /D "_MBCS" /Yu"stdafx.h" /FD /GZ /c
|
||||||
|
# ADD CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /I "$(MIC_COTS_CPPUNIT_DIR)/include" /I "../../include" /I "../../extras" /I "D:\cots\freetype-2.0.5\include" /D "WIN32" /D "_DEBUG" /D "_CONSOLE" /D "_MBCS" /D "FTGL_LIBRARY_STATIC" /FD /GZ /c
|
||||||
|
# SUBTRACT CPP /YX /Yc /Yu
|
||||||
|
# ADD BASE RSC /l 0x409 /d "_DEBUG"
|
||||||
|
# ADD RSC /l 0x409 /d "_DEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /debug /machine:I386 /pdbtype:sept
|
||||||
|
# ADD LINK32 freetype204MT_D.lib ftgl_static_MT_d.lib cppunitd.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib opengl32.lib glu32.lib /nologo /subsystem:console /debug /machine:I386 /pdbtype:sept /libpath:"..\Build" /libpath:"D:\cots\freetype-2.0.5\objs" /libpath:"D:\cots\cppunit-1.9.8\lib"
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# Begin Target
|
||||||
|
|
||||||
|
# Name "unit_tests - Win32 Release"
|
||||||
|
# Name "unit_tests - Win32 Debug"
|
||||||
|
# Begin Group "Source Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTBBox-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTCharmap-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTContour-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTFace-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTFont-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTGlyphContainer-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTLibrary-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTList-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTMesh-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTPoint-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTSize-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTTesselation-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTVector-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE="..\..\test\FTVectoriser-Test.cpp"
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\test\HPGCalc_afm.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\test\HPGCalc_pfb.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\test\TestMain.cpp
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# Begin Group "Header Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "h;hpp;hxx;hm;inl"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\test\Fontdefs.h
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# End Target
|
||||||
|
# End Project
|
||||||
46
extern/bullet2/CMakeLists.txt
vendored
Normal file
46
extern/bullet2/CMakeLists.txt
vendored
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
# $Id$
|
||||||
|
# ***** BEGIN GPL/BL DUAL 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. The Blender
|
||||||
|
# Foundation also sells licenses for use in proprietary software under
|
||||||
|
# the Blender License. See http://www.blender.org/BL/ for information
|
||||||
|
# about this.
|
||||||
|
#
|
||||||
|
# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
#
|
||||||
|
# The Original Code is Copyright (C) 2006, Blender Foundation
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# The Original Code is: all of this file.
|
||||||
|
#
|
||||||
|
# Contributor(s): Jacques Beaurai, Erwin Coumans
|
||||||
|
#
|
||||||
|
# ***** END GPL/BL DUAL LICENSE BLOCK *****
|
||||||
|
|
||||||
|
SET(INC . src)
|
||||||
|
|
||||||
|
FILE(GLOB SRC
|
||||||
|
src/LinearMath/*.cpp
|
||||||
|
src/BulletCollision/BroadphaseCollision/*.cpp
|
||||||
|
src/BulletCollision/CollisionShapes/*.cpp
|
||||||
|
src/BulletCollision/NarrowPhaseCollision/*.cpp
|
||||||
|
src/BulletCollision//CollisionDispatch/*.cpp
|
||||||
|
src/BulletDynamics/ConstraintSolver/*.cpp
|
||||||
|
src/BulletDynamics/Vehicle/*.cpp
|
||||||
|
src/BulletDynamics/Dynamics/*.cpp
|
||||||
|
)
|
||||||
|
|
||||||
|
ADD_DEFINITIONS(-D_LIB)
|
||||||
|
|
||||||
|
BLENDERLIB(extern_bullet "${SRC}" "${INC}")
|
||||||
|
#, libtype=['game2', 'player'], priority=[20, 170], compileflags=cflags )
|
||||||
64
extern/bullet2/Makefile
vendored
Normal file
64
extern/bullet2/Makefile
vendored
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
#
|
||||||
|
# $Id$
|
||||||
|
#
|
||||||
|
# ***** BEGIN GPL/BL DUAL 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. The Blender
|
||||||
|
# Foundation also sells licenses for use in proprietary software under
|
||||||
|
# the Blender License. See http://www.blender.org/BL/ for information
|
||||||
|
# about this.
|
||||||
|
#
|
||||||
|
# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
#
|
||||||
|
# The Original Code is Copyright (C) 2002 by Hans Lambermont
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# The Original Code is: all of this file.
|
||||||
|
#
|
||||||
|
# Contributor(s):
|
||||||
|
#
|
||||||
|
# ***** END GPL/BL DUAL LICENSE BLOCK *****
|
||||||
|
LIBNAME = bullet2
|
||||||
|
include nan_definitions.mk
|
||||||
|
SOURCEDIR = extern/$(LIBNAME)
|
||||||
|
DIR = $(OCGDIR)/extern/$(LIBNAME)
|
||||||
|
DIRS = src
|
||||||
|
DISTDIR = src
|
||||||
|
|
||||||
|
BULLETDIRS = \
|
||||||
|
LinearMath \
|
||||||
|
BulletCollision/BroadphaseCollision \
|
||||||
|
BulletCollision/CollisionShapes \
|
||||||
|
BulletCollision/NarrowPhaseCollision \
|
||||||
|
BulletCollision//CollisionDispatch \
|
||||||
|
BulletDynamics/ConstraintSolver \
|
||||||
|
BulletDynamics/Vehicle \
|
||||||
|
BulletDynamics/Dynamics
|
||||||
|
|
||||||
|
include nan_subdirs.mk
|
||||||
|
|
||||||
|
CP = $(NANBLENDERHOME)/intern/tools/cpifdiff.sh
|
||||||
|
|
||||||
|
install: all debug
|
||||||
|
@[ -d $(NAN_BULLET2) ] || mkdir -p $(NAN_BULLET2)
|
||||||
|
@[ -d $(NAN_BULLET2)/include ] || mkdir -p $(NAN_BULLET2)/include
|
||||||
|
@for i in $(BULLETDIRS); do \
|
||||||
|
[ -d $(NAN_BULLET2)/include/$$i ] || mkdir -p $(NAN_BULLET2)/include/$$i; \
|
||||||
|
$(CP) $(DISTDIR)/$$i/*.h $(NAN_BULLET2)/include/$$i; \
|
||||||
|
done
|
||||||
|
@[ -d $(NAN_BULLET2)/lib ] || mkdir -p $(NAN_BULLET2)/lib
|
||||||
|
@$(CP) $(DISTDIR)/*.h $(NAN_BULLET2)/include
|
||||||
|
@$(CP) $(OCGDIR)/extern/bullet2/libbullet2.a $(NAN_BULLET2)/lib
|
||||||
|
ifeq ($(OS),darwin)
|
||||||
|
ranlib $(NAN_BULLET2)/lib/libbullet2.a
|
||||||
|
endif
|
||||||
921
extern/bullet2/make/msvc_7_0/Bullet_vc7.vcproj
vendored
Normal file
921
extern/bullet2/make/msvc_7_0/Bullet_vc7.vcproj
vendored
Normal file
@@ -0,0 +1,921 @@
|
|||||||
|
<?xml version="1.0" encoding="Windows-1252"?>
|
||||||
|
<VisualStudioProject
|
||||||
|
ProjectType="Visual C++"
|
||||||
|
Version="7.10"
|
||||||
|
Name="bullet2"
|
||||||
|
ProjectGUID="{FFD3C64A-30E2-4BC7-BC8F-51818C320400}"
|
||||||
|
SccProjectName=""
|
||||||
|
SccLocalPath="">
|
||||||
|
<Platforms>
|
||||||
|
<Platform
|
||||||
|
Name="Win32"/>
|
||||||
|
</Platforms>
|
||||||
|
<Configurations>
|
||||||
|
<Configuration
|
||||||
|
Name="Blender Debug|Win32"
|
||||||
|
OutputDirectory="..\..\..\..\..\build\msvc_7\extern\bullet\debug"
|
||||||
|
IntermediateDirectory="..\..\..\..\..\build\msvc_7\extern\bullet\debug"
|
||||||
|
ConfigurationType="4"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="FALSE"
|
||||||
|
CharacterSet="2">
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\src"
|
||||||
|
PreprocessorDefinitions="_DEBUG;_LIB;WIN32;BUM_INLINED;USE_ALGEBRAIC"
|
||||||
|
ExceptionHandling="FALSE"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="1"
|
||||||
|
UsePrecompiledHeader="2"
|
||||||
|
PrecompiledHeaderFile="..\..\..\..\..\build\msvc_7\extern\bullet\debug\Bullet.pch"
|
||||||
|
AssemblerListingLocation="..\..\..\..\..\build\msvc_7\extern\bullet\debug\"
|
||||||
|
ObjectFile="..\..\..\..\..\build\msvc_7\extern\bullet\debug\"
|
||||||
|
ProgramDataBaseFileName="..\..\..\..\..\build\msvc_7\extern\bullet\debug\"
|
||||||
|
WarningLevel="3"
|
||||||
|
SuppressStartupBanner="TRUE"
|
||||||
|
DebugInformationFormat="4"
|
||||||
|
CompileAs="0"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
OutputFile="..\..\..\..\..\build\msvc_7\libs\extern\debug\Bullet.lib"
|
||||||
|
SuppressStartupBanner="TRUE"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
CommandLine="ECHO Copying header files
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\BroadphaseCollision MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\BroadphaseCollision
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\NarrowPhaseCollision MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\NarrowPhaseCollision
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\CollisionDispatch MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionDispatch
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\CollisionShapes MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionShapes
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics\ConstraintSolver MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\ConstraintSolver
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics\Dynamics MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Dynamics
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics\Vehicle MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Vehicle
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\LinearMath MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\LinearMath
|
||||||
|
|
||||||
|
XCOPY /Y ..\..\src\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include
|
||||||
|
XCOPY /Y ..\..\src\LinearMath\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\LinearMath
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\BroadphaseCollision\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\BroadphaseCollision
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\NarrowPhaseCollision\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\NarrowPhaseCollision
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\NarrowPhaseCollision\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\NarrowPhaseCollision
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\CollisionDispatch\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionDispatch
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\CollisionShapes\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionShapes
|
||||||
|
XCOPY /Y ..\..\src\BulletDynamics\ConstraintSolver\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\ConstraintSolver
|
||||||
|
XCOPY /Y ..\..\src\BulletDynamics\Dynamics\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Dynamics
|
||||||
|
XCOPY /Y ..\..\src\BulletDynamics\Vehicle\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Vehicle
|
||||||
|
|
||||||
|
ECHO Done
|
||||||
|
"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="_DEBUG"
|
||||||
|
Culture="1033"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedWrapperGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="Blender Release|Win32"
|
||||||
|
OutputDirectory="..\..\..\..\..\build\msvc_7\extern\bullet"
|
||||||
|
IntermediateDirectory="..\..\..\..\..\build\msvc_7\extern\bullet"
|
||||||
|
ConfigurationType="4"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="FALSE"
|
||||||
|
CharacterSet="2">
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="1"
|
||||||
|
AdditionalIncludeDirectories="..\..\src"
|
||||||
|
PreprocessorDefinitions="NDEBUG;_LIB;WIN32;BUM_INLINED;USE_ALGEBRAIC"
|
||||||
|
StringPooling="TRUE"
|
||||||
|
ExceptionHandling="FALSE"
|
||||||
|
RuntimeLibrary="0"
|
||||||
|
EnableFunctionLevelLinking="TRUE"
|
||||||
|
UsePrecompiledHeader="2"
|
||||||
|
PrecompiledHeaderFile="..\..\..\..\..\build\msvc_7\extern\bullet\Bullet.pch"
|
||||||
|
AssemblerListingLocation="..\..\..\..\..\build\msvc_7\extern\bullet\"
|
||||||
|
ObjectFile="..\..\..\..\..\build\msvc_7\extern\bullet\"
|
||||||
|
ProgramDataBaseFileName="..\..\..\..\..\build\msvc_7\extern\bullet\"
|
||||||
|
WarningLevel="3"
|
||||||
|
SuppressStartupBanner="TRUE"
|
||||||
|
DebugInformationFormat="2"
|
||||||
|
CompileAs="0"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
OutputFile="..\..\..\..\..\build\msvc_7\libs\extern\Bullet.lib"
|
||||||
|
SuppressStartupBanner="TRUE"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
CommandLine="ECHO Copying header files
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\BroadphaseCollision MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\BroadphaseCollision
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\NarrowPhaseCollision MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\NarrowPhaseCollision
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\CollisionDispatch MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionDispatch
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\CollisionShapes MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionShapes
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics\ConstraintSolver MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\ConstraintSolver
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics\Dynamics MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Dynamics
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics\Vehicle MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Vehicle
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\LinearMath MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\LinearMath
|
||||||
|
|
||||||
|
XCOPY /Y ..\..\src\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include
|
||||||
|
XCOPY /Y ..\..\src\LinearMath\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\LinearMath
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\BroadphaseCollision\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\BroadphaseCollision
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\NarrowPhaseCollision\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\NarrowPhaseCollision
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\NarrowPhaseCollision\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\NarrowPhaseCollision
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\CollisionDispatch\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionDispatch
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\CollisionShapes\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionShapes
|
||||||
|
XCOPY /Y ..\..\src\BulletDynamics\ConstraintSolver\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\ConstraintSolver
|
||||||
|
XCOPY /Y ..\..\src\BulletDynamics\Dynamics\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Dynamics
|
||||||
|
XCOPY /Y ..\..\src\BulletDynamics\Vehicle\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Vehicle
|
||||||
|
|
||||||
|
ECHO Done
|
||||||
|
"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="NDEBUG"
|
||||||
|
Culture="1033"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedWrapperGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="3D Plugin Debug|Win32"
|
||||||
|
OutputDirectory="..\..\..\..\..\build\msvc_7\extern\bullet\mtdll\debug"
|
||||||
|
IntermediateDirectory="..\..\..\..\..\build\msvc_7\extern\bullet\mtdll\debug"
|
||||||
|
ConfigurationType="4"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="FALSE"
|
||||||
|
CharacterSet="2">
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="0"
|
||||||
|
AdditionalIncludeDirectories="..\..\src"
|
||||||
|
PreprocessorDefinitions="_DEBUG;_LIB;WIN32;BUM_INLINED;USE_ALGEBRAIC"
|
||||||
|
ExceptionHandling="FALSE"
|
||||||
|
BasicRuntimeChecks="3"
|
||||||
|
RuntimeLibrary="3"
|
||||||
|
UsePrecompiledHeader="2"
|
||||||
|
PrecompiledHeaderFile="..\..\..\..\..\build\msvc_7\extern\bullet\mtdll\debug\Bullet.pch"
|
||||||
|
AssemblerListingLocation="..\..\..\..\..\build\msvc_7\extern\bullet\mtdll\debug\"
|
||||||
|
ObjectFile="..\..\..\..\..\build\msvc_7\extern\bullet\mtdll\debug\"
|
||||||
|
ProgramDataBaseFileName="..\..\..\..\..\build\msvc_7\extern\bullet\mtdll\debug\"
|
||||||
|
WarningLevel="3"
|
||||||
|
SuppressStartupBanner="TRUE"
|
||||||
|
DebugInformationFormat="4"
|
||||||
|
CompileAs="0"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
OutputFile="..\..\..\..\..\build\msvc_7\libs\extern\mtdll\debug\Bullet.lib"
|
||||||
|
SuppressStartupBanner="TRUE"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
CommandLine="ECHO Copying header files
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\BroadphaseCollision MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\BroadphaseCollision
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\NarrowPhaseCollision MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\NarrowPhaseCollision
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\CollisionDispatch MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionDispatch
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\CollisionShapes MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionShapes
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics\ConstraintSolver MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\ConstraintSolver
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics\Dynamics MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Dynamics
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics\Vehicle MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Vehicle
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\LinearMath MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\LinearMath
|
||||||
|
|
||||||
|
XCOPY /Y ..\..\src\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include
|
||||||
|
XCOPY /Y ..\..\src\LinearMath\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\LinearMath
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\BroadphaseCollision\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\BroadphaseCollision
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\NarrowPhaseCollision\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\NarrowPhaseCollision
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\NarrowPhaseCollision\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\NarrowPhaseCollision
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\CollisionDispatch\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionDispatch
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\CollisionShapes\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionShapes
|
||||||
|
XCOPY /Y ..\..\src\BulletDynamics\ConstraintSolver\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\ConstraintSolver
|
||||||
|
XCOPY /Y ..\..\src\BulletDynamics\Dynamics\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Dynamics
|
||||||
|
XCOPY /Y ..\..\src\BulletDynamics\Vehicle\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Vehicle
|
||||||
|
|
||||||
|
ECHO Done
|
||||||
|
"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="_DEBUG"
|
||||||
|
Culture="1033"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedWrapperGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
||||||
|
</Configuration>
|
||||||
|
<Configuration
|
||||||
|
Name="3D Plugin Release|Win32"
|
||||||
|
OutputDirectory="..\..\..\..\..\build\msvc_7\extern\bullet\mtdll"
|
||||||
|
IntermediateDirectory="..\..\..\..\..\build\msvc_7\extern\bullet\mtdll"
|
||||||
|
ConfigurationType="4"
|
||||||
|
UseOfMFC="0"
|
||||||
|
ATLMinimizesCRunTimeLibraryUsage="FALSE"
|
||||||
|
CharacterSet="2">
|
||||||
|
<Tool
|
||||||
|
Name="VCCLCompilerTool"
|
||||||
|
Optimization="2"
|
||||||
|
InlineFunctionExpansion="1"
|
||||||
|
AdditionalIncludeDirectories="..\..\src"
|
||||||
|
PreprocessorDefinitions="NDEBUG;_LIB;WIN32;BUM_INLINED;USE_ALGEBRAIC"
|
||||||
|
StringPooling="TRUE"
|
||||||
|
ExceptionHandling="FALSE"
|
||||||
|
RuntimeLibrary="2"
|
||||||
|
EnableFunctionLevelLinking="TRUE"
|
||||||
|
UsePrecompiledHeader="2"
|
||||||
|
PrecompiledHeaderFile="..\..\..\..\..\build\msvc_7\extern\bullet\mtdll\Bullet.pch"
|
||||||
|
AssemblerListingLocation="..\..\..\..\..\build\msvc_7\extern\bullet\mtdll\"
|
||||||
|
ObjectFile="..\..\..\..\..\build\msvc_7\extern\bullet\mtdll\"
|
||||||
|
ProgramDataBaseFileName="..\..\..\..\..\build\msvc_7\extern\bullet\mtdll\"
|
||||||
|
WarningLevel="3"
|
||||||
|
SuppressStartupBanner="TRUE"
|
||||||
|
DebugInformationFormat="2"
|
||||||
|
CompileAs="0"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCCustomBuildTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCLibrarianTool"
|
||||||
|
OutputFile="..\..\..\..\..\build\msvc_7\libs\extern\mtdll\Bullet.lib"
|
||||||
|
SuppressStartupBanner="TRUE"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCMIDLTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPostBuildEventTool"
|
||||||
|
CommandLine="ECHO Copying header files
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\BroadphaseCollision MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\BroadphaseCollision
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\NarrowPhaseCollision MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\NarrowPhaseCollision
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\CollisionDispatch MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionDispatch
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletCollision\CollisionShapes MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionShapes
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics\ConstraintSolver MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\ConstraintSolver
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics\Dynamics MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Dynamics
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\BulletDynamics\Vehicle MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Vehicle
|
||||||
|
IF NOT EXIST ..\..\..\..\..\build\msvc_7\extern\bullet2\include\LinearMath MKDIR ..\..\..\..\..\build\msvc_7\extern\bullet\include\LinearMath
|
||||||
|
|
||||||
|
XCOPY /Y ..\..\src\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include
|
||||||
|
XCOPY /Y ..\..\src\LinearMath\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\LinearMath
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\BroadphaseCollision\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\BroadphaseCollision
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\NarrowPhaseCollision\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\NarrowPhaseCollision
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\NarrowPhaseCollision\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\NarrowPhaseCollision
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\CollisionDispatch\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionDispatch
|
||||||
|
XCOPY /Y ..\..\src\BulletCollision\CollisionShapes\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletCollision\CollisionShapes
|
||||||
|
XCOPY /Y ..\..\src\BulletDynamics\ConstraintSolver\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\ConstraintSolver
|
||||||
|
XCOPY /Y ..\..\src\BulletDynamics\Dynamics\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Dynamics
|
||||||
|
XCOPY /Y ..\..\src\BulletDynamics\Vehicle\*.h ..\..\..\..\..\build\msvc_7\extern\bullet\include\BulletDynamics\Vehicle
|
||||||
|
|
||||||
|
ECHO Done
|
||||||
|
"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreBuildEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCPreLinkEventTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCResourceCompilerTool"
|
||||||
|
PreprocessorDefinitions="NDEBUG"
|
||||||
|
Culture="1033"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCWebServiceProxyGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCXMLDataGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCManagedWrapperGeneratorTool"/>
|
||||||
|
<Tool
|
||||||
|
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
||||||
|
</Configuration>
|
||||||
|
</Configurations>
|
||||||
|
<References>
|
||||||
|
</References>
|
||||||
|
<Files>
|
||||||
|
<Filter
|
||||||
|
Name="src"
|
||||||
|
Filter="">
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\btBulletCollisionCommon.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\btBulletDynamicsCommon.h">
|
||||||
|
</File>
|
||||||
|
<Filter
|
||||||
|
Name="BulletDynamics"
|
||||||
|
Filter="">
|
||||||
|
<Filter
|
||||||
|
Name="ConstraintSolver"
|
||||||
|
Filter="">
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btConeTwistConstraint.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btConeTwistConstraint.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btConstraintSolver.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btContactConstraint.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btContactConstraint.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btContactSolverInfo.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btGeneric6DofConstraint.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btGeneric6DofConstraint.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btHingeConstraint.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btHingeConstraint.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btJacobianEntry.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btPoint2PointConstraint.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btPoint2PointConstraint.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btSequentialImpulseConstraintSolver.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btSequentialImpulseConstraintSolver.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btSolve2LinearConstraint.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btSolve2LinearConstraint.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btTypedConstraint.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\ConstraintSolver\btTypedConstraint.h">
|
||||||
|
</File>
|
||||||
|
</Filter>
|
||||||
|
<Filter
|
||||||
|
Name="Dynamics"
|
||||||
|
Filter="">
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\Dynamics\btDiscreteDynamicsWorld.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\Dynamics\btDiscreteDynamicsWorld.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\Dynamics\btDynamicsWorld.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\Dynamics\btRigidBody.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\Dynamics\btRigidBody.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\Dynamics\btSimpleDynamicsWorld.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\Dynamics\btSimpleDynamicsWorld.h">
|
||||||
|
</File>
|
||||||
|
</Filter>
|
||||||
|
<Filter
|
||||||
|
Name="Vehicle"
|
||||||
|
Filter="">
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\Vehicle\btRaycastVehicle.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\Vehicle\btRaycastVehicle.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\Vehicle\btVehicleRaycaster.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\Vehicle\btWheelInfo.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletDynamics\Vehicle\btWheelInfo.h">
|
||||||
|
</File>
|
||||||
|
</Filter>
|
||||||
|
</Filter>
|
||||||
|
<Filter
|
||||||
|
Name="BulletCollision"
|
||||||
|
Filter="">
|
||||||
|
<Filter
|
||||||
|
Name="BroadphaseCollision"
|
||||||
|
Filter="">
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\BroadphaseCollision\btAxisSweep3.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\BroadphaseCollision\btAxisSweep3.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\BroadphaseCollision\btBroadphaseInterface.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\BroadphaseCollision\btBroadphaseProxy.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\BroadphaseCollision\btBroadphaseProxy.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\BroadphaseCollision\btCollisionAlgorithm.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\BroadphaseCollision\btCollisionAlgorithm.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\BroadphaseCollision\btDispatcher.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\BroadphaseCollision\btDispatcher.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\BroadphaseCollision\btOverlappingPairCache.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\BroadphaseCollision\btOverlappingPairCache.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\BroadphaseCollision\btSimpleBroadphase.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\BroadphaseCollision\btSimpleBroadphase.h">
|
||||||
|
</File>
|
||||||
|
</Filter>
|
||||||
|
<Filter
|
||||||
|
Name="NarrowPhaseCollision"
|
||||||
|
Filter="">
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btContinuousConvexCollision.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btContinuousConvexCollision.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btConvexCast.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btConvexCast.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btConvexPenetrationDepthSolver.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btDiscreteCollisionDetectorInterface.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btGjkConvexCast.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btGjkConvexCast.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btGjkEpa.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btGjkEpa.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btGjkEpaPenetrationDepthSolver.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btGjkEpaPenetrationDepthSolver.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btGjkPairDetector.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btGjkPairDetector.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btManifoldPoint.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btMinkowskiPenetrationDepthSolver.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btMinkowskiPenetrationDepthSolver.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btPersistentManifold.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btPersistentManifold.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btPointCollector.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btRaycastCallback.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btRaycastCallback.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btSimplexSolverInterface.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btSubSimplexConvexCast.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btSubSimplexConvexCast.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btVoronoiSimplexSolver.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\NarrowPhaseCollision\btVoronoiSimplexSolver.h">
|
||||||
|
</File>
|
||||||
|
</Filter>
|
||||||
|
<Filter
|
||||||
|
Name="CollisionDispatch"
|
||||||
|
Filter="">
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btCollisionCreateFunc.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btCollisionDispatcher.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btCollisionDispatcher.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btCollisionObject.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btCollisionObject.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btCollisionWorld.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btCollisionWorld.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btCompoundCollisionAlgorithm.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btCompoundCollisionAlgorithm.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btConvexConcaveCollisionAlgorithm.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btConvexConcaveCollisionAlgorithm.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btConvexConvexAlgorithm.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btConvexConvexAlgorithm.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btEmptyCollisionAlgorithm.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btEmptyCollisionAlgorithm.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btManifoldResult.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btManifoldResult.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btSimulationIslandManager.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btSimulationIslandManager.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btSphereBoxCollisionAlgorithm.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btSphereBoxCollisionAlgorithm.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btSphereSphereCollisionAlgorithm.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btSphereSphereCollisionAlgorithm.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btSphereTriangleCollisionAlgorithm.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btSphereTriangleCollisionAlgorithm.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btUnionFind.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\btUnionFind.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\SphereTriangleDetector.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionDispatch\SphereTriangleDetector.h">
|
||||||
|
</File>
|
||||||
|
</Filter>
|
||||||
|
<Filter
|
||||||
|
Name="CollisionShapes"
|
||||||
|
Filter="">
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btBoxShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btBoxShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btBvhTriangleMeshShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btBvhTriangleMeshShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btCapsuleShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btCapsuleShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btCollisionMargin.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btCollisionShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btCollisionShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btCompoundShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btCompoundShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btConcaveShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btConcaveShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btConeShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btConeShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btConvexHullShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btConvexHullShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btConvexShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btConvexShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btConvexTriangleMeshShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btConvexTriangleMeshShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btCylinderShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btCylinderShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btEmptyShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btEmptyShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btHeightfieldTerrainShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btHeightfieldTerrainShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btMinkowskiSumShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btMinkowskiSumShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btMultiSphereShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btMultiSphereShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btOptimizedBvh.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btOptimizedBvh.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btPolyhedralConvexShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btPolyhedralConvexShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btSphereShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btSphereShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btStaticPlaneShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btStaticPlaneShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btStridingMeshInterface.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btStridingMeshInterface.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btTetrahedronShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btTetrahedronShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btTriangleBuffer.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btTriangleBuffer.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btTriangleCallback.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btTriangleCallback.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btTriangleIndexVertexArray.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btTriangleIndexVertexArray.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btTriangleMesh.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btTriangleMesh.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btTriangleMeshShape.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btTriangleMeshShape.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\BulletCollision\CollisionShapes\btTriangleShape.h">
|
||||||
|
</File>
|
||||||
|
</Filter>
|
||||||
|
</Filter>
|
||||||
|
<Filter
|
||||||
|
Name="LinearMath"
|
||||||
|
Filter="">
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btAabbUtil2.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btAlignedAllocator.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btAlignedAllocator.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btAlignedObjectArray.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btDefaultMotionState.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btGeometryUtil.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btGeometryUtil.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btIDebugDraw.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btList.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btMatrix3x3.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btMinMax.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btMotionState.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btPoint3.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btQuadWord.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btQuaternion.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btQuickprof.cpp">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btQuickprof.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btRandom.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btScalar.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btSimdMinMax.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btStackAlloc.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btTransform.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btTransformUtil.h">
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\LinearMath\btVector3.h">
|
||||||
|
</File>
|
||||||
|
</Filter>
|
||||||
|
</Filter>
|
||||||
|
</Files>
|
||||||
|
<Globals>
|
||||||
|
</Globals>
|
||||||
|
</VisualStudioProject>
|
||||||
12
extern/bullet2/readme.txt
vendored
Normal file
12
extern/bullet2/readme.txt
vendored
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
|
||||||
|
*** These files in extern/bullet2 are NOT part of the Blender build yet ***
|
||||||
|
|
||||||
|
This is the new refactored version of Bullet physics library version 2.x
|
||||||
|
|
||||||
|
Soon this will replace the old Bullet version in extern/bullet.
|
||||||
|
First the integration in Blender Game Engine needs to be updated.
|
||||||
|
Once that is done all build systems can be updated to use/build extern/bullet2 files.
|
||||||
|
|
||||||
|
Questions? mail blender at erwincoumans.com, or check the bf-blender mailing list.
|
||||||
|
Thanks,
|
||||||
|
Erwin
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user