2017 © Pedro Peláez
 

library parser

Replace placeholders with proper data

image

ayeo/parser

Replace placeholders with proper data

  • Monday, June 6, 2016
  • by ayeo
  • Repository
  • 1 Watchers
  • 0 Stars
  • 4,369 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 1 Versions
  • 17 % Grown

The README.md

Build Status Scrutinizer Code Quality Software License Code Coverage, (*1)

Simple placeholder parser

Parser replaces specific placeholders with proper data., (*2)

Basic usage

Let's take a look at the simplest possible example:, (*3)

$parser = new Parser;
$string = "Hello {{name}}!";
$parser->parse($string, ['name' => 'Nikola Tesla']); //returns: Hello Nikola Tesla!

Of course you may use object instead of primitive array, (*4)

$parser = new Parser;

$customer = new Customer;
$customer->name = 'Nikola Tesla';

$string = "Hello {{customer.name}}!";
$parser->parse($string, ['customer' => $customer]); //returns: Hello Nikola Tesla!

Parser is smart enough to access private properties using getters., (*5)

It also supports nested objects as well, (*6)

$parser = new Parser;

$customer = new Customer;
$address = new Address('Green Alley', 12, 'London', 'LN4 4GD', 'United Kingdom');
$customer->setAddress($address);

$string = "{{customer.address.street}}";
$parser->parse($string, ['customer' => $customer]); //returns: Green Alley

Nested array are also welcome, (*7)

$parser = new Parser();
$data = ['user' =>  ['supervisor' => ['name' => 'Harry']]];
$parser->parse('Hi {{user.supervisor.name}}!', $data); //returns: Hi Harry!

Use custom embrace string

By default Parser uses "{{" as open string and "}}" as close string. You can set your own embrace strings using method, (*8)

$parser = new Parser();
$parser->setEmbraceStrings("*", "*");
$parser->parse("All *fruit* are *color*.", ["fruit" => "oranges", "color" => "orange"]);
//returns "All oranges are orange."

or using constructor, (*9)

$parser = new Parser("", "*", "*");

Note, embrace strings can not contains # char., (*10)

Formatting

Sometimes you need to use additional formatting for specific objects. The great example is DateTime. The best way to achieve this goal is use adapter pattern (or decorator) for your object. The parser shouldnt be able to do that for you., (*11)

The Versions

06/06 2016

dev-master

9999999-dev https://github.com/ayeo/parser

Replace placeholders with proper data

  Sources   Download

MIT

The Requires

  • php >=5.4.0

 

The Development Requires

parser placeholder