Merge "mediawiki.toc.test: Cleanup"
[lhc/web/wiklou.git] / languages / classes / LanguageHy.php
index cc3492b..b7767eb 100644 (file)
@@ -1,71 +1,96 @@
 <?php
-/** Armenian (Հայերեն)
-  *
-  * @addtogroup Language
-  * @author Ruben Vardanyan (Me@RubenVardanyan.com)
-  */
+/**
+ * Armenian (Հայերեն) specific code.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ * http://www.gnu.org/copyleft/gpl.html
+ *
+ * @file
+ * @author Ruben Vardanyan (Me@RubenVardanyan.com)
+ * @ingroup Language
+ */
 
-/* Please, see Language.php for general function comments */
+/**
+ * Armenian (Հայերեն)
+ *
+ * @ingroup Language
+ */
 class LanguageHy extends Language {
-       # Convert from the nominative form of a noun to some other case
-       # Invoked with {{grammar:case|word}}
+
+       /**
+        * Convert from the nominative form of a noun to some other case
+        * Invoked with {{grammar:case|word}}
+        *
+        * @param string $word
+        * @param string $case
+        * @return string
+        */
        function convertGrammar( $word, $case ) {
                global $wgGrammarForms;
-               if ( isset($wgGrammarForms['hy'][$case][$word]) ) {
+               if ( isset( $wgGrammarForms['hy'][$case][$word] ) ) {
                        return $wgGrammarForms['hy'][$case][$word];
                }
 
                # These rules are not perfect, but they are currently only used for site names so it doesn't
                # matter if they are wrong sometimes. Just add a special case for your site name if necessary.
 
-               #join and array_slice instead mb_substr
+               # join and array_slice instead mb_substr
                $ar = array();
                preg_match_all( '/./us', $word, $ar );
-               if (!preg_match("/[a-zA-Z_]/us", $word))
+               if ( !preg_match( "/[a-zA-Z_]/us", $word ) ) {
                        switch ( $case ) {
-                               case 'genitive': #սեռական հոլով
-                                       if (join('',array_slice($ar[0],-1))=='ա')
-                                               $word = join('',array_slice($ar[0],0,-1)).'այի';
-                                       elseif (join('',array_slice($ar[0],-1))=='ո')
-                                               $word=join('',array_slice($ar[0],0,-1)).'ոյի';
-                                       elseif (join('',array_slice($ar[0],-4))=='գիրք')
-                                               $word=join('',array_slice($ar[0],0,-4)).'գրքի';
-                                       else
-                                               $word.='ի';
+                               case 'genitive': # սեռական հոլով
+                                       if ( join( '', array_slice( $ar[0], -1 ) ) == 'ա' ) {
+                                               $word = join( '', array_slice( $ar[0], 0, -1 ) ) . 'այի';
+                                       } elseif ( join( '', array_slice( $ar[0], -1 ) ) == 'ո' ) {
+                                               $word = join( '', array_slice( $ar[0], 0, -1 ) ) . 'ոյի';
+                                       } elseif ( join( '', array_slice( $ar[0], -4 ) ) == 'գիրք' ) {
+                                               $word = join( '', array_slice( $ar[0], 0, -4 ) ) . 'գրքի';
+                                       } else {
+                                               $word .= 'ի';
+                                       }
                                        break;
-                               case 'dative':  #Տրական հոլով
-                                       #stub
+                               case 'dative':  # Տրական հոլով
+                                       # stub
                                        break;
-                               case 'accusative': #Հայցական հոլով
-                                       #stub
+                               case 'accusative': # Հայցական հոլով
+                                       # stub
                                        break;
                                case 'instrumental':  #
-                                       #stub
+                                       # stub
                                        break;
                                case 'prepositional': #
-                                       #stub
+                                       # stub
                                        break;
                        }
+               }
                return $word;
        }
 
-       function convertPlural( $count, $forms ) {
-               if ( !count($forms) ) { return ''; }
-               $forms = $this->preConvertPlural( $forms, 2 );
-
-               return (abs($count) <= 1) ? $forms[0] : $forms[1];
-       }
-
-       /*
+       /**
         * Armenian numeric format is "12 345,67" but "1234,56"
+        *
+        * @param string $_
+        *
+        * @return string
         */
-
-       function commafy($_) {
-               if (!preg_match('/^\d{1,4}$/',$_)) {
-                       return strrev((string)preg_replace('/(\d{3})(?=\d)(?!\d*\.)/','$1,',strrev($_)));
+       function commafy( $_ ) {
+               if ( !preg_match( '/^\d{1,4}$/', $_ ) ) {
+                       return strrev( (string)preg_replace( '/(\d{3})(?=\d)(?!\d*\.)/', '$1,', strrev( $_ ) ) );
                } else {
                        return $_;
                }
        }
 }
-