NEW Fix incorrect scalar types in doc blocks, add chainable returns in setters

This commit is contained in:
Robbie Averill 2017-08-29 11:40:20 +12:00
parent c09305be9e
commit 0b34066f0c

View File

@ -31,7 +31,7 @@ class DataQuery {
private $queriedColumns = null; private $queriedColumns = null;
/** /**
* @var Boolean * @var boolean
*/ */
private $queryFinalised = false; private $queryFinalised = false;
@ -43,7 +43,7 @@ class DataQuery {
/** /**
* Create a new DataQuery. * Create a new DataQuery.
* *
* @param String The name of the DataObject class that you wish to query * @param string The name of the DataObject class that you wish to query
*/ */
public function __construct($dataClass) { public function __construct($dataClass) {
$this->dataClass = $dataClass; $this->dataClass = $dataClass;
@ -59,6 +59,8 @@ class DataQuery {
/** /**
* Return the {@link DataObject} class that is being queried. * Return the {@link DataObject} class that is being queried.
*
* @return string
*/ */
public function dataClass() { public function dataClass() {
return $this->dataClass; return $this->dataClass;
@ -67,6 +69,8 @@ class DataQuery {
/** /**
* Return the {@link SQLQuery} object that represents the current query; note that it will * Return the {@link SQLQuery} object that represents the current query; note that it will
* be a clone of the object. * be a clone of the object.
*
* @return SQLQuery
*/ */
public function query() { public function query() {
return $this->getFinalisedQuery(); return $this->getFinalisedQuery();
@ -79,7 +83,7 @@ class DataQuery {
* @param string|array $fieldExpression The predicate of the condition to remove * @param string|array $fieldExpression The predicate of the condition to remove
* (ignoring parameters). The expression will be considered a match if it's * (ignoring parameters). The expression will be considered a match if it's
* contained within any other predicate. * contained within any other predicate.
* @return DataQuery Self reference * @return $this
*/ */
public function removeFilterOn($fieldExpression) { public function removeFilterOn($fieldExpression) {
$matched = false; $matched = false;
@ -159,8 +163,13 @@ class DataQuery {
$obj->extend('augmentDataQueryCreation', $this->query, $this); $obj->extend('augmentDataQueryCreation', $this->query, $this);
} }
/**
* @param array $queriedColumns
* @return $this
*/
public function setQueriedColumns($queriedColumns) { public function setQueriedColumns($queriedColumns) {
$this->queriedColumns = $queriedColumns; $this->queriedColumns = $queriedColumns;
return $this;
} }
/** /**
@ -292,6 +301,7 @@ class DataQuery {
* Ensure that if a query has an order by clause, those columns are present in the select. * Ensure that if a query has an order by clause, those columns are present in the select.
* *
* @param SQLQuery $query * @param SQLQuery $query
* @param array $originalSelect
* @return null * @return null
*/ */
protected function ensureSelectContainsOrderbyColumns($query, $originalSelect = array()) { protected function ensureSelectContainsOrderbyColumns($query, $originalSelect = array()) {
@ -361,6 +371,8 @@ class DataQuery {
/** /**
* Execute the query and return the result as {@link Query} object. * Execute the query and return the result as {@link Query} object.
*
* @return SS_Query
*/ */
public function execute() { public function execute() {
return $this->getFinalisedQuery()->execute(); return $this->getFinalisedQuery()->execute();
@ -379,6 +391,8 @@ class DataQuery {
/** /**
* Return the number of records in this query. * Return the number of records in this query.
* Note that this will issue a separate SELECT COUNT() query. * Note that this will issue a separate SELECT COUNT() query.
*
* @return int
*/ */
public function count() { public function count() {
$baseClass = ClassInfo::baseDataClass($this->dataClass); $baseClass = ClassInfo::baseDataClass($this->dataClass);
@ -388,7 +402,7 @@ class DataQuery {
/** /**
* Return the maximum value of the given field in this DataList * Return the maximum value of the given field in this DataList
* *
* @param String $field Unquoted database column name. Will be ANSI quoted * @param string $field Unquoted database column name. Will be ANSI quoted
* automatically so must not contain double quotes. * automatically so must not contain double quotes.
* @return string * @return string
*/ */
@ -403,7 +417,7 @@ class DataQuery {
/** /**
* Return the minimum value of the given field in this DataList * Return the minimum value of the given field in this DataList
* *
* @param String $field Unquoted database column name. Will be ANSI quoted * @param string $field Unquoted database column name. Will be ANSI quoted
* automatically so must not contain double quotes. * automatically so must not contain double quotes.
* @return string * @return string
*/ */
@ -418,7 +432,7 @@ class DataQuery {
/** /**
* Return the average value of the given field in this DataList * Return the average value of the given field in this DataList
* *
* @param String $field Unquoted database column name. Will be ANSI quoted * @param string $field Unquoted database column name. Will be ANSI quoted
* automatically so must not contain double quotes. * automatically so must not contain double quotes.
* @return string * @return string
*/ */
@ -433,7 +447,7 @@ class DataQuery {
/** /**
* Return the sum of the values of the given field in this DataList * Return the sum of the values of the given field in this DataList
* *
* @param String $field Unquoted database column name. Will be ANSI quoted * @param string $field Unquoted database column name. Will be ANSI quoted
* automatically so must not contain double quotes. * automatically so must not contain double quotes.
* @return string * @return string
*/ */
@ -447,6 +461,9 @@ class DataQuery {
/** /**
* Runs a raw aggregate expression. Please handle escaping yourself * Runs a raw aggregate expression. Please handle escaping yourself
*
* @param string $expression
* @return string
*/ */
public function aggregate($expression) { public function aggregate($expression) {
return $this->getFinalisedQuery()->aggregate($expression)->execute()->value(); return $this->getFinalisedQuery()->aggregate($expression)->execute()->value();
@ -455,6 +472,8 @@ class DataQuery {
/** /**
* Return the first row that would be returned by this full DataQuery * Return the first row that would be returned by this full DataQuery
* Note that this will issue a separate SELECT ... LIMIT 1 query. * Note that this will issue a separate SELECT ... LIMIT 1 query.
*
* @return SQLSelect
*/ */
public function firstRow() { public function firstRow() {
return $this->getFinalisedQuery()->firstRow(); return $this->getFinalisedQuery()->firstRow();
@ -463,6 +482,8 @@ class DataQuery {
/** /**
* Return the last row that would be returned by this full DataQuery * Return the last row that would be returned by this full DataQuery
* Note that this will issue a separate SELECT ... LIMIT query. * Note that this will issue a separate SELECT ... LIMIT query.
*
* @return SQLSelect
*/ */
public function lastRow() { public function lastRow() {
return $this->getFinalisedQuery()->lastRow(); return $this->getFinalisedQuery()->lastRow();
@ -470,6 +491,10 @@ class DataQuery {
/** /**
* Update the SELECT clause of the query with the columns from the given table * Update the SELECT clause of the query with the columns from the given table
*
* @param SQLQuery $query
* @param string $tableClass
* @param array $columns
*/ */
protected function selectColumnsFromTable(SQLQuery &$query, $tableClass, $columns = null) { protected function selectColumnsFromTable(SQLQuery &$query, $tableClass, $columns = null) {
// Add SQL for multi-value fields // Add SQL for multi-value fields
@ -498,7 +523,8 @@ class DataQuery {
/** /**
* Append a GROUP BY clause to this query. * Append a GROUP BY clause to this query.
* *
* @param String $groupby Escaped SQL statement * @param string $groupby Escaped SQL statement
* @return $this
*/ */
public function groupby($groupby) { public function groupby($groupby) {
$this->query->addGroupBy($groupby); $this->query->addGroupBy($groupby);
@ -508,7 +534,8 @@ class DataQuery {
/** /**
* Append a HAVING clause to this query. * Append a HAVING clause to this query.
* *
* @param String $having Escaped SQL statement * @param string $having Escaped SQL statement
* @return $this
*/ */
public function having($having) { public function having($having) {
$this->query->addHaving($having); $this->query->addHaving($having);
@ -545,7 +572,7 @@ class DataQuery {
* *
* @param string|array|SQLConditionGroup $filter Predicate(s) to set, as escaped SQL statements or * @param string|array|SQLConditionGroup $filter Predicate(s) to set, as escaped SQL statements or
* paramaterised queries * paramaterised queries
* @return DataQuery * @return $this
*/ */
public function where($filter) { public function where($filter) {
if($filter) { if($filter) {
@ -562,7 +589,7 @@ class DataQuery {
* *
* @param string|array|SQLConditionGroup $filter Predicate(s) to set, as escaped SQL statements or * @param string|array|SQLConditionGroup $filter Predicate(s) to set, as escaped SQL statements or
* paramaterised queries * paramaterised queries
* @return DataQuery * @return $this
*/ */
public function whereAny($filter) { public function whereAny($filter) {
if($filter) { if($filter) {
@ -576,10 +603,10 @@ class DataQuery {
* *
* @see SQLQuery::orderby() * @see SQLQuery::orderby()
* *
* @param String $sort Column to sort on (escaped SQL statement) * @param string $sort Column to sort on (escaped SQL statement)
* @param String $direction Direction ("ASC" or "DESC", escaped SQL statement) * @param string $direction Direction ("ASC" or "DESC", escaped SQL statement)
* @param Boolean $clear Clear existing values * @param boolean $clear Clear existing values
* @return DataQuery * @return $this
*/ */
public function sort($sort = null, $direction = null, $clear = true) { public function sort($sort = null, $direction = null, $clear = true) {
if($clear) { if($clear) {
@ -594,7 +621,7 @@ class DataQuery {
/** /**
* Reverse order by clause * Reverse order by clause
* *
* @return DataQuery * @return $this
*/ */
public function reverseSort() { public function reverseSort() {
$this->query->reverseOrderBy(); $this->query->reverseOrderBy();
@ -616,7 +643,7 @@ class DataQuery {
* Set whether this query should be distinct or not. * Set whether this query should be distinct or not.
* *
* @param bool $value * @param bool $value
* @return DataQuery * @return $this
*/ */
public function distinct($value) { public function distinct($value) {
$this->query->setDistinct($value); $this->query->setDistinct($value);
@ -626,13 +653,14 @@ class DataQuery {
/** /**
* Add an INNER JOIN clause to this query. * Add an INNER JOIN clause to this query.
* *
* @param String $table The unquoted table name to join to. * @param string $table The unquoted table name to join to.
* @param String $onClause The filter for the join (escaped SQL statement) * @param string $onClause The filter for the join (escaped SQL statement)
* @param String $alias An optional alias name (unquoted) * @param string $alias An optional alias name (unquoted)
* @param int $order A numerical index to control the order that joins are added to the query; lower order values * @param int $order A numerical index to control the order that joins are added to the query; lower order values
* will cause the query to appear first. The default is 20, and joins created automatically by the * will cause the query to appear first. The default is 20, and joins created automatically by the
* ORM have a value of 10. * ORM have a value of 10.
* @param array $parameters Any additional parameters if the join is a parameterised subquery * @param array $parameters Any additional parameters if the join is a parameterised subquery
* @return $this
*/ */
public function innerJoin($table, $onClause, $alias = null, $order = 20, $parameters = array()) { public function innerJoin($table, $onClause, $alias = null, $order = 20, $parameters = array()) {
if($table) { if($table) {
@ -651,6 +679,7 @@ class DataQuery {
* will cause the query to appear first. The default is 20, and joins created automatically by the * will cause the query to appear first. The default is 20, and joins created automatically by the
* ORM have a value of 10. * ORM have a value of 10.
* @param array $parameters Any additional parameters if the join is a parameterised subquery * @param array $parameters Any additional parameters if the join is a parameterised subquery
* @return $this
*/ */
public function leftJoin($table, $onClause, $alias = null, $order = 20, $parameters = array()) { public function leftJoin($table, $onClause, $alias = null, $order = 20, $parameters = array()) {
if($table) { if($table) {
@ -664,8 +693,8 @@ class DataQuery {
* mappings to the query object state. This has to be called * mappings to the query object state. This has to be called
* in any overloaded {@link SearchFilter->apply()} methods manually. * in any overloaded {@link SearchFilter->apply()} methods manually.
* *
* @param String|array $relation The array/dot-syntax relation to follow * @param string|array $relation The array/dot-syntax relation to follow
* @return The model class of the related item * @return string The model class of the related item
*/ */
public function applyRelation($relation) { public function applyRelation($relation) {
// NO-OP // NO-OP
@ -749,6 +778,7 @@ class DataQuery {
* *
* @param DataQuery $subtractQuery * @param DataQuery $subtractQuery
* @param string $field * @param string $field
* @return $this
*/ */
public function subtract(DataQuery $subtractQuery, $field='ID') { public function subtract(DataQuery $subtractQuery, $field='ID') {
$fieldExpression = $subtractQuery->expressionForField($field); $fieldExpression = $subtractQuery->expressionForField($field);
@ -765,8 +795,9 @@ class DataQuery {
/** /**
* Select only the given fields from the given table. * Select only the given fields from the given table.
* *
* @param String $table Unquoted table name (will be escaped automatically) * @param string $table Unquoted table name (will be escaped automatically)
* @param Array $fields Database column names (will be escaped automatically) * @param array $fields Database column names (will be escaped automatically)
* @return $this
*/ */
public function selectFromTable($table, $fields) { public function selectFromTable($table, $fields) {
$fieldExpressions = array_map(function($item) use($table) { $fieldExpressions = array_map(function($item) use($table) {
@ -781,8 +812,9 @@ class DataQuery {
/** /**
* Add the given fields from the given table to the select statement. * Add the given fields from the given table to the select statement.
* *
* @param String $table Unquoted table name (will be escaped automatically) * @param string $table Unquoted table name (will be escaped automatically)
* @param Array $fields Database column names (will be escaped automatically) * @param array $fields Database column names (will be escaped automatically)
* @return $this
*/ */
public function addSelectFromTable($table, $fields) { public function addSelectFromTable($table, $fields) {
$fieldExpressions = array_map(function($item) use($table) { $fieldExpressions = array_map(function($item) use($table) {
@ -812,9 +844,9 @@ class DataQuery {
} }
/** /**
* @param String $field Select statement identifier, either the unquoted column name, * @param string $field Select statement identifier, either the unquoted column name,
* the full composite SQL statement, or the alias set through {@link SQLQuery->selectField()}. * the full composite SQL statement, or the alias set through {@link SQLQuery->selectField()}.
* @return String The expression used to query this field via this DataQuery * @return string|null The expression used to query this field via this DataQuery
*/ */
protected function expressionForField($field) { protected function expressionForField($field) {
@ -835,8 +867,9 @@ class DataQuery {
/** /**
* Select the given field expressions. * Select the given field expressions.
* *
* @param $fieldExpression String The field to select (escaped SQL statement) * @param string $fieldExpression The field to select (escaped SQL statement)
* @param $alias String The alias of that field (escaped SQL statement) * @param string $alias The alias of that field (escaped SQL statement)
*
*/ */
protected function selectField($fieldExpression, $alias = null) { protected function selectField($fieldExpression, $alias = null) {
$this->query->selectField($fieldExpression, $alias); $this->query->selectField($fieldExpression, $alias);
@ -853,13 +886,21 @@ class DataQuery {
/** /**
* Set an arbitrary query parameter, that can be used by decorators to add additional meta-data to the query. * Set an arbitrary query parameter, that can be used by decorators to add additional meta-data to the query.
* It's expected that the $key will be namespaced, e.g, 'Versioned.stage' instead of just 'stage'. * It's expected that the $key will be namespaced, e.g, 'Versioned.stage' instead of just 'stage'.
*
* @param string $key
* @param mixed $value
* @return $this
*/ */
public function setQueryParam($key, $value) { public function setQueryParam($key, $value) {
$this->queryParams[$key] = $value; $this->queryParams[$key] = $value;
return $this;
} }
/** /**
* Set an arbitrary query parameter, that can be used by decorators to add additional meta-data to the query. * Set an arbitrary query parameter, that can be used by decorators to add additional meta-data to the query.
*
* @param string $key
* @return mixed
*/ */
public function getQueryParam($key) { public function getQueryParam($key) {
if(isset($this->queryParams[$key])) return $this->queryParams[$key]; if(isset($this->queryParams[$key])) return $this->queryParams[$key];