Mercurial > SimpleWebPresenter
annotate Language.inc @ 57:fd3dd497eba6
Documentation cleanup.
| author | Tom Fredrik Blenning Klaussen <bfg@blenning.no> |
|---|---|
| date | Thu, 11 Oct 2012 02:05:09 +0200 |
| parents | 0f1e08cdfff2 |
| children | 74f7b64bdb78 |
| rev | line source |
|---|---|
|
0
d2da64705bce
Refactored everything in the CMS into this repos.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
diff
changeset
|
1 <?php |
|
51
2cfea6e84694
Documentation update.
Tom Fredrik Blenning Klaussen <bfg@blenning.no>
parents:
24
diff
changeset
|
2 /** |
|
2cfea6e84694
Documentation update.
Tom Fredrik Blenning Klaussen <bfg@blenning.no>
parents:
24
diff
changeset
|
3 * @file |
|
2cfea6e84694
Documentation update.
Tom Fredrik Blenning Klaussen <bfg@blenning.no>
parents:
24
diff
changeset
|
4 * Functionality for determining language use |
|
2cfea6e84694
Documentation update.
Tom Fredrik Blenning Klaussen <bfg@blenning.no>
parents:
24
diff
changeset
|
5 */ |
|
54
f938b292f046
Something went wrong during last merge. Fix it now.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
53
diff
changeset
|
6 class Language { |
|
55
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
7 /** |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
8 * Extracts the accepted languages from the GET query, sorted by |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
9 * preference(q-value). |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
10 * |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
11 * @return associative array of language codes with q value |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
12 */ |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
13 function accepted() { |
|
54
f938b292f046
Something went wrong during last merge. Fix it now.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
53
diff
changeset
|
14 $langs = array(); |
|
51
2cfea6e84694
Documentation update.
Tom Fredrik Blenning Klaussen <bfg@blenning.no>
parents:
24
diff
changeset
|
15 |
|
55
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
16 if (isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])) { |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
17 // break up string into pieces (languages and q factors) |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
18 preg_match_all('/([a-z]{1,8}(-[a-z]{1,8})?)\s*(;\s*q\s*=\s*(1|0\.[0-9]+))?/i', $_SERVER['HTTP_ACCEPT_LANGUAGE'], $lang_parse); |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
19 |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
20 if (count($lang_parse[1])) { |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
21 // create a list like "en" => 0.8 |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
22 $langs = array_combine($lang_parse[1], $lang_parse[4]); |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
23 |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
24 // set default to 1 for any without q factor |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
25 foreach ($langs as $lang => $val) { |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
26 if ($val === '') $langs[$lang] = 1; |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
27 } |
|
0
d2da64705bce
Refactored everything in the CMS into this repos.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
diff
changeset
|
28 |
|
55
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
29 // sort list based on value |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
30 arsort($langs, SORT_NUMERIC); |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
31 } |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
32 } |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
33 return $langs; |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
34 } |
|
0
d2da64705bce
Refactored everything in the CMS into this repos.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
diff
changeset
|
35 |
|
55
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
36 /** |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
37 * From the list of desired languages, pick the best which we can serve. |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
38 * |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
39 * @param $default what to choose if no match could be found. |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
40 */ |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
41 static function prefer($default) |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
42 { |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
43 $language = $default; |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
44 $langs = self::accepted(); |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
45 if ($langs) { |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
46 foreach ($langs as $l => $val) { |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
47 if (file_exists($l)) { |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
48 $language = $l; |
|
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
49 break; |
| 52 | 50 } |
| 51 } | |
| 52 } | |
|
55
88482c6636c4
Yet another fix for failed merge.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
54
diff
changeset
|
53 return $language; |
| 52 | 54 } |
|
24
5c4d7c758fda
Remove name as hardcoded attribute.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
9
diff
changeset
|
55 } |
|
0
d2da64705bce
Refactored everything in the CMS into this repos.
Tom Fredrik "BFG" Klaussen <bfg@blenning.no>
parents:
diff
changeset
|
56 ?> |
