-
Notifications
You must be signed in to change notification settings - Fork 7
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
f0aec50
commit 5d68a2b
Showing
6 changed files
with
1,305 additions
and
18 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,135 @@ | ||
<?php | ||
|
||
/* | ||
* This file is part of the symfony package. | ||
* (c) 2004-2006 Fabien Potencier <fabien.potencier@symfony-project.com> | ||
* | ||
* For the full copyright and license information, please view the LICENSE | ||
* file that was distributed with this source code. | ||
*/ | ||
|
||
/** | ||
* sfYaml offers convenience methods to load and dump YAML. | ||
* | ||
* @package symfony | ||
* @subpackage yaml | ||
* @author Fabien Potencier <fabien.potencier@symfony-project.com> | ||
* @version SVN: $Id: sfYaml.class.php 8988 2008-05-15 20:24:26Z fabien $ | ||
*/ | ||
class sfYaml | ||
{ | ||
static protected | ||
$spec = '1.2'; | ||
|
||
/** | ||
* Sets the YAML specification version to use. | ||
* | ||
* @param string $version The YAML specification version | ||
*/ | ||
static public function setSpecVersion($version) | ||
{ | ||
if (!in_array($version, array('1.1', '1.2'))) | ||
{ | ||
throw new InvalidArgumentException(sprintf('Version %s of the YAML specifications is not supported', $version)); | ||
} | ||
|
||
self::$spec = $version; | ||
} | ||
|
||
/** | ||
* Gets the YAML specification version to use. | ||
* | ||
* @return string The YAML specification version | ||
*/ | ||
static public function getSpecVersion() | ||
{ | ||
return self::$spec; | ||
} | ||
|
||
/** | ||
* Loads YAML into a PHP array. | ||
* | ||
* The load method, when supplied with a YAML stream (string or file), | ||
* will do its best to convert YAML in a file into a PHP array. | ||
* | ||
* Usage: | ||
* <code> | ||
* $array = sfYaml::load('config.yml'); | ||
* print_r($array); | ||
* </code> | ||
* | ||
* @param string $input Path of YAML file or string containing YAML | ||
* | ||
* @return array The YAML converted to a PHP array | ||
* | ||
* @throws InvalidArgumentException If the YAML is not valid | ||
*/ | ||
public static function load($input) | ||
{ | ||
$file = ''; | ||
|
||
// if input is a file, process it | ||
if (strpos($input, "\n") === false && is_file($input)) | ||
{ | ||
$file = $input; | ||
|
||
ob_start(); | ||
$retval = include($input); | ||
$content = ob_get_clean(); | ||
|
||
// if an array is returned by the config file assume it's in plain php form else in YAML | ||
$input = is_array($retval) ? $retval : $content; | ||
} | ||
|
||
// if an array is returned by the config file assume it's in plain php form else in YAML | ||
if (is_array($input)) | ||
{ | ||
return $input; | ||
} | ||
|
||
require_once dirname(__FILE__).'/sfYamlParser.php'; | ||
|
||
$yaml = new sfYamlParser(); | ||
|
||
try | ||
{ | ||
$ret = $yaml->parse($input); | ||
} | ||
catch (Exception $e) | ||
{ | ||
throw new InvalidArgumentException(sprintf('Unable to parse %s: %s', $file ? sprintf('file "%s"', $file) : 'string', $e->getMessage())); | ||
} | ||
|
||
return $ret; | ||
} | ||
|
||
/** | ||
* Dumps a PHP array to a YAML string. | ||
* | ||
* The dump method, when supplied with an array, will do its best | ||
* to convert the array into friendly YAML. | ||
* | ||
* @param array $array PHP array | ||
* @param integer $inline The level where you switch to inline YAML | ||
* | ||
* @return string A YAML string representing the original PHP array | ||
*/ | ||
public static function dump($array, $inline = 2) | ||
{ | ||
require_once dirname(__FILE__).'/sfYamlDumper.php'; | ||
|
||
$yaml = new sfYamlDumper(); | ||
|
||
return $yaml->dump($array, $inline); | ||
} | ||
} | ||
|
||
/** | ||
* Wraps echo to automatically provide a newline. | ||
* | ||
* @param string $string The string to echo with new line | ||
*/ | ||
function echoln($string) | ||
{ | ||
echo $string."\n"; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
<?php | ||
|
||
/* | ||
* This file is part of the symfony package. | ||
* (c) Fabien Potencier <fabien.potencier@symfony-project.com> | ||
* | ||
* For the full copyright and license information, please view the LICENSE | ||
* file that was distributed with this source code. | ||
*/ | ||
|
||
require_once(dirname(__FILE__).'/sfYamlInline.php'); | ||
|
||
/** | ||
* sfYamlDumper dumps PHP variables to YAML strings. | ||
* | ||
* @package symfony | ||
* @subpackage yaml | ||
* @author Fabien Potencier <fabien.potencier@symfony-project.com> | ||
* @version SVN: $Id: sfYamlDumper.class.php 10575 2008-08-01 13:08:42Z nicolas $ | ||
*/ | ||
class sfYamlDumper | ||
{ | ||
/** | ||
* Dumps a PHP value to YAML. | ||
* | ||
* @param mixed $input The PHP value | ||
* @param integer $inline The level where you switch to inline YAML | ||
* @param integer $indent The level o indentation indentation (used internally) | ||
* | ||
* @return string The YAML representation of the PHP value | ||
*/ | ||
public function dump($input, $inline = 0, $indent = 0) | ||
{ | ||
$output = ''; | ||
$prefix = $indent ? str_repeat(' ', $indent) : ''; | ||
|
||
if ($inline <= 0 || !is_array($input) || empty($input)) | ||
{ | ||
$output .= $prefix.sfYamlInline::dump($input); | ||
} | ||
else | ||
{ | ||
$isAHash = array_keys($input) !== range(0, count($input) - 1); | ||
|
||
foreach ($input as $key => $value) | ||
{ | ||
$willBeInlined = $inline - 1 <= 0 || !is_array($value) || empty($value); | ||
|
||
$output .= sprintf('%s%s%s%s', | ||
$prefix, | ||
$isAHash ? sfYamlInline::dump($key).':' : '-', | ||
$willBeInlined ? ' ' : "\n", | ||
$this->dump($value, $inline - 1, $willBeInlined ? 0 : $indent + 2) | ||
).($willBeInlined ? "\n" : ''); | ||
} | ||
} | ||
|
||
return $output; | ||
} | ||
} |
Oops, something went wrong.