Cleanup Convert

* remove unneeded parenthesis and double quotes
* simplify flow / remove unneeded else
This commit is contained in:
Werner M. Krauß 2018-11-07 17:45:01 +01:00
parent 26c047c04f
commit bc0f17fb09
2 changed files with 52 additions and 52 deletions

View File

@ -70,9 +70,9 @@ class Convert
} }
return $val; return $val;
} else {
return self::raw2att($val);
} }
return self::raw2att($val);
} }
/** /**
@ -93,7 +93,8 @@ class Convert
} }
return $val; return $val;
} else { }
return trim( return trim(
preg_replace( preg_replace(
'/_+/', '/_+/',
@ -103,7 +104,6 @@ class Convert
'_' '_'
); );
} }
}
/** /**
* Ensure that text is properly escaped for XML. * Ensure that text is properly escaped for XML.
@ -119,9 +119,9 @@ class Convert
$val[$k] = self::raw2xml($v); $val[$k] = self::raw2xml($v);
} }
return $val; return $val;
} else {
return htmlspecialchars($val, ENT_QUOTES, 'UTF-8');
} }
return htmlspecialchars($val, ENT_QUOTES, 'UTF-8');
} }
/** /**
@ -137,15 +137,15 @@ class Convert
$val[$k] = self::raw2js($v); $val[$k] = self::raw2js($v);
} }
return $val; return $val;
} else { }
return str_replace( return str_replace(
// Intercepts some characters such as <, >, and & which can interfere // Intercepts some characters such as <, >, and & which can interfere
array("\\", '"', "\n", "\r", "'", "<", ">", "&"), array("\\", '"', "\n", "\r", "'", '<', '>', '&'),
array("\\\\", '\"', '\n', '\r', "\\'", "\\x3c", "\\x3e", "\\x26"), array("\\\\", '\"', '\n', '\r', "\\'", "\\x3c", "\\x3e", "\\x26"),
$val $val
); );
} }
}
/** /**
* Encode a value as a JSON encoded string. You can optionally pass a bitmask of * Encode a value as a JSON encoded string. You can optionally pass a bitmask of
@ -195,14 +195,14 @@ class Convert
$val[$k] = self::raw2sql($v, $quoted); $val[$k] = self::raw2sql($v, $quoted);
} }
return $val; return $val;
} else { }
if ($quoted) { if ($quoted) {
return DB::get_conn()->quoteString($val); return DB::get_conn()->quoteString($val);
} else { }
return DB::get_conn()->escapeString($val); return DB::get_conn()->escapeString($val);
} }
}
}
/** /**
* Safely encodes a SQL symbolic identifier (or list of identifiers), such as a database, * Safely encodes a SQL symbolic identifier (or list of identifiers), such as a database,
@ -233,15 +233,15 @@ class Convert
$val[$k] = self::xml2raw($v); $val[$k] = self::xml2raw($v);
} }
return $val; return $val;
} else { }
// More complex text needs to use html2raw instead // More complex text needs to use html2raw instead
if (strpos($val, '<') !== false) { if (strpos($val, '<') !== false) {
return self::html2raw($val); return self::html2raw($val);
} else { }
return html_entity_decode($val, ENT_QUOTES, 'UTF-8'); return html_entity_decode($val, ENT_QUOTES, 'UTF-8');
} }
}
}
/** /**
* Convert a JSON encoded string into an object. * Convert a JSON encoded string into an object.
@ -332,7 +332,7 @@ class Convert
$xml = get_object_vars($xml); $xml = get_object_vars($xml);
} }
if (is_array($xml)) { if (is_array($xml)) {
if (count($xml) == 0) { if (count($xml) === 0) {
return (string)$x; return (string)$x;
} // for CDATA } // for CDATA
$r = []; $r = [];
@ -359,9 +359,9 @@ class Convert
{ {
if (preg_match('/^[a-z+]+\:\/\/[a-zA-Z0-9$-_.+?&=!*\'()%]+$/', $string)) { if (preg_match('/^[a-z+]+\:\/\/[a-zA-Z0-9$-_.+?&=!*\'()%]+$/', $string)) {
return "<a style=\"white-space: nowrap\" href=\"$string\">$string</a>"; return "<a style=\"white-space: nowrap\" href=\"$string\">$string</a>";
} else {
return $string;
} }
return $string;
} }
/** /**
@ -387,8 +387,8 @@ class Convert
$config = $defaultConfig; $config = $defaultConfig;
} }
$data = preg_replace("/<style([^A-Za-z0-9>][^>]*)?>.*?<\/style[^>]*>/is", "", $data); $data = preg_replace("/<style([^A-Za-z0-9>][^>]*)?>.*?<\/style[^>]*>/is", '', $data);
$data = preg_replace("/<script([^A-Za-z0-9>][^>]*)?>.*?<\/script[^>]*>/is", "", $data); $data = preg_replace("/<script([^A-Za-z0-9>][^>]*)?>.*?<\/script[^>]*>/is", '', $data);
if ($config['ReplaceBoldAsterisk']) { if ($config['ReplaceBoldAsterisk']) {
$data = preg_replace('%<(strong|b)( [^>]*)?>|</(strong|b)>%i', '*', $data); $data = preg_replace('%<(strong|b)( [^>]*)?>|</(strong|b)>%i', '*', $data);
@ -412,7 +412,7 @@ class Convert
// Compress whitespace // Compress whitespace
if ($config['CompressWhitespace']) { if ($config['CompressWhitespace']) {
$data = preg_replace("/\s+/u", " ", $data); $data = preg_replace("/\s+/u", ' ', $data);
} }
// Parse newline tags // Parse newline tags
@ -421,9 +421,9 @@ class Convert
$data = preg_replace("/\s*<[Dd][Ii][Vv]([^A-Za-z0-9>][^>]*)?> */u", "\n\n", $data); $data = preg_replace("/\s*<[Dd][Ii][Vv]([^A-Za-z0-9>][^>]*)?> */u", "\n\n", $data);
$data = preg_replace("/\n\n\n+/", "\n\n", $data); $data = preg_replace("/\n\n\n+/", "\n\n", $data);
$data = preg_replace("/<[Bb][Rr]([^A-Za-z0-9>][^>]*)?> */", "\n", $data); $data = preg_replace('/<[Bb][Rr]([^A-Za-z0-9>][^>]*)?> */', "\n", $data);
$data = preg_replace("/<[Tt][Rr]([^A-Za-z0-9>][^>]*)?> */", "\n", $data); $data = preg_replace('/<[Tt][Rr]([^A-Za-z0-9>][^>]*)?> */', "\n", $data);
$data = preg_replace("/<\/[Tt][Dd]([^A-Za-z0-9>][^>]*)?> */", " ", $data); $data = preg_replace("/<\/[Tt][Dd]([^A-Za-z0-9>][^>]*)?> */", ' ', $data);
$data = preg_replace('/<\/p>/i', "\n\n", $data); $data = preg_replace('/<\/p>/i', "\n\n", $data);
// Replace HTML entities // Replace HTML entities

