 
 
 
 , (*1)
, (*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)
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)