2 Unix SMB/CIFS implementation.
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 3 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>.
18 Created by Ryo Kawahara <rkawa@lbe.co.jp>
22 #include "web/swat_proto.h"
25 during a file download we first check to see if there is a language
26 specific file available. If there is then use that, otherwise
27 just open the specified file
29 int web_open(const char *fname
, int flags
, mode_t mode
)
32 char *lang
= lang_tdb_current();
35 if (asprintf(&p
, "lang/%s/%s", lang
, fname
) != -1) {
36 fd
= sys_open(p
, flags
, mode
);
44 /* fall through to default name */
45 return sys_open(fname
, flags
, mode
);
54 static int qsort_cmp_list(const void *x
, const void *y
) {
55 struct pri_list
*a
= (struct pri_list
*)x
;
56 struct pri_list
*b
= (struct pri_list
*)y
;
57 if (a
->pri
> b
->pri
) return -1;
58 if (a
->pri
< b
->pri
) return 1;
63 choose from a list of languages. The list can be comma or space
65 Keep choosing until we get a hit
66 Changed to habdle priority -- Simo
69 void web_set_lang(const char *lang_string
)
71 char **lang_list
, **count
;
75 /* build the lang list */
76 lang_list
= str_list_make(talloc_tos(), lang_string
, ", \t\r\n");
77 if (!lang_list
) return;
79 /* sort the list by priority */
82 while (*count
&& **count
) {
86 pl
= SMB_MALLOC_ARRAY(struct pri_list
, lang_num
);
91 for (i
= 0; i
< lang_num
; i
++) {
93 if ((pri_code
=strstr(lang_list
[i
], ";q="))) {
96 sscanf(pri_code
, "%f", &(pl
[i
].pri
));
100 pl
[i
].string
= SMB_STRDUP(lang_list
[i
]);
102 TALLOC_FREE(lang_list
);
104 qsort(pl
, lang_num
, sizeof(struct pri_list
), &qsort_cmp_list
);
106 /* it's not an error to not initialise - we just fall back to
109 for (i
= 0; i
< lang_num
; i
++) {
110 if (lang_tdb_init(pl
[i
].string
)) break;
113 for (i
= 0; i
< lang_num
; i
++) {
114 SAFE_FREE(pl
[i
].string
);