HTML_QuickForm2
[ class tree: HTML_QuickForm2 ] [ index: HTML_QuickForm2 ] [ all elements ]

Source for file Regex.php

Documentation is available at Regex.php

  1. <?php
  2. /**
  3.  * Validates values using regular expressions
  4.  *
  5.  * PHP version 5
  6.  *
  7.  * LICENSE:
  8.  *
  9.  * Copyright (c) 2006, 2007, Alexey Borzov <avb@php.net>,
  10.  *                           Bertrand Mansion <golgote@mamasam.com>
  11.  * All rights reserved.
  12.  *
  13.  * Redistribution and use in source and binary forms, with or without
  14.  * modification, are permitted provided that the following conditions
  15.  * are met:
  16.  *
  17.  *    * Redistributions of source code must retain the above copyright
  18.  *      notice, this list of conditions and the following disclaimer.
  19.  *    * Redistributions in binary form must reproduce the above copyright
  20.  *      notice, this list of conditions and the following disclaimer in the
  21.  *      documentation and/or other materials provided with the distribution.
  22.  *    * The names of the authors may not be used to endorse or promote products
  23.  *      derived from this software without specific prior written permission.
  24.  *
  25.  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
  26.  * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
  27.  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  28.  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
  29.  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  30.  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  31.  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  32.  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
  33.  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
  34.  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  35.  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  36.  *
  37.  * @category   HTML
  38.  * @package    HTML_QuickForm2
  39.  * @author     Alexey Borzov <avb@php.net>
  40.  * @author     Bertrand Mansion <golgote@mamasam.com>
  41.  * @license    http://opensource.org/licenses/bsd-license.php New BSD License
  42.  * @version    CVS: $Id: Regex.php,v 1.3 2007/10/13 16:18:22 avb Exp $
  43.  * @link       http://pear.php.net/package/HTML_QuickForm2
  44.  */
  45.  
  46. /**
  47.  * Base class for HTML_QuickForm2 rules
  48.  */
  49. require_once 'HTML/QuickForm2/Rule.php';
  50.  
  51. /**
  52.  * Validates values using regular expressions
  53.  *
  54.  * The Rule needs one configuration parameter for its work: a Perl-compatible
  55.  * regular expression. This expression can be passed either to
  56.  * {@link HTML_QuickForm2_Rule::setOptions() setOptions()} or to
  57.  * {@link HTML_QuickForm2_Factory::registerRule()}. Regular expression
  58.  * registered with the Factory overrides one set for the particular Rule
  59.  * instance via setOptions().
  60.  *  
  61.  * The Rule can also validate file uploads, in this case the regular expression
  62.  * is applied to upload's 'name' field.
  63.  *
  64.  * The Rule considers empty fields (file upload fields with UPLOAD_ERR_NO_FILE)
  65.  * as valid and doesn't try to test them with the regular expression.
  66.  * 
  67.  * @category   HTML
  68.  * @package    HTML_QuickForm2
  69.  * @author     Alexey Borzov <avb@php.net>
  70.  * @author     Bertrand Mansion <golgote@mamasam.com>
  71.  * @version    Release: 0.2.0
  72.  */
  73. {
  74.    /**
  75.     * Validates the element's value
  76.     * 
  77.     * @return   bool    whether element's value matches given regular expression
  78.     * @throws   HTML_QuickForm2_InvalidArgumentException if a bogus $registeredType
  79.     *            was passed to constructor
  80.     * @throws   HTML_QuickForm2_Exception if regular expression is missing
  81.     */
  82.     protected function checkValue($value)
  83.     {
  84.         if (!empty($this->registeredType)) {
  85.             $regex HTML_QuickForm2_Factory::getRuleConfig($this->registeredType);
  86.         else {
  87.             $regex = null;
  88.         }
  89.         if (null === $regex{
  90.             $regex $this->getOptions();
  91.         }
  92.         if (!is_string($regex)) {
  93.             throw new HTML_QuickForm2_Exception(
  94.                 'Regex Rule requires a regular expression, ' .
  95.                 preg_replace('/\s+/'' 'var_export($regextrue)) ' given'
  96.             );
  97.         }
  98.  
  99.         if ($this->owner instanceof HTML_QuickForm2_Element_InputFile{
  100.             if (!isset($value['error']|| UPLOAD_ERR_NO_FILE == $value['error']{
  101.                 return true;
  102.             }
  103.             $value $value['name'];
  104.         elseif (!strlen($value)) {
  105.             return true;
  106.         }
  107.         return preg_match($regex 'D'$value);
  108.     }
  109. }
  110. ?>

Documentation generated on Mon, 22 Oct 2007 12:30:22 -0400 by phpDocumentor 1.4.0. PEAR Logo Copyright © PHP Group 2004.