[editor note] This example script is misleading. preg_last_error() only returns PREG_*_ERROR constants.
This function might come in handy to debug regular expressions in preg_.. calls
<?php
function pcre_error_deocde() {
switch (preg_last_error()) {
case PREG_PATTERN_ORDER:
print "Orders results so that $matches[0] is an array of full pattern matches, $matches[1] is an array of strings matched by the first parenthesized subpattern, and so on. This flag is only used with preg_match_all().\n";
break;
case PREG_SET_ORDER:
print "Orders results so that $matches[0] is an array of first set of matches, $matches[1] is an array of second set of matches, and so on. This flag is only used with preg_match_all().\n";
break;
case PREG_OFFSET_CAPTURE:
print "See the description of PREG_SPLIT_OFFSET_CAPTURE. This flag is available since PHP 4.3.0.\n";
break;
case PREG_SPLIT_NO_EMPTY:
print "This flag tells preg_split() to return only non-empty pieces.\n";
break;
case PREG_SPLIT_DELIM_CAPTURE:
print "This flag tells preg_split() to capture parenthesized expression in the delimiter pattern as well. This flag is available since PHP 4.0.5.\n";
break;
case PREG_SPLIT_OFFSET_CAPTURE:
print "If this flag is set, for every occurring match the appendant string offset will also be returned. Note that this changes the return values in an array where every element is an array consisting of the matched string at offset 0 and its string offset within subject at offset 1. This flag is available since PHP 4.3.0 and is only used for preg_split().\n";
break;
case PREG_NO_ERROR:
// do not print in this case
//print "Returned by preg_last_error() if there were no errors. Available since PHP 5.2.0.\n";
break;
case PREG_INTERNAL_ERROR:
print "Returned by preg_last_error() if there was an internal PCRE error. Available since PHP 5.2.0.\n";
break;
case PREG_BACKTRACK_LIMIT_ERROR:
print "Returned by preg_last_error() if backtrack limit was exhausted. Available since PHP 5.2.0.\n";
break;
case PREG_RECURSION_LIMIT_ERROR:
print "Returned by preg_last_error() if recursion limit was exhausted. Available since PHP 5.2.0.\n";
break;
case PREG_BAD_UTF8_ERROR:
print "Returned by preg_last_error() if the last error was caused by malformed UTF-8 data (only when running a regex in UTF-8 mode). Available since PHP 5.2.0.\n";
break;
case PREG_BAD_UTF8_OFFSET_ERROR:
print "Returned by preg_last_error() if the offset didn't correspond to the begin of a valid UTF-8 code point (only when running a regex in UTF-8 mode). Available since PHP 5.3.0.\n";
break;
case PCRE_VERSION:
print "PCRE version and release date (e.g. '7.0 18-Dec-2006'). Available since PHP 5.2.4.\n";
break;
}
}
?>
Öntanımlı Sabitler
Buradaki sabitler bu eklenti için tanımlanmış olup, sadece eklentinin PHP içinde derlenmiş olması veya çalışma anında devingen olarak yüklenmesi halinde kullanılabilir.
| Sabit | Açıklama |
|---|---|
| PREG_PATTERN_ORDER | Sonuçlar sıralanır. Yani, $eşleşen[0] şablonla eşleşen dizgenin tamamını, $eşleşen[1] ilk parantezli grupla eşleşen alt dizgeyi, $eşleşen[2] ikincisini, vb. içerir. Bu seçenek sadece preg_match_all() işlevi ile kullanılır. |
| PREG_SET_ORDER | Sonuçlar sıralanır. Yani, $eşleşen[0] şablonla eşleşen ilk kümeyi, $eşleşen[2] ikincisini, vb. içerir. Bu seçenek sadece preg_match_all() işlevi ile kullanılır. |
| PREG_OFFSET_CAPTURE | PREG_SPLIT_OFFSET_CAPTURE sabitinin açıklamasına bakın. Bu seçenek PHP 4.3.0'dan beri kullanılabilmektedir. |
| PREG_SPLIT_NO_EMPTY | Bu seçenek preg_split() işlevinin sadece boş olmayan parçaları döndürmesini sağlar. |
| PREG_SPLIT_DELIM_CAPTURE | Bu seçenek preg_split() işlevinin ayraçlı şablon içindeki parantezli grupları da yakalamasını sağlar. Bu seçenek PHP 4.0.5'ten beri kullanılabilmektedir. |
| PREG_SPLIT_OFFSET_CAPTURE | Bu seçenek etkinse, her eşleşmede ayrıca sona eklenen dizgenin başlangıcı da döndürülür. Bu, dizi içindeki dönüş değerini değiştirir. Böylece dizinin her elemanı 0. başlangıçtan itibaren eşleşen dizgeyi ve 1. başlangıca konu dizge başlangıcını içeren bir dizi içerir. Bu seçenek PHP 4.3.0'dan beri sadece preg_split() için kullanılabilmektedir. |
| PREG_NO_ERROR | Hiçbir hata oluşmamışsa preg_last_error() işlevi tarafından döndürülür. Bu seçenek PHP 5.2.0'dan beri kullanılabilmektedir. |
| PREG_INTERNAL_ERROR | Dahili bir PCRE hatası oluşmuşsa preg_last_error() işlevi tarafından döndürülür. Bu seçenek PHP 5.2.0'dan beri kullanılabilmektedir. |
| PREG_BACKTRACK_LIMIT_ERROR | Bu seçenek, geriye doğru izleme sınırına ulaşılmışsa preg_last_error() işlevi tarafından döndürülür. Bu seçenek PHP 5.2.0'dan beri kullanılabilmektedir. |
| PREG_RECURSION_LIMIT_ERROR | Bu seçenek, iç içelik sınırına ulaşılmışsa preg_last_error() işlevi tarafından döndürülür. Bu seçenek PHP 5.2.0'dan beri kullanılabilmektedir. |
| PREG_BAD_UTF8_ERROR | Son hata bozuk bir UTF-8 verisinden kaynaklanmışsa bu seçenek preg_last_error() işlevi tarafından döndürülür. (Bu sadece düzenli ifade UTF-8 kipinde çalışıyorsa mümkündür.) Bu seçenek PHP 5.2.0'dan beri kullanılabilmektedir. |
| PREG_BAD_UTF8_OFFSET_ERROR | Başlangıç, geçerli bir UTF-8 kodun başlangıcı değilse bu seçenek preg_last_error() işlevi tarafından döndürülür. (Bu sadece düzenli ifade UTF-8 kipinde çalışıyorsa mümkündür.) Bu seçenek PHP 5.3.0'dan beri kullanılabilmektedir. |
| PCRE_VERSION | PCRE sürümü ve dağıtım tarihi ("7.0 18-Dec-2006" gibi). Bu seçenek PHP 5.2.4'ten beri kullanılabilmektedir. |
Öntanımlı Sabitler
Bastiaan
23-Jan-2009 01:22
23-Jan-2009 01:22
