Skip to content

Commit a289712

Browse files
author
arutyunyan
committed
add examples of extending suql syntax. remove config. update change log and readme
1 parent 9a3a0c2 commit a289712

9 files changed

+42
-61
lines changed

CHANGELOG.md

+1
Original file line numberDiff line numberDiff line change
@@ -5,6 +5,7 @@
55
**New features:**
66
- Add filter modifier
77
- Remove commands (no need anymore since we use orm approach)
8+
- Add examples of extending SuQL syntax
89

910
---
1011

README.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -32,7 +32,7 @@ SuQL is syntactic sugar for SQL.
3232
3. Expand SuQL syntax on your own. SQL isn't the limit. There's no limit really.
3333

3434
### Examples
35-
There are couple examples in the ```tests``` directory
35+
There are couple examples in the ```tests``` directory and an example of extending SuQL syntax in the ```syntax``` directory.
3636

3737
## Conclusion
3838
SuQL is all about modifiers and commands. Modifiers already replace standart SQL clauses such as `WHERE`, `GROUP`, `JOIN`, `ORDER` and SQL functions etc. Meanwhile commands can do everything that SuQL or SQL can\'t.

composer.json

-1
Original file line numberDiff line numberDiff line change
@@ -15,7 +15,6 @@
1515
]
1616
},
1717
"require": {
18-
"sagittaracc/config": "@dev",
1918
"sagittaracc/regexp": "@dev",
2019
"sagittaracc/strings": "@dev",
2120
"sagittaracc/arrays": "@dev",

composer.lock

+1-33
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

config/main.php

-17
This file was deleted.

src/core/SuQLObject.php

+15-5
Original file line numberDiff line numberDiff line change
@@ -2,14 +2,26 @@
22
namespace core;
33

44
use builder\SQLAdapter;
5-
use sagittaracc\Config;
65

76
class SuQLObject {
87
private $queries = [];
98
private $scheme = ['rel' => [], 'temp_rel' => []];
109
protected $adapter = null;
1110
private $log = [];
12-
private $configFile = __DIR__ . '/../../config/main.php';
11+
12+
protected function modifierList()
13+
{
14+
return [
15+
'SQLBaseModifier',
16+
'SQLWhereModifier',
17+
'SQLFilterModifier',
18+
'SQLOrderModifier',
19+
'SQLGroupModifier',
20+
'SQLFunctionModifier',
21+
'SQLCaseModifier',
22+
'SQLConditionModifier',
23+
];
24+
}
1325

1426
public function clear() {
1527
$this->queries = [];
@@ -150,9 +162,7 @@ public function hasQuery($name) {
150162
}
151163

152164
public function getModifierClass($modifierHandler) {
153-
$modifierClassList = Config::load($this->configFile)->get('modifier.handler');
154-
155-
foreach ($modifierClassList as $modifierClass) {
165+
foreach ($this->modifierList() as $modifierClass) {
156166
if (method_exists($modifierClass, $modifierHandler))
157167
return $modifierClass;
158168
}

src/model/User.php

+2-2
Original file line numberDiff line numberDiff line change
@@ -3,9 +3,9 @@
33
namespace sagittaracc\model;
44

55
use \SuQL;
6-
use \SuQLExt;
6+
use \SuQLExtensionExample;
77

8-
class User extends SuQLExt
8+
class User extends SuQLExtensionExample
99
{
1010
public function query()
1111
{

src/syntax/SuQLExt.php src/syntax/SuQLExtensionExample.php

+11-1
Original file line numberDiff line numberDiff line change
@@ -2,8 +2,18 @@
22

33
// Example: extend SuQL functionality on your own
44

5-
class SuQLExt extends SuQL
5+
class SuQLExtensionExample extends SuQL
66
{
7+
protected function modifierList()
8+
{
9+
return array_merge(
10+
parent::modifierList(),
11+
[
12+
'SQLArithmeticModifier',
13+
]
14+
);
15+
}
16+
717
public function max($field)
818
{
919
$this->field($field, [

tests/SuQLTest.php

+11-1
Original file line numberDiff line numberDiff line change
@@ -133,7 +133,7 @@ public function testFunction(): void
133133
);
134134
}
135135

136-
public function testSuQLExt(): void
136+
public function testSuQLExtension(): void
137137
{
138138
$this->assertEquals(
139139
User::find()->max('id')->getRawSql(),
@@ -150,4 +150,14 @@ public function testSuQLExt(): void
150150
'select users.name from users'
151151
);
152152
}
153+
154+
public function testSuQLExtensionArithmeticModifier(): void
155+
{
156+
$this->assertEquals(
157+
User::find()->field('id', [
158+
'div' => [2]
159+
])->getRawSql(),
160+
'select users.id / 2 from users'
161+
);
162+
}
153163
}

0 commit comments

Comments
 (0)