diff options
author | Rob Haarsma <phaseIV@zonnet.nl> | 2003-05-03 16:59:33 +0400 |
---|---|---|
committer | Rob Haarsma <phaseIV@zonnet.nl> | 2003-05-03 16:59:33 +0400 |
commit | d7e7dc1928e7033c387675e7d9bd054bfb8f09f8 (patch) | |
tree | f93d209ab6de33f673ea367c4e18061113d09f53 | |
parent | c3ac92565550251f1b0795ec3d94b84dd237b936 (diff) |
Multilingual interface support added.
Added compileflag INTERNATIONAL to the 'release'
projectfiles for msvc and added the FTF_ftfont project
to the main blender project.
-rw-r--r-- | projectfiles/blender/ftfont/FTF_ftfont.dsp | 122 | ||||
-rw-r--r-- | source/blender/include/BIF_language.h | 46 | ||||
-rw-r--r-- | source/blender/src/language.c | 295 |
3 files changed, 463 insertions, 0 deletions
diff --git a/projectfiles/blender/ftfont/FTF_ftfont.dsp b/projectfiles/blender/ftfont/FTF_ftfont.dsp new file mode 100644 index 00000000000..e898af031b5 --- /dev/null +++ b/projectfiles/blender/ftfont/FTF_ftfont.dsp @@ -0,0 +1,122 @@ +# Microsoft Developer Studio Project File - Name="FTF_ftfont" - Package Owner=<4> +# Microsoft Developer Studio Generated Build File, Format Version 6.00 +# ** DO NOT EDIT ** + +# TARGTYPE "Win32 (x86) Static Library" 0x0104 + +CFG=FTF_ftfont - 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 "FTF_ftfont.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 "FTF_ftfont.mak" CFG="FTF_ftfont - Win32 Debug" +!MESSAGE +!MESSAGE Possible choices for configuration are: +!MESSAGE +!MESSAGE "FTF_ftfont - Win32 Release" (based on "Win32 (x86) Static Library") +!MESSAGE "FTF_ftfont - Win32 Debug" (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)" == "FTF_ftfont - 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 "..\..\..\obj\windows\blender\ftfont" +# PROP Intermediate_Dir "..\..\..\obj\windows\blender\ftfont" +# PROP Target_Dir "" +LINK32=link.exe -lib +# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /YX /FD /c +# ADD CPP /nologo /W3 /GX /O2 /I "../../../source\blender\makesdna" /I "../../../source\blender\blenloader" /I "../../../../lib/windows/ftgl/include" /I "../../../../lib/windows/freetype/include" /I "../../../lib/windows/iconv/include" /I "../../../../lib/windows/gettext/include" /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /D "WCHAR_T16" /D "HAVE_LC_MESSAGES" /YX /FD /c +# ADD BASE RSC /l 0x411 /d "NDEBUG" +# ADD RSC /l 0x411 /d "NDEBUG" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LIB32=link.exe -lib +# ADD BASE LIB32 /nologo +# ADD LIB32 /nologo + +!ELSEIF "$(CFG)" == "FTF_ftfont - 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 "..\..\..\obj\windows\blender\ftfont" +# PROP Intermediate_Dir "..\..\..\obj\windows\blender\ftfont" +# PROP Target_Dir "" +LINK32=link.exe -lib +# ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /YX /FD /GZ /c +# ADD CPP /nologo /W3 /Gm /GX /ZI /Od /I "../../../../lib/windows/ftgl/include" /I "../../../../lib/windows/freetype/include" /I "../../../lib/windows/iconv/include" /I "../../../../lib/windows/gettext/include" /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /D "WCHAR_T16" /D "INTERNATIONAL" /YX /FD /GZ /c +# ADD BASE RSC /l 0x411 /d "_DEBUG" +# ADD RSC /l 0x411 /d "_DEBUG" +BSC32=bscmake.exe +# ADD BASE BSC32 /nologo +# ADD BSC32 /nologo +LIB32=link.exe -lib +# ADD BASE LIB32 /nologo +# ADD LIB32 /nologo +# Begin Special Build Tool +SOURCE="$(InputPath)" +PostBuild_Cmds=XCOPY /Y ..\..\*.h ..\..\..\..\lib\windows\ftfont\include\ XCOPY /Y ..\..\..\..\obj\windows\intern\ftfont\*.lib ..\..\..\..\lib\windows\ftfont\lib\*.a +# End Special Build Tool + +!ENDIF + +# Begin Target + +# Name "FTF_ftfont - Win32 Release" +# Name "FTF_ftfont - Win32 Debug" +# Begin Group "Source Files" + +# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat" +# Begin Source File + +SOURCE=..\..\..\source\blender\ftfont\intern\FTF_Api.cpp +# End Source File +# Begin Source File + +SOURCE=..\..\..\source\blender\ftfont\intern\FTF_TTFont.cpp +# End Source File +# End Group +# Begin Group "extern" + +# PROP Default_Filter "" +# Begin Source File + +SOURCE=..\..\..\source\blender\ftfont\FTF_Api.h +# End Source File +# Begin Source File + +SOURCE=..\..\..\source\blender\ftfont\FTF_Settings.h +# End Source File +# End Group +# Begin Group "intern" + +# PROP Default_Filter "" +# Begin Source File + +SOURCE=..\..\..\source\blender\ftfont\intern\FTF_TTFont.h +# End Source File +# End Group +# End Target +# End Project diff --git a/source/blender/include/BIF_language.h b/source/blender/include/BIF_language.h new file mode 100644 index 00000000000..24edc4343e7 --- /dev/null +++ b/source/blender/include/BIF_language.h @@ -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) 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 ***** + */ + +#ifndef BIF_LANGUAGE_H +#define BIF_LANGUAGE_H + +int readMultiLingualFiles(void); /* usiblender.c */ +void languagesmenu_free(void); /* usiblender.c */ + +void set_interface_font(char *str); /* headerbuttons.c */ +void set_ML_interface_font(void); /* headerbuttons.c */ +void lang_setlanguage(void); /* usiblender.c */ + +char *language_pup(void); +char *fontsize_pup(void); + +#endif /* BIF_LANGUAGE_H */
\ No newline at end of file diff --git a/source/blender/src/language.c b/source/blender/src/language.c new file mode 100644 index 00000000000..9bd92cc6774 --- /dev/null +++ b/source/blender/src/language.c @@ -0,0 +1,295 @@ +/** + * $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 written by Rob Haarsma (phase) + * + * Contributor(s): none yet. + * + * ***** END GPL/BL DUAL LICENSE BLOCK ***** + */ + +/* dynamic popup generation for languages */ + +#ifdef INTERNATIONAL + +#include <string.h> +#include <stdlib.h> + +#include "DNA_userdef_types.h" + +#include "BKE_global.h" /* G */ +#include "BKE_utildefines.h" + +#include "BLI_blenlib.h" +#include "BLI_linklist.h" /* linknode */ + +#include "BIF_language.h" +#include "BIF_space.h" /* allqueue() */ +#include "BIF_toolbox.h" /* error() */ + +#include "MEM_guardedalloc.h" /* vprintf, etc ??? */ + +#include "mydevice.h" /* REDRAWALL */ + +#include "FTF_Api.h" + +typedef struct _LANGMenuEntry LANGMenuEntry; +struct _LANGMenuEntry { + LANGMenuEntry *next; + + char *line; + char *language; + char *code; + int id; +}; + +static LANGMenuEntry *langmenu= 0; + +static int tot_lang = 0; + + +char *fontsize_pup(void) +{ + static char string[1024]; + char formatstring[1024]; + + strcpy(formatstring, "Choose Font Size: %%t|%s %%x%d|%s %%x%d|%s %%x%d|%s %%x%d|%s %%x%d|%s %%x%d|%s %%x%d|%s %%x%d|%s %%x%d"); + + sprintf(string, formatstring, + "Font Size: 8", 8, + "Font Size: 9", 9, + "Font Size: 10", 10, + "Font Size: 11", 11, + "Font Size: 12", 12, + "Font Size: 13", 13, + "Font Size: 14", 14, + "Font Size: 15", 15, + "Font Size: 16", 16 + ); + + return (string); +} + + +char *language_pup(void) +{ + LANGMenuEntry *lme = langmenu; + static char string[1024]; + static char tmp[1024]; + + if(tot_lang == 0) + sprintf(string, "Choose Language: %%t|Language: English %%x0"); + else { + sprintf(string, "Choose Language: %%t"); + while(lme) { + sprintf(tmp, "|Language: %s %%x%d", lme->language, lme->id); + strcat(string, tmp); + lme= lme->next; + } + } + + return string; +} + + +LANGMenuEntry *find_language(short langid){ + LANGMenuEntry *lme = langmenu; + + while(lme) { + if(lme->id == langid) + return lme; + + lme=lme->next; + } + return NULL; +} + + +void lang_setlanguage(void) { + LANGMenuEntry *lme; + + lme = find_language(U.language); + if(lme) FTF_SetLanguage(lme->code); + else FTF_SetLanguage("en_US"); +} + + +void set_interface_font(char *str) { + char di[FILE_MAXDIR]; + + if(FTF_SetFont(str, U.fontsize)) { + + lang_setlanguage(); + + BLI_split_dirfile(str, di, U.fontname); + + G.ui_international = TRUE; + } else { + sprintf(U.fontname, "Invalid font."); + G.ui_international = FALSE; + } + allqueue(REDRAWALL, 0); +} + + +void set_ML_interface_font(void) { + char tstr[FILE_MAXDIR+FILE_MAXFILE]; + int result = 0; + + /* dirty hack to find out if we have saved language/font settings, + if not, try default font --phase */ + + if(U.fontsize != 0) { + BLI_make_file_string("/", tstr, U.fontdir, U.fontname); + + result = FTF_SetFont(tstr, U.fontsize); + } else { + U.language= 0; + U.fontsize= 12; + U.encoding= 0; + sprintf(U.fontname, ".bfont.ttf\0"); + + result = FTF_SetFont(U.fontname, U.fontsize); + } + + if(!result) result = FTF_SetFont(".bfont.ttf", U.fontsize); +// printf(" res = %d\n ", result); + if(result) { + lang_setlanguage(); + + G.ui_international = TRUE; + } else { + printf("no way ftf\n"); + G.ui_international = FALSE; + } + + allqueue(REDRAWALL, 0); +} + + +char *first_dpointchar(char *string) { + char *dpointchar; + + dpointchar= strchr(string, ':'); + + return dpointchar; +} + + +void splitlangline(char *line, LANGMenuEntry *lme) +{ + char *dpointchar= first_dpointchar(line); + + if (dpointchar) { + lme->code= BLI_strdup(dpointchar+1); + *(dpointchar)=0; + lme->language= BLI_strdup(line); + } else { + error("Invalid language file"); + } +} + + +void puplang_insert_entry(char *line) +{ + LANGMenuEntry *lme, *prev; + int sorted = 0; + + prev= NULL; + lme= langmenu; + + for (; lme; prev= lme, lme= lme->next) { + if (lme->line) { + if (BLI_streq(line, lme->line)) { + return; + } else if (sorted && strcmp(line, lme->line)<0) { + break; + } + } + } + + lme= MEM_mallocN(sizeof(*lme), "lme"); + lme->line = BLI_strdup(line); + splitlangline(line, lme); + lme->id = tot_lang; + tot_lang++; + + if (prev) { + lme->next= prev->next; + prev->next= lme; + } else { + lme->next= langmenu; + langmenu= lme; + } +} + + +int readMultiLingualFiles(void) { + char name[FILE_MAXDIR+FILE_MAXFILE]; + LinkNode *l, *lines; + + /* .Blanguages */ + + BLI_make_file_string("/", name, BLI_gethome(), ".Blanguages"); + lines= BLI_read_file_as_lines(name); + + if(lines == NULL) { + /* If not found in home, try current dir */ + strcpy(name, ".Blanguages"); + lines= BLI_read_file_as_lines(name); + if(lines == NULL) { + error("File \".Blanguages\" not found"); + return 0; + } + } + + for (l= lines; l; l= l->next) { + char *line= l->link; + + if (!BLI_streq(line, "")) { + puplang_insert_entry(line); + } + } + + BLI_free_file_lines(lines); + + return 1; +} + + +void languagesmenu_free(void) +{ + LANGMenuEntry *lme= langmenu; + + while (lme) { + LANGMenuEntry *n= lme->next; + + if (lme->line) MEM_freeN(lme->line); + if (lme->language) MEM_freeN(lme->language); + if (lme->code) MEM_freeN(lme->code); + MEM_freeN(lme); + + lme= n; + } +} + +#endif /* INTERNATIONAL */ |