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
|
<?php
# this include file provides support for i18n
#
# usage:
# use the __() function for returning translated strings of
# text. The string can contain escape codes %h for HTML
# and %s for regular text.
#
# supporting scripts:
# there is a supporting script, web/utils/genpopo, that will
# parse the PHP files and create PHP include files that contain
# a mapping for each translated language. The include files
# have the form,
#
# $_t["en"]["My cat is large."] = "My cat is large.";
# $_t["es"]["My cat is large."] = "Mi gato esta grande.";
#
# examples:
# print __("%s has %s apples.", "Bill", "5");
# print __("This is a %h%s%h problem!", "<b>","major","</b>");
#
# deprecated usage:
# print __("%s has %s apples.", array("Bill", "5"));
include_once("common_po.inc");
function __() {
global $_t;
global $LANG;
# create the translation, if it doesn't exist, highlight it
#
$args = func_get_args();
# First argument is always string to be translated
$tag = $args[0];
if (empty($LANG) || $LANG == DEFAULT_LANG)
$translated = $tag;
else
$translated = $_t[$LANG][$tag];
if (empty($translated)) {
# if it's a supported language, but there isn't a translation,
# alert the visitor to the missing translation.
#
$translated = "_${tag}_";
}
# This condition is to reorganise the arguments in case of
# deprecated usage. __("string", array("string","string"))
if (!empty($args[1]) && is_array($args[1])) {
array_unshift($args[1], $tag);
$args = $args[1];
}
$num_args = sizeof($args);
# Subsequent arguments are strings to be formatted
if ( $num_args > 1 ) {
for ($i = 1; $i < $num_args; $i++) {
$translated = preg_replace("/\%[sh]/", $args[$i], $translated, 1);
}
}
return $translated;
}
|