/var/lib/gnumed/server/sql/gmI18N-dynamic.sql is in gnumed-server 19.6-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 | -- ======================================================
-- GNUmed fixed string internationalisation (SQL gettext)
-- ======================================================
-- $Source: /home/ncq/Projekte/cvs2git/vcs-mirror/gnumed/gnumed/server/sql/gmI18N-dynamic.sql,v $
-- $Id: gmI18N-dynamic.sql,v 1.5 2006-07-24 14:18:52 ncq Exp $
-- license: GPL v2 or later
-- author: Karsten.Hilbert@gmx.net
-- =============================================
-- Import this script into any GNUmed database you create.
-- This will allow for transparent translation of 'fixed'
-- strings in the database. Simply switching the language in
-- i18n_curr_lang will enable the user to see another language.
-- For details please see the Developer's Guide.
-- =============================================
-- force terminate + exit(3) on errors if non-interactive
\set ON_ERROR_STOP 1
-- =============================================
comment on table i18n.curr_lang is
'holds the currently selected per-user default
language for fixed strings in the database';
-- =============================================
comment on table i18n.keys is
'this table holds all the original strings that need
translation so give this to your language teams,
the function i18n.i18n() will take care to enter relevant
strings into this table, the table table does NOT
play any role in runtime translation activity';
-- =============================================
\unset ON_ERROR_STOP
drop index i18n.idx_orig;
\set ON_ERROR_STOP 1
create index idx_orig on i18n.translations(orig);
comment on table i18n.translations is
'this table holds all the translated strings';
comment on column i18n.translations.lang is
'the language (corresponding to i18n.curr_lang for
a given user) that this translation belongs to';
comment on column i18n.translations.orig is
'the original, untranslated string, used as the search key.';
comment on column i18n.translations.trans is
'the translation of <orig> into <lang>';
-- =============================================
create or replace function i18n.i18n(text)
returns text
language 'plpgsql'
security definer
as '
DECLARE
original ALIAS FOR $1;
BEGIN
if not exists(select pk from i18n.keys where orig = original) then
insert into i18n.keys (orig) values (original);
end if;
return original;
END;
';
comment on function i18n.i18n(text) is
'insert original strings into i18n.keys for later translation';
-- =============================================
-- FIXME: if _orig does not exist - call i18n() on it ?
-- FIXME: support upd_tx(text, text) and take language from curr_lang
create or replace function i18n.upd_tx(text, text, text)
returns boolean
language 'plpgsql'
security definer
as '
declare
_lang alias for $1;
_orig alias for $2;
_trans alias for $3;
_tmp text;
begin
select into _tmp ''1'' from i18n.keys where orig=_orig;
if not found then
_tmp := ''String "'' || _orig || ''" not found in i18n.keys. No use storing translation.'';
raise notice ''%'', _tmp;
-- return ''String "'' || _orig || ''" not found in i18n.keys. No use storing translation.'';
return False;
end if;
delete from i18n.translations where lang=_lang and orig=_orig;
insert into i18n.translations (lang, orig, trans) values (_lang, _orig, _trans);
-- return _orig || '' == ('' || _lang || '') ==> '' || _trans;
return True;
end;';
-- =============================================
create or replace function _(text)
returns text
language 'plpgsql'
security definer
as '
DECLARE
_orig ALIAS FOR $1;
trans_str text;
my_lang text;
BEGIN
-- get language
select into my_lang lang from i18n.curr_lang where user = CURRENT_USER;
if not found then
return _orig;
end if;
-- get translation
select into trans_str trans from i18n.translations
where lang = my_lang and orig = _orig;
if found then
return trans_str;
end if;
return _orig;
END;
';
comment on function _(text) is
'will return either the translation into
i18n.curr_lang.lang for the current user
or the input,
created in public schema for easy access';
-- =============================================
create or replace function _(text, text)
returns text
language 'plpgsql'
security definer
as '
DECLARE
_orig alias for $1;
_lang alias for $2;
trans_str text;
BEGIN
-- no translation available at all ?
if not exists(select 1 from i18n.translations where orig = _orig) then
return _orig;
end if;
-- get translation
select into trans_str trans
from i18n.translations
where
lang = _lang
and
orig = _orig;
if not found then
return _orig;
end if;
return trans_str;
END;
';
comment on function _(text, text) is
'will return either the translation into <text>
(2nd argument) for the current user or the input,
created in public schema for easy access';
-- =============================================
create or replace function i18n.set_curr_lang(text)
returns unknown
language 'plpgsql'
security definer
as '
DECLARE
_lang ALIAS FOR $1;
BEGIN
if exists(select pk from i18n.translations where lang = _lang) then
delete from i18n.curr_lang where user = CURRENT_USER;
insert into i18n.curr_lang (lang) values (_lang);
return true;
end if;
raise notice ''Cannot set current language to [%]. No translations available.'', _lang;
return false;
END;
';
comment on function i18n.set_curr_lang(text) is
'set preferred language:
- for "current user"
- only if translations for this language are available';
-- =============================================
create or replace function i18n.force_curr_lang(text)
returns unknown
language 'plpgsql'
security definer
as '
DECLARE
_lang ALIAS FOR $1;
BEGIN
raise notice ''Forcing current language to [%] without checking for translations..'', _lang;
delete from i18n.curr_lang where user = CURRENT_USER;
insert into i18n.curr_lang(lang) values (_lang);
return 1;
END;
';
comment on function i18n.force_curr_lang(text) is
'force preferred language to some language:
- for "current user"';
-- =============================================
create or replace function i18n.set_curr_lang(text, name)
returns boolean
language 'plpgsql'
security definer
as '
DECLARE
_lang ALIAS FOR $1;
_user ALIAS FOR $2;
BEGIN
if exists(select pk from i18n.translations where lang = _lang) then
delete from i18n.curr_lang where user = _user;
insert into i18n.curr_lang("user", lang) values (_user, _lang);
return true;
end if;
raise notice ''Cannot set current language to [%]. No translations available.'', _lang;
return False;
END;
';
comment on function i18n.set_curr_lang(text, name) is
'set language to first argument for the user named in
the second argument if translations are available';
-- =============================================
\unset ON_ERROR_STOP
drop view i18n.v_missing_translations;
\set ON_ERROR_STOP 1
create view i18n.v_missing_translations as
select
icl.lang,
ik.orig
from
(select distinct on (lang) lang from i18n.curr_lang) as icl,
i18n.keys ik
where
ik.orig not in (select orig from i18n.translations)
;
comment on view i18n.v_missing_translations is
'lists per language which strings are lacking a translation';
-- =============================================
grant usage on schema i18n to group "gm-public";
GRANT SELECT on
i18n.curr_lang
, i18n.keys
, i18n.translations
, i18n.v_missing_translations
TO group "gm-public";
-- =============================================
-- do simple schema revision tracking
select log_script_insertion('$RCSfile: gmI18N-dynamic.sql,v $', '$Revision: 1.5 $');
-- =============================================
-- $Log: gmI18N-dynamic.sql,v $
-- Revision 1.5 2006-07-24 14:18:52 ncq
-- - add comment
--
-- Revision 1.4 2006/07/01 15:22:03 ncq
-- - do not hard-fail set_curr_lang()
--
-- Revision 1.3 2006/02/06 13:18:27 ncq
-- - quote user when column name
--
-- Revision 1.2 2006/01/10 08:44:22 ncq
-- - drop index does not require "on"
--
-- Revision 1.1 2006/01/09 13:42:29 ncq
-- - factor out dynamic stuff
-- - move into schema "i18n" (except for _())
--
-- Revision 1.23 2005/09/19 16:38:51 ncq
-- - adjust to removed is_core from gm_schema_revision
--
-- Revision 1.22 2005/07/14 21:31:42 ncq
-- - partially use improved schema revision tracking
--
-- Revision 1.21 2005/07/04 11:42:24 ncq
-- - fix _(text, text)
--
-- Revision 1.20 2005/03/31 20:08:38 ncq
-- - add i18n_upd_tx() for safe update of translations
--
-- Revision 1.19 2005/03/01 20:38:19 ncq
-- - varchar -> text
--
-- Revision 1.18 2005/02/03 20:28:25 ncq
-- - improved comments
-- - added _(text, text)
--
-- Revision 1.17 2005/02/01 16:52:50 ncq
-- - added force_curr_lang()
--
-- Revision 1.16 2004/07/17 20:57:53 ncq
-- - don't use user/_user workaround anymore as we dropped supporting
-- it (but we did NOT drop supporting readonly connections on > 7.3)
--
-- Revision 1.15 2003/12/29 15:40:42 uid66147
-- - added not null
-- - added v_missing_translations
--
-- Revision 1.14 2003/06/10 09:58:11 ncq
-- - i18n() inserts strings into i18n_keys, not _(), fix comment to that effect
--
-- Revision 1.13 2003/05/12 12:43:39 ncq
-- - gmI18N, gmServices and gmSchemaRevision are imported globally at the
-- database level now, don't include them in individual schema file anymore
--
-- Revision 1.12 2003/05/02 15:06:44 ncq
-- - fix comment
--
-- Revision 1.11 2003/04/23 08:36:00 michaelb
-- made i18n_curr_lang longer still (11 to 15)
--
-- Revision 1.9 2003/02/04 13:22:01 ncq
-- - refined set_curr_lang to only work if translations available
-- - also auto-set for both "user" and "_user"
--
-- Revision 1.8 2003/02/04 12:22:52 ncq
-- - valid until in create user cannot do a sub-query :-(
-- - columns "owner" should really be of type "name" if defaulting to "CURRENT_USER"
-- - new functions set_curr_lang(*)
--
-- Revision 1.7 2003/01/24 14:16:18 ncq
-- - don't drop functions repeatedly since that will kill views created earlier
--
-- Revision 1.6 2003/01/20 20:21:53 ncq
-- - keep the last useful bit from i18n.sql as documentation
--
-- Revision 1.5 2003/01/20 19:42:47 ncq
-- - simplified creation of translating view a lot
--
-- Revision 1.4 2003/01/17 00:24:33 ncq
-- - add a few access right definitions
--
-- Revision 1.3 2003/01/05 13:05:51 ncq
-- - schema_revision -> gm_schema_revision
--
-- Revision 1.2 2003/01/04 10:30:26 ncq
-- - better documentation
-- - insert default english "translation" into i18n_translations
--
-- Revision 1.1 2003/01/01 17:41:57 ncq
-- - improved database i18n
--
|