lastwhitebird/lgml-parser

配置解析器,用于自定义缩进格式的配置文件(如YAML、python等)

0.0.6beta2 2019-12-02 13:41 UTC

README

配置解析器,用于自定义缩进格式的配置文件(如YAML、python等)

代码示例

PHP

		use \LWB\LGMLParser\Tree as Tree;
		$tree = Tree::factoryFromFile('tree.lgml');
		//serialization
		file_put_contents('tree.json', $tree->toJSON());
		//accessing tree nodes
		if (isset($tree['domains'][0]))
		foreach ($tree['domains'][0] as $domain)
			$domains[$domain['@!element']] = $domain['@'];

tree.lgml

/*...config sample*/
domains
      year, type dateTime, 
      		validator "digits_between:4,4"
      date, type dateTime
tables
  admin_rights, timestamps, softdeletes,
   section "user"
    columns
      key, type string, title "Key (in the form of: latin_letters)"
      name, type string,  title "Readable name"
    rows
      row
       key. process_complain_cancel
       name. Processing cancelling payment on customer complain
    

等等!

动机

这个组件是为了让生活更美好而制作的:制表符、点和逗号都更容易输入。即使在俄语键盘布局或任何您想要的布局中。

上帝保佑Hamish Friedlander和SilverStripe Limited,因为他们提供了php-peg解析器。

安装

composer require lastwhitebird/lgml-parser

API参考

主类

namespace LWB\LGMLParser;
class Tree
{
	use Tree\Quotes;
	/* 2 helper methods. dunno, they must be in the Basic class probably */
	public static function textNode($text);
	public static function node($element, $attributes = [])
	/* serialize methods */
	public function __toString()
	public function toXML($filename, $quote_function = false, $quote_attribute_function = false)
	public function toJSON()
	/* factory methods */
	public static function factoryFromJSON($string, array $options = [])
	public static function factoryFromFile($filename, array $options = [])
	public static function factoryFromString($string, array $options = [])
	public function fromJSON($string)
	public function fromFile($filename)
	/* the basic "read" method. You may use it with the generator yielding each line with no \r\n-s 
	 * (working with sockets or whatever
	 */
	public function fromGenerator($generator)

父类

namespace LWB\LGMLParser\Tree;
class Configurable extends Basic
{
	/* yes, it's public. you may use it directly */
	public $options;
	/* all the methods are self-documenting */
	public function __construct(array $options = []) {}
	public function setOption($name, $value) {}
	/* this 2 methods return $this */
	public function setOptions(array $options) {}
	public function getOption($name) {}
}

辅助函数

namespace LWB\LGMLParser\Tree;
trait Quotes
{
	/* this un-escapes \" and \\ */
	public static function unEscapeDoubleQuotes($string) {}
	/* this un-escapes \' and \\ */
	public static function unEscapeSingleQuotes($string) {}
	/*this surrounds with proper quotes pair the 1st argument in k=>v pair of the 
 	 * markup language, i.e. element's or attribute's name if needed
	 */
	public static function quoteProperly1($string) {}
	/* this surrounds with proper quotes pair the 2nd argument in k=>v pair of the 
 	 * markup language, i.e. attribute's value if needed
	 */
	public static function quoteProperly2($string) {}
	/* adds indentation ($level spaces) to each every-but-1st line of the multiline string. 
	 * if $first===true adds the same spaces to the 1st line.
	 * or $first*spaces if $first is not false
	 */
	public static function addIndent($level, $string, $first = false) {}
	/* converts tabs to spaces (by default tab=4*space. use ->setOption('tabs') method 
	 * to overrride
	 */
	private function normalizeTabs($string) {}
}

基本类。实现\Iterator、\ArrayAccess、\Countable

namespace LWB\LGMLParser\Tree;
class Basic 
{
	/* the tree data structure itself */
	public $tree = null;
	/* this allows us to iterate only certain kind of nodes, i.e. "table" */
	public $filter = false;
	/* "factory" method */
	public static function factoryFromTree(array &$tree, $filter = false) {}
	/* Iterating in foreach operator section */
	function rewind() {}
	function current() {}
	function key() {}
	function next() {}
	function valid() {}
	/* this allows us to get count($tree_instance) */
	public function count() {}
	/* check if tree_as_array's offset exists e.g.: isset($tree_object['table']) */
	public function offsetExists($offset) {}
	/* treating tree as array e.g.: $tree_object['table'][0] */
	public function offsetGet($offset) {}
}

测试

cd vendor\lastwhitebird\lgml-parser\tests
php runtest.php

许可协议

这个库根据LGPL v2.1许可