Skip to content
This repository has been archived by the owner on Jan 30, 2020. It is now read-only.

Commit

Permalink
Merge branch 'feature/5908' into develop
Browse files Browse the repository at this point in the history
  • Loading branch information
weierophinney committed Mar 5, 2014
178 parents 0cf26a5 + 144fb7e + 712a04b + 4dbc11a + c99b627 + 740abb6 + 9b5478d + 91a23e2 + 8649d44 + 3f353b0 + d340adb + 1e0e8f4 + 5c4289e + fb94cca + 2a3844c + 906bbcf + 3d9b8bb + 84844ae + 62fc651 + b0a3dd4 + 0dca0ef + 910bbbf + e574b9b + f30ec7d + 1fa84de + 41b8543 + 9e2c9d5 + 913f51c + 39924f3 + c2a11e1 + 61b9322 + 413a38b + e51b2b8 + 20e328b + 6437ec0 + e9b8476 + 95e54a0 + 7ea3aed + df6a706 + a82fc82 + 7c2a059 + 4fefb53 + 599ee3a + ea3fc65 + f6c04c2 + 6591e3d + a4f76e3 + 33c7531 + 2d59782 + 8152327 + e56ce9b + db9b18f + b88635a + a262823 + b79aef6 + c2284e4 + 70193eb + 96acf77 + 9675426 + 5f02411 + 0dafea7 + 15dc674 + 4a2447d + e6eb7f3 + e9499c5 + 272b15f + 11c7758 + 6f0e918 + 5f4980a + ecca95a + 88b5971 + ecb8d13 + 9de1c08 + 44aad17 + 13269e9 + 654cdb6 + dc708db + 380ffba + ff67e7f + fe2e025 + 95f0efa + 68cc4b3 + bf13b96 + 8870381 + 56480f4 + 1fa90d7 + 5c7fe1f + abe9bc1 + a33cacd + cdd7d9f + 6a261b1 + 5e594c4 + 01c1241 + 30d1dd2 + d4af079 + c9aa9b4 + 10f47ca + ef20fa1 + 2187ae2 + e7f3993 + db93d37 + aa57612 + 4af81d8 + 2f90998 + 3013404 + 69d83fe + f383ca9 + 1b26f48 + 054f09d + 0c86829 + f22d81a + e7ebffe + 72a7a54 + cc09223 + ab99f58 + 2c69e37 + b6ccfbc + b92a5da + 773a133 + 9ee28ff + 5865e20 + 63c7303 + 73371d0 + b96f402 + b36e36b + 60fa081 + a1d27a6 + 43e9240 + 9e59ae6 + be1ce44 + 5a6465d + 7e455b4 + 83d837e + 28bc01e + 215be48 + efcc8e0 + 5192ae6 + 7e1ba0f + dec8ccf + 94afc0f + 8c3ea5f + d680762 + 9092473 + 041fc63 + ea6499d + 1f59300 + a75142b + f592cc2 + f523aef + 2d12221 + 34ad758 + 23cc229 + 1fa15a0 + 6b74fc7 + 1472e82 + d816ccc + 7b26586 + 08d26c4 + a5cc444 + fe92acf + 6bd67b2 + 371ba41 + 8651b9e + a313570 + 7a1829c + 39d06a8 + c05aee7 + 04f4340 + 2494ed2 + 952fe57 + 5d8a1d9 + 147d497 + a17086b + 8848167 + 9f9c3cd + 06374ae + 95dd270 + be6d4a6 commit 3e839cb
Show file tree
Hide file tree
Showing 2 changed files with 74 additions and 7 deletions.
48 changes: 41 additions & 7 deletions src/Translator/TextDomain.php
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,13 @@ class TextDomain extends ArrayObject
*/
protected $pluralRule;

/**
* Default plural rule shared between instances.
*
* @var PluralRule
*/
protected static $defaultPluralRule;

/**
* Set the plural rule
*
Expand All @@ -40,17 +47,40 @@ public function setPluralRule(PluralRule $rule)
/**
* Get the plural rule.
*
* Lazy loads a default rule if none already registered
* @param bool $fallbackToDefaultRule
* @return PluralRule|null
*/
public function getPluralRule($fallbackToDefaultRule = true)
{
if ($this->pluralRule === null && $fallbackToDefaultRule) {
return static::getDefaultPluralRule();
}

return $this->pluralRule;
}

/**
* Checks whether the text domain has a plural rule.
*
* @return bool
*/
public function hasPluralRule()
{
return ($this->pluralRule !== null);
}

/**
* Returns a shared default plural rule.
*
* @return PluralRule
*/
public function getPluralRule()
public static function getDefaultPluralRule()
{
if ($this->pluralRule === null) {
$this->setPluralRule(PluralRule::fromString('nplurals=2; plural=n != 1;'));
if (static::$defaultPluralRule === null) {
static::$defaultPluralRule = PluralRule::fromString('nplurals=2; plural=n != 1;');
}

return $this->pluralRule;
return static::$defaultPluralRule;
}

/**
Expand All @@ -66,8 +96,12 @@ public function getPluralRule()
*/
public function merge(TextDomain $textDomain)
{
if ($this->getPluralRule()->getNumPlurals() !== $textDomain->getPluralRule()->getNumPlurals()) {
throw new Exception\RuntimeException('Plural rule of merging text domain is not compatible with the current one');
if ($this->hasPluralRule() && $textDomain->hasPluralRule()) {
if ($this->getPluralRule()->getNumPlurals() !== $textDomain->getPluralRule()->getNumPlurals()) {
throw new Exception\RuntimeException('Plural rule of merging text domain is not compatible with the current one');
}
} elseif ($textDomain->hasPluralRule()) {
$this->setPluralRule($textDomain->getPluralRule());
}

$this->exchangeArray(
Expand Down
33 changes: 33 additions & 0 deletions test/Translator/TextDomainTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -58,10 +58,43 @@ public function testMergingIncompatibleTextDomains()
{
$this->setExpectedException('Zend\I18n\Exception\RuntimeException', 'is not compatible');

$domainA = new TextDomain();
$domainB = new TextDomain();
$domainA->setPluralRule(PluralRule::fromString('nplurals=3; plural=n'));
$domainB->setPluralRule(PluralRule::fromString('nplurals=2; plural=n'));

$domainA->merge($domainB);
}

public function testMergingTextDomainsWithPluralRules()
{
$domainA = new TextDomain();
$domainB = new TextDomain();

$domainA->merge($domainB);
$this->assertFalse($domainA->hasPluralRule());
$this->assertFalse($domainB->hasPluralRule());
}

public function testMergingTextDomainWithPluralRuleIntoTextDomainWithoutPluralRule()
{
$domainA = new TextDomain();
$domainB = new TextDomain();
$domainB->setPluralRule(PluralRule::fromString('nplurals=3; plural=n'));

$domainA->merge($domainB);
$this->assertEquals(3, $domainA->getPluralRule()->getNumPlurals());
$this->assertEquals(3, $domainB->getPluralRule()->getNumPlurals());
}

public function testMergingTextDomainWithoutPluralRuleIntoTextDomainWithPluralRule()
{
$domainA = new TextDomain();
$domainB = new TextDomain();
$domainA->setPluralRule(PluralRule::fromString('nplurals=3; plural=n'));

$domainA->merge($domainB);
$this->assertEquals(3, $domainA->getPluralRule()->getNumPlurals());
$this->assertFalse($domainB->hasPluralRule());
}
}

0 comments on commit 3e839cb

Please sign in to comment.