diff --git a/features/makephp.feature b/features/makephp.feature index 0fab416..1afc9e6 100644 --- a/features/makephp.feature +++ b/features/makephp.feature @@ -126,7 +126,7 @@ Feature: Generate PHP files from PO files """ And the foo-plugin/foo-plugin-de_DE.l10n.php file should contain: """ - 'messages'=>[''=>['Foo Plugin'=>['Foo Plugin']]] + 'messages'=>['Foo Plugin'=>'Foo Plugin'] """ Scenario: Does include translations @@ -150,9 +150,20 @@ Feature: Generate PHP files from PO files "X-Domain: foo-plugin\n" "Plural-Forms: nplurals=2; plural=(n != 1);\n" + #: foo-plugin.js:15 + msgctxt "Plugin Name" + msgid "Foo Plugin (EN)" + msgstr "Foo Plugin (DE)" + #: foo-plugin.js:15 msgid "Foo Plugin" msgstr "Bar Plugin" + + #: foo-plugin.php:60 + msgid "You have %d new message" + msgid_plural "You have %d new messages" + msgstr[0] "Sie haben %d neue Nachricht" + msgstr[1] "Sie haben %d neue Nachrichten" """ When I run `wp i18n make-php foo-plugin` @@ -163,5 +174,5 @@ Feature: Generate PHP files from PO files And the return code should be 0 And the foo-plugin/foo-plugin-de_DE.l10n.php file should contain: """ - 'messages'=>[''=>['Foo Plugin'=>['Bar Plugin']]] + return ['domain'=>'foo-plugin','plural-forms'=>'nplurals=2; plural=(n != 1);','messages'=>['Plugin NameFoo Plugin (EN)'=>'Foo Plugin (DE)','Foo Plugin'=>'Bar Plugin','You have %d new message'=>'Sie haben %d neue Nachricht' . "\0" . 'Sie haben %d neue Nachrichten'],'language'=>'de_DE']; """ diff --git a/src/PhpArrayGenerator.php b/src/PhpArrayGenerator.php index 28c1c57..544d522 100644 --- a/src/PhpArrayGenerator.php +++ b/src/PhpArrayGenerator.php @@ -3,6 +3,7 @@ namespace WP_CLI\I18n; use Gettext\Generators\PhpArray; +use Gettext\Translation; use Gettext\Translations; /** @@ -39,6 +40,67 @@ public static function toString( Translations $translations, array $options = [] return ' [ static::generateHeaders( $translations ) ], + ]; + } + + /** + * @var Translation $translation + */ + foreach ( $translations as $translation ) { + if ( $translation->isDisabled() ) { + continue; + } + + $context = $translation->getContext(); + $original = $translation->getOriginal(); + + $key = $context ? $context . "\4" . $original : $original; + + if ( $translation->hasPluralTranslations() ) { + $msg_translations = $translation->getPluralTranslations(); + array_unshift( $msg_translations, $translation->getTranslation() ); + $messages[ $key ] = implode( "\0", $msg_translations ); + } else { + $messages[ $key ] = $translation->getTranslation(); + } + } + + return [ + 'domain' => $translations->getDomain(), + 'plural-forms' => $translations->getHeader( 'Plural-Forms' ), + 'messages' => $messages, + ]; + } + /** * Determines if the given array is a list. *