Code Coverage
 
Classes and Traits
Functions and Methods
Lines
Total
0.00%
0 / 1
85.71%
12 / 14
CRAP
85.71%
12 / 14
ExpressionBuilder
0.00%
0 / 1
85.71%
12 / 14
14.57
85.71%
12 / 14
 andX($x = null)
100.00%
1 / 1
1
100.00%
1 / 1
 orX($x = null)
100.00%
1 / 1
1
100.00%
1 / 1
 eq($field, $value)
100.00%
1 / 1
1
100.00%
1 / 1
 gt($field, $value)
100.00%
1 / 1
1
100.00%
1 / 1
 lt($field, $value)
100.00%
1 / 1
1
100.00%
1 / 1
 gte($field, $value)
100.00%
1 / 1
1
100.00%
1 / 1
 lte($field, $value)
100.00%
1 / 1
1
100.00%
1 / 1
 neq($field, $value)
100.00%
1 / 1
1
100.00%
1 / 1
 isNull($field)
100.00%
1 / 1
1
100.00%
1 / 1
 in($field, array $values)
100.00%
1 / 1
1
100.00%
1 / 1
 notIn($field, array $values)
100.00%
1 / 1
1
100.00%
1 / 1
 contains($field, $value)
100.00%
1 / 1
1
100.00%
1 / 1
 startsWith($field, $value)
0.00%
0 / 1
2
0.00%
0 / 1
 endsWith($field, $value)
0.00%
0 / 1
2
0.00%
0 / 1
<?php
// Copyright (c) Lellys Informática. All rights reserved. See License.txt in the project root for license information.
namespace Easy\Collections\Linq;
use Easy\Collections\Linq\Expr\Comparison;
use Easy\Collections\Linq\Expr\CompositeExpression;
use Easy\Collections\Linq\Expr\Value;
/**
 * Builder for Expressions in the {@link Selectable} interface.
 *
 * @author Benjamin Eberlei <kontakt@beberlei.de>
 * @since  2.1
 */
class ExpressionBuilder
{
    /**
     * @param mixed $x
     *
     * @return CompositeExpression
     */
    public function andX($x = null)
    {
        return new CompositeExpression(CompositeExpression::TYPE_AND, func_get_args());
    }
    /**
     * @param mixed $x
     *
     * @return CompositeExpression
     */
    public function orX($x = null)
    {
        return new CompositeExpression(CompositeExpression::TYPE_OR, func_get_args());
    }
    /**
     * @param string $field
     * @param mixed  $value
     *
     * @return Comparison
     */
    public function eq($field, $value)
    {
        return new Comparison($field, Comparison::EQ, new Value($value));
    }
    /**
     * @param string $field
     * @param mixed  $value
     *
     * @return Comparison
     */
    public function gt($field, $value)
    {
        return new Comparison($field, Comparison::GT, new Value($value));
    }
    /**
     * @param string $field
     * @param mixed  $value
     *
     * @return Comparison
     */
    public function lt($field, $value)
    {
        return new Comparison($field, Comparison::LT, new Value($value));
    }
    /**
     * @param string $field
     * @param mixed  $value
     *
     * @return Comparison
     */
    public function gte($field, $value)
    {
        return new Comparison($field, Comparison::GTE, new Value($value));
    }
    /**
     * @param string $field
     * @param mixed  $value
     *
     * @return Comparison
     */
    public function lte($field, $value)
    {
        return new Comparison($field, Comparison::LTE, new Value($value));
    }
    /**
     * @param string $field
     * @param mixed  $value
     *
     * @return Comparison
     */
    public function neq($field, $value)
    {
        return new Comparison($field, Comparison::NEQ, new Value($value));
    }
    /**
     * @param string $field
     *
     * @return Comparison
     */
    public function isNull($field)
    {
        return new Comparison($field, Comparison::EQ, new Value(null));
    }
    /**
     * @param string $field
     * @param mixed  $values
     *
     * @return Comparison
     */
    public function in($field, array $values)
    {
        return new Comparison($field, Comparison::IN, new Value($values));
    }
    /**
     * @param string $field
     * @param mixed  $values
     *
     * @return Comparison
     */
    public function notIn($field, array $values)
    {
        return new Comparison($field, Comparison::NIN, new Value($values));
    }
    /**
     * Returns a value indicating whether a specified substring occurs within this string.
     * 
     * @param string $field
     * @param mixed  $value
     *
     * @return Comparison
     */
    public function contains($field, $value)
    {
        return new Comparison($field, Comparison::CONTAINS, new Value($value));
    }
    /**
     * Determines whether the beginning of this string instance matches a specified string.
     * @param string $field
     * @param mixed  $value
     *
     * @return Comparison
     */
    public function startsWith($field, $value)
    {
        return new Comparison($field, Comparison::STARTS_WITH, new Value($value));
    }
    /**
     * Determines whether the end of this string instance matches a specified string.
     * @param string $field
     * @param mixed  $value
     *
     * @return Comparison
     */
    public function endsWith($field, $value)
    {
        return new Comparison($field, Comparison::ENDS_WITH, new Value($value));
    }
}