Skip to content

Commit

Permalink
Merge pull request #2208 from maxgalbu/issue2157
Browse files Browse the repository at this point in the history
criteria: fix issue #2157 and added tests
  • Loading branch information
Phalcon committed Mar 31, 2014
2 parents 8c79696 + 2c635e3 commit 7b90cff
Show file tree
Hide file tree
Showing 10 changed files with 209 additions and 64 deletions.
4 changes: 2 additions & 2 deletions build/32bits/phalcon.c
Original file line number Diff line number Diff line change
Expand Up @@ -45722,7 +45722,7 @@ static PHP_METHOD(Phalcon_DI_Service, getParameter){

/* Update the parameter */
if (
phalcon_array_isset_string_fetch(&arguments, definition, SS("arguments"))
phalcon_array_isset_string_fetch(&arguments, definition, SS("arguments"))
&& phalcon_array_isset_fetch(&parameter, arguments, *position)
) {
RETURN_ZVAL(parameter, 1, 0);
Expand All @@ -45744,7 +45744,7 @@ static PHP_METHOD(Phalcon_DI_Service, __set_state){
phalcon_fetch_params(0, 1, 0, &attributes);

if (
!phalcon_array_isset_string_fetch(&name, attributes, SS("_name"))
!phalcon_array_isset_string_fetch(&name, attributes, SS("_name"))
|| !phalcon_array_isset_string_fetch(&definition, attributes, SS("_definition"))
|| !phalcon_array_isset_string_fetch(&shared, attributes, SS("_shared"))
) {
Expand Down
4 changes: 2 additions & 2 deletions build/64bits/phalcon.c
Original file line number Diff line number Diff line change
Expand Up @@ -45722,7 +45722,7 @@ static PHP_METHOD(Phalcon_DI_Service, getParameter){

/* Update the parameter */
if (
phalcon_array_isset_string_fetch(&arguments, definition, SS("arguments"))
phalcon_array_isset_string_fetch(&arguments, definition, SS("arguments"))
&& phalcon_array_isset_fetch(&parameter, arguments, *position)
) {
RETURN_ZVAL(parameter, 1, 0);
Expand All @@ -45744,7 +45744,7 @@ static PHP_METHOD(Phalcon_DI_Service, __set_state){
phalcon_fetch_params(0, 1, 0, &attributes);

if (
!phalcon_array_isset_string_fetch(&name, attributes, SS("_name"))
!phalcon_array_isset_string_fetch(&name, attributes, SS("_name"))
|| !phalcon_array_isset_string_fetch(&definition, attributes, SS("_definition"))
|| !phalcon_array_isset_string_fetch(&shared, attributes, SS("_shared"))
) {
Expand Down
4 changes: 2 additions & 2 deletions build/safe/phalcon.c
Original file line number Diff line number Diff line change
Expand Up @@ -45722,7 +45722,7 @@ static PHP_METHOD(Phalcon_DI_Service, getParameter){

/* Update the parameter */
if (
phalcon_array_isset_string_fetch(&arguments, definition, SS("arguments"))
phalcon_array_isset_string_fetch(&arguments, definition, SS("arguments"))
&& phalcon_array_isset_fetch(&parameter, arguments, *position)
) {
RETURN_ZVAL(parameter, 1, 0);
Expand All @@ -45744,7 +45744,7 @@ static PHP_METHOD(Phalcon_DI_Service, __set_state){
phalcon_fetch_params(0, 1, 0, &attributes);

if (
!phalcon_array_isset_string_fetch(&name, attributes, SS("_name"))
!phalcon_array_isset_string_fetch(&name, attributes, SS("_name"))
|| !phalcon_array_isset_string_fetch(&definition, attributes, SS("_definition"))
|| !phalcon_array_isset_string_fetch(&shared, attributes, SS("_shared"))
) {
Expand Down
18 changes: 18 additions & 0 deletions ext/db/result/pdo.c
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ PHP_METHOD(Phalcon_Db_Result_Pdo, numRows);
PHP_METHOD(Phalcon_Db_Result_Pdo, dataSeek);
PHP_METHOD(Phalcon_Db_Result_Pdo, setFetchMode);
PHP_METHOD(Phalcon_Db_Result_Pdo, getInternalResult);
PHP_METHOD(Phalcon_Db_Result_Pdo, nextRowset);

ZEND_BEGIN_ARG_INFO_EX(arginfo_phalcon_db_result___construct, 0, 0, 2)
ZEND_ARG_INFO(0, connection)
Expand All @@ -76,6 +77,7 @@ static const zend_function_entry phalcon_db_result_pdo_method_entry[] = {
PHP_ME(Phalcon_Db_Result_Pdo, dataSeek, arginfo_phalcon_db_resultinterface_dataseek, ZEND_ACC_PUBLIC)
PHP_ME(Phalcon_Db_Result_Pdo, setFetchMode, arginfo_phalcon_db_resultinterface_setfetchmode, ZEND_ACC_PUBLIC)
PHP_ME(Phalcon_Db_Result_Pdo, getInternalResult, arginfo_phalcon_db_resultinterface_getinternalresult, ZEND_ACC_PUBLIC)
PHP_ME(Phalcon_Db_Result_Pdo, nextRowset, NULL, ZEND_ACC_PUBLIC)
PHP_FE_END
};

Expand Down Expand Up @@ -469,3 +471,19 @@ PHP_METHOD(Phalcon_Db_Result_Pdo, getInternalResult){
RETURN_MEMBER(this_ptr, "_pdoStatement");
}

/**
* Advances to the next rowset in a multi-rowset statement handle
*
* @return boolean
*/
PHP_METHOD(Phalcon_Db_Result_Pdo, nextRowset){

zval *pdo_statement;

PHALCON_MM_GROW();

pdo_statement = phalcon_fetch_nproperty_this(this_ptr, SL("_pdoStatement"), PH_NOISY TSRMLS_CC);
PHALCON_RETURN_CALL_METHOD(pdo_statement, "nextrowset");

RETURN_MM();
}
4 changes: 2 additions & 2 deletions ext/di/service.c
Original file line number Diff line number Diff line change
Expand Up @@ -520,7 +520,7 @@ PHP_METHOD(Phalcon_DI_Service, getParameter){

/* Update the parameter */
if (
phalcon_array_isset_string_fetch(&arguments, definition, SS("arguments"))
phalcon_array_isset_string_fetch(&arguments, definition, SS("arguments"))
&& phalcon_array_isset_fetch(&parameter, arguments, *position)
) {
RETURN_ZVAL(parameter, 1, 0);
Expand Down Expand Up @@ -553,7 +553,7 @@ PHP_METHOD(Phalcon_DI_Service, __set_state){
phalcon_fetch_params(0, 1, 0, &attributes);

if (
!phalcon_array_isset_string_fetch(&name, attributes, SS("_name"))
!phalcon_array_isset_string_fetch(&name, attributes, SS("_name"))
|| !phalcon_array_isset_string_fetch(&definition, attributes, SS("_definition"))
|| !phalcon_array_isset_string_fetch(&shared, attributes, SS("_shared"))
) {
Expand Down
10 changes: 8 additions & 2 deletions ext/dispatcher.c
Original file line number Diff line number Diff line change
Expand Up @@ -575,6 +575,7 @@ PHP_METHOD(Phalcon_Dispatcher, dispatch){
zval *exception = NULL;
zval *dependency_injector, *events_manager, *tmp;
zval *handler_suffix, *action_suffix, *namespace_name, *handler_name, *action_name;
zval *camelized_namespace = NULL;
int number_dispatches = 0;

PHALCON_MM_GROW();
Expand Down Expand Up @@ -710,7 +711,9 @@ PHP_METHOD(Phalcon_Dispatcher, dispatch){
if (phalcon_end_with_str(namespace_name, SL("\\"))) {
PHALCON_CONCAT_VVV(handler_class, namespace_name, camelized_class, handler_suffix);
} else {
PHALCON_CONCAT_VSVV(handler_class, namespace_name, "\\", camelized_class, handler_suffix);
PHALCON_INIT_VAR(camelized_namespace);
phalcon_camelize(camelized_namespace, namespace_name);
PHALCON_CONCAT_VSVV(handler_class, camelized_namespace, "\\", camelized_class, handler_suffix);
}
} else {
PHALCON_CONCAT_VV(handler_class, camelized_class, handler_suffix);
Expand Down Expand Up @@ -1097,6 +1100,7 @@ PHP_METHOD(Phalcon_Dispatcher, getHandlerClass){

zval *camelized_class = NULL;
zval *handler_suffix, *namespace_name, *handler_name;
zval *camelized_namespace;

PHALCON_MM_GROW();

Expand Down Expand Up @@ -1143,7 +1147,9 @@ PHP_METHOD(Phalcon_Dispatcher, getHandlerClass){
if (phalcon_end_with_str(namespace_name, SL("\\"))) {
PHALCON_CONCAT_VVV(return_value, namespace_name, camelized_class, handler_suffix);
} else {
PHALCON_CONCAT_VSVV(return_value, namespace_name, "\\", camelized_class, handler_suffix);
PHALCON_INIT_VAR(camelized_namespace);
phalcon_camelize(camelized_namespace, namespace_name);
PHALCON_CONCAT_VSVV(return_value, camelized_namespace, "\\", camelized_class, handler_suffix);
}
} else {
PHALCON_CONCAT_VV(return_value, camelized_class, handler_suffix);
Expand Down
31 changes: 29 additions & 2 deletions ext/http/request/file.c
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
#include "http/request/exception.h"

#include <main/SAPI.h>
#include <ext/spl/spl_directory.h>

#include "kernel/main.h"
#include "kernel/memory.h"
Expand Down Expand Up @@ -66,6 +67,7 @@ PHP_METHOD(Phalcon_Http_Request_File, getKey);
PHP_METHOD(Phalcon_Http_Request_File, isUploadedFile);
PHP_METHOD(Phalcon_Http_Request_File, moveTo);
PHP_METHOD(Phalcon_Http_Request_File, __set_state);
PHP_METHOD(Phalcon_Http_Request_File, getExtension);

ZEND_BEGIN_ARG_INFO_EX(arginfo_phalcon_http_request_file___construct, 0, 0, 1)
ZEND_ARG_INFO(0, file)
Expand All @@ -87,6 +89,7 @@ static const zend_function_entry phalcon_http_request_file_method_entry[] = {
PHP_ME(Phalcon_Http_Request_File, isUploadedFile, NULL, ZEND_ACC_PUBLIC)
PHP_ME(Phalcon_Http_Request_File, moveTo, arginfo_phalcon_http_request_fileinterface_moveto, ZEND_ACC_PUBLIC)
PHP_ME(Phalcon_Http_Request_File, __set_state, arginfo_phalcon_http_request_file___set_state, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
PHP_ME(Phalcon_Http_Request_File, getExtension, NULL, ZEND_ACC_PUBLIC)
PHP_FE_END
};

Expand All @@ -95,7 +98,7 @@ static const zend_function_entry phalcon_http_request_file_method_entry[] = {
*/
PHALCON_INIT_CLASS(Phalcon_Http_Request_File){

PHALCON_REGISTER_CLASS(Phalcon\\Http\\Request, File, http_request_file, phalcon_http_request_file_method_entry, 0);
PHALCON_REGISTER_CLASS_EX(Phalcon\\Http\\Request, File, http_request_file, spl_ce_SplFileInfo, phalcon_http_request_file_method_entry, 0);

zend_declare_property_null(phalcon_http_request_file_ce, SL("_name"), ZEND_ACC_PROTECTED TSRMLS_CC);
zend_declare_property_null(phalcon_http_request_file_ce, SL("_tmp"), ZEND_ACC_PROTECTED TSRMLS_CC);
Expand All @@ -104,6 +107,7 @@ PHALCON_INIT_CLASS(Phalcon_Http_Request_File){
zend_declare_property_null(phalcon_http_request_file_ce, SL("_real_type"), ZEND_ACC_PROTECTED TSRMLS_CC);
zend_declare_property_null(phalcon_http_request_file_ce, SL("_error"), ZEND_ACC_PROTECTED TSRMLS_CC);
zend_declare_property_null(phalcon_http_request_file_ce, SL("_key"), ZEND_ACC_PROTECTED TSRMLS_CC);
zend_declare_property_null(phalcon_http_request_file_ce, SL("_extension"), ZEND_ACC_PROTECTED TSRMLS_CC);

zend_class_implements(phalcon_http_request_file_ce TSRMLS_CC, 1, phalcon_http_request_fileinterface_ce);

Expand All @@ -118,6 +122,7 @@ PHALCON_INIT_CLASS(Phalcon_Http_Request_File){
PHP_METHOD(Phalcon_Http_Request_File, __construct){

zval *file, *name, *temp_name, *size, *type, *error, *key = NULL;
zval *constant, *extension = NULL;

PHALCON_MM_GROW();

Expand All @@ -131,13 +136,22 @@ PHP_METHOD(Phalcon_Http_Request_File, __construct){
PHALCON_OBS_VAR(name);
phalcon_array_fetch_string(&name, file, SL("name"), PH_NOISY);
phalcon_update_property_this(this_ptr, SL("_name"), name TSRMLS_CC);

PHALCON_INIT_VAR(constant);
if (zend_get_constant(SL("PATHINFO_EXTENSION"), constant TSRMLS_CC)) {
PHALCON_CALL_FUNCTION(&extension, "pathinfo", name, constant);
phalcon_update_property_this(this_ptr, SL("_extension"), extension TSRMLS_CC);
}
}

if (phalcon_array_isset_string(file, SS("tmp_name"))) {
PHALCON_OBS_VAR(temp_name);
phalcon_array_fetch_string(&temp_name, file, SL("tmp_name"), PH_NOISY);
phalcon_update_property_this(this_ptr, SL("_tmp"), temp_name TSRMLS_CC);
}
} else {
PHALCON_INIT_VAR(temp_name);
ZVAL_NULL(temp_name);
}

if (phalcon_array_isset_string(file, SS("size"))) {
PHALCON_OBS_VAR(size);
Expand All @@ -161,6 +175,8 @@ PHP_METHOD(Phalcon_Http_Request_File, __construct){
phalcon_update_property_this(this_ptr, SL("_key"), key TSRMLS_CC);
}

PHALCON_CALL_PARENT(NULL, phalcon_http_request_file_ce, this_ptr, "__construct", temp_name);

PHALCON_MM_RESTORE();
}

Expand Down Expand Up @@ -319,3 +335,14 @@ PHP_METHOD(Phalcon_Http_Request_File, __set_state) {
PHALCON_CALL_METHOD(NULL, return_value, "__construct", data);
PHALCON_MM_RESTORE();
}

/**
* Returns the file extension
*
* @return string
*/
PHP_METHOD(Phalcon_Http_Request_File, getExtension){


RETURN_MEMBER(this_ptr, "_extension ");
}
Loading

0 comments on commit 7b90cff

Please sign in to comment.