diff options
author | Luke Shumaker <lukeshu@sbcglobal.net> | 2016-05-01 15:12:12 -0400 |
---|---|---|
committer | Luke Shumaker <lukeshu@sbcglobal.net> | 2016-05-01 15:12:12 -0400 |
commit | c9aa36da061816dee256a979c2ff8d2ee41824d9 (patch) | |
tree | 29f7002b80ee984b488bd047dbbd80b36bf892e9 /extensions/LocalisationUpdate/reader/ReaderFactory.php | |
parent | b4274e0e33eafb5e9ead9d949ebf031a9fb8363b (diff) | |
parent | d1ba966140d7a60cd5ae4e8667ceb27c1a138592 (diff) |
Merge branch 'archwiki'
# Conflicts:
# skins/ArchLinux.php
# skins/ArchLinux/archlogo.gif
Diffstat (limited to 'extensions/LocalisationUpdate/reader/ReaderFactory.php')
-rw-r--r-- | extensions/LocalisationUpdate/reader/ReaderFactory.php | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/extensions/LocalisationUpdate/reader/ReaderFactory.php b/extensions/LocalisationUpdate/reader/ReaderFactory.php new file mode 100644 index 00000000..530ab3f9 --- /dev/null +++ b/extensions/LocalisationUpdate/reader/ReaderFactory.php @@ -0,0 +1,36 @@ +<?php +/** + * @file + * @author Niklas Laxström + * @license GPL-2.0+ + */ + +/** + * Constructs readers for files based on the names. + */ +class LU_ReaderFactory { + /** + * Constructs a suitable reader for a given path. + * @param string $filename Usually a relative path to the file name. + * @return LU_Reader + * @throw MWException + */ + public function getReader( $filename ) { + if ( preg_match( '/i18n\.php$/', $filename ) ) { + return new LU_PHPReader(); + } + + // Ugly hack for core i18n files + if ( preg_match( '/Messages(.*)\.php$/', $filename ) ) { + $code = Language::getCodeFromFileName( basename( $filename ), 'Messages' ); + return new LU_PHPReader( $code ); + } + + if ( preg_match( '/\.json/', $filename ) ) { + $code = basename( $filename, '.json' ); + return new LU_JSONReader( $code ); + } + + throw new MWException( "Unknown file format: " . $filename ); + } +} |