Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93

Warning: Undefined array key "page_file_edit_line" in /home/sportsfever/public_html/filemanger/edit_text_line.php on line 32
/home/sportsfe.../httpdocs/clone/wp-conte.../plugins/advanced.../lib/mobilede.../mobilede...
File: Mobile_Detect.php
* @return boolean If there were CloudFront headers to be set
[1000] Fix | Delete
*/
[1001] Fix | Delete
public function setCfHeaders($cfHeaders = null) {
[1002] Fix | Delete
// use global _SERVER if $cfHeaders aren't defined
[1003] Fix | Delete
if (!is_array($cfHeaders) || !count($cfHeaders)) {
[1004] Fix | Delete
$cfHeaders = $_SERVER;
[1005] Fix | Delete
}
[1006] Fix | Delete
[1007] Fix | Delete
// clear existing headers
[1008] Fix | Delete
$this->cloudfrontHeaders = array();
[1009] Fix | Delete
[1010] Fix | Delete
// Only save CLOUDFRONT headers. In PHP land, that means only _SERVER vars that
[1011] Fix | Delete
// start with cloudfront-.
[1012] Fix | Delete
$response = false;
[1013] Fix | Delete
foreach ($cfHeaders as $key => $value) {
[1014] Fix | Delete
if (substr(strtolower($key), 0, 16) === 'http_cloudfront_') {
[1015] Fix | Delete
$this->cloudfrontHeaders[strtoupper($key)] = $value;
[1016] Fix | Delete
$response = true;
[1017] Fix | Delete
}
[1018] Fix | Delete
}
[1019] Fix | Delete
[1020] Fix | Delete
return $response;
[1021] Fix | Delete
}
[1022] Fix | Delete
[1023] Fix | Delete
/**
[1024] Fix | Delete
* Retrieves the cloudfront headers.
[1025] Fix | Delete
*
[1026] Fix | Delete
* @return array
[1027] Fix | Delete
*/
[1028] Fix | Delete
public function getCfHeaders()
[1029] Fix | Delete
{
[1030] Fix | Delete
return $this->cloudfrontHeaders;
[1031] Fix | Delete
}
[1032] Fix | Delete
[1033] Fix | Delete
/**
[1034] Fix | Delete
* @param string $userAgent
[1035] Fix | Delete
* @return string
[1036] Fix | Delete
*/
[1037] Fix | Delete
private function prepareUserAgent($userAgent) {
[1038] Fix | Delete
$userAgent = trim($userAgent);
[1039] Fix | Delete
$userAgent = substr($userAgent, 0, 500);
[1040] Fix | Delete
return $userAgent;
[1041] Fix | Delete
}
[1042] Fix | Delete
[1043] Fix | Delete
/**
[1044] Fix | Delete
* Set the User-Agent to be used.
[1045] Fix | Delete
*
[1046] Fix | Delete
* @param string $userAgent The user agent string to set.
[1047] Fix | Delete
*
[1048] Fix | Delete
* @return string|null
[1049] Fix | Delete
*/
[1050] Fix | Delete
public function setUserAgent($userAgent = null)
[1051] Fix | Delete
{
[1052] Fix | Delete
// Invalidate cache due to #375
[1053] Fix | Delete
$this->cache = array();
[1054] Fix | Delete
[1055] Fix | Delete
if (false === empty($userAgent)) {
[1056] Fix | Delete
return $this->userAgent = $this->prepareUserAgent($userAgent);
[1057] Fix | Delete
} else {
[1058] Fix | Delete
$this->userAgent = null;
[1059] Fix | Delete
foreach ($this->getUaHttpHeaders() as $altHeader) {
[1060] Fix | Delete
if (false === empty($this->httpHeaders[$altHeader])) { // @todo: should use getHttpHeader(), but it would be slow. (Serban)
[1061] Fix | Delete
$this->userAgent .= $this->httpHeaders[$altHeader] . " ";
[1062] Fix | Delete
}
[1063] Fix | Delete
}
[1064] Fix | Delete
[1065] Fix | Delete
if (!empty($this->userAgent)) {
[1066] Fix | Delete
return $this->userAgent = $this->prepareUserAgent($this->userAgent);
[1067] Fix | Delete
}
[1068] Fix | Delete
}
[1069] Fix | Delete
[1070] Fix | Delete
if (count($this->getCfHeaders()) > 0) {
[1071] Fix | Delete
return $this->userAgent = 'Amazon CloudFront';
[1072] Fix | Delete
}
[1073] Fix | Delete
return $this->userAgent = null;
[1074] Fix | Delete
}
[1075] Fix | Delete
[1076] Fix | Delete
/**
[1077] Fix | Delete
* Retrieve the User-Agent.
[1078] Fix | Delete
*
[1079] Fix | Delete
* @return string|null The user agent if it's set.
[1080] Fix | Delete
*/
[1081] Fix | Delete
public function getUserAgent()
[1082] Fix | Delete
{
[1083] Fix | Delete
return $this->userAgent;
[1084] Fix | Delete
}
[1085] Fix | Delete
[1086] Fix | Delete
/**
[1087] Fix | Delete
* Set the detection type. Must be one of self::DETECTION_TYPE_MOBILE or
[1088] Fix | Delete
* self::DETECTION_TYPE_EXTENDED. Otherwise, nothing is set.
[1089] Fix | Delete
*
[1090] Fix | Delete
* @deprecated since version 2.6.9
[1091] Fix | Delete
*
[1092] Fix | Delete
* @param string $type The type. Must be a self::DETECTION_TYPE_* constant. The default
[1093] Fix | Delete
* parameter is null which will default to self::DETECTION_TYPE_MOBILE.
[1094] Fix | Delete
*/
[1095] Fix | Delete
public function setDetectionType($type = null)
[1096] Fix | Delete
{
[1097] Fix | Delete
if ($type === null) {
[1098] Fix | Delete
$type = self::DETECTION_TYPE_MOBILE;
[1099] Fix | Delete
}
[1100] Fix | Delete
[1101] Fix | Delete
if ($type !== self::DETECTION_TYPE_MOBILE && $type !== self::DETECTION_TYPE_EXTENDED) {
[1102] Fix | Delete
return;
[1103] Fix | Delete
}
[1104] Fix | Delete
[1105] Fix | Delete
$this->detectionType = $type;
[1106] Fix | Delete
}
[1107] Fix | Delete
[1108] Fix | Delete
public function getMatchingRegex()
[1109] Fix | Delete
{
[1110] Fix | Delete
return $this->matchingRegex;
[1111] Fix | Delete
}
[1112] Fix | Delete
[1113] Fix | Delete
public function getMatchesArray()
[1114] Fix | Delete
{
[1115] Fix | Delete
return $this->matchesArray;
[1116] Fix | Delete
}
[1117] Fix | Delete
[1118] Fix | Delete
/**
[1119] Fix | Delete
* Retrieve the list of known phone devices.
[1120] Fix | Delete
*
[1121] Fix | Delete
* @return array List of phone devices.
[1122] Fix | Delete
*/
[1123] Fix | Delete
public static function getPhoneDevices()
[1124] Fix | Delete
{
[1125] Fix | Delete
return self::$phoneDevices;
[1126] Fix | Delete
}
[1127] Fix | Delete
[1128] Fix | Delete
/**
[1129] Fix | Delete
* Retrieve the list of known tablet devices.
[1130] Fix | Delete
*
[1131] Fix | Delete
* @return array List of tablet devices.
[1132] Fix | Delete
*/
[1133] Fix | Delete
public static function getTabletDevices()
[1134] Fix | Delete
{
[1135] Fix | Delete
return self::$tabletDevices;
[1136] Fix | Delete
}
[1137] Fix | Delete
[1138] Fix | Delete
/**
[1139] Fix | Delete
* Alias for getBrowsers() method.
[1140] Fix | Delete
*
[1141] Fix | Delete
* @return array List of user agents.
[1142] Fix | Delete
*/
[1143] Fix | Delete
public static function getUserAgents()
[1144] Fix | Delete
{
[1145] Fix | Delete
return self::getBrowsers();
[1146] Fix | Delete
}
[1147] Fix | Delete
[1148] Fix | Delete
/**
[1149] Fix | Delete
* Retrieve the list of known browsers. Specifically, the user agents.
[1150] Fix | Delete
*
[1151] Fix | Delete
* @return array List of browsers / user agents.
[1152] Fix | Delete
*/
[1153] Fix | Delete
public static function getBrowsers()
[1154] Fix | Delete
{
[1155] Fix | Delete
return self::$browsers;
[1156] Fix | Delete
}
[1157] Fix | Delete
[1158] Fix | Delete
/**
[1159] Fix | Delete
* Retrieve the list of known utilities.
[1160] Fix | Delete
*
[1161] Fix | Delete
* @return array List of utilities.
[1162] Fix | Delete
*/
[1163] Fix | Delete
public static function getUtilities()
[1164] Fix | Delete
{
[1165] Fix | Delete
return self::$utilities;
[1166] Fix | Delete
}
[1167] Fix | Delete
[1168] Fix | Delete
/**
[1169] Fix | Delete
* Method gets the mobile detection rules. This method is used for the magic methods $detect->is*().
[1170] Fix | Delete
*
[1171] Fix | Delete
* @deprecated since version 2.6.9
[1172] Fix | Delete
*
[1173] Fix | Delete
* @return array All the rules (but not extended).
[1174] Fix | Delete
*/
[1175] Fix | Delete
public static function getMobileDetectionRules()
[1176] Fix | Delete
{
[1177] Fix | Delete
static $rules;
[1178] Fix | Delete
[1179] Fix | Delete
if (!$rules) {
[1180] Fix | Delete
$rules = array_merge(
[1181] Fix | Delete
self::$phoneDevices,
[1182] Fix | Delete
self::$tabletDevices,
[1183] Fix | Delete
self::$operatingSystems,
[1184] Fix | Delete
self::$browsers
[1185] Fix | Delete
);
[1186] Fix | Delete
}
[1187] Fix | Delete
[1188] Fix | Delete
return $rules;
[1189] Fix | Delete
[1190] Fix | Delete
}
[1191] Fix | Delete
[1192] Fix | Delete
/**
[1193] Fix | Delete
* Method gets the mobile detection rules + utilities.
[1194] Fix | Delete
* The reason this is separate is because utilities rules
[1195] Fix | Delete
* don't necessary imply mobile. This method is used inside
[1196] Fix | Delete
* the new $detect->is('stuff') method.
[1197] Fix | Delete
*
[1198] Fix | Delete
* @deprecated since version 2.6.9
[1199] Fix | Delete
*
[1200] Fix | Delete
* @return array All the rules + extended.
[1201] Fix | Delete
*/
[1202] Fix | Delete
public function getMobileDetectionRulesExtended()
[1203] Fix | Delete
{
[1204] Fix | Delete
static $rules;
[1205] Fix | Delete
[1206] Fix | Delete
if (!$rules) {
[1207] Fix | Delete
// Merge all rules together.
[1208] Fix | Delete
$rules = array_merge(
[1209] Fix | Delete
self::$phoneDevices,
[1210] Fix | Delete
self::$tabletDevices,
[1211] Fix | Delete
self::$operatingSystems,
[1212] Fix | Delete
self::$browsers,
[1213] Fix | Delete
self::$utilities
[1214] Fix | Delete
);
[1215] Fix | Delete
}
[1216] Fix | Delete
[1217] Fix | Delete
return $rules;
[1218] Fix | Delete
}
[1219] Fix | Delete
[1220] Fix | Delete
/**
[1221] Fix | Delete
* Retrieve the current set of rules.
[1222] Fix | Delete
*
[1223] Fix | Delete
* @deprecated since version 2.6.9
[1224] Fix | Delete
*
[1225] Fix | Delete
* @return array
[1226] Fix | Delete
*/
[1227] Fix | Delete
public function getRules()
[1228] Fix | Delete
{
[1229] Fix | Delete
if ($this->detectionType == self::DETECTION_TYPE_EXTENDED) {
[1230] Fix | Delete
return self::getMobileDetectionRulesExtended();
[1231] Fix | Delete
} else {
[1232] Fix | Delete
return self::getMobileDetectionRules();
[1233] Fix | Delete
}
[1234] Fix | Delete
}
[1235] Fix | Delete
[1236] Fix | Delete
/**
[1237] Fix | Delete
* Retrieve the list of mobile operating systems.
[1238] Fix | Delete
*
[1239] Fix | Delete
* @return array The list of mobile operating systems.
[1240] Fix | Delete
*/
[1241] Fix | Delete
public static function getOperatingSystems()
[1242] Fix | Delete
{
[1243] Fix | Delete
return self::$operatingSystems;
[1244] Fix | Delete
}
[1245] Fix | Delete
[1246] Fix | Delete
/**
[1247] Fix | Delete
* Check the HTTP headers for signs of mobile.
[1248] Fix | Delete
* This is the fastest mobile check possible; it's used
[1249] Fix | Delete
* inside isMobile() method.
[1250] Fix | Delete
*
[1251] Fix | Delete
* @return bool
[1252] Fix | Delete
*/
[1253] Fix | Delete
public function checkHttpHeadersForMobile()
[1254] Fix | Delete
{
[1255] Fix | Delete
[1256] Fix | Delete
foreach ($this->getMobileHeaders() as $mobileHeader => $matchType) {
[1257] Fix | Delete
if (isset($this->httpHeaders[$mobileHeader])) {
[1258] Fix | Delete
if (isset($matchType['matches']) && is_array($matchType['matches'])) {
[1259] Fix | Delete
foreach ($matchType['matches'] as $_match) {
[1260] Fix | Delete
if (strpos($this->httpHeaders[$mobileHeader], $_match) !== false) {
[1261] Fix | Delete
return true;
[1262] Fix | Delete
}
[1263] Fix | Delete
}
[1264] Fix | Delete
[1265] Fix | Delete
return false;
[1266] Fix | Delete
} else {
[1267] Fix | Delete
return true;
[1268] Fix | Delete
}
[1269] Fix | Delete
}
[1270] Fix | Delete
}
[1271] Fix | Delete
[1272] Fix | Delete
return false;
[1273] Fix | Delete
[1274] Fix | Delete
}
[1275] Fix | Delete
[1276] Fix | Delete
/**
[1277] Fix | Delete
* Magic overloading method.
[1278] Fix | Delete
*
[1279] Fix | Delete
* @method boolean is[...]()
[1280] Fix | Delete
* @param string $name
[1281] Fix | Delete
* @param array $arguments
[1282] Fix | Delete
* @return mixed
[1283] Fix | Delete
* @throws BadMethodCallException when the method doesn't exist and doesn't start with 'is'
[1284] Fix | Delete
*/
[1285] Fix | Delete
public function __call($name, $arguments)
[1286] Fix | Delete
{
[1287] Fix | Delete
// make sure the name starts with 'is', otherwise
[1288] Fix | Delete
if (substr($name, 0, 2) !== 'is') {
[1289] Fix | Delete
throw new BadMethodCallException("No such method exists: $name");
[1290] Fix | Delete
}
[1291] Fix | Delete
[1292] Fix | Delete
$this->setDetectionType(self::DETECTION_TYPE_MOBILE);
[1293] Fix | Delete
[1294] Fix | Delete
$key = substr($name, 2);
[1295] Fix | Delete
[1296] Fix | Delete
return $this->matchUAAgainstKey($key);
[1297] Fix | Delete
}
[1298] Fix | Delete
[1299] Fix | Delete
/**
[1300] Fix | Delete
* Find a detection rule that matches the current User-agent.
[1301] Fix | Delete
*
[1302] Fix | Delete
* @param null $userAgent deprecated
[1303] Fix | Delete
* @return boolean
[1304] Fix | Delete
*/
[1305] Fix | Delete
protected function matchDetectionRulesAgainstUA($userAgent = null)
[1306] Fix | Delete
{
[1307] Fix | Delete
// Begin general search.
[1308] Fix | Delete
foreach ($this->getRules() as $_regex) {
[1309] Fix | Delete
if (empty($_regex)) {
[1310] Fix | Delete
continue;
[1311] Fix | Delete
}
[1312] Fix | Delete
[1313] Fix | Delete
if ($this->match($_regex, $userAgent)) {
[1314] Fix | Delete
return true;
[1315] Fix | Delete
}
[1316] Fix | Delete
}
[1317] Fix | Delete
[1318] Fix | Delete
return false;
[1319] Fix | Delete
}
[1320] Fix | Delete
[1321] Fix | Delete
/**
[1322] Fix | Delete
* Search for a certain key in the rules array.
[1323] Fix | Delete
* If the key is found then try to match the corresponding
[1324] Fix | Delete
* regex against the User-Agent.
[1325] Fix | Delete
*
[1326] Fix | Delete
* @param string $key
[1327] Fix | Delete
*
[1328] Fix | Delete
* @return boolean
[1329] Fix | Delete
*/
[1330] Fix | Delete
protected function matchUAAgainstKey($key)
[1331] Fix | Delete
{
[1332] Fix | Delete
// Make the keys lowercase so we can match: isIphone(), isiPhone(), isiphone(), etc.
[1333] Fix | Delete
$key = strtolower($key);
[1334] Fix | Delete
if (false === isset($this->cache[$key])) {
[1335] Fix | Delete
[1336] Fix | Delete
// change the keys to lower case
[1337] Fix | Delete
$_rules = array_change_key_case($this->getRules());
[1338] Fix | Delete
[1339] Fix | Delete
if (false === empty($_rules[$key])) {
[1340] Fix | Delete
$this->cache[$key] = $this->match($_rules[$key]);
[1341] Fix | Delete
}
[1342] Fix | Delete
[1343] Fix | Delete
if (false === isset($this->cache[$key])) {
[1344] Fix | Delete
$this->cache[$key] = false;
[1345] Fix | Delete
}
[1346] Fix | Delete
}
[1347] Fix | Delete
[1348] Fix | Delete
return $this->cache[$key];
[1349] Fix | Delete
}
[1350] Fix | Delete
[1351] Fix | Delete
/**
[1352] Fix | Delete
* Check if the device is mobile.
[1353] Fix | Delete
* Returns true if any type of mobile device detected, including special ones
[1354] Fix | Delete
* @param null $userAgent deprecated
[1355] Fix | Delete
* @param null $httpHeaders deprecated
[1356] Fix | Delete
* @return bool
[1357] Fix | Delete
*/
[1358] Fix | Delete
public function isMobile($userAgent = null, $httpHeaders = null)
[1359] Fix | Delete
{
[1360] Fix | Delete
[1361] Fix | Delete
if ($httpHeaders) {
[1362] Fix | Delete
$this->setHttpHeaders($httpHeaders);
[1363] Fix | Delete
}
[1364] Fix | Delete
[1365] Fix | Delete
if ($userAgent) {
[1366] Fix | Delete
$this->setUserAgent($userAgent);
[1367] Fix | Delete
}
[1368] Fix | Delete
[1369] Fix | Delete
// Check specifically for cloudfront headers if the useragent === 'Amazon CloudFront'
[1370] Fix | Delete
if ($this->getUserAgent() === 'Amazon CloudFront') {
[1371] Fix | Delete
$cfHeaders = $this->getCfHeaders();
[1372] Fix | Delete
if(array_key_exists('HTTP_CLOUDFRONT_IS_MOBILE_VIEWER', $cfHeaders) && $cfHeaders['HTTP_CLOUDFRONT_IS_MOBILE_VIEWER'] === 'true') {
[1373] Fix | Delete
return true;
[1374] Fix | Delete
}
[1375] Fix | Delete
}
[1376] Fix | Delete
[1377] Fix | Delete
$this->setDetectionType(self::DETECTION_TYPE_MOBILE);
[1378] Fix | Delete
[1379] Fix | Delete
if ($this->checkHttpHeadersForMobile()) {
[1380] Fix | Delete
return true;
[1381] Fix | Delete
} else {
[1382] Fix | Delete
return $this->matchDetectionRulesAgainstUA();
[1383] Fix | Delete
}
[1384] Fix | Delete
[1385] Fix | Delete
}
[1386] Fix | Delete
[1387] Fix | Delete
/**
[1388] Fix | Delete
* Check if the device is a tablet.
[1389] Fix | Delete
* Return true if any type of tablet device is detected.
[1390] Fix | Delete
*
[1391] Fix | Delete
* @param string $userAgent deprecated
[1392] Fix | Delete
* @param array $httpHeaders deprecated
[1393] Fix | Delete
* @return bool
[1394] Fix | Delete
*/
[1395] Fix | Delete
public function isTablet($userAgent = null, $httpHeaders = null)
[1396] Fix | Delete
{
[1397] Fix | Delete
// Check specifically for cloudfront headers if the useragent === 'Amazon CloudFront'
[1398] Fix | Delete
if ($this->getUserAgent() === 'Amazon CloudFront') {
[1399] Fix | Delete
$cfHeaders = $this->getCfHeaders();
[1400] Fix | Delete
if(array_key_exists('HTTP_CLOUDFRONT_IS_TABLET_VIEWER', $cfHeaders) && $cfHeaders['HTTP_CLOUDFRONT_IS_TABLET_VIEWER'] === 'true') {
[1401] Fix | Delete
return true;
[1402] Fix | Delete
}
[1403] Fix | Delete
}
[1404] Fix | Delete
[1405] Fix | Delete
$this->setDetectionType(self::DETECTION_TYPE_MOBILE);
[1406] Fix | Delete
[1407] Fix | Delete
foreach (self::$tabletDevices as $_regex) {
[1408] Fix | Delete
if ($this->match($_regex, $userAgent)) {
[1409] Fix | Delete
return true;
[1410] Fix | Delete
}
[1411] Fix | Delete
}
[1412] Fix | Delete
[1413] Fix | Delete
return false;
[1414] Fix | Delete
}
[1415] Fix | Delete
[1416] Fix | Delete
/**
[1417] Fix | Delete
* This method checks for a certain property in the
[1418] Fix | Delete
* userAgent.
[1419] Fix | Delete
* @todo: The httpHeaders part is not yet used.
[1420] Fix | Delete
*
[1421] Fix | Delete
* @param string $key
[1422] Fix | Delete
* @param string $userAgent deprecated
[1423] Fix | Delete
* @param string $httpHeaders deprecated
[1424] Fix | Delete
* @return bool|int|null
[1425] Fix | Delete
*/
[1426] Fix | Delete
public function is($key, $userAgent = null, $httpHeaders = null)
[1427] Fix | Delete
{
[1428] Fix | Delete
// Set the UA and HTTP headers only if needed (eg. batch mode).
[1429] Fix | Delete
if ($httpHeaders) {
[1430] Fix | Delete
$this->setHttpHeaders($httpHeaders);
[1431] Fix | Delete
}
[1432] Fix | Delete
[1433] Fix | Delete
if ($userAgent) {
[1434] Fix | Delete
$this->setUserAgent($userAgent);
[1435] Fix | Delete
}
[1436] Fix | Delete
[1437] Fix | Delete
$this->setDetectionType(self::DETECTION_TYPE_EXTENDED);
[1438] Fix | Delete
[1439] Fix | Delete
return $this->matchUAAgainstKey($key);
[1440] Fix | Delete
}
[1441] Fix | Delete
[1442] Fix | Delete
/**
[1443] Fix | Delete
* Some detection rules are relative (not standard),
[1444] Fix | Delete
* because of the diversity of devices, vendors and
[1445] Fix | Delete
* their conventions in representing the User-Agent or
[1446] Fix | Delete
* the HTTP headers.
[1447] Fix | Delete
*
[1448] Fix | Delete
* This method will be used to check custom regexes against
[1449] Fix | Delete
* the User-Agent string.
[1450] Fix | Delete
*
[1451] Fix | Delete
* @param $regex
[1452] Fix | Delete
* @param string $userAgent
[1453] Fix | Delete
* @return bool
[1454] Fix | Delete
*
[1455] Fix | Delete
* @todo: search in the HTTP headers too.
[1456] Fix | Delete
*/
[1457] Fix | Delete
public function match($regex, $userAgent = null)
[1458] Fix | Delete
{
[1459] Fix | Delete
if (!\is_string($userAgent) && !\is_string($this->userAgent)) {
[1460] Fix | Delete
return false;
[1461] Fix | Delete
}
[1462] Fix | Delete
[1463] Fix | Delete
$match = (bool) preg_match(sprintf('#%s#is', $regex), (false === empty($userAgent) ? $userAgent : $this->userAgent), $matches);
[1464] Fix | Delete
// If positive match is found, store the results for debug.
[1465] Fix | Delete
if ($match) {
[1466] Fix | Delete
$this->matchingRegex = $regex;
[1467] Fix | Delete
$this->matchesArray = $matches;
[1468] Fix | Delete
}
[1469] Fix | Delete
[1470] Fix | Delete
return $match;
[1471] Fix | Delete
}
[1472] Fix | Delete
[1473] Fix | Delete
/**
[1474] Fix | Delete
* Get the properties array.
[1475] Fix | Delete
*
[1476] Fix | Delete
* @return array
[1477] Fix | Delete
*/
[1478] Fix | Delete
public static function getProperties()
[1479] Fix | Delete
{
[1480] Fix | Delete
return self::$properties;
[1481] Fix | Delete
}
[1482] Fix | Delete
[1483] Fix | Delete
/**
[1484] Fix | Delete
* Prepare the version number.
[1485] Fix | Delete
*
[1486] Fix | Delete
* @todo Remove the error supression from str_replace() call.
[1487] Fix | Delete
*
[1488] Fix | Delete
* @param string $ver The string version, like "2.6.21.2152";
[1489] Fix | Delete
*
[1490] Fix | Delete
* @return float
[1491] Fix | Delete
*/
[1492] Fix | Delete
public function prepareVersionNo($ver)
[1493] Fix | Delete
{
[1494] Fix | Delete
$ver = str_replace(array('_', ' ', '/'), '.', $ver);
[1495] Fix | Delete
$arrVer = explode('.', $ver, 2);
[1496] Fix | Delete
[1497] Fix | Delete
if (isset($arrVer[1])) {
[1498] Fix | Delete
$arrVer[1] = @str_replace('.', '', $arrVer[1]); // @todo: treat strings versions.
[1499] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function