Page Menu
Home
Phorge
Search
Configure Global Search
Log In
Files
F2680405
PhutilSimpleOptions.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Award Token
Flag For Later
Advanced/Developer...
View Handle
View Hovercard
Size
4 KB
Referenced Files
None
Subscribers
None
PhutilSimpleOptions.php
View Options
<?php
/**
* Utilities for parsing simple option lists used in Remarkup, like codeblocks:
*
* lang=text
* lang=php, name=example.php, lines=30, counterexample
*
* @task parse Parsing Simple Options
* @task unparse Unparsing Simple Options
* @task config Parser Configuration
* @task internal Internals
*/
final
class
PhutilSimpleOptions
extends
Phobject
{
private
$caseSensitive
;
/* -( Parsing Simple Options )--------------------------------------------- */
/**
* Convert a simple option list into a dict. For example:
*
* legs=4, eyes=2
*
* ...becomes:
*
* array(
* 'legs' => '4',
* 'eyes' => '2',
* );
*
* @param string $input Input option list.
* @return dict Parsed dictionary.
* @task parse
*/
public
function
parse
(
$input
)
{
$result
=
array
(
)
;
$lexer
=
new
PhutilSimpleOptionsLexer
(
)
;
$tokens
=
$lexer
->
getNiceTokens
(
$input
)
;
$state
=
'key'
;
$pairs
=
array
(
)
;
foreach
(
$tokens
as
$token
)
{
list
(
$type
,
$value
)
=
$token
;
switch
(
$state
)
{
case
'key'
:
if
(
$type
!=
'word'
)
{
return
array
(
)
;
}
if
(
!
strlen
(
$value
)
)
{
return
array
(
)
;
}
$key
=
$this
->
normalizeKey
(
$value
)
;
$state
=
'='
;
break
;
case
'='
:
if
(
$type
==
'='
)
{
$state
=
'value'
;
break
;
}
if
(
$type
==
','
)
{
$pairs
[
]
=
array
(
$key
,
true
)
;
$state
=
'key'
;
break
;
}
return
array
(
)
;
case
'value'
:
if
(
$type
==
','
)
{
$pairs
[
]
=
array
(
$key
,
null
)
;
$state
=
'key'
;
break
;
}
if
(
$type
!=
'word'
)
{
return
array
(
)
;
}
$pairs
[
]
=
array
(
$key
,
$value
)
;
$state
=
','
;
break
;
case
','
:
if
(
$type
==
'word'
)
{
$pair
=
array_pop
(
$pairs
)
;
$pair
[
1
]
.=
$value
;
$pairs
[
]
=
$pair
;
break
;
}
if
(
$type
!=
','
)
{
return
array
(
)
;
}
$state
=
'key'
;
break
;
}
}
if
(
$state
==
'='
)
{
$pairs
[
]
=
array
(
$key
,
true
)
;
}
if
(
$state
==
'value'
)
{
$pairs
[
]
=
array
(
$key
,
null
)
;
}
$result
=
array
(
)
;
foreach
(
$pairs
as
$pair
)
{
list
(
$key
,
$value
)
=
$pair
;
if
(
$value
===
null
)
{
unset
(
$result
[
$key
]
)
;
}
else
{
$result
[
$key
]
=
$value
;
}
}
return
$result
;
}
/* -( Unparsing Simple Options )------------------------------------------- */
/**
* Convert a dictionary into a simple option list. For example:
*
* array(
* 'legs' => '4',
* 'eyes' => '2',
* );
*
* ...becomes:
*
* legs=4, eyes=2
*
* @param dict $options Input dictionary.
* @param string $escape (optional) Additional characters to escape.
* @return string Unparsed option list.
*/
public
function
unparse
(
array
$options
,
$escape
=
''
)
{
$result
=
array
(
)
;
foreach
(
$options
as
$name
=>
$value
)
{
$name
=
$this
->
normalizeKey
(
$name
)
;
if
(
!
strlen
(
$value
)
)
{
continue
;
}
if
(
$value
===
true
)
{
$result
[
]
=
$this
->
quoteString
(
$name
,
$escape
)
;
}
else
{
$qn
=
$this
->
quoteString
(
$name
,
$escape
)
;
$qv
=
$this
->
quoteString
(
$value
,
$escape
)
;
$result
[
]
=
$qn
.
'='
.
$qv
;
}
}
return
implode
(
', '
,
$result
)
;
}
/* -( Parser Configuration )----------------------------------------------- */
/**
* Configure case sensitivity of the parser. By default, the parser is
* case insensitive, so "legs=4" has the same meaning as "LEGS=4". If you
* set it to be case sensitive, the keys have different meanings.
*
* @param bool $case_sensitive True to make the parser case sensitive, false
* to make it case-insensitive.
* @return $this
* @task config
*/
public
function
setCaseSensitive
(
$case_sensitive
)
{
$this
->
caseSensitive
=
$case_sensitive
;
return
$this
;
}
/* -( Internals )---------------------------------------------------------- */
private
function
normalizeKey
(
$key
)
{
if
(
!
strlen
(
$key
)
)
{
throw
new
Exception
(
pht
(
'Empty key is invalid!'
)
)
;
}
if
(
!
$this
->
caseSensitive
)
{
$key
=
strtolower
(
$key
)
;
}
return
$key
;
}
private
function
quoteString
(
$string
,
$escape
)
{
if
(
preg_match
(
'/[^a-zA-Z0-9]/'
,
$string
)
)
{
$string
=
'"'
.
addcslashes
(
$string
,
'\\\'"'
.
$escape
)
.
'"'
;
}
return
$string
;
}
}
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Thu, Dec 19, 17:00 (21 h, 48 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
1014862
Default Alt Text
PhutilSimpleOptions.php (4 KB)
Attached To
Mode
rARC Arcanist
Attached
Detach File
Event Timeline
Log In to Comment