| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122 | <?php/** * PHPExcel * * Copyright (c) 2006 - 2014 PHPExcel * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA * * @category   PHPExcel * @package    PHPExcel_Cell * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt    LGPL * @version    1.8.0, 2014-03-02 *//** * PHPExcel_Cell_DataType * * @category   PHPExcel * @package    PHPExcel_Cell * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) */class PHPExcel_Cell_DataType{    /* Data types */    const TYPE_STRING2  = 'str';    const TYPE_STRING   = 's';    const TYPE_FORMULA  = 'f';    const TYPE_NUMERIC  = 'n';    const TYPE_BOOL     = 'b';    const TYPE_NULL     = 'null';    const TYPE_INLINE   = 'inlineStr';    const TYPE_ERROR    = 'e';    /**     * List of error codes     *     * @var array     */    private static $_errorCodes = array(        '#NULL!'  => 0,        '#DIV/0!' => 1,        '#VALUE!' => 2,        '#REF!'   => 3,        '#NAME?'  => 4,        '#NUM!'   => 5,        '#N/A'    => 6    );    /**     * Get list of error codes     *     * @return array     */    public static function getErrorCodes() {        return self::$_errorCodes;    }    /**     * DataType for value     *     * @deprecated  Replaced by PHPExcel_Cell_IValueBinder infrastructure, will be removed in version 1.8.0     * @param       mixed  $pValue     * @return      string     */    public static function dataTypeForValue($pValue = null) {        return PHPExcel_Cell_DefaultValueBinder::dataTypeForValue($pValue);    }    /**     * Check a string that it satisfies Excel requirements     *     * @param  mixed  Value to sanitize to an Excel string     * @return mixed  Sanitized value     */    public static function checkString($pValue = null)    {        if ($pValue instanceof PHPExcel_RichText) {            // TODO: Sanitize Rich-Text string (max. character count is 32,767)            return $pValue;        }        // string must never be longer than 32,767 characters, truncate if necessary        $pValue = PHPExcel_Shared_String::Substring($pValue, 0, 32767);        // we require that newline is represented as "\n" in core, not as "\r\n" or "\r"        $pValue = str_replace(array("\r\n", "\r"), "\n", $pValue);        return $pValue;    }    /**     * Check a value that it is a valid error code     *     * @param  mixed   Value to sanitize to an Excel error code     * @return string  Sanitized value     */    public static function checkErrorCode($pValue = null)    {        $pValue = (string) $pValue;        if ( !array_key_exists($pValue, self::$_errorCodes) ) {            $pValue = '#NULL!';        }        return $pValue;    }}
 |