blob: 650f796f9ecf41cb4d6ba0999b5a01478bd700ad (
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
|
<?php
set_include_path(get_include_path() . PATH_SEPARATOR . '../lib' . PATH_SEPARATOR . '../lang');
# This 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 %hmajor%h problem!", "<b>", "</b>");
include_once('config.inc');
global $_t;
function __() {
global $_t;
global $LANG;
# Create the translation.
$args = func_get_args();
# First argument is always string to be translated
$tag = $args[0];
if (empty($LANG) || $LANG == DEFAULT_LANG){
$translated = $tag;
}
# If there is no translation, just print the given string.
if (empty($_t[$tag])) {
$translated = $tag;
}
else {
$translated = $_t[$tag];
}
$translated = htmlspecialchars($translated, ENT_QUOTES);
$num_args = sizeof($args);
# Subsequent arguments are strings to be formatted
#
# TODO: make this more robust.
# '%%' should translate to a literal '%'
if ( $num_args > 1 ) {
for ($i = 1; $i < $num_args; $i++) {
$translated = preg_replace("/\%[sh]/", $args[$i], $translated, 1);
}
}
return $translated;
}
|