115 lines
31 KiB
HTML
115 lines
31 KiB
HTML
|
|
<div id="content">
|
|
<h1 align="center">Source for file Exception.php</h1>
|
|
<p>Documentation is available at <a href="../Doctrine/_Doctrine---Connection---Pgsql---Exception.php.html">Exception.php</a></p>
|
|
<div class="src-code"><span class="php">
|
|
<ol><li><div class="src-line"><a name="a1"></a><span class="src-php"><?php</span></div></li>
|
|
<li><div class="src-line"><a name="a2"></a><span class="src-comm">/*</span></div></li>
|
|
<li><div class="src-line"><a name="a3"></a><span class="src-comm"> * $Id: Exception.php 1080 2007-02-10 18:17:08Z romanb $</span></div></li>
|
|
<li><div class="src-line"><a name="a4"></a><span class="src-comm"> *</span></div></li>
|
|
<li><div class="src-line"><a name="a5"></a><span class="src-comm"> * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS</span></div></li>
|
|
<li><div class="src-line"><a name="a6"></a><span class="src-comm"> * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT</span></div></li>
|
|
<li><div class="src-line"><a name="a7"></a><span class="src-comm"> * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR</span></div></li>
|
|
<li><div class="src-line"><a name="a8"></a><span class="src-comm"> * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT</span></div></li>
|
|
<li><div class="src-line"><a name="a9"></a><span class="src-comm"> * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,</span></div></li>
|
|
<li><div class="src-line"><a name="a10"></a><span class="src-comm"> * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT</span></div></li>
|
|
<li><div class="src-line"><a name="a11"></a><span class="src-comm"> * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,</span></div></li>
|
|
<li><div class="src-line"><a name="a12"></a><span class="src-comm"> * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY</span></div></li>
|
|
<li><div class="src-line"><a name="a13"></a><span class="src-comm"> * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT</span></div></li>
|
|
<li><div class="src-line"><a name="a14"></a><span class="src-comm"> * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE</span></div></li>
|
|
<li><div class="src-line"><a name="a15"></a><span class="src-comm"> * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.</span></div></li>
|
|
<li><div class="src-line"><a name="a16"></a><span class="src-comm"> *</span></div></li>
|
|
<li><div class="src-line"><a name="a17"></a><span class="src-comm"> * This software consists of voluntary contributions made by many individuals</span></div></li>
|
|
<li><div class="src-line"><a name="a18"></a><span class="src-comm"> * and is licensed under the LGPL. For more information, see</span></div></li>
|
|
<li><div class="src-line"><a name="a19"></a><span class="src-comm"> * <http://www.phpdoctrine.com>.</span></div></li>
|
|
<li><div class="src-line"><a name="a20"></a><span class="src-comm"> */</span></div></li>
|
|
<li><div class="src-line"><a name="a21"></a><span class="src-id"><a href="../Doctrine/Doctrine.html">Doctrine</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine.html#methodautoload">autoload</a><span class="src-sym">(</span><span class="src-str">'Doctrine_Connection_Exception'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a22"></a><span class="src-doc">/**</span></div></li>
|
|
<li><div class="src-line"><a name="a23"></a><span class="src-doc"> * Doctrine_Connection_Pgsql_Exception</span></div></li>
|
|
<li><div class="src-line"><a name="a24"></a><span class="src-doc"> *</span></div></li>
|
|
<li><div class="src-line"><a name="a25"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@package</span><span class="src-doc"> Doctrine</span></div></li>
|
|
<li><div class="src-line"><a name="a26"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@category</span><span class="src-doc"> Object Relational Mapping</span></div></li>
|
|
<li><div class="src-line"><a name="a27"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@license</span><span class="src-doc"> http://www.opensource.org/licenses/lgpl-license.php LGPL</span></div></li>
|
|
<li><div class="src-line"><a name="a28"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@link</span><span class="src-doc"> www.phpdoctrine.com</span></div></li>
|
|
<li><div class="src-line"><a name="a29"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@author</span><span class="src-doc"> Konsta Vesterinen <kvesteri@cc.hut.fi></span></div></li>
|
|
<li><div class="src-line"><a name="a30"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@author</span><span class="src-doc"> Paul Cooper <pgc@ucecom.com> (PEAR MDB2 Pgsql driver)</span></div></li>
|
|
<li><div class="src-line"><a name="a31"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@author</span><span class="src-doc"> Lukas Smith <smith@pooteeweet.org> (PEAR MDB2 library)</span></div></li>
|
|
<li><div class="src-line"><a name="a32"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@since</span><span class="src-doc"> 1.0</span></div></li>
|
|
<li><div class="src-line"><a name="a33"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@version</span><span class="src-doc"> $Revision: 1080 $</span></div></li>
|
|
<li><div class="src-line"><a name="a34"></a><span class="src-doc"> */</span></div></li>
|
|
<li><div class="src-line"><a name="a35"></a><span class="src-key">class </span><a href="../Doctrine/Doctrine_Connection_Pgsql_Exception.html">Doctrine_Connection_Pgsql_Exception</a> <span class="src-key">extends </span><a href="../Doctrine/Doctrine_Connection_Exception.html">Doctrine_Connection_Exception</a></div></li>
|
|
<li><div class="src-line"><a name="a36"></a><span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a37"></a> <span class="src-doc">/**</span></div></li>
|
|
<li><div class="src-line"><a name="a38"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@var </span><span class="src-doc-type">array </span><span class="src-doc-var">$errorRegexps </span><span class="src-doc"> an array that is used for determining portable</span></div></li>
|
|
<li><div class="src-line"><a name="a39"></a><span class="src-doc"> * error code from a native database error message</span></div></li>
|
|
<li><div class="src-line"><a name="a40"></a><span class="src-doc"> */</span></div></li>
|
|
<li><div class="src-line"><a name="a41"></a> <span class="src-key">protected </span><span class="src-key">static </span><span class="src-var">$errorRegexps </span>= <span class="src-key">array</span><span class="src-sym">(</span></div></li>
|
|
<li><div class="src-line"><a name="a42"></a> <span class="src-str">'/parser: parse error at or near/i'</span></div></li>
|
|
<li><div class="src-line"><a name="a43"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_SYNTAX</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a44"></a> <span class="src-str">'/syntax error at/'</span></div></li>
|
|
<li><div class="src-line"><a name="a45"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_SYNTAX</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a46"></a> <span class="src-str">'/column reference .* is ambiguous/i'</span></div></li>
|
|
<li><div class="src-line"><a name="a47"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_SYNTAX</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a48"></a> <span class="src-str">'/column .* (of relation .*)?does not exist/i'</span></div></li>
|
|
<li><div class="src-line"><a name="a49"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_NOSUCHFIELD</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a50"></a> <span class="src-str">'/attribute .* not found|relation .* does not have attribute/i'</span></div></li>
|
|
<li><div class="src-line"><a name="a51"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_NOSUCHFIELD</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a52"></a> <span class="src-str">'/column .* specified in USING clause does not exist in (left|right) table/i'</span></div></li>
|
|
<li><div class="src-line"><a name="a53"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_NOSUCHFIELD</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a54"></a> <span class="src-str">'/(relation|sequence|table).*does not exist|class .* not found/i'</span></div></li>
|
|
<li><div class="src-line"><a name="a55"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_NOSUCHTABLE</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a56"></a> <span class="src-str">'/index .* does not exist/'</span></div></li>
|
|
<li><div class="src-line"><a name="a57"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_NOT_FOUND</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a58"></a> <span class="src-str">'/relation .* already exists/i'</span></div></li>
|
|
<li><div class="src-line"><a name="a59"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_ALREADY_EXISTS</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a60"></a> <span class="src-str">'/(divide|division) by zero$/i'</span></div></li>
|
|
<li><div class="src-line"><a name="a61"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_DIVZERO</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a62"></a> <span class="src-str">'/pg_atoi: error in .*: can\'t parse /i'</span></div></li>
|
|
<li><div class="src-line"><a name="a63"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_INVALID_NUMBER</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a64"></a> <span class="src-str">'/invalid input syntax for( type)? (integer|numeric)/i'</span></div></li>
|
|
<li><div class="src-line"><a name="a65"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_INVALID_NUMBER</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a66"></a> <span class="src-str">'/value .* is out of range for type \w*int/i'</span></div></li>
|
|
<li><div class="src-line"><a name="a67"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_INVALID_NUMBER</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a68"></a> <span class="src-str">'/integer out of range/i'</span></div></li>
|
|
<li><div class="src-line"><a name="a69"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_INVALID_NUMBER</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a70"></a> <span class="src-str">'/value too long for type character/i'</span></div></li>
|
|
<li><div class="src-line"><a name="a71"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_INVALID</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a72"></a> <span class="src-str">'/permission denied/'</span></div></li>
|
|
<li><div class="src-line"><a name="a73"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_ACCESS_VIOLATION</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a74"></a> <span class="src-str">'/violates [\w ]+ constraint/'</span></div></li>
|
|
<li><div class="src-line"><a name="a75"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_CONSTRAINT</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a76"></a> <span class="src-str">'/referential integrity violation/'</span></div></li>
|
|
<li><div class="src-line"><a name="a77"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_CONSTRAINT</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a78"></a> <span class="src-str">'/violates not-null constraint/'</span></div></li>
|
|
<li><div class="src-line"><a name="a79"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_CONSTRAINT_NOT_NULL</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a80"></a> <span class="src-str">'/more expressions than target columns/i'</span></div></li>
|
|
<li><div class="src-line"><a name="a81"></a> => <a href="../Doctrine/Doctrine.html">Doctrine</a><span class="src-sym">::</span><span class="src-id">ERR_VALUE_COUNT_ON_ROW</span><span class="src-sym">,</span></div></li>
|
|
<li><div class="src-line"><a name="a82"></a> <span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a83"></a> <span class="src-doc">/**</span></div></li>
|
|
<li><div class="src-line"><a name="a84"></a><span class="src-doc"> * This method checks if native error code/message can be</span></div></li>
|
|
<li><div class="src-line"><a name="a85"></a><span class="src-doc"> * converted into a portable code and then adds this</span></div></li>
|
|
<li><div class="src-line"><a name="a86"></a><span class="src-doc"> * portable error code to $portableCode field</span></div></li>
|
|
<li><div class="src-line"><a name="a87"></a><span class="src-doc"> *</span></div></li>
|
|
<li><div class="src-line"><a name="a88"></a><span class="src-doc"> * the portable error code is added at the end of array</span></div></li>
|
|
<li><div class="src-line"><a name="a89"></a><span class="src-doc"> *</span></div></li>
|
|
<li><div class="src-line"><a name="a90"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">array </span><span class="src-doc-var">$errorInfo </span><span class="src-doc"> error info array</span></div></li>
|
|
<li><div class="src-line"><a name="a91"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@since</span><span class="src-doc"> 1.0</span></div></li>
|
|
<li><div class="src-line"><a name="a92"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@see</span><span class="src-doc"> Doctrine::ERR_* constants</span></div></li>
|
|
<li><div class="src-line"><a name="a93"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@see</span><span class="src-doc"> Doctrine_Connection::$portableCode</span></div></li>
|
|
<li><div class="src-line"><a name="a94"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">boolean </span><span class="src-doc"> whether or not the error info processing was successfull</span></div></li>
|
|
<li><div class="src-line"><a name="a95"></a><span class="src-doc"> * (the process is successfull if portable error code was found)</span></div></li>
|
|
<li><div class="src-line"><a name="a96"></a><span class="src-doc"> */</span></div></li>
|
|
<li><div class="src-line"><a name="a97"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Connection_Pgsql_Exception.html#methodprocessErrorInfo">processErrorInfo</a><span class="src-sym">(</span><span class="src-key">array </span><span class="src-var">$errorInfo</span><span class="src-sym">)</span></div></li>
|
|
<li><div class="src-line"><a name="a98"></a> <span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a99"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$errorRegexps </span><span class="src-key">as </span><span class="src-var">$regexp </span>=> <span class="src-var">$code</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a100"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/preg_match">preg_match</a><span class="src-sym">(</span><span class="src-var">$regexp</span><span class="src-sym">, </span><span class="src-var">$errorInfo</span><span class="src-sym">[</span><span class="src-num">2</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a101"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Connection_Exception.html#var$portableCode">portableCode</a> = <span class="src-var">$code</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a102"></a> <span class="src-key">return </span><span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a103"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a104"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a105"></a> <span class="src-key">return </span><span class="src-id">false</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a106"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a107"></a><span class="src-sym">}</span></div></li>
|
|
</ol>
|
|
</span></div>
|
|
</div> |