Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[NFR]Add Phalcon\Db::FETCH_GROUP\FETCH_COLUMN\FETCH_KEY_PAIR #1669

Closed
wants to merge 1,168 commits into from
Closed
Show file tree
Hide file tree
Changes from 7 commits
Commits
Show all changes
1168 commits
Select commit Hold shift + click to select a range
fd66ad3
Merge pull request #1411 from dreamsxin/acl
Oct 22, 2013
64ed378
Merge pull request #1414 from Cinderella-Man/1.3.0-tidy-up
Oct 22, 2013
a295c79
Test case for #1413
sjinks Oct 21, 2013
05417fe
Fix #1413
sjinks Oct 22, 2013
bf2c073
Use -DPHALCON_RELEASE
sjinks Oct 23, 2013
b941ca0
Merge pull request #1420 from sjinks/issue-1413
Oct 23, 2013
4a81bb8
Merge pull request #1424 from sjinks/build
Oct 23, 2013
e242b14
Http\Cookie::__toString() should not throw exceptions
sjinks Oct 24, 2013
fea189c
Test case for #1427
sjinks Oct 24, 2013
a1b41e9
Test case for #1428
sjinks Oct 24, 2013
6840ca8
Fix #1428
sjinks Oct 24, 2013
16b54dd
Phalcon\Translate is empty and not used
sjinks Oct 24, 2013
419eaaf
Camelize was ignoring the last character of a string.
richmulhern Oct 24, 2013
46f6182
Merge pull request #1427 from sjinks/issue-1413
Oct 24, 2013
da759f0
\Phalcon\Config Support for reading PHP files
dreamsxin Oct 25, 2013
45f8b98
Updated ConfigTest.php
dreamsxin Oct 25, 2013
43d5df4
Add include file.h
dreamsxin Oct 25, 2013
259caa9
Add config.php
dreamsxin Oct 25, 2013
f9ee154
Use \Phalcon\Config\Adapter\Php
dreamsxin Oct 25, 2013
62052db
Updated
dreamsxin Oct 25, 2013
1d309ca
Change php.h to configphp.h
dreamsxin Oct 25, 2013
6f6993b
Change php.h to configphp.h
dreamsxin Oct 25, 2013
8f3ac1b
Remove unused
dreamsxin Oct 25, 2013
5519ab5
Fix #406
sjinks Oct 25, 2013
f1bf0cb
Test case for #406
sjinks Oct 25, 2013
cf60f43
Merge pull request #1430 from sjinks/translate
Oct 25, 2013
b8d4100
Merge pull request #1436 from richmulhern/camelfix
Oct 25, 2013
3fcdbc0
Merge pull request #1439 from dreamsxin/config
Oct 25, 2013
2cb7e5b
Merge pull request #1440 from sjinks/issue-406
Oct 25, 2013
69d7ef5
Fix #1442
dreamsxin Oct 26, 2013
49183df
Fix #1442
dreamsxin Oct 26, 2013
7d9b33c
Fix #1442
dreamsxin Oct 26, 2013
0796e77
#406 - make sure the string is not interned
sjinks Oct 26, 2013
cb4f64b
Updated RequestTest.php
dreamsxin Oct 26, 2013
4ec303f
Updated
dreamsxin Oct 26, 2013
c6836c5
Updated
dreamsxin Oct 26, 2013
eb0d2bb
mvc/micro.c response isSent #1426
FlatEarthTruth Oct 26, 2013
29750ba
Merge pull request #1443 from gxela/1.3.0
Oct 26, 2013
79570ec
Merge pull request #1444 from dreamsxin/request_file
Oct 26, 2013
cce748c
Fix #1449
sjinks Oct 27, 2013
75f52d5
Test case for #1446
sjinks Oct 27, 2013
07ab879
Fix #1446
sjinks Oct 27, 2013
3235080
Test case for #1455
sjinks Oct 27, 2013
245b817
Fix #1455
sjinks Oct 27, 2013
5fc474a
Safer queryKeys()
sjinks Oct 27, 2013
e1a7f3b
Test case for #1451
sjinks Oct 27, 2013
48c0202
Fix #1451
sjinks Oct 27, 2013
ac83d11
Test case for #1457
sjinks Oct 27, 2013
275e457
Fix #1457
sjinks Oct 27, 2013
7517332
Fix flush() arginfo
sjinks Oct 27, 2013
0b29301
Add increment/decrement to the interface
sjinks Oct 27, 2013
110d388
Fix #1422
dreamsxin Oct 28, 2013
f9fbe78
Updated TagTest.php
dreamsxin Oct 28, 2013
5bf1bd3
Updated TagTest.php
dreamsxin Oct 28, 2013
8b42364
Fix #1462
dreamsxin Oct 28, 2013
e372a4d
Merge pull request #1453 from sjinks/issue-1449
Oct 28, 2013
abb8b03
Merge pull request #1445 from sjinks/issue-406
Oct 28, 2013
7b3770d
Merge pull request #1454 from sjinks/issue-1446
Oct 28, 2013
94cacca
Merge pull request #1456 from sjinks/issue-1455
Oct 28, 2013
63066a7
Merge pull request #1458 from sjinks/issue-1451
Oct 28, 2013
6e99461
Merge pull request #1459 from sjinks/issue-1457
Oct 28, 2013
1f99cb9
Merge pull request #1460 from sjinks/arginfo
Oct 28, 2013
177d4bc
Merge pull request #1463 from dreamsxin/tag_select
Oct 28, 2013
b2fd0bd
Fix #1467
sjinks Oct 28, 2013
6a40a3e
Test case for #1467
sjinks Oct 28, 2013
44f7622
Fix #1466
sjinks Oct 28, 2013
9312edc
Merge pull request #1468 from sjinks/issue-1467
Oct 29, 2013
5752327
Merge pull request #1469 from sjinks/issue-1466
Oct 29, 2013
99caadf
Faster version of Phalcon\DI using object handlers
sjinks Oct 28, 2013
617911b
Deny serializaton
sjinks Oct 29, 2013
1e921fd
clone support
sjinks Oct 29, 2013
a5c1dc5
Tests
sjinks Oct 29, 2013
615f686
Throw exception on invalid method call
sjinks Oct 29, 2013
b01cf18
Fix test case for #1455
sjinks Oct 29, 2013
95b40dd
Fix #1470
sjinks Oct 28, 2013
41cd4d3
Merge pull request #1471 from sjinks/issue-1470
Oct 29, 2013
2c61853
Use FILEINFO_MIME_TYPE
dreamsxin Oct 30, 2013
75be9fc
Use FILEINFO_MIME_TYPE
dreamsxin Oct 30, 2013
f1df004
Updated
dreamsxin Oct 30, 2013
df5b93a
Merge pull request #1464 from dreamsxin/1462
Oct 30, 2013
6aef7a2
Merge pull request #1477 from dreamsxin/request_file
Oct 30, 2013
c4351e6
Merge pull request #1473 from sjinks/fastdi
Oct 30, 2013
85ceb1e
Forgot to implement offsetUnset()
sjinks Oct 30, 2013
abe148e
Fix #1485
sjinks Oct 30, 2013
97417ca
Merge pull request #1487 from sjinks/fastdi
Oct 30, 2013
899da2a
Merge pull request #1488 from sjinks/issue-1485
Oct 30, 2013
9e3bf7f
Fix #1486 for v1.3.0
dreamsxin Oct 31, 2013
b9e347a
Enable memcached.so
sjinks Oct 31, 2013
5c9c64b
Merge pull request #1492 from dreamsxin/bug_1486_1.3.0
niden Oct 31, 2013
7ba405d
Fix #1494
sjinks Oct 31, 2013
556c988
Fix Log Formatter getTypeString EMERGENCY bug
SamHennessy Oct 30, 2013
dfe768d
Test case
sjinks Oct 31, 2013
412258c
Merge pull request #1493 from sjinks/memcached
Nov 1, 2013
b5b622a
Merge pull request #1496 from sjinks/issue-1494
Nov 1, 2013
7437261
Merge pull request #1498 from sjinks/logger
Nov 1, 2013
b475730
Test case for #1501
sjinks Nov 1, 2013
742d94b
Fix #1501
sjinks Nov 1, 2013
38e7053
Merge pull request #1503 from sjinks/issue-1501
Nov 2, 2013
3f514e7
Test case for #1504
sjinks Nov 2, 2013
176dfdb
Fix #1504
sjinks Nov 2, 2013
ffa02c4
Implement #1495
sjinks Nov 2, 2013
b7f69e9
Test case for #1509
sjinks Nov 2, 2013
831b230
Fix #1509
sjinks Nov 2, 2013
dea1dc2
Merge pull request #1507 from sjinks/issue-1504
Nov 3, 2013
b41d846
Merge pull request #1508 from sjinks/issue-1495
Nov 3, 2013
fd90710
Merge pull request #1510 from sjinks/issue-1509
Nov 3, 2013
17ef5a9
emergence => emergency
sjinks Nov 3, 2013
502d4a0
Merge pull request #1512 from sjinks/logger
niden Nov 4, 2013
c3a10cf
Fix #1513 use zend_symtable_update instead of zend_hash_update
dreamsxin Nov 5, 2013
48aeb82
Updated
dreamsxin Nov 5, 2013
88789a3
Update file.c
xboston Nov 5, 2013
52219b4
typo
tmihalik Nov 5, 2013
4aa0b08
[NFR]When not found option renturn null
dreamsxin Nov 7, 2013
bd37dfa
[NFR]When not found option renturn null
dreamsxin Nov 7, 2013
8cb22ef
Merge pull request #1517 from dreamsxin/1513
Nov 7, 2013
af3f019
Merge pull request #1521 from xboston/patch-2
Nov 7, 2013
683683a
Merge pull request #1523 from tmihalik/1.3.0
Nov 7, 2013
56bce07
Merge pull request #1531 from dreamsxin/model_validator_1.3.0
Nov 8, 2013
88e6af7
Initialization order matters
sjinks Oct 24, 2013
007e97d
Assets\Filters\Cssmin should implement Assets\FilterInterface
sjinks Oct 24, 2013
6a3e00f
Assets\Filters\Jsmin should implement Assets\FilterInterface
sjinks Oct 24, 2013
50ede68
Updated README.md (#1525)
sjinks Nov 8, 2013
6fd612a
Merge pull request #1539 from sjinks/filterinterface
Nov 8, 2013
2f3ba60
Fix BUG #1536
dreamsxin Nov 11, 2013
beb8b47
Merge pull request #1544 from dreamsxin/1536
Nov 11, 2013
c24994c
Merge pull request #1519 from dreamsxin/selectWriteConnection
Nov 11, 2013
2249676
[#1548] Missing main/php_variables.h header breaks compilation on Win…
Nov 12, 2013
8d79278
Merge pull request #1551 from WooDzu/1.3.0-local-build
Nov 14, 2013
7aa4c2f
Test stubs for ViewSimple
Nov 16, 2013
45c2001
Update ViewSimpleTest.php
Nov 16, 2013
959fef2
Phalcon\Mvc\View\Simple::setViewsDir() should return self
Nov 17, 2013
c5d415e
Use setExpectedException method instead of annotation @expectedException
Nov 17, 2013
a59b1c2
Merge remote-tracking branch 'origin/1.3.0-tests-viewsimple' into 1.3…
Nov 17, 2013
ea5fa03
revert a59b1c2
Nov 17, 2013
e0dbfef
Stubs for Phalcon\Mvc\View
Nov 17, 2013
af6d168
Stubs for partials
Nov 17, 2013
be2596a
debug travis =]
Nov 17, 2013
d6c7104
possible solution for partial not seeing $this->view
Nov 17, 2013
61e7302
possible solution 2 for partial not seeing $this->view
Nov 17, 2013
053788d
Fix #1529
sjinks Nov 18, 2013
b466d75
Bug fix
sjinks Nov 18, 2013
5bc0558
Updated tests
sjinks Nov 18, 2013
0146540
Fix #1534
sjinks Nov 18, 2013
319bce9
Update mysql/phalcon_test.sql
sjinks Nov 18, 2013
e63f137
Test case for #1534
sjinks Nov 18, 2013
087116c
Update testDbMysql()
sjinks Nov 18, 2013
9d4aede
Merge pull request #1563 from WooDzu/1.3.0-tests-views
Nov 18, 2013
d43e90e
Merge pull request #1565 from sjinks/issue-1529
Nov 18, 2013
6589765
Merge pull request #1566 from sjinks/issue-1534
Nov 18, 2013
a2e0d6b
Changed indent style to tabs instead of spaces. Added license header
Nov 18, 2013
a4926b7
Changed indent style to tabs instead of spaces
Nov 18, 2013
b8ca50e
Fixed class name in setExpectedException
Nov 19, 2013
efc71c7
Merge pull request #1568 from WooDzu/1.3.0-tests-views-indents
Nov 20, 2013
43935f1
Updated pattern of Http\Request::getDigestAuth
dreamsxin Nov 20, 2013
7c4907e
Updated pattern of Http\Request::getDigestAuth
dreamsxin Nov 20, 2013
f8b238f
Merge pull request #1571 from dreamsxin/http_request_digest
Nov 20, 2013
caacb9d
Implement #1555
sjinks Nov 20, 2013
1bf7f07
Test case for #1555
sjinks Nov 20, 2013
524fa6b
Update README.md
sjinks Nov 20, 2013
f37aa44
Fix #1567
sjinks Nov 20, 2013
d80976d
Test case for #1567
sjinks Nov 20, 2013
34b0c56
Update test case for #1498
sjinks Nov 20, 2013
1007783
Merge pull request #1572 from sjinks/issue-1555
Nov 21, 2013
f39c582
Merge pull request #1573 from sjinks/patch-1
Nov 21, 2013
e796e0c
Merge pull request #1574 from sjinks/issue-1567
Nov 21, 2013
1d8d7a8
Implement #1575
sjinks Nov 22, 2013
920e9f2
Test case for #1575
sjinks Nov 22, 2013
442665f
Merge pull request #1581 from sjinks/issue-1575
Nov 22, 2013
ccb33e4
Tests for ViewCache
Nov 23, 2013
f6a0cb2
RequestTest::testIssues1442 requires fileinfo extension, skip if not …
Nov 23, 2013
e4a21f1
Fix: Windows test fails due to UNIX-style line ends
Nov 23, 2013
1e4c12d
Fix doc in Phalcon\Mvc\ModuleDefinitionInterface
endeveit Nov 23, 2013
1fd5516
Fix: Windows test fails due to expected UNIX-style line ends
Nov 23, 2013
fed0c41
I'd rather not use symlinks. They make testing on windows even more d…
Nov 23, 2013
3d7227e
Symbolic link to be removed
Nov 23, 2013
c942a7b
Symbolic link replaced with file
Nov 23, 2013
6021ffc
Note in Readme file about testing on Windows
Nov 23, 2013
bab72c6
Symbolic link to be removed
Nov 23, 2013
e575752
Windows test fails due to expected UNIX-style line ends
Nov 23, 2013
69a9c02
Symbolic link replaced with file
Nov 23, 2013
e6fada1
CryptTest cases require mcrypt extension
Nov 23, 2013
63fe666
oops... Wrong extension name
Nov 23, 2013
104fc59
Statement incorrectly assumes that trailing DS from user always equal…
Nov 24, 2013
b25cb10
Fix #1532 Add Phalcon\Assets\Collection::setTargetLocal
dreamsxin Nov 25, 2013
58ddbf4
Merge pull request #1586 from endeveit/1.3.0
Nov 25, 2013
38842e5
Merge pull request #1588 from WooDzu/1.3.0-unit-tests
Nov 25, 2013
b67009d
Merge pull request #1591 from WooDzu/1.3.0-loader-paths
Nov 25, 2013
cc0e879
Merge pull request #1593 from dreamsxin/issue_1532
Nov 25, 2013
f6c6738
Testing issue 1527
Nov 25, 2013
9af2787
Merge remote-tracking branch 'remotes/upstream/1.3.0' into 1.3.0-test…
Nov 25, 2013
97fd2f3
Suppress output from $view->partial()
Nov 25, 2013
9388b10
Merge pull request #1560 from WooDzu/1.3.0-tests-viewsimple
Nov 26, 2013
1e53e53
Backport #1506 from 1.2.5
sjinks Nov 26, 2013
c57fdd4
Merge pull request #1604 from sjinks/issue-1506
Nov 27, 2013
ddf9048
phalcon_dump_current_frame() to debug memory frames
sjinks Nov 28, 2013
f994a3c
zim_Phalcon_Cache_Backend_Memory_get() should update _lastKey
sjinks Nov 28, 2013
428284a
Test case for #1607
sjinks Nov 28, 2013
f2a3d0b
Fix #1607
sjinks Nov 28, 2013
3f5dd6a
Merge pull request #1600 from WooDzu/1.3.0-issue-1527
Nov 28, 2013
d14ea1f
Merge pull request #1611 from sjinks/issue-1607
Nov 28, 2013
f166604
Revert #1600 temporarily
sjinks Nov 28, 2013
d886494
Merge pull request #1614 from sjinks/revert-1600
Nov 29, 2013
dc33da3
Phalcon\Mvc\Model\Row using object handlers
sjinks Nov 27, 2013
78ab6b8
Phalcon\Mvc\Model\Row using object handlers
sjinks Nov 27, 2013
8f96abb
Disallow to override superglobals
sjinks Nov 29, 2013
f65e239
Merge pull request #1606 from sjinks/fast-row
Nov 29, 2013
bbff6d5
Test case for #1617
sjinks Nov 30, 2013
43a8031
Install beanstalkd
sjinks Nov 30, 2013
ce77b38
Be less verbose
sjinks Nov 30, 2013
3883b2b
Unit test for Beanstalk
sjinks Nov 30, 2013
32e82db
Method name bug fix
sjinks Nov 30, 2013
2dfe548
Updated test
sjinks Nov 30, 2013
701e365
Use native functions; fix #1612; fix #1348
sjinks Nov 30, 2013
720344b
Merge pull request #1618 from sjinks/beanstalk
Nov 30, 2013
9be0cfb
Test case for #1480
sjinks Dec 1, 2013
02fde4f
Fix #1480
sjinks Dec 1, 2013
5d137d9
Regenerated parsers
sjinks Dec 1, 2013
d931cf8
Merge pull request #1621 from sjinks/beanstalk
Dec 2, 2013
908d03f
Merge pull request #1617 from sjinks/view-superglobals
Dec 2, 2013
fa4b0d3
Merge pull request #1623 from sjinks/issue-1480
Dec 2, 2013
255094b
Fix phalcon/docs#263
sjinks Dec 2, 2013
d8ff5b3
Merge pull request #1626 from sjinks/1.3.0
Dec 2, 2013
7f10fbb
Optimize Phalcon\Paginator\Adapter\QueryBuilder
sjinks Dec 3, 2013
5b5ecce
Make sure that the 'limit' is positive
sjinks Dec 4, 2013
2e520f9
return ;
sjinks Dec 4, 2013
9634e93
Safer job unserialization
sjinks Dec 4, 2013
162b4e0
Test case
sjinks Dec 4, 2013
395b895
Safe serialization/unserialization
sjinks Dec 4, 2013
4311f65
Test case
sjinks Dec 4, 2013
6f4b3db
Merge pull request #1632 from sjinks/paginator_builder
Dec 4, 2013
f9c9110
Merge pull request #1633 from sjinks/setcurrentpage
Dec 4, 2013
fab567a
Merge pull request #1634 from sjinks/beanstalk-job
Dec 4, 2013
b6e3e90
Test case for #1637
sjinks Dec 5, 2013
4807e84
Use zend_update_property for dynamic properties
sjinks Dec 5, 2013
11001ae
Phalcon\Session\Bag fixes
sjinks Dec 5, 2013
863089c
Fix compilation error under NTS
sjinks Dec 5, 2013
f1b0d5a
Merge pull request #1635 from sjinks/beanstalk-queue
Dec 5, 2013
c513fe3
Merge pull request #1639 from sjinks/issue-1637
Dec 5, 2013
f535d6e
Merge pull request #1641 from sjinks/1.3.0
Dec 5, 2013
8503ddf
Optimized Phalcon\Paginator\Adapter\NativeArray
sjinks Dec 7, 2013
315a26f
Fix #1654
sjinks Dec 8, 2013
84374c0
Test case for #1654
sjinks Dec 8, 2013
fbe6d24
Use native iterators for Phalcon\Validation\Message\Group
sjinks Dec 9, 2013
c55ac8f
Test case
sjinks Dec 9, 2013
6c3a724
Merge pull request #1653 from sjinks/native-array
Dec 9, 2013
1b083cf
Merge pull request #1655 from sjinks/issue-1654
Dec 9, 2013
e94bfed
Merge pull request #1657 from sjinks/group_iterator
Dec 9, 2013
1e4c5f5
Updated CHANGELOG
sjinks Dec 10, 2013
133aa32
Merge pull request #1660 from sjinks/1.3.0
Dec 10, 2013
2ef9554
Fix #1642
dreamsxin Dec 11, 2013
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
746 changes: 494 additions & 252 deletions ext/di.c

Large diffs are not rendered by default.

4 changes: 4 additions & 0 deletions ext/di.h
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@ extern zend_class_entry *phalcon_di_ce;

PHALCON_INIT_CLASS(Phalcon_DI);

PHALCON_STATIC void phalcon_di_set_services(zval *this_ptr, zval *services TSRMLS_DC);

PHP_METHOD(Phalcon_DI, __construct);
PHP_METHOD(Phalcon_DI, set);
PHP_METHOD(Phalcon_DI, setShared);
Expand All @@ -39,6 +41,7 @@ PHP_METHOD(Phalcon_DI, __call);
PHP_METHOD(Phalcon_DI, setDefault);
PHP_METHOD(Phalcon_DI, getDefault);
PHP_METHOD(Phalcon_DI, reset);
PHP_METHOD(Phalcon_DI, __clone);

ZEND_BEGIN_ARG_INFO_EX(arginfo_phalcon_di_set, 0, 0, 2)
ZEND_ARG_INFO(0, name)
Expand Down Expand Up @@ -119,6 +122,7 @@ PHALCON_INIT_FUNCS(phalcon_di_method_entry){
PHP_ME(Phalcon_DI, setDefault, arginfo_phalcon_di_setdefault, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
PHP_ME(Phalcon_DI, getDefault, NULL, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
PHP_ME(Phalcon_DI, reset, NULL, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
PHP_ME(Phalcon_DI, __clone, NULL, ZEND_ACC_PUBLIC)
PHP_FE_END
};

2 changes: 1 addition & 1 deletion ext/di/factorydefault.c
Original file line number Diff line number Diff line change
Expand Up @@ -350,7 +350,7 @@ PHP_METHOD(Phalcon_DI_FactoryDefault, __construct){
/**
* Update the internal services properties
*/
phalcon_update_property_this(this_ptr, SL("_services"), services TSRMLS_CC);
phalcon_di_set_services(this_ptr, services TSRMLS_CC);

PHALCON_MM_RESTORE();
}
Expand Down
3 changes: 2 additions & 1 deletion ext/di/factorydefault/cli.c
Original file line number Diff line number Diff line change
Expand Up @@ -201,8 +201,9 @@ PHP_METHOD(Phalcon_DI_FactoryDefault_CLI, __construct){
phalcon_array_update_string(&services, SL("security"), &security, PH_COPY);
phalcon_array_update_string(&services, SL("eventsManager"), &events_manager, PH_COPY);
phalcon_array_update_string(&services, SL("transactionManager"), &transaction_manager, PH_COPY);
phalcon_update_property_this(this_ptr, SL("_services"), services TSRMLS_CC);

phalcon_di_set_services(this_ptr, services TSRMLS_CC);

PHALCON_MM_RESTORE();
}

113 changes: 64 additions & 49 deletions ext/kernel/object.c
Original file line number Diff line number Diff line change
Expand Up @@ -302,6 +302,26 @@ int phalcon_class_exists(const zval *class_name, int autoload TSRMLS_DC) {
return 0;
}

int phalcon_class_exists_ex(zend_class_entry **zce, const zval *class_name, int autoload TSRMLS_DC) {

zend_class_entry **ce;

if (Z_TYPE_P(class_name) == IS_STRING) {
if (zend_lookup_class(Z_STRVAL_P(class_name), Z_STRLEN_P(class_name), &ce TSRMLS_CC) == SUCCESS) {
*zce = *ce;
#if PHP_VERSION_ID < 50400
return (((*ce)->ce_flags & ZEND_ACC_INTERFACE) == 0);
#else
return ((*ce)->ce_flags & (ZEND_ACC_INTERFACE | (ZEND_ACC_TRAIT - ZEND_ACC_EXPLICIT_ABSTRACT_CLASS))) == 0;
#endif
}
return 0;
}

php_error_docref(NULL TSRMLS_CC, E_WARNING, "class name must be a string");
return 0;
}

/**
* Clones an object from obj to destination
*/
Expand Down Expand Up @@ -1277,59 +1297,14 @@ int phalcon_read_class_property(zval **result, int type, char *property, int len
return FAILURE;
}

/**
* Creates a new instance dynamically. Call constructor without parameters
*/
int phalcon_create_instance(zval *return_value, const zval *class_name TSRMLS_DC){

zend_class_entry *ce;

if (Z_TYPE_P(class_name) != IS_STRING) {
phalcon_throw_exception_string(phalcon_exception_ce, "Invalid class name" TSRMLS_CC);
return FAILURE;
}

ce = zend_fetch_class(Z_STRVAL_P(class_name), Z_STRLEN_P(class_name), ZEND_FETCH_CLASS_DEFAULT TSRMLS_CC);
if (!ce) {
return FAILURE;
}
int phalcon_create_instance_params_ce(zval *return_value, zend_class_entry *ce, zval *params TSRMLS_DC)
{
int outcome = SUCCESS;

object_init_ex(return_value, ce);
if (phalcon_has_constructor_ce(ce)) {
return phalcon_call_method_params(NULL, NULL, return_value, SL("__construct"), zend_inline_hash_func(SS("__construct")) TSRMLS_CC, 0);
}

return SUCCESS;
}

/**
* Creates a new instance dynamically calling constructor with parameters
*/
int phalcon_create_instance_params(zval *return_value, const zval *class_name, zval *params TSRMLS_DC){

int outcome;
zend_class_entry *ce;

if (Z_TYPE_P(class_name) != IS_STRING) {
phalcon_throw_exception_string(phalcon_exception_ce, "Invalid class name" TSRMLS_CC);
return FAILURE;
}

if (Z_TYPE_P(params) != IS_ARRAY) {
phalcon_throw_exception_string(phalcon_exception_ce, "Instantiation parameters must be an array" TSRMLS_CC);
return FAILURE;
}

ce = zend_fetch_class(Z_STRVAL_P(class_name), Z_STRLEN_P(class_name), ZEND_FETCH_CLASS_DEFAULT TSRMLS_CC);
if (!ce) {
return FAILURE;
}

object_init_ex(return_value, ce);
outcome = SUCCESS;

if (phalcon_has_constructor_ce(ce)) {
int param_count = zend_hash_num_elements(Z_ARRVAL_P(params));
int param_count = (Z_TYPE_P(params) == IS_ARRAY) ? zend_hash_num_elements(Z_ARRVAL_P(params)) : 0;
zval *static_params[10];
zval **params_ptr, **params_arr = NULL;

Expand Down Expand Up @@ -1368,6 +1343,46 @@ int phalcon_create_instance_params(zval *return_value, const zval *class_name, z
return outcome;
}

/**
* Creates a new instance dynamically. Call constructor without parameters
*/
int phalcon_create_instance(zval *return_value, const zval *class_name TSRMLS_DC){

zend_class_entry *ce;

if (unlikely(Z_TYPE_P(class_name) != IS_STRING)) {
phalcon_throw_exception_string(phalcon_exception_ce, "Invalid class name" TSRMLS_CC);
return FAILURE;
}

ce = zend_fetch_class(Z_STRVAL_P(class_name), Z_STRLEN_P(class_name), ZEND_FETCH_CLASS_DEFAULT TSRMLS_CC);
if (!ce) {
return FAILURE;
}

return phalcon_create_instance_params_ce(return_value, ce, PHALCON_GLOBAL(z_null) TSRMLS_CC);
}

/**
* Creates a new instance dynamically calling constructor with parameters
*/
int phalcon_create_instance_params(zval *return_value, const zval *class_name, zval *params TSRMLS_DC){

zend_class_entry *ce;

if (unlikely(Z_TYPE_P(class_name) != IS_STRING)) {
phalcon_throw_exception_string(phalcon_exception_ce, "Invalid class name" TSRMLS_CC);
return FAILURE;
}

ce = zend_fetch_class(Z_STRVAL_P(class_name), Z_STRLEN_P(class_name), ZEND_FETCH_CLASS_DEFAULT TSRMLS_CC);
if (!ce) {
return FAILURE;
}

return phalcon_create_instance_params_ce(return_value, ce, params TSRMLS_CC);
}

/**
* Increments an object property
*/
Expand Down
66 changes: 34 additions & 32 deletions ext/kernel/object.h
Original file line number Diff line number Diff line change
Expand Up @@ -18,12 +18,13 @@
*/

/** Class Retrieving/Checking */
extern int phalcon_class_exists(const zval *class_name, int autoload TSRMLS_DC);
extern void phalcon_get_class(zval *result, zval *object, int lower TSRMLS_DC);
extern void phalcon_get_class_ns(zval *result, zval *object, int lower TSRMLS_DC);
extern void phalcon_get_ns_class(zval *result, zval *object, int lower TSRMLS_DC);
extern void phalcon_get_called_class(zval *return_value TSRMLS_DC);
extern zend_class_entry *phalcon_fetch_class(const zval *class_name TSRMLS_DC);
int phalcon_class_exists(const zval *class_name, int autoload TSRMLS_DC);
int phalcon_class_exists_ex(zend_class_entry **zce, const zval *class_name, int autoload TSRMLS_DC);
void phalcon_get_class(zval *result, zval *object, int lower TSRMLS_DC);
void phalcon_get_class_ns(zval *result, zval *object, int lower TSRMLS_DC);
void phalcon_get_ns_class(zval *result, zval *object, int lower TSRMLS_DC);
void phalcon_get_called_class(zval *return_value TSRMLS_DC);
zend_class_entry *phalcon_fetch_class(const zval *class_name TSRMLS_DC);
zend_class_entry* phalcon_fetch_self_class(TSRMLS_D);
zend_class_entry* phalcon_fetch_parent_class(TSRMLS_D);
zend_class_entry* phalcon_fetch_static_class(TSRMLS_D);
Expand All @@ -37,22 +38,22 @@ zend_class_entry* phalcon_fetch_static_class(TSRMLS_D);
} while (0)

/** Class constants */
extern int phalcon_get_class_constant(zval *return_value, zend_class_entry *ce, char *constant_name, unsigned int constant_length TSRMLS_DC);
int phalcon_get_class_constant(zval *return_value, zend_class_entry *ce, char *constant_name, unsigned int constant_length TSRMLS_DC);

/** Cloning/Instance of*/
extern int phalcon_clone(zval *destiny, zval *obj TSRMLS_DC);
extern int phalcon_instance_of(zval *result, const zval *object, const zend_class_entry *ce TSRMLS_DC);
extern int phalcon_is_instance_of(zval *object, const char *class_name, unsigned int class_length TSRMLS_DC);
int phalcon_clone(zval *destiny, zval *obj TSRMLS_DC);
int phalcon_instance_of(zval *result, const zval *object, const zend_class_entry *ce TSRMLS_DC);
int phalcon_is_instance_of(zval *object, const char *class_name, unsigned int class_length TSRMLS_DC);

/** Method exists */
extern int phalcon_method_exists(const zval *object, const zval *method_name TSRMLS_DC);
extern int phalcon_method_exists_ex(const zval *object, const char *method_name, unsigned int method_len TSRMLS_DC);
extern int phalcon_method_quick_exists_ex(const zval *object, const char *method_name, unsigned int method_len, unsigned long hash TSRMLS_DC);
int phalcon_method_exists(const zval *object, const zval *method_name TSRMLS_DC);
int phalcon_method_exists_ex(const zval *object, const char *method_name, unsigned int method_len TSRMLS_DC);
int phalcon_method_quick_exists_ex(const zval *object, const char *method_name, unsigned int method_len, unsigned long hash TSRMLS_DC);

/** Isset properties */
extern int phalcon_isset_property(zval *object, const char *property_name, unsigned int property_length TSRMLS_DC);
extern int phalcon_isset_property_quick(zval *object, const char *property_name, unsigned int property_length, unsigned long hash TSRMLS_DC);
extern int phalcon_isset_property_zval(zval *object, const zval *property TSRMLS_DC);
int phalcon_isset_property(zval *object, const char *property_name, unsigned int property_length TSRMLS_DC);
int phalcon_isset_property_quick(zval *object, const char *property_name, unsigned int property_length, unsigned long hash TSRMLS_DC);
int phalcon_isset_property_zval(zval *object, const zval *property TSRMLS_DC);

/** Reading properties */
int phalcon_read_property_this(zval **result, zval *object, char *property_name, unsigned int property_length, int silent TSRMLS_DC);
Expand All @@ -67,26 +68,26 @@ int phalcon_return_property(zval *return_value, zval **return_value_ptr, zval *o
int phalcon_return_property_quick(zval *return_value, zval **return_value_ptr, zval *object, char *property_name, unsigned int property_length, unsigned long key TSRMLS_DC);

/** Updating properties */
extern int phalcon_update_property_this(zval *object, char *property_name, unsigned int property_length, zval *value TSRMLS_DC);
extern int phalcon_update_property_long(zval *obj, char *property_name, unsigned int property_length, long value TSRMLS_DC);
extern int phalcon_update_property_string(zval *object, char *property_name, unsigned int property_length, char *str, unsigned int str_length TSRMLS_DC);
extern int phalcon_update_property_bool(zval *obj, char *property_name, unsigned int property_length, int value TSRMLS_DC);
extern int phalcon_update_property_null(zval *obj, char *property_name, unsigned int property_length TSRMLS_DC);
extern int phalcon_update_property_zval(zval *obj, char *property_name, unsigned int property_length, zval *value TSRMLS_DC);
extern int phalcon_update_property_zval_zval(zval *obj, zval *property, zval *value TSRMLS_DC);
extern int phalcon_update_property_empty_array(zend_class_entry *ce, zval *object, char *property, unsigned int property_length TSRMLS_DC);
int phalcon_update_property_this(zval *object, char *property_name, unsigned int property_length, zval *value TSRMLS_DC);
int phalcon_update_property_long(zval *obj, char *property_name, unsigned int property_length, long value TSRMLS_DC);
int phalcon_update_property_string(zval *object, char *property_name, unsigned int property_length, char *str, unsigned int str_length TSRMLS_DC);
int phalcon_update_property_bool(zval *obj, char *property_name, unsigned int property_length, int value TSRMLS_DC);
int phalcon_update_property_null(zval *obj, char *property_name, unsigned int property_length TSRMLS_DC);
int phalcon_update_property_zval(zval *obj, char *property_name, unsigned int property_length, zval *value TSRMLS_DC);
int phalcon_update_property_zval_zval(zval *obj, zval *property, zval *value TSRMLS_DC);
int phalcon_update_property_empty_array(zend_class_entry *ce, zval *object, char *property, unsigned int property_length TSRMLS_DC);

/** Updating array properties */
extern int phalcon_update_property_array(zval *object, char *property, unsigned int property_length, zval *index, zval *value TSRMLS_DC);
extern int phalcon_update_property_array_string(zval *object, char *property, unsigned int property_length, char *index, unsigned int index_length, zval *value TSRMLS_DC);
extern int phalcon_update_property_array_append(zval *object, char *property, unsigned int property_length, zval *value TSRMLS_DC);
int phalcon_update_property_array(zval *object, char *property, unsigned int property_length, zval *index, zval *value TSRMLS_DC);
int phalcon_update_property_array_string(zval *object, char *property, unsigned int property_length, char *index, unsigned int index_length, zval *value TSRMLS_DC);
int phalcon_update_property_array_append(zval *object, char *property, unsigned int property_length, zval *value TSRMLS_DC);

/** Increment/Decrement properties */
extern int phalcon_property_incr(zval *object, char *property_name, unsigned int property_length TSRMLS_DC);
extern int phalcon_property_decr(zval *object, char *property_name, unsigned int property_length TSRMLS_DC);
int phalcon_property_incr(zval *object, char *property_name, unsigned int property_length TSRMLS_DC);
int phalcon_property_decr(zval *object, char *property_name, unsigned int property_length TSRMLS_DC);

/** Unset Array properties */
extern int phalcon_unset_property_array(zval *object, char *property, unsigned int property_length, zval *index TSRMLS_DC);
int phalcon_unset_property_array(zval *object, char *property, unsigned int property_length, zval *index TSRMLS_DC);

/** Static properties */
int phalcon_read_static_property(zval **result, const char *class_name, unsigned int class_length, char *property_name, unsigned int property_length TSRMLS_DC);
Expand All @@ -97,6 +98,7 @@ int phalcon_read_class_property(zval **result, int type, char *property, int len
zval* phalcon_fetch_static_property_ce(zend_class_entry *ce, char *property, int len TSRMLS_DC);

/** Create instances */
extern int phalcon_create_instance(zval *return_value, const zval *class_name TSRMLS_DC);
extern int phalcon_create_instance_params(zval *return_value, const zval *class_name, zval *params TSRMLS_DC);
int phalcon_create_instance_params_ce(zval *return_value, zend_class_entry *ce, zval *params TSRMLS_DC);
int phalcon_create_instance(zval *return_value, const zval *class_name TSRMLS_DC);
int phalcon_create_instance_params(zval *return_value, const zval *class_name, zval *params TSRMLS_DC);

3 changes: 3 additions & 0 deletions ext/tests/issue-1455.phpt
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,9 @@ include('skipif.inc');
if (!PHP_DEBUG) {
die('skip PHP must be compiled in debug mode');
}
if (!function_exists('apc_store')) {
die('skip APC or APCu is required');
}
?>
--FILE--
<?php
Expand Down
93 changes: 93 additions & 0 deletions ext/tests/issue-1473.phpt
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
--TEST--
Faster version of Phalcon\DI using object handlers - https://github.com/phalcon/cphalcon/pull/1473
--SKIPIF--
<?php include('skipif.inc'); ?>
--FILE--
<?php

class MyDI extends \Phalcon\DI
{
public function offsetGet($offset)
{
echo __METHOD__, PHP_EOL;
return parent::offsetGet($offset);
}

public function offsetSet($offset, $value)
{
echo __METHOD__, PHP_EOL;
return parent::offsetSet($offset, $value);
}

public function offsetExists($offset)
{
echo __METHOD__, PHP_EOL;
return parent::offsetExists($offset);
}

public function __call($method, $params = null)
{
echo __METHOD__, PHP_EOL;
if ('test' == $method) {
$method = 'getTest';
}

return parent::__call($method, $params);
}

public function __clone()
{
echo __METHOD__, PHP_EOL;
return parent::__clone();
}
}

$di = new MyDI();
$di['test'] = function() { return new stdClass(); };
$di['test'];
var_dump(isset($di['test']));
var_dump(get_class($di->test()));

try {
$s = serialize($di);
}
catch (Exception $e) {
echo $e->getMessage(), PHP_EOL;
}

$s = 'C:20:"Phalcon\\DI":0:{}';
$x = unserialize($s);

$s = 'O:20:"Phalcon\\DI":0:{}';
$x = unserialize($s);

$clone = clone $di;
var_dump(isset($clone['test']));
var_dump(get_class($clone->test()));

try {
$di->somethingWeird();
}
catch (\Phalcon\DI\Exception $e) {
echo $e->getMessage(), PHP_EOL;
}
?>
--EXPECTF--
MyDI::offsetSet
MyDI::offsetGet
MyDI::offsetExists
bool(true)
MyDI::__call
string(8) "stdClass"
Serialization of 'MyDI' is not allowed

Notice: unserialize(): Error at offset %d of %d bytes in %s on line %d

Notice: unserialize(): Error at offset %d of %d bytes in %s on line %d
MyDI::__clone
MyDI::offsetExists
bool(true)
MyDI::__call
string(8) "stdClass"
MyDI::__call
Call to undefined method or service 'somethingWeird'