30da114d0c7a625a47381f5c8828294084f3a2fd
[freeside.git] / rt / lib / RT / I18N / cs.pm
1 # BEGIN BPS TAGGED BLOCK {{{
2 #
3 # COPYRIGHT:
4 #
5 # This software is Copyright (c) 1996-2014 Best Practical Solutions, LLC
6 #                                          <sales@bestpractical.com>
7 #
8 # (Except where explicitly superseded by other copyright notices)
9 #
10 #
11 # LICENSE:
12 #
13 # This work is made available to you under the terms of Version 2 of
14 # the GNU General Public License. A copy of that license should have
15 # been provided with this software, but in any event can be snarfed
16 # from www.gnu.org.
17 #
18 # This work is distributed in the hope that it will be useful, but
19 # WITHOUT ANY WARRANTY; without even the implied warranty of
20 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
21 # General Public License for more details.
22 #
23 # You should have received a copy of the GNU General Public License
24 # along with this program; if not, write to the Free Software
25 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
26 # 02110-1301 or visit their web page on the internet at
27 # http://www.gnu.org/licenses/old-licenses/gpl-2.0.html.
28 #
29 #
30 # CONTRIBUTION SUBMISSION POLICY:
31 #
32 # (The following paragraph is not intended to limit the rights granted
33 # to you to modify and distribute this software under the terms of
34 # the GNU General Public License and is only of importance to you if
35 # you choose to contribute your changes and enhancements to the
36 # community by submitting them to Best Practical Solutions, LLC.)
37 #
38 # By intentionally submitting any modifications, corrections or
39 # derivatives to this work, or any other work intended for use with
40 # Request Tracker, to Best Practical Solutions, LLC, you confirm that
41 # you are the copyright holder for those contributions and you grant
42 # Best Practical Solutions,  LLC a nonexclusive, worldwide, irrevocable,
43 # royalty-free, perpetual, license to use, copy, create derivative
44 # works based on those contributions, and sublicense and distribute
45 # those contributions and any derivatives thereof.
46 #
47 # END BPS TAGGED BLOCK }}}
48
49 use strict;
50 use warnings;
51
52 package RT::I18N::cs;
53 use base 'RT::I18N';
54
55 use strict;
56 use warnings;
57
58 # # CZECH TRANSLATORS COMMENTS see Locale::Maketext::TPJ13
59 # Obecne parametry musi byt docela slozite (v pripade Slavistickych jazyku)
60 # typu pocet, slovo, pad a rod 
61 #
62 #pad 1., rod muzsky:
63 #0 krecku
64 #1 krecek
65 #2..4 krecci
66 #5.. krecku (nehodi se zde resit pravidlo mod 1,2,3,4 krom mod 11,12,13,14)
67 #
68 #0 kabatu
69 #1 kabat
70 #2..4 kabaty
71 #5 kabatu
72 #
73 # => Vyplati se udelat quant s parametry typu pocet, slovo1, slovo2..4, slovo5 a slovo0
74 #
75
76 sub quant {
77   my($handle, $num, @forms) = @_;
78
79   return $num if @forms == 0; # what should this mean?
80   return $forms[3] if @forms > 3 and $num == 0; # special zeroth case
81
82   # Normal case:
83   # Note that the formatting of $num is preserved.
84   #return( $handle->numf($num) . ' ' . $handle->numerate($num, @forms) );
85   return( $handle->numerate($num, @forms) );
86    # Most human languages put the number phrase before the qualified phrase.
87 }
88
89
90 sub numerate {
91  # return this lexical item in a form appropriate to this number
92   my($handle, $num, @forms) = @_;
93   my $s = ($num == 1);
94
95   return '' unless @forms;
96   return
97    $s ? $forms[0] :
98    ( $num > 1 && $num < 5 ) ? $forms[1] :
99    $forms[2];
100 }
101
102 #--------------------------------------------------------------------------
103
104 sub numf {
105   my($handle, $num) = @_[0,1];
106   if($num < 10_000_000_000 and $num > -10_000_000_000 and $num == int($num)) {
107     $num += 0;  # Just use normal integer stringification.
108          # Specifically, don't let %G turn ten million into 1E+007
109   } else {
110     $num = CORE::sprintf("%G", $num);
111      # "CORE::" is there to avoid confusion with the above sub sprintf.
112   }
113   while( $num =~ s/^([-+]?\d+)(\d{3})/$1,$2/s ) {1}  # right from perlfaq5
114    # The initial \d+ gobbles as many digits as it can, and then we
115    #  backtrack so it un-eats the rightmost three, and then we
116    #  insert the comma there.
117
118   $num =~ tr<.,><,.> if ref($handle) and $handle->{'numf_comma'};
119    # This is just a lame hack instead of using Number::Format
120   return $num;
121 }
122
123 RT::Base->_ImportOverlays();
124
125 1;