View File

@ -133,7 +133,7 @@ class ConvertTest extends SapphireTest
$this->assertEquals( $this->assertEquals(
"That's absolutely correct", "That's absolutely correct",
Convert::html2raw($val7), Convert::html2raw($val7),
"Single quotes are decoded correctly" 'Single quotes are decoded correctly'
); );
$val8 = 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor ' . 'incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud ' . 'exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute ' . 'irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla ' . 'pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia ' . 'deserunt mollit anim id est laborum.'; $val8 = 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor ' . 'incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud ' . 'exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute ' . 'irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla ' . 'pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia ' . 'deserunt mollit anim id est laborum.';
@ -280,7 +280,7 @@ PHP
protected function assertEqualsQuoted($expected, $actual) protected function assertEqualsQuoted($expected, $actual)
{ {
$message = sprintf( $message = sprintf(
"Expected \"%s\" but given \"%s\"", 'Expected "%s" but given "%s"',
addcslashes($expected, "\r\n"), addcslashes($expected, "\r\n"),
addcslashes($actual, "\r\n") addcslashes($actual, "\r\n")
); );
@ -296,8 +296,8 @@ PHP
foreach (array("\r\n", "\r", "\n") as $nl) { foreach (array("\r\n", "\r", "\n") as $nl) {
// Base case: no action // Base case: no action
$this->assertEqualsQuoted( $this->assertEqualsQuoted(
"Base case", 'Base case',
Convert::nl2os("Base case", $nl) Convert::nl2os('Base case', $nl)
); );
// Mixed formats // Mixed formats
@ -426,7 +426,7 @@ XML
// Test without doctype validation // Test without doctype validation
$expected = array( $expected = array(
'result' => array( 'result' => array(
"Now include SOME_SUPER_LONG_STRING lots of times to expand the in-memory size of this XML structure", 'Now include SOME_SUPER_LONG_STRING lots of times to expand the in-memory size of this XML structure',
array( array(
'long' => array( 'long' => array(
array( array(
@ -607,11 +607,11 @@ XML
{ {
return [ return [
[200, '200B'], [200, '200B'],
[(2 * 1024), '2K'], [2 * 1024, '2K'],
[(512 * 1024 * 1024), '512M'], [512 * 1024 * 1024, '512M'],
[(512 * 1024 * 1024 * 1024), '512G'], [512 * 1024 * 1024 * 1024, '512G'],
[(512 * 1024 * 1024 * 1024 * 1024), '512T'], [512 * 1024 * 1024 * 1024 * 1024, '512T'],
[(512 * 1024 * 1024 * 1024 * 1024 * 1024), '512P'] [512 * 1024 * 1024 * 1024 * 1024 * 1024, '512P']
]; ];
} }