summaryrefslogtreecommitdiff
path: root/source/t/xfig/xfig.3.2.4-locale.diff
blob: 5bb9f9252302a9a43b1ac6da581bfa4f02402e3b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
--- main.c
+++ main.c	2006-07-31 17:56:25.000000000 +0200
@@ -62,6 +62,7 @@
 #ifdef I18N
 #include <X11/keysym.h>
 #include <locale.h>
+#include <langinfo.h>
 #endif  /* I18N */
 
 /* EXPORTS */
@@ -709,11 +710,6 @@ main(argc, argv)
 	}
     }
 
-#ifdef I18N
-    setlocale(LC_ALL, "");
-    XtSetLanguageProc(NULL, NULL, NULL);
-#endif  /* I18N */
-
     /*
      * save the command line arguments
      */
@@ -807,6 +803,10 @@ main(argc, argv)
     }
 
 #ifdef I18N
+    if (NULL == strcasestr(nl_langinfo(CODESET),"ANSI") &&
+	 NULL == strcasestr(nl_langinfo(CODESET),"ISO-8859-1"))
+	appres.international = True;
+
     /************************************************************/
     /* if the international option has been set, set the locale */
     /************************************************************/
@@ -1523,6 +1523,11 @@ setup_visual(argc_p, argv, args)
 	 */
 	tool = XtAppInitialize (&tool_app, "Fig", options, XtNumber (options), argc_p, argv,
 			       (String *) NULL, args, 0);
+#ifdef I18N
+	setlocale(LC_ALL, "");
+	setlocale(LC_NUMERIC, "C");
+	XtSetLanguageProc(tool_app, NULL, NULL);
+#endif  /* I18N */
 	/* save important info */
 	tool_d = XtDisplay(tool);
 	tool_s = XtScreen(tool);
--- u_print.c
+++ u_print.c	2006-11-16 12:45:46.000000000 +0000
@@ -15,6 +15,7 @@
  *
  */
 
+#include <locale.h>
 #include "fig.h"
 #include "resources.h"
 #include "mode.h"
@@ -75,6 +76,7 @@ char *shell_protect_string(string)
     return(buf);
 }
 
+void
 print_to_printer(printer, backgrnd, mag, print_all_layers, grid, params)
     char	    printer[];
     char	   *backgrnd;
@@ -111,6 +113,8 @@ print_to_printer(printer, backgrnd, mag,
 	name = shell_protect_string(cur_filename);
 
 #ifdef I18N
+    /* set the numeric locale to C so we set decimal points for numbers */
+    setlocale(LC_NUMERIC, "C");
     sprintf(tmpcmd, "%s %s -L ps -z %s -m %f %s -n %s",
 	    fig2dev_cmd, appres.international ? appres.fig2dev_localize_option : "",
 #else
@@ -119,6 +123,10 @@ print_to_printer(printer, backgrnd, mag,
 #endif /* I18N */
 	    paper_sizes[appres.papersize].sname, mag/100.0,
 	    appres.landscape ? "-l xxx" : "-p xxx", name);
+#ifdef I18N
+    /* reset to original locale */
+    setlocale(LC_NUMERIC, "");
+#endif /* I18N */
 
     if (appres.correct_font_size)
 	strcat(tmpcmd," -F ");
@@ -223,9 +231,13 @@ print_to_file(file, lang, mag, xoff, yof
 
     /* start with the command, language and internationalization, if applicable */
 #ifdef I18N
+    /* set the numeric locale to C so we set decimal points for numbers */
+    setlocale(LC_NUMERIC, "C");
     sprintf(prcmd, "%s %s -L %s -m %f ", 
 		fig2dev_cmd, appres.international ? appres.fig2dev_localize_option : "",
 		real_lang, mag/100.0);
+    /* reset to original locale */
+    setlocale(LC_NUMERIC, "");
 #else
     sprintf(prcmd, "%s -L %s -m %f ", fig2dev_cmd, real_lang, mag/100.0);
 #endif  /* I18N */
@@ -324,6 +336,8 @@ print_to_file(file, lang, mag, xoff, yof
 	strcat(tmp_name,"_t");
 	/* make it automatically input the postscript/pdf part (-p option) */
 #ifdef I18N
+	/* set the numeric locale to C so we set decimal points for numbers */
+	setlocale(LC_NUMERIC, "C");
 	sprintf(prcmd, "%s %s -L %s -E %d -p %s -m %f ",
 		fig2dev_cmd, appres.international ? appres.fig2dev_localize_option : "",
 #else
@@ -332,6 +346,10 @@ print_to_file(file, lang, mag, xoff, yof
 #endif  /* I18N */
 		!strcmp(lang,"pstex")? "pstex_t": "pdftex_t",
 		appres.encoding, outfile, mag/100.0);
+#ifdef I18N
+	/* reset to original locale */
+	setlocale(LC_NUMERIC, "");
+#endif  /* I18N */
 	/* add the -D +list if user doesn't want all layers printed */
 	if (!print_all_layers)
 	    strcat(prcmd, layers);