From f9dfa9f34c9c667db6522f32080debdbca0c0081 Mon Sep 17 00:00:00 2001 From: Elliot Sawyer Date: Wed, 20 Jul 2022 19:17:01 +1200 Subject: [PATCH] PHP 8.1 compatibility --- code/SQLite3Database.php | 20 ++++++++++---------- code/SQLite3SchemaManager.php | 4 ++-- 2 files changed, 12 insertions(+), 12 deletions(-) diff --git a/code/SQLite3Database.php b/code/SQLite3Database.php index 9ee2c9f..b52c07a 100644 --- a/code/SQLite3Database.php +++ b/code/SQLite3Database.php @@ -411,7 +411,7 @@ class SQLite3Database extends Database $queries[$class]->setFrom('"'.DataObject::getSchema()->baseDataTable($class).'"'); $queries[$class]->setSelect(array()); foreach ($select[$class] as $clause) { - if (preg_match('/^(.*) +AS +"?([^"]*)"?/i', $clause, $matches)) { + if (preg_match('/^(.*) +AS +"?([^"]*)"?/i', $clause ?? '', $matches)) { $queries[$class]->selectField($matches[1], $matches[2]); } else { $queries[$class]->selectField(str_replace('"', '', $clause)); @@ -672,7 +672,7 @@ class SQLite3Database extends Database public function formattedDatetimeClause($date, $format) { - preg_match_all('/%(.)/', $format, $matches); + preg_match_all('/%(.)/', $format ?? '', $matches); foreach ($matches[1] as $match) { if (array_search($match, array('Y', 'm', 'd', 'H', 'i', 's', 'U')) === false) { user_error('formattedDatetimeClause(): unsupported format character %' . $match, E_USER_WARNING); @@ -694,9 +694,9 @@ class SQLite3Database extends Database $modifiers[] = 'localtime'; } - if (preg_match('/^now$/i', $date)) { + if (preg_match('/^now$/i', $date ?? '')) { $date = "'now'"; - } elseif (preg_match('/^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}$/i', $date)) { + } elseif (preg_match('/^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}$/i', $date ?? '')) { $date = "'$date'"; } @@ -711,9 +711,9 @@ class SQLite3Database extends Database $modifiers[] = 'localtime'; } - if (preg_match('/^now$/i', $date)) { + if (preg_match('/^now$/i', $date ?? '')) { $date = "'now'"; - } elseif (preg_match('/^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}$/i', $date)) { + } elseif (preg_match('/^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}$/i', $date ?? '')) { $date = "'$date'"; } @@ -733,15 +733,15 @@ class SQLite3Database extends Database $modifiers2[] = 'localtime'; } - if (preg_match('/^now$/i', $date1)) { + if (preg_match('/^now$/i', $date1 ?? '')) { $date1 = "'now'"; - } elseif (preg_match('/^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}$/i', $date1)) { + } elseif (preg_match('/^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}$/i', $date1 ?? '')) { $date1 = "'$date1'"; } - if (preg_match('/^now$/i', $date2)) { + if (preg_match('/^now$/i', $date2 ?? '')) { $date2 = "'now'"; - } elseif (preg_match('/^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}$/i', $date2)) { + } elseif (preg_match('/^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}$/i', $date2 ?? '')) { $date2 = "'$date2'"; } diff --git a/code/SQLite3SchemaManager.php b/code/SQLite3SchemaManager.php index d02fa89..e88f122 100644 --- a/code/SQLite3SchemaManager.php +++ b/code/SQLite3SchemaManager.php @@ -232,7 +232,7 @@ class SQLite3SchemaManager extends DBSchemaManager if (self::$vacuum) { $this->query('VACUUM', E_USER_NOTICE); $message = $this->database->getConnector()->getLastError(); - if (preg_match('/authoriz/', $message)) { + if (preg_match('/authoriz/', $message ?? '')) { $this->alterationMessage("VACUUM | $message", "error"); } else { $this->alterationMessage("VACUUMing", "repaired"); @@ -371,7 +371,7 @@ class SQLite3SchemaManager extends DBSchemaManager if ($sqlCreate && $sqlCreate['sql']) { preg_match( '/^[\s]*CREATE[\s]+TABLE[\s]+[\'"]?[a-zA-Z0-9_\\\]+[\'"]?[\s]*\((.+)\)[\s]*$/ims', - $sqlCreate['sql'], + $sqlCreate['sql'] ?? '', $matches ); $fields = isset($matches[1])