mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-05-10 12:32:14 +09:00
Query cache file - added condition to skip null arguments that do not need validation and are not mandatory.
git-svn-id: http://xe-core.googlecode.com/svn/branches/1.5.0@9066 201d5d3c-b55e-5fd7-737f-ddc643e51545
This commit is contained in:
parent
34246aa267
commit
33df36e715
12 changed files with 148 additions and 116 deletions
|
|
@ -11,7 +11,6 @@
|
||||||
var $_show;
|
var $_show;
|
||||||
var $_value_to_string;
|
var $_value_to_string;
|
||||||
|
|
||||||
|
|
||||||
function Condition($column_name, $argument, $operation, $pipe){
|
function Condition($column_name, $argument, $operation, $pipe){
|
||||||
$this->column_name = $column_name;
|
$this->column_name = $column_name;
|
||||||
$this->argument = $argument;
|
$this->argument = $argument;
|
||||||
|
|
|
||||||
|
|
@ -3,31 +3,38 @@
|
||||||
class ConditionWithArgument extends Condition {
|
class ConditionWithArgument extends Condition {
|
||||||
|
|
||||||
function ConditionWithArgument($column_name, $argument, $operation, $pipe = ""){
|
function ConditionWithArgument($column_name, $argument, $operation, $pipe = ""){
|
||||||
|
if($argument === null) { $this->_show = false; return; }
|
||||||
parent::Condition($column_name, $argument, $operation, $pipe);
|
parent::Condition($column_name, $argument, $operation, $pipe);
|
||||||
$this->_value = $argument->getValue();
|
$this->_value = $argument->getValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
function getArgument(){
|
function getArgument(){
|
||||||
return $this->argument;
|
if(!$this->show()) return;
|
||||||
|
return $this->argument;
|
||||||
}
|
}
|
||||||
|
|
||||||
function toStringWithoutValue(){
|
function toStringWithoutValue(){
|
||||||
$value = $this->argument->getUnescapedValue();
|
$value = $this->argument->getUnescapedValue();
|
||||||
|
|
||||||
if(is_array($value)){
|
if(is_array($value)){
|
||||||
$q = '';
|
$q = '';
|
||||||
foreach ($value as $v) $q .= '?,';
|
foreach ($value as $v) $q .= '?,';
|
||||||
if($q !== '') $q = substr($q, 0, -1);
|
if($q !== '') $q = substr($q, 0, -1);
|
||||||
$q = '(' . $q . ')';
|
$q = '(' . $q . ')';
|
||||||
}
|
}
|
||||||
else $q = '?';
|
else $q = '?';
|
||||||
return $this->pipe . ' ' . $this->getConditionPart($q);
|
return $this->pipe . ' ' . $this->getConditionPart($q);
|
||||||
}
|
}
|
||||||
|
|
||||||
function show(){
|
function show(){
|
||||||
if(!$this->argument->isValid()) return false;
|
if(!isset($this->_show)){
|
||||||
if($this->_value === '\'\'') return false;
|
if(!$this->argument->isValid()) $this->_show = false;
|
||||||
return parent::show();
|
if($this->_value === '\'\'') $this->_show = false;
|
||||||
|
if(!isset($this->_show)){
|
||||||
|
return parent::show();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $this->_show;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -44,50 +44,41 @@
|
||||||
|
|
||||||
|
|
||||||
class XmlQueryParser extends XmlParser {
|
class XmlQueryParser extends XmlParser {
|
||||||
static $dbParser = null;
|
|
||||||
var $db_type;
|
|
||||||
|
|
||||||
function XmlQueryParser($db_type = NULL){
|
function XmlQueryParser(){
|
||||||
$this->db_type = $db_type;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function &getInstance($db_type = NULL){
|
function &getInstance(){
|
||||||
static $theInstance = null;
|
static $theInstance = null;
|
||||||
if(!isset($theInstance)){
|
if(!isset($theInstance)){
|
||||||
$theInstance = new XmlQueryParser($db_type);
|
$theInstance = new XmlQueryParser();
|
||||||
}
|
}
|
||||||
return $theInstance;
|
return $theInstance;
|
||||||
}
|
}
|
||||||
|
|
||||||
function parse($query_id, $xml_file, $cache_file) {
|
function parse($query_id, $xml_file, $cache_file) {
|
||||||
|
|
||||||
// Read xml file
|
// Read xml file
|
||||||
$xml_obj = $this->getXmlFileContent($xml_file);
|
$xml_obj = $this->getXmlFileContent($xml_file);
|
||||||
|
|
||||||
// insert, update, delete, select action
|
// insert, update, delete, select action
|
||||||
$action = strtolower($xml_obj->query->attrs->action);
|
$action = strtolower($xml_obj->query->attrs->action);
|
||||||
if(!$action) return;
|
if(!$action) return;
|
||||||
|
|
||||||
$parser = new QueryParser($xml_obj->query);
|
$parser = new QueryParser($xml_obj->query);
|
||||||
|
|
||||||
FileHandler::writeFile($cache_file, $parser->toString());
|
FileHandler::writeFile($cache_file, $parser->toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
// singleton
|
// singleton
|
||||||
function &getDBParser(){
|
function &getDBParser($force = false){
|
||||||
if(!$self->dbParser){
|
static $dbParser = null;
|
||||||
is_a($this,'XmlQueryParser')?$self=&$this:$self=&XmlQueryParser::getInstance();
|
if(!$dbParser || $force) {
|
||||||
if(isset($self->db_type))
|
$oDB = &DB::getInstance();
|
||||||
$oDB = &DB::getInstance($self->db_type);
|
$dbParser = $oDB->getParser();
|
||||||
else
|
}
|
||||||
$oDB = &DB::getInstance();
|
|
||||||
$self->dbParser = $oDB->getParser();
|
|
||||||
}
|
|
||||||
return $self->dbParser;
|
|
||||||
}
|
|
||||||
|
|
||||||
function setDBParser($value){
|
return $dbParser;
|
||||||
$self->dbParser = $value;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function getXmlFileContent($xml_file){
|
function getXmlFileContent($xml_file){
|
||||||
|
|
|
||||||
|
|
@ -51,35 +51,58 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
function toString(){
|
function toString(){
|
||||||
if($this->isConditionArgument())
|
if($this->argument_validator->hasOnlyDefaultValue()){
|
||||||
$arg = sprintf("\n$%s_argument = new ConditionArgument('%s', %s, '%s');\n"
|
return sprintf("\n$%s_argument = %s;\n"
|
||||||
, $this->argument_name
|
, $this->argument_name
|
||||||
, $this->argument_name
|
, $this->argument_validator->getDefaultValueString()
|
||||||
, '$args->'.$this->variable_name
|
|
||||||
, $this->operation
|
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
else
|
if($this->isConditionArgument()){
|
||||||
$arg = sprintf("\n$%s_argument = new Argument('%s', %s);\n"
|
// Instantiation
|
||||||
, $this->argument_name
|
$arg = sprintf("\n$%s_argument = new ConditionArgument('%s', %s, '%s');\n"
|
||||||
, $this->argument_name
|
, $this->argument_name
|
||||||
, '$args->'.$this->variable_name);
|
, $this->argument_name
|
||||||
|
, '$args->'.$this->variable_name
|
||||||
|
, $this->operation
|
||||||
|
);
|
||||||
|
// Call methods to validate argument and ensure default value
|
||||||
|
$arg .= $this->argument_validator->toString();
|
||||||
|
|
||||||
|
// Prepare condition string
|
||||||
|
$arg .= sprintf("$%s_argument->createConditionValue();\n"
|
||||||
|
, $this->argument_name
|
||||||
|
);
|
||||||
|
|
||||||
$arg .= $this->argument_validator->toString();
|
// Check that argument passed validation, else return
|
||||||
|
$arg .= sprintf("if(!$%s_argument->isValid()) return $%s_argument->getErrorMessage();\n"
|
||||||
|
, $this->argument_name
|
||||||
|
, $this->argument_name
|
||||||
|
);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$arg = sprintf("\n$%s_argument = new Argument('%s', %s);\n"
|
||||||
|
, $this->argument_name
|
||||||
|
, $this->argument_name
|
||||||
|
, '$args->'.$this->variable_name);
|
||||||
|
|
||||||
if($this->isConditionArgument()){
|
$arg .= $this->argument_validator->toString();
|
||||||
$arg .= sprintf("$%s_argument->createConditionValue();\n"
|
|
||||||
, $this->argument_name
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
$arg .= sprintf("if(!$%s_argument->isValid()) return $%s_argument->getErrorMessage();\n"
|
$arg .= sprintf("if(!$%s_argument->isValid()) return $%s_argument->getErrorMessage();\n"
|
||||||
, $this->argument_name
|
, $this->argument_name
|
||||||
, $this->argument_name
|
, $this->argument_name
|
||||||
);
|
);
|
||||||
return $arg;
|
}
|
||||||
}
|
|
||||||
|
// If the argument is null, skip it
|
||||||
|
if($this->argument_validator->isIgnorable()){
|
||||||
|
$arg = sprintf("if(isset(%s)) {", '$args->'.$this->variable_name)
|
||||||
|
. $arg
|
||||||
|
. sprintf("} else \n$%s_argument = null;", $this->argument_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $arg;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -22,10 +22,15 @@
|
||||||
$this->max_length = $tag->attrs->max_length;
|
$this->max_length = $tag->attrs->max_length;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function isIgnorable(){
|
||||||
|
if(isset($this->default_value) || isset($this->notnull)) return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
function toString(){
|
function toString(){
|
||||||
$validator = '';
|
$validator = '';
|
||||||
if(isset($this->default_value)){
|
if(isset($this->default_value)){
|
||||||
$this->default_value = new DefaultValue($this->argument_name, $this->default_value);
|
$this->default_value = new DefaultValue($this->argument_name, $this->default_value);
|
||||||
if($this->default_value->isSequence())
|
if($this->default_value->isSequence())
|
||||||
$validator .= '$db = &DB::getInstance(); $sequence = $db->getNextSequence(); ';
|
$validator .= '$db = &DB::getInstance(); $sequence = $db->getNextSequence(); ';
|
||||||
if($this->default_value->isOperation())
|
if($this->default_value->isOperation())
|
||||||
|
|
@ -33,10 +38,10 @@
|
||||||
, $this->argument_name
|
, $this->argument_name
|
||||||
, $this->default_value->getOperation()
|
, $this->default_value->getOperation()
|
||||||
);
|
);
|
||||||
$validator .= sprintf("$%s_argument->ensureDefaultValue(%s);\n"
|
$validator .= sprintf("$%s_argument->ensureDefaultValue(%s);\n"
|
||||||
, $this->argument_name
|
, $this->argument_name
|
||||||
, $this->default_value->toString()
|
, $this->default_value->toString()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if($this->notnull){
|
if($this->notnull){
|
||||||
$validator .= sprintf("$%s_argument->checkNotNull();\n"
|
$validator .= sprintf("$%s_argument->checkNotNull();\n"
|
||||||
|
|
|
||||||
|
|
@ -84,14 +84,18 @@ class QueryTag {
|
||||||
|
|
||||||
$prebuff = '';
|
$prebuff = '';
|
||||||
foreach($arguments as $argument){
|
foreach($arguments as $argument){
|
||||||
if(isset($argument) && $argument->getArgumentName()){
|
if(isset($argument)){
|
||||||
$prebuff .= $argument->toString();
|
$arg_name = $argument->getArgumentName();
|
||||||
$column_type = $this->column_type[$this->getQueryId()][$argument->getColumnName()];
|
if($arg_name){
|
||||||
if(isset($column_type))
|
$prebuff .= $argument->toString();
|
||||||
$prebuff .= sprintf("$%s_argument->setColumnType('%s');\n"
|
$column_type = $this->column_type[$this->getQueryId()][$argument->getColumnName()];
|
||||||
, $argument->getArgumentName()
|
if(isset($column_type))
|
||||||
, $column_type );
|
$prebuff .= sprintf("if($%s_argument !== null) $%s_argument->setColumnType('%s');\n"
|
||||||
}
|
, $arg_name
|
||||||
|
, $arg_name
|
||||||
|
, $column_type );
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
$prebuff .= "\n";
|
$prebuff .= "\n";
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -34,6 +34,8 @@
|
||||||
|
|
||||||
// remove cache dir
|
// remove cache dir
|
||||||
FileHandler::removeDir( _XE_PATH_ . 'files/cache');
|
FileHandler::removeDir( _XE_PATH_ . 'files/cache');
|
||||||
|
|
||||||
|
XmlQueryParser::getDBParser(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -41,7 +43,6 @@
|
||||||
*/
|
*/
|
||||||
protected function tearDown() {
|
protected function tearDown() {
|
||||||
unset($GLOBALS['__DB__']);
|
unset($GLOBALS['__DB__']);
|
||||||
XmlQueryParser::setDBParser(null);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
|
|
|
||||||
|
|
@ -16,6 +16,7 @@
|
||||||
$db_info->slave_db = array(array('db_type' => 'cubrid','db_table_prefix' => 'xe_'));
|
$db_info->slave_db = array(array('db_type' => 'cubrid','db_table_prefix' => 'xe_'));
|
||||||
|
|
||||||
$oContext->setDbInfo($db_info);
|
$oContext->setDbInfo($db_info);
|
||||||
|
XmlQueryParser::getDBParser(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -23,7 +24,6 @@
|
||||||
*/
|
*/
|
||||||
protected function tearDown() {
|
protected function tearDown() {
|
||||||
unset($GLOBALS['__DB__']);
|
unset($GLOBALS['__DB__']);
|
||||||
XmlQueryParser::setDBParser(null);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
|
|
|
||||||
|
|
@ -34,6 +34,8 @@
|
||||||
|
|
||||||
// remove cache dir
|
// remove cache dir
|
||||||
FileHandler::removeDir( _XE_PATH_ . 'files/cache');
|
FileHandler::removeDir( _XE_PATH_ . 'files/cache');
|
||||||
|
|
||||||
|
XmlQueryParser::getDBParser(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -41,7 +43,6 @@
|
||||||
*/
|
*/
|
||||||
protected function tearDown() {
|
protected function tearDown() {
|
||||||
unset($GLOBALS['__DB__']);
|
unset($GLOBALS['__DB__']);
|
||||||
XmlQueryParser::setDBParser(null);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
|
|
|
||||||
|
|
@ -14,11 +14,12 @@
|
||||||
$db_info->slave_db = array(array('db_type' => 'mssql','db_table_prefix' => 'xe_'));
|
$db_info->slave_db = array(array('db_type' => 'mssql','db_table_prefix' => 'xe_'));
|
||||||
|
|
||||||
$oContext->setDbInfo($db_info);
|
$oContext->setDbInfo($db_info);
|
||||||
|
|
||||||
|
XmlQueryParser::getDBParser(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function tearDown() {
|
protected function tearDown() {
|
||||||
unset($GLOBALS['__DB__']);
|
unset($GLOBALS['__DB__']);
|
||||||
XmlQueryParser::setDBParser(null);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
|
|
|
||||||
|
|
@ -14,7 +14,7 @@
|
||||||
$this->_test($xml_file, $argsString, $expected);
|
$this->_test($xml_file, $argsString, $expected);
|
||||||
}
|
}
|
||||||
|
|
||||||
function testRquiredParameter(){
|
function testRequiredParameter(){
|
||||||
$xml_file = _XE_PATH_ . "modules/module/queries/getAdminId.xml";
|
$xml_file = _XE_PATH_ . "modules/module/queries/getAdminId.xml";
|
||||||
$argsString = '';
|
$argsString = '';
|
||||||
$expected = 'Date incorecte! Query-ul nu a putut fi executat.';
|
$expected = 'Date incorecte! Query-ul nu a putut fi executat.';
|
||||||
|
|
|
||||||
|
|
@ -14,7 +14,7 @@
|
||||||
$this->_test($xml_file, $argsString, $expected, array(10));
|
$this->_test($xml_file, $argsString, $expected, array(10));
|
||||||
}
|
}
|
||||||
|
|
||||||
function testRquiredParameter(){
|
function testRequiredParameter(){
|
||||||
$xml_file = _XE_PATH_ . "modules/module/queries/getAdminId.xml";
|
$xml_file = _XE_PATH_ . "modules/module/queries/getAdminId.xml";
|
||||||
$argsString = '';
|
$argsString = '';
|
||||||
$expected = 'Date incorecte! Query-ul nu a putut fi executat.';
|
$expected = 'Date incorecte! Query-ul nu a putut fi executat.';
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue