aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llwindow/llwindowsdl.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llwindow/llwindowsdl.cpp')
-rw-r--r--linden/indra/llwindow/llwindowsdl.cpp98
1 files changed, 95 insertions, 3 deletions
diff --git a/linden/indra/llwindow/llwindowsdl.cpp b/linden/indra/llwindow/llwindowsdl.cpp
index d9dc040..0d1d622 100644
--- a/linden/indra/llwindow/llwindowsdl.cpp
+++ b/linden/indra/llwindow/llwindowsdl.cpp
@@ -39,6 +39,7 @@
39#include "llgl.h" 39#include "llgl.h"
40#include "llstring.h" 40#include "llstring.h"
41#include "lldir.h" 41#include "lldir.h"
42#include "llfindlocale.h"
42 43
43#include "llglheaders.h" 44#include "llglheaders.h"
44 45
@@ -51,6 +52,10 @@ extern "C" {
51#include <locale.h> 52#include <locale.h>
52#endif // LL_GTK 53#endif // LL_GTK
53 54
55extern "C" {
56# include "fontconfig/fontconfig.h"
57}
58
54#if LL_LINUX || LL_SOLARIS 59#if LL_LINUX || LL_SOLARIS
55// not necessarily available on random SDL platforms, so #if LL_LINUX 60// not necessarily available on random SDL platforms, so #if LL_LINUX
56// for execv(), waitpid(), fork() 61// for execv(), waitpid(), fork()
@@ -2030,7 +2035,8 @@ void LLWindowSDL::gatherInput()
2030 // the locale to protect it, as exotic/non-C locales 2035 // the locale to protect it, as exotic/non-C locales
2031 // causes our code lots of general critical weirdness 2036 // causes our code lots of general critical weirdness
2032 // and crashness. (SL-35450) 2037 // and crashness. (SL-35450)
2033 std::string saved_locale = setlocale(LC_ALL, NULL); 2038 static std::string saved_locale;
2039 saved_locale = ll_safe_string(setlocale(LC_ALL, NULL));
2034 2040
2035 // Pump until we've nothing left to do or passed 1/15th of a 2041 // Pump until we've nothing left to do or passed 1/15th of a
2036 // second pumping for this frame. 2042 // second pumping for this frame.
@@ -2751,8 +2757,8 @@ void spawn_web_browser(const char* escaped_url)
2751# endif // LL_X11 2757# endif // LL_X11
2752 2758
2753 std::string cmd; 2759 std::string cmd;
2754 cmd = gDirUtilp->getAppRODataDir().c_str(); 2760 cmd = gDirUtilp->getAppRODataDir();
2755 cmd += gDirUtilp->getDirDelimiter().c_str(); 2761 cmd += gDirUtilp->getDirDelimiter();
2756 cmd += "launch_url.sh"; 2762 cmd += "launch_url.sh";
2757 char* const argv[] = {(char*)cmd.c_str(), (char*)escaped_url, NULL}; 2763 char* const argv[] = {(char*)cmd.c_str(), (char*)escaped_url, NULL};
2758 2764
@@ -2829,4 +2835,90 @@ void LLWindowSDL::bringToFront()
2829#endif // LL_X11 2835#endif // LL_X11
2830} 2836}
2831 2837
2838//static
2839std::string LLWindowSDL::getFontListSans()
2840{
2841 // Use libfontconfig to find us a nice ordered list of fallback fonts
2842 // specific to this system.
2843 std::string final_fallback("/usr/share/fonts/truetype/kochi/kochi-gothic.ttf");
2844 // Our 'ideal' font properties which define the sorting results.
2845 // slant=0 means Roman, index=0 means the first face in a font file
2846 // (the one we actually use), weight=80 means medium weight,
2847 // spacing=0 means proportional spacing.
2848 std::string sort_order("slant=0:index=0:weight=80:spacing=0");
2849 // elide_unicode_coverage removes fonts from the list whose unicode
2850 // range is covered by fonts earlier in the list. This usually
2851 // removes ~90% of the fonts as redundant (which is great because
2852 // the font list can be huge), but might unnecessarily reduce the
2853 // renderable range if for some reason our FreeType actually fails
2854 // to use some of the fonts we want it to.
2855 const bool elide_unicode_coverage = true;
2856 std::string rtn;
2857 FcFontSet *fs = NULL;
2858 FcPattern *sortpat = NULL;
2859 int font_count = 0;
2860
2861 llinfos << "Getting system font list from FontConfig..." << llendl;
2862
2863 // If the user has a system-wide language preference, then favor
2864 // fonts from that language group. This doesn't affect the types
2865 // of languages that can be displayed, but ensures that their
2866 // preferred language is rendered from a single consistent font where
2867 // possible.
2868 FL_Locale *locale = NULL;
2869 FL_Success success = FL_FindLocale(&locale, FL_MESSAGES);
2870 if (success != 0)
2871 {
2872 if (success >= 2 && locale->lang) // confident!
2873 {
2874 llinfos << "Preferring fonts of language: "
2875 << locale->lang
2876 << llendl;
2877 sort_order = "lang=" + std::string(locale->lang) + ":"
2878 + sort_order;
2879 }
2880 FL_FreeLocale(&locale);
2881 }
2882
2883 if (!FcInit())
2884 {
2885 llwarns << "FontConfig failed to initialize." << llendl;
2886 return final_fallback;
2887 }
2888
2889 sortpat = FcNameParse((FcChar8*) sort_order.c_str());
2890 if (sortpat)
2891 {
2892 // Sort the list of system fonts from most-to-least-desirable.
2893 fs = FcFontSort(NULL, sortpat, elide_unicode_coverage,
2894 NULL, NULL);
2895 FcPatternDestroy(sortpat);
2896 }
2897
2898 if (fs)
2899 {
2900 // Get the full pathnames to the fonts, where available,
2901 // which is what we really want.
2902 int i;
2903 for (i=0; i<fs->nfont; ++i)
2904 {
2905 FcChar8 *filename;
2906 if (FcResultMatch == FcPatternGetString(fs->fonts[i],
2907 FC_FILE, 0,
2908 &filename)
2909 && filename)
2910 {
2911 rtn += std::string((const char*)filename)+";";
2912 ++font_count;
2913 }
2914 }
2915 FcFontSetDestroy (fs);
2916 }
2917
2918 lldebugs << "Using font list: " << rtn << llendl;
2919 llinfos << "Using " << font_count << " system font(s)." << llendl;
2920
2921 return rtn + final_fallback;
2922}
2923
2832#endif // LL_SDL 2924#endif // LL_SDL