mirror of
				https://github.com/dg/dibi.git
				synced 2025-10-26 11:17:40 +01:00 
			
		
		
		
	Connection::substitute() fixed [Closes #197]
This commit is contained in:
		| @@ -545,7 +545,7 @@ class Connection | |||||||
| 	{ | 	{ | ||||||
| 		return strpos($value, ':') === FALSE | 		return strpos($value, ':') === FALSE | ||||||
| 			? $value | 			? $value | ||||||
| 			: preg_replace_callback('#:([^:\s]*):#', function ($m) { $this->substitutes->{$m[1]}; }, $value); | 			: preg_replace_callback('#:([^:\s]*):#', function ($m) { return $this->substitutes->{$m[1]}; }, $value); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -11,16 +11,46 @@ $conn = new Dibi\Connection($config); | |||||||
| $conn->getSubstitutes()->blog = 'wp_'; | $conn->getSubstitutes()->blog = 'wp_'; | ||||||
|  |  | ||||||
| Assert::same( | Assert::same( | ||||||
| 	reformat('UPDATE wp_items SET [text]=\'Hello World\''), | 	reformat('UPDATE wp_items SET [val]=1'), | ||||||
| 	$conn->translate("UPDATE :blog:items SET [text]='Hello World'") | 	$conn->translate('UPDATE :blog:items SET [val]=1') | ||||||
| ); | ); | ||||||
|  |  | ||||||
| Assert::same( | Assert::same( | ||||||
| 	reformat('UPDATE \'wp_\' SET [text]=\'Hello World\''), | 	reformat('UPDATE [wp_items] SET [val]=1'), | ||||||
| 	$conn->translate("UPDATE :blog: SET [text]='Hello World'") | 	$conn->translate('UPDATE [:blog:items] SET [val]=1') | ||||||
| ); | ); | ||||||
|  |  | ||||||
| Assert::same( | Assert::same( | ||||||
| 	reformat('UPDATE \':blg:\' SET [text]=\'Hello World\''), | 	reformat("UPDATE 'wp_' SET [val]=1"), | ||||||
| 	$conn->translate("UPDATE :blg: SET [text]='Hello World'") | 	$conn->translate('UPDATE :blog: SET [val]=1') | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | Assert::same( | ||||||
|  | 	reformat("UPDATE ':blg:' SET [val]=1"), | ||||||
|  | 	$conn->translate('UPDATE :blg: SET [val]=1') | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | Assert::same( | ||||||
|  | 	reformat("UPDATE table SET [text]=':blog:a'"), | ||||||
|  | 	$conn->translate("UPDATE table SET [text]=':blog:a'") | ||||||
|  | ); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // create new substitution :: (empty)  ==>  my_ | ||||||
|  | $conn->getSubstitutes()->{''} = 'my_'; | ||||||
|  |  | ||||||
|  | Assert::same( | ||||||
|  | 	reformat('UPDATE my_table SET [val]=1'), | ||||||
|  | 	$conn->translate('UPDATE ::table SET [val]=1') | ||||||
|  | ); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // create substitutions using fallback callback | ||||||
|  | $conn->getSubstitutes()->setCallback(function ($expr) { | ||||||
|  | 	return '_' . $expr . '_'; | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | Assert::same( | ||||||
|  | 	reformat('UPDATE _account_user SET [val]=1'), | ||||||
|  | 	$conn->translate('UPDATE :account:user SET [val]=1') | ||||||
| ); | ); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user