2017 © Pedro Peláez
 

library messageformat

image

karwana/messageformat

  • Saturday, December 13, 2014
  • by mattcg
  • Repository
  • 1 Watchers
  • 1 Stars
  • 80 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 5 Versions
  • 0 % Grown

The README.md

MessageFormat

Build Status, (*1)

Fast and reliable message formatting using INI language files and MessageFormatter., (*2)

Supports caching of serialized language files using Stash., (*3)

Why INI?

INI file parsing in PHP is much faster than YAML, although slightly slower but more readable than serialized PHP arrays. We think that's a good trade-off., (*4)

Usage

The MessageFormat constructor accepts three arguments: the path to directory where your INI files are kept, the locale name and an optional third argument, which is a chained MessageFormat instance that will be used as a fallback for nonexistent keys., (*5)

Using a single INI file with sections


use Karwana\MessageFormat\MessageFormat; $mf = new MessageFormat('/path/to/language/files/directory', 'en'); // Assume en.ini contains the following: // // [my_domain] // my_key = "My mesage is \"{0}\"." // my_other_key = "The colors of the rainbow." // The following line will print 'My message is "Hello".' to output. echo $mf->format('my_domain.my_key', array('Hello'));

Chaining multiple instances

$mf = new MessageFormat($ini_dir, 'en-gb', new MessageFormat($ini_dir, 'en'));

// Assume en-gb.ini contains the following:
//
// [my_domain]
// my_other_key = "The colours of the rainbow."

// The following line will print the British English message from en-gb.ini.
echo $mf->format('my_domain.my_other_key');

// The following line will print the fallback from en.ini.
echo $mf->format('my_domain.my_key', array('Yo'));

With chaining, only the messages which vary in between language or regional variants need to be specified in each variant file. This saves you having to keep track of and repeat changes across multiple files., (*6)

Caching parsed INI files

For large projects, parsing INI files can be a bottleneck which you can avoid by using Stash caching., (*7)

$mf->setCache(new Stash\Pool($my_stash_driver));

License

See LICENSE., (*8)

The Versions

13/12 2014

dev-master

9999999-dev

  Sources   Download

MIT

The Requires

  • ext-intl ~1.1.0
  • php >=5.4.0

 

The Development Requires

13/12 2014

1.2.1

1.2.1.0

  Sources   Download

MIT

The Requires

  • php >=5.4.0
  • ext-intl ~1.1.0

 

The Development Requires

31/07 2014

1.2.0

1.2.0.0

  Sources   Download

MIT

The Requires

  • php >=5.4.0
  • ext-intl ~1.1.0

 

The Development Requires

09/07 2014

1.1.0

1.1.0.0

  Sources   Download

MIT

The Requires

  • php >=5.3.0
  • ext-intl ~1.1.0
  • karwana/cache ~1.0.0

 

The Development Requires

09/07 2014

1.0.0

1.0.0.0

  Sources   Download

MIT

The Requires

  • php >=5.3.0
  • ext-intl ~1.1.0
  • karwana/cache ~1.0.0

 

The Development Requires