rroonga 7.0.2-x86-mingw32 → 7.1.1-x86-mingw32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Rakefile +2 -2
- data/doc/text/news.md +46 -7
- data/ext/groonga/rb-grn-array.c +1 -272
- data/ext/groonga/rb-grn-column-cache.c +240 -0
- data/ext/groonga/rb-grn-column.c +1 -1
- data/ext/groonga/rb-grn-context.c +28 -4
- data/ext/groonga/rb-grn-expression.c +23 -1
- data/ext/groonga/rb-grn-object.c +44 -1
- data/ext/groonga/rb-grn-procedure.c +16 -1
- data/ext/groonga/rb-grn-query-logger.c +55 -6
- data/ext/groonga/rb-grn-table.c +170 -1
- data/ext/groonga/rb-grn-utils.c +21 -2
- data/ext/groonga/rb-grn.h +18 -3
- data/ext/groonga/rb-groonga.c +2 -1
- data/lib/2.1/groonga.so +0 -0
- data/lib/2.2/groonga.so +0 -0
- data/lib/2.3/groonga.so +0 -0
- data/lib/2.4/groonga.so +0 -0
- data/lib/2.5/groonga.so +0 -0
- data/lib/groonga.rb +8 -5
- data/lib/groonga/column.rb +0 -5
- data/lib/groonga/database.rb +0 -10
- data/lib/groonga/index-column.rb +0 -10
- data/lib/groonga/query-logger.rb +1 -1
- data/rroonga-build.rb +6 -6
- data/rroonga.gemspec +1 -1
- data/test/groonga-test-utils.rb +5 -8
- data/test/test-array.rb +1 -131
- data/test/test-column-cache.rb +46 -0
- data/test/test-command-select.rb +36 -1
- data/test/test-context.rb +1 -2
- data/test/test-database.rb +16 -2
- data/test/test-logger.rb +13 -1
- data/test/test-procedure.rb +7 -1
- data/test/test-query-logger.rb +12 -1
- data/test/test-table-arrow.rb +193 -0
- data/test/test-table-offset-and-limit.rb +3 -1
- data/vendor/local/bin/cv2pdb.exe +0 -0
- data/vendor/local/bin/generate-pdb.bat +36 -0
- data/vendor/local/bin/grndb.exe +0 -0
- data/vendor/local/bin/groonga-benchmark.exe +0 -0
- data/vendor/local/bin/groonga-suggest-create-dataset.exe +0 -0
- data/vendor/local/bin/groonga.exe +0 -0
- data/vendor/local/bin/libgcc_s_sjlj-1.dll +0 -0
- data/vendor/local/bin/libgroonga-0.dll +0 -0
- data/vendor/local/bin/libmecab-2.dll +0 -0
- data/vendor/local/bin/libmsgpackc.dll +0 -0
- data/vendor/local/bin/libonigmo-6.dll +0 -0
- data/vendor/local/bin/libpcre-1.dll +0 -0
- data/vendor/local/bin/libpcrecpp-0.dll +0 -0
- data/vendor/local/bin/libpcreposix-0.dll +0 -0
- data/vendor/local/bin/libstdc++-6.dll +0 -0
- data/vendor/local/bin/lz4.exe +0 -0
- data/vendor/local/bin/lz4c.exe +0 -0
- data/vendor/local/bin/lz4cat +0 -0
- data/vendor/local/bin/mecab.exe +0 -0
- data/vendor/local/bin/pcre-config +1 -1
- data/vendor/local/bin/pcregrep.exe +0 -0
- data/vendor/local/bin/pcretest.exe +0 -0
- data/vendor/local/bin/zlib1.dll +0 -0
- data/vendor/local/etc/groonga/httpd/groonga-httpd.conf +1 -1
- data/vendor/local/include/groonga/groonga.h +1 -0
- data/vendor/local/include/groonga/groonga.hpp +21 -0
- data/vendor/local/include/groonga/groonga/arrow.h +38 -0
- data/vendor/local/include/groonga/groonga/arrow.hpp +21 -0
- data/vendor/local/include/groonga/groonga/column.h +9 -0
- data/vendor/local/include/groonga/groonga/expr.h +9 -1
- data/vendor/local/include/groonga/groonga/groonga.h +19 -3
- data/vendor/local/include/groonga/groonga/obj.h +3 -0
- data/vendor/local/include/groonga/groonga/operator.h +2 -1
- data/vendor/local/include/groonga/groonga/plugin.h +8 -0
- data/vendor/local/include/groonga/groonga/portability.h +19 -1
- data/vendor/local/include/groonga/groonga/table.h +14 -0
- data/vendor/local/include/groonga/groonga/util.h +3 -0
- data/vendor/local/include/groonga/groonga/window_function.h +2 -0
- data/vendor/local/include/pcre.h +2 -2
- data/vendor/local/include/pcre_stringpiece.h +2 -2
- data/vendor/local/lib/groonga/plugins/functions/index_column.a +0 -0
- data/vendor/local/lib/groonga/plugins/functions/index_column.dll +0 -0
- data/vendor/local/lib/groonga/plugins/functions/index_column.dll.a +0 -0
- data/vendor/local/lib/groonga/plugins/functions/index_column.la +41 -0
- data/vendor/local/lib/groonga/plugins/functions/math.a +0 -0
- data/vendor/local/lib/groonga/plugins/functions/math.dll +0 -0
- data/vendor/local/lib/groonga/plugins/functions/math.dll.a +0 -0
- data/vendor/local/lib/groonga/plugins/functions/math.la +41 -0
- data/vendor/local/lib/groonga/plugins/functions/number.a +0 -0
- data/vendor/local/lib/groonga/plugins/functions/number.dll +0 -0
- data/vendor/local/lib/groonga/plugins/functions/number.dll.a +0 -0
- data/vendor/local/lib/groonga/plugins/functions/number.la +1 -1
- data/vendor/local/lib/groonga/plugins/functions/string.a +0 -0
- data/vendor/local/lib/groonga/plugins/functions/string.dll +0 -0
- data/vendor/local/lib/groonga/plugins/functions/string.dll.a +0 -0
- data/vendor/local/lib/groonga/plugins/functions/string.la +1 -1
- data/vendor/local/lib/groonga/plugins/functions/time.a +0 -0
- data/vendor/local/lib/groonga/plugins/functions/time.dll +0 -0
- data/vendor/local/lib/groonga/plugins/functions/time.dll.a +0 -0
- data/vendor/local/lib/groonga/plugins/functions/time.la +1 -1
- data/vendor/local/lib/groonga/plugins/functions/vector.a +0 -0
- data/vendor/local/lib/groonga/plugins/functions/vector.dll +0 -0
- data/vendor/local/lib/groonga/plugins/functions/vector.dll.a +0 -0
- data/vendor/local/lib/groonga/plugins/functions/vector.la +1 -1
- data/vendor/local/lib/groonga/plugins/normalizers/mysql.a +0 -0
- data/vendor/local/lib/groonga/plugins/normalizers/mysql.dll +0 -0
- data/vendor/local/lib/groonga/plugins/normalizers/mysql.dll.a +0 -0
- data/vendor/local/lib/groonga/plugins/normalizers/mysql.la +1 -1
- data/vendor/local/lib/groonga/plugins/query_expanders/tsv.a +0 -0
- data/vendor/local/lib/groonga/plugins/query_expanders/tsv.dll +0 -0
- data/vendor/local/lib/groonga/plugins/query_expanders/tsv.dll.a +0 -0
- data/vendor/local/lib/groonga/plugins/query_expanders/tsv.la +1 -1
- data/vendor/local/lib/groonga/plugins/ruby/eval.rb +1 -1
- data/vendor/local/lib/groonga/plugins/sharding.rb +3 -0
- data/vendor/local/lib/groonga/plugins/sharding/dynamic_columns.rb +152 -0
- data/vendor/local/lib/groonga/plugins/sharding/keys_parsable.rb +12 -0
- data/vendor/local/lib/groonga/plugins/sharding/logical_count.rb +149 -106
- data/vendor/local/lib/groonga/plugins/sharding/logical_enumerator.rb +11 -3
- data/vendor/local/lib/groonga/plugins/sharding/logical_range_filter.rb +80 -6
- data/vendor/local/lib/groonga/plugins/sharding/logical_select.rb +43 -206
- data/vendor/local/lib/groonga/plugins/sharding/range_expression_builder.rb +15 -0
- data/vendor/local/lib/groonga/plugins/suggest/suggest.a +0 -0
- data/vendor/local/lib/groonga/plugins/suggest/suggest.dll +0 -0
- data/vendor/local/lib/groonga/plugins/suggest/suggest.dll.a +0 -0
- data/vendor/local/lib/groonga/plugins/suggest/suggest.la +1 -1
- data/vendor/local/lib/groonga/plugins/token_filters/stop_word.a +0 -0
- data/vendor/local/lib/groonga/plugins/token_filters/stop_word.dll +0 -0
- data/vendor/local/lib/groonga/plugins/token_filters/stop_word.dll.a +0 -0
- data/vendor/local/lib/groonga/plugins/token_filters/stop_word.la +1 -1
- data/vendor/local/lib/groonga/plugins/tokenizers/mecab.a +0 -0
- data/vendor/local/lib/groonga/plugins/tokenizers/mecab.dll +0 -0
- data/vendor/local/lib/groonga/plugins/tokenizers/mecab.dll.a +0 -0
- data/vendor/local/lib/groonga/plugins/tokenizers/mecab.la +1 -1
- data/vendor/local/lib/groonga/scripts/ruby/command_line/grndb.rb +163 -1
- data/vendor/local/lib/groonga/scripts/ruby/command_line_parser.rb +12 -0
- data/vendor/local/lib/groonga/scripts/ruby/expression_tree/function_call.rb +8 -3
- data/vendor/local/lib/groonga/scripts/ruby/expression_tree_builder.rb +1 -0
- data/{lib/groonga/table.rb → vendor/local/lib/groonga/scripts/ruby/groonga-log.rb} +6 -12
- data/vendor/local/lib/groonga/scripts/ruby/groonga-log/parser.rb +81 -0
- data/vendor/local/lib/groonga/scripts/ruby/groonga-log/statistic.rb +23 -0
- data/vendor/local/lib/groonga/scripts/ruby/groonga-log/version.rb +3 -0
- data/vendor/local/lib/groonga/scripts/ruby/initialize/post.rb +10 -0
- data/vendor/local/lib/groonga/scripts/ruby/labeled_arguments.rb +21 -0
- data/vendor/local/lib/groonga/scripts/ruby/logger/level.rb +8 -2
- data/vendor/local/lib/groonga/scripts/ruby/object.rb +7 -0
- data/vendor/local/lib/groonga/scripts/ruby/scan_info.rb +3 -0
- data/vendor/local/lib/groonga/scripts/ruby/scan_info_builder.rb +2 -0
- data/vendor/local/lib/groonga/scripts/ruby/scan_info_data.rb +40 -9
- data/vendor/local/lib/groonga/scripts/ruby/table.rb +12 -2
- data/vendor/local/lib/libgroonga.a +0 -0
- data/vendor/local/lib/libgroonga.dll.a +0 -0
- data/vendor/local/lib/libgroonga.la +1 -1
- data/vendor/local/lib/liblz4.a +0 -0
- data/vendor/local/lib/liblz4.dll +0 -0
- data/vendor/local/lib/liblz4.dll.1 +0 -0
- data/vendor/local/lib/liblz4.dll.1.5.0 +0 -0
- data/vendor/local/lib/libmecab.a +0 -0
- data/vendor/local/lib/libmecab.dll.a +0 -0
- data/vendor/local/lib/libmecab.la +2 -2
- data/vendor/local/lib/libmsgpackc.a +0 -0
- data/vendor/local/lib/libmsgpackc.dll.a +0 -0
- data/vendor/local/lib/libonigmo.a +0 -0
- data/vendor/local/lib/libonigmo.dll.a +0 -0
- data/vendor/local/lib/libpcre.a +0 -0
- data/vendor/local/lib/libpcre.dll.a +0 -0
- data/vendor/local/lib/libpcre.la +1 -1
- data/vendor/local/lib/libpcrecpp.a +0 -0
- data/vendor/local/lib/libpcrecpp.dll.a +0 -0
- data/vendor/local/lib/libpcreposix.a +0 -0
- data/vendor/local/lib/libpcreposix.dll.a +0 -0
- data/vendor/local/lib/libpcreposix.la +1 -1
- data/vendor/local/lib/libz.a +0 -0
- data/vendor/local/lib/libz.dll.a +0 -0
- data/vendor/local/lib/pkgconfig/groonga.pc +2 -2
- data/vendor/local/lib/pkgconfig/libpcre.pc +1 -1
- data/vendor/local/lib/pkgconfig/libpcrecpp.pc +1 -1
- data/vendor/local/lib/pkgconfig/libpcreposix.pc +1 -1
- data/vendor/local/libexec/mecab/mecab-cost-train.exe +0 -0
- data/vendor/local/libexec/mecab/mecab-dict-gen.exe +0 -0
- data/vendor/local/libexec/mecab/mecab-dict-index.exe +0 -0
- data/vendor/local/libexec/mecab/mecab-system-eval.exe +0 -0
- data/vendor/local/libexec/mecab/mecab-test-gen.exe +0 -0
- data/vendor/local/share/doc/groonga/en/html/.buildinfo +1 -1
- data/vendor/local/share/doc/groonga/en/html/_static/basic.css +47 -19
- data/vendor/local/share/doc/groonga/en/html/_static/comment-bright.png +0 -0
- data/vendor/local/share/doc/groonga/en/html/_static/comment-close.png +0 -0
- data/vendor/local/share/doc/groonga/en/html/_static/comment.png +0 -0
- data/vendor/local/share/doc/groonga/en/html/_static/doctools.js +1 -1
- data/vendor/local/share/doc/groonga/en/html/_static/down-pressed.png +0 -0
- data/vendor/local/share/doc/groonga/en/html/_static/down.png +0 -0
- data/vendor/local/share/doc/groonga/en/html/_static/file.png +0 -0
- data/vendor/local/share/doc/groonga/en/html/_static/{jquery-1.11.1.js → jquery-3.1.0.js} +4245 -4479
- data/vendor/local/share/doc/groonga/en/html/_static/jquery.js +4 -4
- data/vendor/local/share/doc/groonga/en/html/_static/minus.png +0 -0
- data/vendor/local/share/doc/groonga/en/html/_static/plus.png +0 -0
- data/vendor/local/share/doc/groonga/en/html/_static/searchtools.js +112 -5
- data/vendor/local/share/doc/groonga/en/html/_static/up-pressed.png +0 -0
- data/vendor/local/share/doc/groonga/en/html/_static/up.png +0 -0
- data/vendor/local/share/doc/groonga/en/html/_static/websupport.js +1 -1
- data/vendor/local/share/doc/groonga/en/html/characteristic.html +9 -19
- data/vendor/local/share/doc/groonga/en/html/client.html +9 -19
- data/vendor/local/share/doc/groonga/en/html/community.html +9 -19
- data/vendor/local/share/doc/groonga/en/html/contribution.html +9 -19
- data/vendor/local/share/doc/groonga/en/html/contribution/development.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/development/build.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/development/build/unix_autotools.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/development/build/unix_cmake.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/development/build/windows_cmake.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/development/com.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/development/cooperation.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/development/query.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/development/release.html +10 -21
- data/vendor/local/share/doc/groonga/en/html/contribution/development/repository.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/development/test.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/documentation.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/documentation/c-api.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/documentation/i18n.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/documentation/introduction.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/contribution/report.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/development.html +13 -23
- data/vendor/local/share/doc/groonga/en/html/development/travis-ci.html +15 -26
- data/vendor/local/share/doc/groonga/en/html/genindex.html +819 -1560
- data/vendor/local/share/doc/groonga/en/html/index.html +42 -45
- data/vendor/local/share/doc/groonga/en/html/install.html +11 -20
- data/vendor/local/share/doc/groonga/en/html/install/centos.html +14 -25
- data/vendor/local/share/doc/groonga/en/html/install/debian.html +92 -28
- data/vendor/local/share/doc/groonga/en/html/install/fedora.html +13 -24
- data/vendor/local/share/doc/groonga/en/html/install/mac_os_x.html +13 -24
- data/vendor/local/share/doc/groonga/en/html/install/others.html +13 -24
- data/vendor/local/share/doc/groonga/en/html/install/solaris.html +12 -23
- data/vendor/local/share/doc/groonga/en/html/install/ubuntu.html +15 -25
- data/vendor/local/share/doc/groonga/en/html/install/windows.html +18 -29
- data/vendor/local/share/doc/groonga/en/html/limitations.html +13 -23
- data/vendor/local/share/doc/groonga/en/html/news.html +650 -43
- data/vendor/local/share/doc/groonga/en/html/news/0.x.html +15 -25
- data/vendor/local/share/doc/groonga/en/html/news/1.0.x.html +13 -23
- data/vendor/local/share/doc/groonga/en/html/news/1.1.x.html +10 -20
- data/vendor/local/share/doc/groonga/en/html/news/1.2.x.html +12 -22
- data/vendor/local/share/doc/groonga/en/html/news/1.3.x.html +10 -20
- data/vendor/local/share/doc/groonga/en/html/news/2.x.html +11 -21
- data/vendor/local/share/doc/groonga/en/html/news/3.x.html +10 -20
- data/vendor/local/share/doc/groonga/en/html/news/4.x.html +10 -20
- data/vendor/local/share/doc/groonga/en/html/news/5.x.html +10 -20
- data/vendor/local/share/doc/groonga/en/html/news/6.x.html +10 -20
- data/vendor/local/share/doc/groonga/en/html/news/senna.html +10 -20
- data/vendor/local/share/doc/groonga/en/html/objects.inv +0 -0
- data/vendor/local/share/doc/groonga/en/html/reference.html +32 -40
- data/vendor/local/share/doc/groonga/en/html/reference/alias.html +12 -24
- data/vendor/local/share/doc/groonga/en/html/reference/api.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/global_configurations.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_cache.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_column.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_command_version.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_content_type.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_ctx.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_db.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_encoding.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_expr.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_geo.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_hook.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_ii.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_index_cursor.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_info.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_match_escalation.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_obj.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_proc.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_search.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_table.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_table_cursor.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_thread.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_type.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/grn_user_data.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/overview.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/api/plugin.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/cast.html +10 -20
- data/vendor/local/share/doc/groonga/en/html/reference/column.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/columns/index.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/columns/pseudo.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/columns/scalar.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/columns/vector.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/command.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/command/command_version.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/command/output_format.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/command/pretty_print.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/command/request_id.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/command/request_timeout.html +10 -21
- data/vendor/local/share/doc/groonga/en/html/reference/command/return_code.html +10 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/cache_limit.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/check.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/clearlock.html +11 -22
- data/vendor/local/share/doc/groonga/en/html/reference/commands/column_copy.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/column_create.html +35 -37
- data/vendor/local/share/doc/groonga/en/html/reference/commands/column_list.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/column_remove.html +10 -21
- data/vendor/local/share/doc/groonga/en/html/reference/commands/column_rename.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/config_delete.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/config_get.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/config_set.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/database_unmap.html +10 -21
- data/vendor/local/share/doc/groonga/en/html/reference/commands/define_selector.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/defrag.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/delete.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/dump.html +56 -28
- data/vendor/local/share/doc/groonga/en/html/reference/commands/io_flush.html +42 -21
- data/vendor/local/share/doc/groonga/en/html/reference/commands/load.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/lock_acquire.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/lock_clear.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/lock_release.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/log_level.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/log_put.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/log_reopen.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/logical_count.html +583 -107
- data/vendor/local/share/doc/groonga/en/html/reference/commands/logical_parameters.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/logical_range_filter.html +1143 -51
- data/vendor/local/share/doc/groonga/en/html/reference/commands/logical_select.html +166 -29
- data/vendor/local/share/doc/groonga/en/html/reference/commands/logical_shard_list.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/logical_table_remove.html +13 -24
- data/vendor/local/share/doc/groonga/en/html/reference/commands/normalize.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/normalizer_list.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/object_exist.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/object_inspect.html +12 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/object_list.html +138 -143
- data/vendor/local/share/doc/groonga/en/html/reference/commands/object_remove.html +14 -24
- data/vendor/local/share/doc/groonga/en/html/reference/commands/plugin_register.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/plugin_unregister.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/query_expand.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/quit.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/range_filter.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/register.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/reindex.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/request_cancel.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/ruby_eval.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/ruby_load.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/schema.html +95 -65
- data/vendor/local/share/doc/groonga/en/html/reference/commands/select.html +37 -25
- data/vendor/local/share/doc/groonga/en/html/reference/commands/shutdown.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/status.html +15 -26
- data/vendor/local/share/doc/groonga/en/html/reference/commands/suggest.html +14 -33
- data/vendor/local/share/doc/groonga/en/html/reference/commands/table_copy.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/table_create.html +11 -21
- data/vendor/local/share/doc/groonga/en/html/reference/commands/table_list.html +9 -60
- data/vendor/local/share/doc/groonga/en/html/reference/commands/table_remove.html +12 -23
- data/vendor/local/share/doc/groonga/en/html/reference/commands/table_rename.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/table_tokenize.html +15 -53
- data/vendor/local/share/doc/groonga/en/html/reference/commands/thread_limit.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/tokenize.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/commands/tokenizer_list.html +9 -23
- data/vendor/local/share/doc/groonga/en/html/reference/commands/truncate.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/configuration.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/executables.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/executables/grndb.html +118 -21
- data/vendor/local/share/doc/groonga/en/html/reference/executables/grnslap.html +11 -22
- data/vendor/local/share/doc/groonga/en/html/reference/executables/groonga-benchmark.html +21 -32
- data/vendor/local/share/doc/groonga/en/html/reference/executables/groonga-httpd.html +17 -27
- data/vendor/local/share/doc/groonga/en/html/reference/executables/groonga-server-http.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/executables/groonga-suggest-create-dataset.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/executables/groonga-suggest-httpd.html +26 -39
- data/vendor/local/share/doc/groonga/en/html/reference/executables/groonga-suggest-learner.html +17 -28
- data/vendor/local/share/doc/groonga/en/html/reference/executables/groonga.html +44 -55
- data/vendor/local/share/doc/groonga/en/html/reference/function.html +29 -39
- data/vendor/local/share/doc/groonga/en/html/reference/functions/between.html +56 -111
- data/vendor/local/share/doc/groonga/en/html/reference/functions/edit_distance.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/functions/fuzzy_search.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/functions/geo_distance.html +11 -22
- data/vendor/local/share/doc/groonga/en/html/reference/functions/geo_in_circle.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/functions/geo_in_rectangle.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/functions/highlight_full.html +11 -22
- data/vendor/local/share/doc/groonga/en/html/reference/functions/highlight_html.html +11 -22
- data/vendor/local/share/doc/groonga/en/html/reference/functions/html_untag.html +10 -21
- data/vendor/local/share/doc/groonga/en/html/reference/functions/in_records.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/functions/in_values.html +15 -26
- data/vendor/local/share/doc/groonga/en/html/reference/functions/math_abs.html +237 -0
- data/vendor/local/share/doc/groonga/en/html/reference/functions/now.html +30 -41
- data/vendor/local/share/doc/groonga/en/html/reference/functions/number_classify.html +27 -38
- data/vendor/local/share/doc/groonga/en/html/reference/functions/prefix_rk_search.html +37 -50
- data/vendor/local/share/doc/groonga/en/html/reference/functions/query.html +50 -61
- data/vendor/local/share/doc/groonga/en/html/reference/functions/rand.html +31 -42
- data/vendor/local/share/doc/groonga/en/html/reference/functions/snippet_html.html +36 -47
- data/vendor/local/share/doc/groonga/en/html/reference/functions/string_length.html +27 -38
- data/vendor/local/share/doc/groonga/en/html/reference/functions/string_substring.html +27 -38
- data/vendor/local/share/doc/groonga/en/html/reference/functions/sub_filter.html +35 -46
- data/vendor/local/share/doc/groonga/en/html/reference/functions/time_classify_day.html +27 -38
- data/vendor/local/share/doc/groonga/en/html/reference/functions/time_classify_hour.html +27 -38
- data/vendor/local/share/doc/groonga/en/html/reference/functions/time_classify_minute.html +27 -38
- data/vendor/local/share/doc/groonga/en/html/reference/functions/time_classify_month.html +27 -38
- data/vendor/local/share/doc/groonga/en/html/reference/functions/time_classify_second.html +27 -38
- data/vendor/local/share/doc/groonga/en/html/reference/functions/time_classify_week.html +27 -38
- data/vendor/local/share/doc/groonga/en/html/reference/functions/time_classify_year.html +27 -38
- data/vendor/local/share/doc/groonga/en/html/reference/functions/vector_new.html +29 -40
- data/vendor/local/share/doc/groonga/en/html/reference/functions/vector_size.html +32 -43
- data/vendor/local/share/doc/groonga/en/html/reference/functions/vector_slice.html +23 -34
- data/vendor/local/share/doc/groonga/en/html/reference/grn_expr.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/grn_expr/query_syntax.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/grn_expr/script_syntax.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/indexing.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/log.html +11 -22
- data/vendor/local/share/doc/groonga/en/html/reference/normalizers.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/operations.html +13 -24
- data/vendor/local/share/doc/groonga/en/html/reference/operations/geolocation_search.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/operations/prefix_rk_search.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/output.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/query_expanders.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/query_expanders/tsv.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/regular_expression.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/scorer.html +14 -25
- data/vendor/local/share/doc/groonga/en/html/reference/scorers/scorer_tf_at_most.html +10 -21
- data/vendor/local/share/doc/groonga/en/html/reference/scorers/scorer_tf_idf.html +10 -21
- data/vendor/local/share/doc/groonga/en/html/reference/sharding.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/suggest.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/suggest/completion.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/suggest/correction.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/suggest/introduction.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/suggest/suggestion.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/tables.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/token_filters.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/tokenizers.html +22 -37
- data/vendor/local/share/doc/groonga/en/html/reference/tuning.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/types.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/reference/window_function.html +16 -26
- data/vendor/local/share/doc/groonga/en/html/reference/window_functions/record_number.html +14 -25
- data/vendor/local/share/doc/groonga/en/html/reference/window_functions/window_count.html +152 -0
- data/vendor/local/share/doc/groonga/en/html/reference/window_functions/window_record_number.html +28 -39
- data/vendor/local/share/doc/groonga/en/html/reference/window_functions/window_sum.html +23 -34
- data/vendor/local/share/doc/groonga/en/html/search.html +9 -12
- data/vendor/local/share/doc/groonga/en/html/searchindex.js +1 -1
- data/vendor/local/share/doc/groonga/en/html/server.html +9 -19
- data/vendor/local/share/doc/groonga/en/html/server/gqtp.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/server/http.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/server/http/comparison.html +10 -21
- data/vendor/local/share/doc/groonga/en/html/server/http/groonga-httpd.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/server/http/groonga.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/server/memcached.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/server/package.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/spec.html +9 -19
- data/vendor/local/share/doc/groonga/en/html/spec/gqtp.html +17 -27
- data/vendor/local/share/doc/groonga/en/html/spec/search.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/troubleshooting.html +18 -24
- data/vendor/local/share/doc/groonga/en/html/troubleshooting/different_results_with_the_same_keyword.html +20 -31
- data/vendor/local/share/doc/groonga/en/html/troubleshooting/how_to_analyze_error_message.html +188 -0
- data/vendor/local/share/doc/groonga/en/html/troubleshooting/mmap_cannot_allocate_memory.html +22 -33
- data/vendor/local/share/doc/groonga/en/html/tutorial.html +9 -19
- data/vendor/local/share/doc/groonga/en/html/tutorial/data.html +10 -21
- data/vendor/local/share/doc/groonga/en/html/tutorial/drilldown.html +12 -23
- data/vendor/local/share/doc/groonga/en/html/tutorial/index.html +10 -21
- data/vendor/local/share/doc/groonga/en/html/tutorial/introduction.html +21 -31
- data/vendor/local/share/doc/groonga/en/html/tutorial/lexicon.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/tutorial/match_columns.html +174 -22
- data/vendor/local/share/doc/groonga/en/html/tutorial/micro_blog.html +10 -81
- data/vendor/local/share/doc/groonga/en/html/tutorial/network.html +16 -26
- data/vendor/local/share/doc/groonga/en/html/tutorial/patricia_trie.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/tutorial/query_expansion.html +9 -20
- data/vendor/local/share/doc/groonga/en/html/tutorial/search.html +14 -25
- data/vendor/local/share/doc/groonga/ja/html/.buildinfo +1 -1
- data/vendor/local/share/doc/groonga/ja/html/_static/basic.css +47 -19
- data/vendor/local/share/doc/groonga/ja/html/_static/comment-bright.png +0 -0
- data/vendor/local/share/doc/groonga/ja/html/_static/comment-close.png +0 -0
- data/vendor/local/share/doc/groonga/ja/html/_static/comment.png +0 -0
- data/vendor/local/share/doc/groonga/ja/html/_static/doctools.js +1 -1
- data/vendor/local/share/doc/groonga/ja/html/_static/down-pressed.png +0 -0
- data/vendor/local/share/doc/groonga/ja/html/_static/down.png +0 -0
- data/vendor/local/share/doc/groonga/ja/html/_static/file.png +0 -0
- data/vendor/local/share/doc/groonga/ja/html/_static/{jquery-1.11.1.js → jquery-3.1.0.js} +4245 -4479
- data/vendor/local/share/doc/groonga/ja/html/_static/jquery.js +4 -4
- data/vendor/local/share/doc/groonga/ja/html/_static/minus.png +0 -0
- data/vendor/local/share/doc/groonga/ja/html/_static/plus.png +0 -0
- data/vendor/local/share/doc/groonga/ja/html/_static/searchtools.js +112 -5
- data/vendor/local/share/doc/groonga/ja/html/_static/up-pressed.png +0 -0
- data/vendor/local/share/doc/groonga/ja/html/_static/up.png +0 -0
- data/vendor/local/share/doc/groonga/ja/html/_static/websupport.js +1 -1
- data/vendor/local/share/doc/groonga/ja/html/characteristic.html +9 -19
- data/vendor/local/share/doc/groonga/ja/html/client.html +9 -19
- data/vendor/local/share/doc/groonga/ja/html/community.html +11 -23
- data/vendor/local/share/doc/groonga/ja/html/contribution.html +12 -25
- data/vendor/local/share/doc/groonga/ja/html/contribution/development.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/contribution/development/build.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/contribution/development/build/unix_autotools.html +13 -28
- data/vendor/local/share/doc/groonga/ja/html/contribution/development/build/unix_cmake.html +12 -26
- data/vendor/local/share/doc/groonga/ja/html/contribution/development/build/windows_cmake.html +16 -34
- data/vendor/local/share/doc/groonga/ja/html/contribution/development/com.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/contribution/development/cooperation.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/contribution/development/query.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/contribution/development/release.html +10 -21
- data/vendor/local/share/doc/groonga/ja/html/contribution/development/repository.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/contribution/development/test.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/contribution/documentation.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/contribution/documentation/c-api.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/contribution/documentation/i18n.html +20 -42
- data/vendor/local/share/doc/groonga/ja/html/contribution/documentation/introduction.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/contribution/report.html +11 -24
- data/vendor/local/share/doc/groonga/ja/html/development.html +13 -23
- data/vendor/local/share/doc/groonga/ja/html/development/travis-ci.html +19 -38
- data/vendor/local/share/doc/groonga/ja/html/genindex.html +819 -1560
- data/vendor/local/share/doc/groonga/ja/html/index.html +41 -44
- data/vendor/local/share/doc/groonga/ja/html/install.html +11 -20
- data/vendor/local/share/doc/groonga/ja/html/install/centos.html +18 -33
- data/vendor/local/share/doc/groonga/ja/html/install/debian.html +84 -32
- data/vendor/local/share/doc/groonga/ja/html/install/fedora.html +15 -28
- data/vendor/local/share/doc/groonga/ja/html/install/mac_os_x.html +13 -24
- data/vendor/local/share/doc/groonga/ja/html/install/others.html +28 -55
- data/vendor/local/share/doc/groonga/ja/html/install/solaris.html +12 -23
- data/vendor/local/share/doc/groonga/ja/html/install/ubuntu.html +17 -29
- data/vendor/local/share/doc/groonga/ja/html/install/windows.html +18 -29
- data/vendor/local/share/doc/groonga/ja/html/limitations.html +17 -35
- data/vendor/local/share/doc/groonga/ja/html/news.html +516 -158
- data/vendor/local/share/doc/groonga/ja/html/news/0.x.html +15 -25
- data/vendor/local/share/doc/groonga/ja/html/news/1.0.x.html +12 -22
- data/vendor/local/share/doc/groonga/ja/html/news/1.1.x.html +10 -20
- data/vendor/local/share/doc/groonga/ja/html/news/1.2.x.html +144 -288
- data/vendor/local/share/doc/groonga/ja/html/news/1.3.x.html +36 -72
- data/vendor/local/share/doc/groonga/ja/html/news/2.x.html +266 -532
- data/vendor/local/share/doc/groonga/ja/html/news/3.x.html +224 -441
- data/vendor/local/share/doc/groonga/ja/html/news/4.x.html +258 -516
- data/vendor/local/share/doc/groonga/ja/html/news/5.x.html +282 -562
- data/vendor/local/share/doc/groonga/ja/html/news/6.x.html +213 -426
- data/vendor/local/share/doc/groonga/ja/html/news/senna.html +10 -20
- data/vendor/local/share/doc/groonga/ja/html/objects.inv +0 -0
- data/vendor/local/share/doc/groonga/ja/html/reference.html +32 -40
- data/vendor/local/share/doc/groonga/ja/html/reference/alias.html +14 -28
- data/vendor/local/share/doc/groonga/ja/html/reference/api.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/global_configurations.html +11 -24
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_cache.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_column.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_command_version.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_content_type.html +10 -22
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_ctx.html +15 -32
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_db.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_encoding.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_expr.html +11 -24
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_geo.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_hook.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_ii.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_index_cursor.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_info.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_match_escalation.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_obj.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_proc.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_search.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_table.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_table_cursor.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_thread.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_type.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/grn_user_data.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/overview.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/api/plugin.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/cast.html +10 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/column.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/columns/index.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/columns/pseudo.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/columns/scalar.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/columns/vector.html +15 -32
- data/vendor/local/share/doc/groonga/ja/html/reference/command.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/command/command_version.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/command/output_format.html +10 -22
- data/vendor/local/share/doc/groonga/ja/html/reference/command/pretty_print.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/command/request_id.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/command/request_timeout.html +10 -21
- data/vendor/local/share/doc/groonga/ja/html/reference/command/return_code.html +12 -24
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/cache_limit.html +11 -24
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/check.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/clearlock.html +11 -22
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/column_copy.html +31 -64
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/column_create.html +56 -85
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/column_list.html +29 -60
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/column_remove.html +10 -21
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/column_rename.html +14 -30
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/config_delete.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/config_get.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/config_set.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/database_unmap.html +10 -21
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/define_selector.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/defrag.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/delete.html +15 -32
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/dump.html +55 -28
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/io_flush.html +45 -45
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/load.html +15 -32
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/lock_acquire.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/lock_clear.html +11 -24
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/lock_release.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/log_level.html +15 -32
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/log_put.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/log_reopen.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/logical_count.html +498 -106
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/logical_parameters.html +13 -27
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/logical_range_filter.html +1051 -56
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/logical_select.html +166 -56
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/logical_shard_list.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/logical_table_remove.html +33 -63
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/normalize.html +17 -36
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/normalizer_list.html +13 -28
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/object_exist.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/object_inspect.html +54 -104
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/object_list.html +183 -233
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/object_remove.html +14 -24
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/plugin_register.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/plugin_unregister.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/query_expand.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/quit.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/range_filter.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/register.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/reindex.html +11 -24
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/request_cancel.html +14 -30
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/ruby_eval.html +10 -22
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/ruby_load.html +10 -22
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/schema.html +136 -147
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/select.html +145 -271
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/shutdown.html +10 -22
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/status.html +23 -42
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/suggest.html +28 -61
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/table_copy.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/table_create.html +32 -65
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/table_list.html +9 -60
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/table_remove.html +22 -43
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/table_rename.html +12 -26
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/table_tokenize.html +15 -53
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/thread_limit.html +11 -24
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/tokenize.html +18 -38
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/tokenizer_list.html +13 -31
- data/vendor/local/share/doc/groonga/ja/html/reference/commands/truncate.html +11 -24
- data/vendor/local/share/doc/groonga/ja/html/reference/configuration.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/executables.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/executables/grndb.html +113 -29
- data/vendor/local/share/doc/groonga/ja/html/reference/executables/grnslap.html +11 -22
- data/vendor/local/share/doc/groonga/ja/html/reference/executables/groonga-benchmark.html +21 -32
- data/vendor/local/share/doc/groonga/ja/html/reference/executables/groonga-httpd.html +20 -33
- data/vendor/local/share/doc/groonga/ja/html/reference/executables/groonga-server-http.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/executables/groonga-suggest-create-dataset.html +10 -22
- data/vendor/local/share/doc/groonga/ja/html/reference/executables/groonga-suggest-httpd.html +70 -127
- data/vendor/local/share/doc/groonga/ja/html/reference/executables/groonga-suggest-learner.html +17 -28
- data/vendor/local/share/doc/groonga/ja/html/reference/executables/groonga.html +71 -109
- data/vendor/local/share/doc/groonga/ja/html/reference/function.html +29 -39
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/between.html +46 -102
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/edit_distance.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/fuzzy_search.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/geo_distance.html +14 -28
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/geo_in_circle.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/geo_in_rectangle.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/highlight_full.html +11 -22
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/highlight_html.html +11 -22
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/html_untag.html +10 -21
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/in_records.html +23 -48
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/in_values.html +16 -27
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/math_abs.html +237 -0
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/now.html +30 -41
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/number_classify.html +27 -38
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/prefix_rk_search.html +37 -50
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/query.html +64 -89
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/rand.html +31 -42
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/snippet_html.html +42 -59
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/string_length.html +27 -38
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/string_substring.html +27 -38
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/sub_filter.html +38 -52
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/time_classify_day.html +27 -38
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/time_classify_hour.html +27 -38
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/time_classify_minute.html +27 -38
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/time_classify_month.html +27 -38
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/time_classify_second.html +27 -38
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/time_classify_week.html +27 -38
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/time_classify_year.html +27 -38
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/vector_new.html +29 -40
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/vector_size.html +32 -43
- data/vendor/local/share/doc/groonga/ja/html/reference/functions/vector_slice.html +23 -34
- data/vendor/local/share/doc/groonga/ja/html/reference/grn_expr.html +13 -28
- data/vendor/local/share/doc/groonga/ja/html/reference/grn_expr/query_syntax.html +18 -38
- data/vendor/local/share/doc/groonga/ja/html/reference/grn_expr/script_syntax.html +17 -36
- data/vendor/local/share/doc/groonga/ja/html/reference/indexing.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/log.html +37 -74
- data/vendor/local/share/doc/groonga/ja/html/reference/normalizers.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/operations.html +13 -24
- data/vendor/local/share/doc/groonga/ja/html/reference/operations/geolocation_search.html +18 -38
- data/vendor/local/share/doc/groonga/ja/html/reference/operations/prefix_rk_search.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/output.html +12 -26
- data/vendor/local/share/doc/groonga/ja/html/reference/query_expanders.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/query_expanders/tsv.html +15 -32
- data/vendor/local/share/doc/groonga/ja/html/reference/regular_expression.html +29 -60
- data/vendor/local/share/doc/groonga/ja/html/reference/scorer.html +16 -29
- data/vendor/local/share/doc/groonga/ja/html/reference/scorers/scorer_tf_at_most.html +10 -21
- data/vendor/local/share/doc/groonga/ja/html/reference/scorers/scorer_tf_idf.html +10 -21
- data/vendor/local/share/doc/groonga/ja/html/reference/sharding.html +16 -34
- data/vendor/local/share/doc/groonga/ja/html/reference/suggest.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/suggest/completion.html +34 -70
- data/vendor/local/share/doc/groonga/ja/html/reference/suggest/correction.html +22 -46
- data/vendor/local/share/doc/groonga/ja/html/reference/suggest/introduction.html +16 -34
- data/vendor/local/share/doc/groonga/ja/html/reference/suggest/suggestion.html +19 -40
- data/vendor/local/share/doc/groonga/ja/html/reference/tables.html +31 -64
- data/vendor/local/share/doc/groonga/ja/html/reference/token_filters.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/tokenizers.html +42 -77
- data/vendor/local/share/doc/groonga/ja/html/reference/tuning.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/types.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/reference/window_function.html +16 -26
- data/vendor/local/share/doc/groonga/ja/html/reference/window_functions/record_number.html +14 -25
- data/vendor/local/share/doc/groonga/ja/html/reference/window_functions/window_count.html +153 -0
- data/vendor/local/share/doc/groonga/ja/html/reference/window_functions/window_record_number.html +28 -39
- data/vendor/local/share/doc/groonga/ja/html/reference/window_functions/window_sum.html +23 -34
- data/vendor/local/share/doc/groonga/ja/html/search.html +9 -12
- data/vendor/local/share/doc/groonga/ja/html/searchindex.js +1 -1
- data/vendor/local/share/doc/groonga/ja/html/server.html +9 -19
- data/vendor/local/share/doc/groonga/ja/html/server/gqtp.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/server/http.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/server/http/comparison.html +47 -95
- data/vendor/local/share/doc/groonga/ja/html/server/http/groonga-httpd.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/server/http/groonga.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/server/memcached.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/server/package.html +26 -54
- data/vendor/local/share/doc/groonga/ja/html/spec.html +9 -19
- data/vendor/local/share/doc/groonga/ja/html/spec/gqtp.html +50 -93
- data/vendor/local/share/doc/groonga/ja/html/spec/search.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/troubleshooting.html +18 -24
- data/vendor/local/share/doc/groonga/ja/html/troubleshooting/different_results_with_the_same_keyword.html +14 -25
- data/vendor/local/share/doc/groonga/ja/html/troubleshooting/how_to_analyze_error_message.html +186 -0
- data/vendor/local/share/doc/groonga/ja/html/troubleshooting/mmap_cannot_allocate_memory.html +22 -35
- data/vendor/local/share/doc/groonga/ja/html/tutorial.html +9 -19
- data/vendor/local/share/doc/groonga/ja/html/tutorial/data.html +12 -25
- data/vendor/local/share/doc/groonga/ja/html/tutorial/drilldown.html +15 -29
- data/vendor/local/share/doc/groonga/ja/html/tutorial/index.html +10 -21
- data/vendor/local/share/doc/groonga/ja/html/tutorial/introduction.html +29 -47
- data/vendor/local/share/doc/groonga/ja/html/tutorial/lexicon.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/tutorial/match_columns.html +177 -28
- data/vendor/local/share/doc/groonga/ja/html/tutorial/micro_blog.html +34 -129
- data/vendor/local/share/doc/groonga/ja/html/tutorial/network.html +16 -26
- data/vendor/local/share/doc/groonga/ja/html/tutorial/patricia_trie.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/tutorial/query_expansion.html +9 -20
- data/vendor/local/share/doc/groonga/ja/html/tutorial/search.html +18 -33
- data/vendor/local/share/doc/pcre/AUTHORS +3 -3
- data/vendor/local/share/doc/pcre/ChangeLog +94 -0
- data/vendor/local/share/doc/pcre/LICENCE +3 -3
- data/vendor/local/share/doc/pcre/NEWS +12 -0
- data/vendor/local/share/doc/pcre/html/pcrecompat.html +1 -1
- data/vendor/local/share/doc/pcre/html/pcrejit.html +52 -5
- data/vendor/local/share/doc/pcre/html/pcrepattern.html +20 -17
- data/vendor/local/share/doc/pcre/html/pcretest.html +7 -2
- data/vendor/local/share/doc/pcre/pcre.txt +1103 -1055
- data/vendor/local/share/doc/pcre/pcretest.txt +6 -2
- data/vendor/local/share/groonga/groonga-log/README.md +44 -0
- data/vendor/local/share/groonga/groonga-log/lgpl-2.1.txt +502 -0
- data/vendor/local/share/groonga/mruby/LEGAL +4 -0
- data/vendor/local/share/license/cv2pdb/LICENSE +201 -0
- data/vendor/local/share/license/cv2pdb/README +138 -0
- data/vendor/local/share/license/groonga-log/README.md +44 -0
- data/vendor/local/share/license/groonga-log/lgpl-2.1.txt +502 -0
- data/vendor/local/share/license/pcre/LICENCE +3 -3
- data/vendor/local/share/man/man1/pcretest.1 +7 -3
- data/vendor/local/share/man/man3/pcrecompat.3 +1 -1
- data/vendor/local/share/man/man3/pcrejit.3 +48 -6
- data/vendor/local/share/man/man3/pcrepattern.3 +20 -17
- metadata +102 -559
- data/lib/groonga/statistic-measurer.rb +0 -37
- data/test/test-statistic-measurer.rb +0 -55
- data/vendor/local/share/doc/groonga/en/html/_sources/characteristic.txt +0 -70
- data/vendor/local/share/doc/groonga/en/html/_sources/client.txt +0 -19
- data/vendor/local/share/doc/groonga/en/html/_sources/community.txt +0 -49
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution.txt +0 -26
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/development.txt +0 -14
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/development/build.txt +0 -19
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/development/build/unix_autotools.txt +0 -101
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/development/build/unix_cmake.txt +0 -94
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/development/build/windows_cmake.txt +0 -93
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/development/com.txt +0 -20
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/development/cooperation.txt +0 -75
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/development/query.txt +0 -214
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/development/release.txt +0 -790
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/development/repository.txt +0 -16
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/development/test.txt +0 -120
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/documentation.txt +0 -18
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/documentation/c-api.txt +0 -14
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/documentation/i18n.txt +0 -200
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/documentation/introduction.txt +0 -81
- data/vendor/local/share/doc/groonga/en/html/_sources/contribution/report.txt +0 -27
- data/vendor/local/share/doc/groonga/en/html/_sources/development.txt +0 -16
- data/vendor/local/share/doc/groonga/en/html/_sources/development/travis-ci.txt +0 -66
- data/vendor/local/share/doc/groonga/en/html/_sources/index.txt +0 -33
- data/vendor/local/share/doc/groonga/en/html/_sources/install.txt +0 -28
- data/vendor/local/share/doc/groonga/en/html/_sources/install/centos.txt +0 -106
- data/vendor/local/share/doc/groonga/en/html/_sources/install/debian.txt +0 -107
- data/vendor/local/share/doc/groonga/en/html/_sources/install/fedora.txt +0 -97
- data/vendor/local/share/doc/groonga/en/html/_sources/install/mac_os_x.txt +0 -66
- data/vendor/local/share/doc/groonga/en/html/_sources/install/others.txt +0 -273
- data/vendor/local/share/doc/groonga/en/html/_sources/install/solaris.txt +0 -43
- data/vendor/local/share/doc/groonga/en/html/_sources/install/ubuntu.txt +0 -99
- data/vendor/local/share/doc/groonga/en/html/_sources/install/windows.txt +0 -92
- data/vendor/local/share/doc/groonga/en/html/_sources/limitations.txt +0 -58
- data/vendor/local/share/doc/groonga/en/html/_sources/news.txt +0 -315
- data/vendor/local/share/doc/groonga/en/html/_sources/news/0.x.txt +0 -126
- data/vendor/local/share/doc/groonga/en/html/_sources/news/1.0.x.txt +0 -289
- data/vendor/local/share/doc/groonga/en/html/_sources/news/1.1.x.txt +0 -31
- data/vendor/local/share/doc/groonga/en/html/_sources/news/1.2.x.txt +0 -390
- data/vendor/local/share/doc/groonga/en/html/_sources/news/1.3.x.txt +0 -52
- data/vendor/local/share/doc/groonga/en/html/_sources/news/2.x.txt +0 -623
- data/vendor/local/share/doc/groonga/en/html/_sources/news/3.x.txt +0 -539
- data/vendor/local/share/doc/groonga/en/html/_sources/news/4.x.txt +0 -689
- data/vendor/local/share/doc/groonga/en/html/_sources/news/5.x.txt +0 -1250
- data/vendor/local/share/doc/groonga/en/html/_sources/news/6.x.txt +0 -1086
- data/vendor/local/share/doc/groonga/en/html/_sources/news/senna.txt +0 -109
- data/vendor/local/share/doc/groonga/en/html/_sources/reference.txt +0 -35
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/alias.txt +0 -164
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api.txt +0 -18
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/global_configurations.txt +0 -49
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_cache.txt +0 -114
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_column.txt +0 -198
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_command_version.txt +0 -37
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_content_type.txt +0 -39
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_ctx.txt +0 -195
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_db.txt +0 -134
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_encoding.txt +0 -49
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_expr.txt +0 -136
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_geo.txt +0 -55
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_hook.txt +0 -67
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_ii.txt +0 -35
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_index_cursor.txt +0 -44
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_info.txt +0 -56
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_match_escalation.txt +0 -39
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_obj.txt +0 -269
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_proc.txt +0 -56
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_search.txt +0 -31
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_table.txt +0 -219
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_table_cursor.txt +0 -109
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_thread.txt +0 -122
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_type.txt +0 -31
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/grn_user_data.txt +0 -29
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/overview.txt +0 -54
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/api/plugin.txt +0 -156
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/cast.txt +0 -8
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/column.txt +0 -34
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/columns/index.txt +0 -19
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/columns/pseudo.txt +0 -40
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/columns/scalar.txt +0 -19
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/columns/vector.txt +0 -332
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/command.txt +0 -23
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/command/command_version.txt +0 -75
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/command/output_format.txt +0 -228
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/command/pretty_print.txt +0 -45
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/command/request_id.txt +0 -41
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/command/request_timeout.txt +0 -78
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/command/return_code.txt +0 -117
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/cache_limit.txt +0 -87
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/check.txt +0 -161
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/clearlock.txt +0 -60
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/column_copy.txt +0 -381
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/column_create.txt +0 -800
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/column_list.txt +0 -209
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/column_remove.txt +0 -57
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/column_rename.txt +0 -101
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/config_delete.txt +0 -95
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/config_get.txt +0 -96
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/config_set.txt +0 -96
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/database_unmap.txt +0 -85
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/define_selector.txt +0 -110
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/defrag.txt +0 -55
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/delete.txt +0 -122
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/dump.txt +0 -202
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/io_flush.txt +0 -266
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/load.txt +0 -100
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/lock_acquire.txt +0 -102
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/lock_clear.txt +0 -90
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/lock_release.txt +0 -98
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/log_level.txt +0 -87
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/log_put.txt +0 -65
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/log_reopen.txt +0 -62
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/logical_count.txt +0 -171
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/logical_parameters.txt +0 -134
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/logical_range_filter.txt +0 -195
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/logical_select.txt +0 -1359
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/logical_shard_list.txt +0 -103
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/logical_table_remove.txt +0 -541
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/normalize.txt +0 -155
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/normalizer_list.txt +0 -64
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/object_exist.txt +0 -95
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/object_inspect.txt +0 -899
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/object_list.txt +0 -405
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/object_remove.txt +0 -140
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/plugin_register.txt +0 -64
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/plugin_unregister.txt +0 -63
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/query_expand.txt +0 -38
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/quit.txt +0 -38
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/range_filter.txt +0 -28
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/register.txt +0 -69
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/reindex.txt +0 -142
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/request_cancel.txt +0 -134
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/ruby_eval.txt +0 -71
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/ruby_load.txt +0 -71
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/schema.txt +0 -627
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/select.txt +0 -2776
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/shutdown.txt +0 -113
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/status.txt +0 -151
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/suggest.txt +0 -271
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/table_copy.txt +0 -64
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/table_create.txt +0 -380
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/table_list.txt +0 -81
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/table_remove.txt +0 -309
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/table_rename.txt +0 -90
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/table_tokenize.txt +0 -120
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/thread_limit.txt +0 -110
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/tokenize.txt +0 -248
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/tokenizer_list.txt +0 -63
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/commands/truncate.txt +0 -95
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/configuration.txt +0 -50
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/executables.txt +0 -14
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/executables/grndb.txt +0 -117
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/executables/grnslap.txt +0 -68
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/executables/groonga-benchmark.txt +0 -287
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/executables/groonga-httpd.txt +0 -552
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/executables/groonga-server-http.txt +0 -57
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/executables/groonga-suggest-create-dataset.txt +0 -63
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/executables/groonga-suggest-httpd.txt +0 -470
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/executables/groonga-suggest-learner.txt +0 -94
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/executables/groonga.txt +0 -473
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/function.txt +0 -20
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/between.txt +0 -105
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/edit_distance.txt +0 -48
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/fuzzy_search.txt +0 -23
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/geo_distance.txt +0 -300
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/geo_in_circle.txt +0 -81
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/geo_in_rectangle.txt +0 -55
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/highlight_full.txt +0 -127
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/highlight_html.txt +0 -105
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/html_untag.txt +0 -80
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/in_records.txt +0 -195
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/in_values.txt +0 -82
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/now.txt +0 -36
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/number_classify.txt +0 -20
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/prefix_rk_search.txt +0 -158
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/query.txt +0 -254
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/rand.txt +0 -43
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/snippet_html.txt +0 -114
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/string_length.txt +0 -33
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/string_substring.txt +0 -27
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/sub_filter.txt +0 -137
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/time_classify_day.txt +0 -18
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/time_classify_hour.txt +0 -18
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/time_classify_minute.txt +0 -18
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/time_classify_month.txt +0 -20
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/time_classify_second.txt +0 -18
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/time_classify_week.txt +0 -18
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/time_classify_year.txt +0 -18
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/vector_new.txt +0 -38
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/vector_size.txt +0 -76
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/functions/vector_slice.txt +0 -27
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/grn_expr.txt +0 -59
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/grn_expr/query_syntax.txt +0 -652
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/grn_expr/script_syntax.txt +0 -1126
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/indexing.txt +0 -112
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/log.txt +0 -236
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/normalizers.txt +0 -133
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/operations.txt +0 -16
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/operations/geolocation_search.txt +0 -52
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/operations/prefix_rk_search.txt +0 -76
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/output.txt +0 -164
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/query_expanders.txt +0 -12
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/query_expanders/tsv.txt +0 -153
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/regular_expression.txt +0 -436
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/scorer.txt +0 -218
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/scorers/scorer_tf_at_most.txt +0 -136
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/scorers/scorer_tf_idf.txt +0 -157
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/sharding.txt +0 -104
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/suggest.txt +0 -17
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/suggest/completion.txt +0 -271
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/suggest/correction.txt +0 -148
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/suggest/introduction.txt +0 -96
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/suggest/suggestion.txt +0 -132
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/tables.txt +0 -216
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/token_filters.txt +0 -120
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/tokenizers.txt +0 -517
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/tuning.txt +0 -177
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/types.txt +0 -170
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/window_function.txt +0 -22
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/window_functions/record_number.txt +0 -28
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/window_functions/window_record_number.txt +0 -25
- data/vendor/local/share/doc/groonga/en/html/_sources/reference/window_functions/window_sum.txt +0 -25
- data/vendor/local/share/doc/groonga/en/html/_sources/server.txt +0 -15
- data/vendor/local/share/doc/groonga/en/html/_sources/server/gqtp.txt +0 -48
- data/vendor/local/share/doc/groonga/en/html/_sources/server/http.txt +0 -25
- data/vendor/local/share/doc/groonga/en/html/_sources/server/http/comparison.txt +0 -298
- data/vendor/local/share/doc/groonga/en/html/_sources/server/http/groonga-httpd.txt +0 -8
- data/vendor/local/share/doc/groonga/en/html/_sources/server/http/groonga.txt +0 -8
- data/vendor/local/share/doc/groonga/en/html/_sources/server/memcached.txt +0 -16
- data/vendor/local/share/doc/groonga/en/html/_sources/server/package.txt +0 -209
- data/vendor/local/share/doc/groonga/en/html/_sources/spec.txt +0 -13
- data/vendor/local/share/doc/groonga/en/html/_sources/spec/gqtp.txt +0 -280
- data/vendor/local/share/doc/groonga/en/html/_sources/spec/search.txt +0 -115
- data/vendor/local/share/doc/groonga/en/html/_sources/troubleshooting.txt +0 -13
- data/vendor/local/share/doc/groonga/en/html/_sources/troubleshooting/different_results_with_the_same_keyword.txt +0 -135
- data/vendor/local/share/doc/groonga/en/html/_sources/troubleshooting/mmap_cannot_allocate_memory.txt +0 -45
- data/vendor/local/share/doc/groonga/en/html/_sources/tutorial.txt +0 -22
- data/vendor/local/share/doc/groonga/en/html/_sources/tutorial/data.txt +0 -173
- data/vendor/local/share/doc/groonga/en/html/_sources/tutorial/drilldown.txt +0 -130
- data/vendor/local/share/doc/groonga/en/html/_sources/tutorial/index.txt +0 -123
- data/vendor/local/share/doc/groonga/en/html/_sources/tutorial/introduction.txt +0 -294
- data/vendor/local/share/doc/groonga/en/html/_sources/tutorial/lexicon.txt +0 -12
- data/vendor/local/share/doc/groonga/en/html/_sources/tutorial/match_columns.txt +0 -234
- data/vendor/local/share/doc/groonga/en/html/_sources/tutorial/micro_blog.txt +0 -539
- data/vendor/local/share/doc/groonga/en/html/_sources/tutorial/network.txt +0 -64
- data/vendor/local/share/doc/groonga/en/html/_sources/tutorial/patricia_trie.txt +0 -58
- data/vendor/local/share/doc/groonga/en/html/_sources/tutorial/query_expansion.txt +0 -69
- data/vendor/local/share/doc/groonga/en/html/_sources/tutorial/search.txt +0 -123
- data/vendor/local/share/doc/groonga/ja/html/_sources/characteristic.txt +0 -70
- data/vendor/local/share/doc/groonga/ja/html/_sources/client.txt +0 -19
- data/vendor/local/share/doc/groonga/ja/html/_sources/community.txt +0 -49
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution.txt +0 -26
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/development.txt +0 -14
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/development/build.txt +0 -19
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/development/build/unix_autotools.txt +0 -101
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/development/build/unix_cmake.txt +0 -94
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/development/build/windows_cmake.txt +0 -93
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/development/com.txt +0 -20
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/development/cooperation.txt +0 -75
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/development/query.txt +0 -214
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/development/release.txt +0 -790
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/development/repository.txt +0 -16
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/development/test.txt +0 -120
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/documentation.txt +0 -18
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/documentation/c-api.txt +0 -14
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/documentation/i18n.txt +0 -200
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/documentation/introduction.txt +0 -81
- data/vendor/local/share/doc/groonga/ja/html/_sources/contribution/report.txt +0 -27
- data/vendor/local/share/doc/groonga/ja/html/_sources/development.txt +0 -16
- data/vendor/local/share/doc/groonga/ja/html/_sources/development/travis-ci.txt +0 -66
- data/vendor/local/share/doc/groonga/ja/html/_sources/index.txt +0 -33
- data/vendor/local/share/doc/groonga/ja/html/_sources/install.txt +0 -28
- data/vendor/local/share/doc/groonga/ja/html/_sources/install/centos.txt +0 -106
- data/vendor/local/share/doc/groonga/ja/html/_sources/install/debian.txt +0 -107
- data/vendor/local/share/doc/groonga/ja/html/_sources/install/fedora.txt +0 -97
- data/vendor/local/share/doc/groonga/ja/html/_sources/install/mac_os_x.txt +0 -66
- data/vendor/local/share/doc/groonga/ja/html/_sources/install/others.txt +0 -273
- data/vendor/local/share/doc/groonga/ja/html/_sources/install/solaris.txt +0 -43
- data/vendor/local/share/doc/groonga/ja/html/_sources/install/ubuntu.txt +0 -99
- data/vendor/local/share/doc/groonga/ja/html/_sources/install/windows.txt +0 -92
- data/vendor/local/share/doc/groonga/ja/html/_sources/limitations.txt +0 -58
- data/vendor/local/share/doc/groonga/ja/html/_sources/news.txt +0 -315
- data/vendor/local/share/doc/groonga/ja/html/_sources/news/0.x.txt +0 -126
- data/vendor/local/share/doc/groonga/ja/html/_sources/news/1.0.x.txt +0 -289
- data/vendor/local/share/doc/groonga/ja/html/_sources/news/1.1.x.txt +0 -31
- data/vendor/local/share/doc/groonga/ja/html/_sources/news/1.2.x.txt +0 -390
- data/vendor/local/share/doc/groonga/ja/html/_sources/news/1.3.x.txt +0 -52
- data/vendor/local/share/doc/groonga/ja/html/_sources/news/2.x.txt +0 -623
- data/vendor/local/share/doc/groonga/ja/html/_sources/news/3.x.txt +0 -539
- data/vendor/local/share/doc/groonga/ja/html/_sources/news/4.x.txt +0 -689
- data/vendor/local/share/doc/groonga/ja/html/_sources/news/5.x.txt +0 -1250
- data/vendor/local/share/doc/groonga/ja/html/_sources/news/6.x.txt +0 -1086
- data/vendor/local/share/doc/groonga/ja/html/_sources/news/senna.txt +0 -109
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference.txt +0 -35
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/alias.txt +0 -164
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api.txt +0 -18
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/global_configurations.txt +0 -49
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_cache.txt +0 -114
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_column.txt +0 -198
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_command_version.txt +0 -37
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_content_type.txt +0 -39
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_ctx.txt +0 -195
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_db.txt +0 -134
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_encoding.txt +0 -49
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_expr.txt +0 -136
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_geo.txt +0 -55
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_hook.txt +0 -67
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_ii.txt +0 -35
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_index_cursor.txt +0 -44
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_info.txt +0 -56
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_match_escalation.txt +0 -39
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_obj.txt +0 -269
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_proc.txt +0 -56
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_search.txt +0 -31
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_table.txt +0 -219
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_table_cursor.txt +0 -109
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_thread.txt +0 -122
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_type.txt +0 -31
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/grn_user_data.txt +0 -29
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/overview.txt +0 -54
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/api/plugin.txt +0 -156
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/cast.txt +0 -8
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/column.txt +0 -34
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/columns/index.txt +0 -19
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/columns/pseudo.txt +0 -40
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/columns/scalar.txt +0 -19
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/columns/vector.txt +0 -332
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/command.txt +0 -23
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/command/command_version.txt +0 -75
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/command/output_format.txt +0 -228
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/command/pretty_print.txt +0 -45
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/command/request_id.txt +0 -41
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/command/request_timeout.txt +0 -78
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/command/return_code.txt +0 -117
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/cache_limit.txt +0 -87
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/check.txt +0 -161
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/clearlock.txt +0 -60
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/column_copy.txt +0 -381
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/column_create.txt +0 -800
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/column_list.txt +0 -209
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/column_remove.txt +0 -57
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/column_rename.txt +0 -101
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/config_delete.txt +0 -95
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/config_get.txt +0 -96
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/config_set.txt +0 -96
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/database_unmap.txt +0 -85
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/define_selector.txt +0 -110
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/defrag.txt +0 -55
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/delete.txt +0 -122
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/dump.txt +0 -202
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/io_flush.txt +0 -266
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/load.txt +0 -100
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/lock_acquire.txt +0 -102
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/lock_clear.txt +0 -90
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/lock_release.txt +0 -98
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/log_level.txt +0 -87
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/log_put.txt +0 -65
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/log_reopen.txt +0 -62
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/logical_count.txt +0 -171
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/logical_parameters.txt +0 -134
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/logical_range_filter.txt +0 -195
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/logical_select.txt +0 -1359
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/logical_shard_list.txt +0 -103
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/logical_table_remove.txt +0 -541
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/normalize.txt +0 -155
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/normalizer_list.txt +0 -64
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/object_exist.txt +0 -95
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/object_inspect.txt +0 -899
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/object_list.txt +0 -405
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/object_remove.txt +0 -140
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/plugin_register.txt +0 -64
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/plugin_unregister.txt +0 -63
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/query_expand.txt +0 -38
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/quit.txt +0 -38
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/range_filter.txt +0 -28
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/register.txt +0 -69
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/reindex.txt +0 -142
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/request_cancel.txt +0 -134
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/ruby_eval.txt +0 -71
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/ruby_load.txt +0 -71
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/schema.txt +0 -627
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/select.txt +0 -2776
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/shutdown.txt +0 -113
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/status.txt +0 -151
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/suggest.txt +0 -271
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/table_copy.txt +0 -64
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/table_create.txt +0 -380
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/table_list.txt +0 -81
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/table_remove.txt +0 -309
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/table_rename.txt +0 -90
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/table_tokenize.txt +0 -120
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/thread_limit.txt +0 -110
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/tokenize.txt +0 -248
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/tokenizer_list.txt +0 -63
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/commands/truncate.txt +0 -95
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/configuration.txt +0 -50
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/executables.txt +0 -14
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/executables/grndb.txt +0 -117
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/executables/grnslap.txt +0 -68
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/executables/groonga-benchmark.txt +0 -287
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/executables/groonga-httpd.txt +0 -552
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/executables/groonga-server-http.txt +0 -57
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/executables/groonga-suggest-create-dataset.txt +0 -63
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/executables/groonga-suggest-httpd.txt +0 -470
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/executables/groonga-suggest-learner.txt +0 -94
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/executables/groonga.txt +0 -473
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/function.txt +0 -20
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/between.txt +0 -105
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/edit_distance.txt +0 -48
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/fuzzy_search.txt +0 -23
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/geo_distance.txt +0 -300
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/geo_in_circle.txt +0 -81
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/geo_in_rectangle.txt +0 -55
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/highlight_full.txt +0 -127
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/highlight_html.txt +0 -105
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/html_untag.txt +0 -80
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/in_records.txt +0 -195
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/in_values.txt +0 -82
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/now.txt +0 -36
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/number_classify.txt +0 -20
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/prefix_rk_search.txt +0 -158
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/query.txt +0 -254
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/rand.txt +0 -43
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/snippet_html.txt +0 -114
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/string_length.txt +0 -33
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/string_substring.txt +0 -27
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/sub_filter.txt +0 -137
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/time_classify_day.txt +0 -18
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/time_classify_hour.txt +0 -18
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/time_classify_minute.txt +0 -18
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/time_classify_month.txt +0 -20
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/time_classify_second.txt +0 -18
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/time_classify_week.txt +0 -18
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/time_classify_year.txt +0 -18
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/vector_new.txt +0 -38
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/vector_size.txt +0 -76
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/functions/vector_slice.txt +0 -27
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/grn_expr.txt +0 -59
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/grn_expr/query_syntax.txt +0 -652
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/grn_expr/script_syntax.txt +0 -1126
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/indexing.txt +0 -112
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/log.txt +0 -236
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/normalizers.txt +0 -133
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/operations.txt +0 -16
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/operations/geolocation_search.txt +0 -52
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/operations/prefix_rk_search.txt +0 -76
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/output.txt +0 -164
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/query_expanders.txt +0 -12
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/query_expanders/tsv.txt +0 -153
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/regular_expression.txt +0 -436
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/scorer.txt +0 -218
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/scorers/scorer_tf_at_most.txt +0 -136
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/scorers/scorer_tf_idf.txt +0 -157
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/sharding.txt +0 -104
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/suggest.txt +0 -17
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/suggest/completion.txt +0 -271
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/suggest/correction.txt +0 -148
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/suggest/introduction.txt +0 -96
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/suggest/suggestion.txt +0 -132
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/tables.txt +0 -216
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/token_filters.txt +0 -120
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/tokenizers.txt +0 -517
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/tuning.txt +0 -177
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/types.txt +0 -170
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/window_function.txt +0 -22
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/window_functions/record_number.txt +0 -28
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/window_functions/window_record_number.txt +0 -25
- data/vendor/local/share/doc/groonga/ja/html/_sources/reference/window_functions/window_sum.txt +0 -25
- data/vendor/local/share/doc/groonga/ja/html/_sources/server.txt +0 -15
- data/vendor/local/share/doc/groonga/ja/html/_sources/server/gqtp.txt +0 -48
- data/vendor/local/share/doc/groonga/ja/html/_sources/server/http.txt +0 -25
- data/vendor/local/share/doc/groonga/ja/html/_sources/server/http/comparison.txt +0 -298
- data/vendor/local/share/doc/groonga/ja/html/_sources/server/http/groonga-httpd.txt +0 -8
- data/vendor/local/share/doc/groonga/ja/html/_sources/server/http/groonga.txt +0 -8
- data/vendor/local/share/doc/groonga/ja/html/_sources/server/memcached.txt +0 -16
- data/vendor/local/share/doc/groonga/ja/html/_sources/server/package.txt +0 -209
- data/vendor/local/share/doc/groonga/ja/html/_sources/spec.txt +0 -13
- data/vendor/local/share/doc/groonga/ja/html/_sources/spec/gqtp.txt +0 -280
- data/vendor/local/share/doc/groonga/ja/html/_sources/spec/search.txt +0 -115
- data/vendor/local/share/doc/groonga/ja/html/_sources/troubleshooting.txt +0 -13
- data/vendor/local/share/doc/groonga/ja/html/_sources/troubleshooting/different_results_with_the_same_keyword.txt +0 -135
- data/vendor/local/share/doc/groonga/ja/html/_sources/troubleshooting/mmap_cannot_allocate_memory.txt +0 -45
- data/vendor/local/share/doc/groonga/ja/html/_sources/tutorial.txt +0 -22
- data/vendor/local/share/doc/groonga/ja/html/_sources/tutorial/data.txt +0 -173
- data/vendor/local/share/doc/groonga/ja/html/_sources/tutorial/drilldown.txt +0 -130
- data/vendor/local/share/doc/groonga/ja/html/_sources/tutorial/index.txt +0 -123
- data/vendor/local/share/doc/groonga/ja/html/_sources/tutorial/introduction.txt +0 -294
- data/vendor/local/share/doc/groonga/ja/html/_sources/tutorial/lexicon.txt +0 -12
- data/vendor/local/share/doc/groonga/ja/html/_sources/tutorial/match_columns.txt +0 -234
- data/vendor/local/share/doc/groonga/ja/html/_sources/tutorial/micro_blog.txt +0 -539
- data/vendor/local/share/doc/groonga/ja/html/_sources/tutorial/network.txt +0 -64
- data/vendor/local/share/doc/groonga/ja/html/_sources/tutorial/patricia_trie.txt +0 -58
- data/vendor/local/share/doc/groonga/ja/html/_sources/tutorial/query_expansion.txt +0 -69
- data/vendor/local/share/doc/groonga/ja/html/_sources/tutorial/search.txt +0 -123
@@ -358,24 +358,24 @@ When PCRE is compiled in EBCDIC mode, \a, \e, \f, \n, \r, and \t
|
|
358
358
|
generate the appropriate EBCDIC code values. The \c escape is processed
|
359
359
|
as specified for Perl in the <b>perlebcdic</b> document. The only characters
|
360
360
|
that are allowed after \c are A-Z, a-z, or one of @, [, \, ], ^, _, or ?. Any
|
361
|
-
other character provokes a compile-time error. The sequence
|
362
|
-
character code 0; the letters (in either case) encode characters 1-26
|
363
|
-
to hex 1A); [, \, ], ^, and _ encode characters 27-31 (hex 1B to hex
|
364
|
-
|
361
|
+
other character provokes a compile-time error. The sequence \c@ encodes
|
362
|
+
character code 0; after \c the letters (in either case) encode characters 1-26
|
363
|
+
(hex 01 to hex 1A); [, \, ], ^, and _ encode characters 27-31 (hex 1B to hex
|
364
|
+
1F), and \c? becomes either 255 (hex FF) or 95 (hex 5F).
|
365
365
|
</P>
|
366
366
|
<P>
|
367
|
-
Thus, apart from
|
367
|
+
Thus, apart from \c?, these escapes generate the same character code values as
|
368
368
|
they do in an ASCII environment, though the meanings of the values mostly
|
369
|
-
differ. For example, \
|
369
|
+
differ. For example, \cG always generates code value 7, which is BEL in ASCII
|
370
370
|
but DEL in EBCDIC.
|
371
371
|
</P>
|
372
372
|
<P>
|
373
|
-
The sequence
|
373
|
+
The sequence \c? generates DEL (127, hex 7F) in an ASCII environment, but
|
374
374
|
because 127 is not a control character in EBCDIC, Perl makes it generate the
|
375
375
|
APC character. Unfortunately, there are several variants of EBCDIC. In most of
|
376
376
|
them the APC character has the value 255 (hex FF), but in the one Perl calls
|
377
377
|
POSIX-BC its value is 95 (hex 5F). If certain other characters have POSIX-BC
|
378
|
-
values, PCRE makes
|
378
|
+
values, PCRE makes \c? generate 95; otherwise it generates 255.
|
379
379
|
</P>
|
380
380
|
<P>
|
381
381
|
After \0 up to two further octal digits are read. If there are fewer than two
|
@@ -1512,13 +1512,8 @@ J, U and X respectively.
|
|
1512
1512
|
<P>
|
1513
1513
|
When one of these option changes occurs at top level (that is, not inside
|
1514
1514
|
subpattern parentheses), the change applies to the remainder of the pattern
|
1515
|
-
that follows.
|
1516
|
-
|
1517
|
-
extracted by the <b>pcre_fullinfo()</b> function).
|
1518
|
-
</P>
|
1519
|
-
<P>
|
1520
|
-
An option change within a subpattern (see below for a description of
|
1521
|
-
subpatterns) affects only that part of the subpattern that follows it, so
|
1515
|
+
that follows. An option change within a subpattern (see below for a description
|
1516
|
+
of subpatterns) affects only that part of the subpattern that follows it, so
|
1522
1517
|
<pre>
|
1523
1518
|
(a(?i)b)c
|
1524
1519
|
</pre>
|
@@ -2160,6 +2155,14 @@ capturing is carried out only for positive assertions. (Perl sometimes, but not
|
|
2160
2155
|
always, does do capturing in negative assertions.)
|
2161
2156
|
</P>
|
2162
2157
|
<P>
|
2158
|
+
WARNING: If a positive assertion containing one or more capturing subpatterns
|
2159
|
+
succeeds, but failure to match later in the pattern causes backtracking over
|
2160
|
+
this assertion, the captures within the assertion are reset only if no higher
|
2161
|
+
numbered captures are already set. This is, unfortunately, a fundamental
|
2162
|
+
limitation of the current implementation, and as PCRE1 is now in
|
2163
|
+
maintenance-only status, it is unlikely ever to change.
|
2164
|
+
</P>
|
2165
|
+
<P>
|
2163
2166
|
For compatibility with Perl, assertion subpatterns may be repeated; though
|
2164
2167
|
it makes no sense to assert the same thing several times, the side effect of
|
2165
2168
|
capturing parentheses may occasionally be useful. In practice, there only three
|
@@ -3264,9 +3267,9 @@ Cambridge CB2 3QH, England.
|
|
3264
3267
|
</P>
|
3265
3268
|
<br><a name="SEC30" href="#TOC1">REVISION</a><br>
|
3266
3269
|
<P>
|
3267
|
-
Last updated:
|
3270
|
+
Last updated: 23 October 2016
|
3268
3271
|
<br>
|
3269
|
-
Copyright © 1997-
|
3272
|
+
Copyright © 1997-2016 University of Cambridge.
|
3270
3273
|
<br>
|
3271
3274
|
<p>
|
3272
3275
|
Return to the <a href="index.html">PCRE index page</a>.
|
@@ -74,6 +74,11 @@ newline as data characters. However, in some Windows environments character 26
|
|
74
74
|
maximum portability, therefore, it is safest to use only ASCII characters in
|
75
75
|
<b>pcretest</b> input files.
|
76
76
|
</P>
|
77
|
+
<P>
|
78
|
+
The input is processed using using C's string functions, so must not
|
79
|
+
contain binary zeroes, even though in Unix-like environments, <b>fgets()</b>
|
80
|
+
treats any bytes other than newline as data characters.
|
81
|
+
</P>
|
77
82
|
<br><a name="SEC3" href="#TOC1">PCRE's 8-BIT, 16-BIT AND 32-BIT LIBRARIES</a><br>
|
78
83
|
<P>
|
79
84
|
From release 8.30, two separate PCRE libraries can be built. The original one
|
@@ -1149,9 +1154,9 @@ Cambridge CB2 3QH, England.
|
|
1149
1154
|
</P>
|
1150
1155
|
<br><a name="SEC17" href="#TOC1">REVISION</a><br>
|
1151
1156
|
<P>
|
1152
|
-
Last updated:
|
1157
|
+
Last updated: 23 February 2017
|
1153
1158
|
<br>
|
1154
|
-
Copyright © 1997-
|
1159
|
+
Copyright © 1997-2017 University of Cambridge.
|
1155
1160
|
<br>
|
1156
1161
|
<p>
|
1157
1162
|
Return to the <a href="index.html">PCRE index page</a>.
|
@@ -4640,7 +4640,7 @@ DIFFERENCES BETWEEN PCRE AND PERL
|
|
4640
4640
|
pattern names is not as general as Perl's. This is a consequence of the
|
4641
4641
|
fact the PCRE works internally just with numbers, using an external ta-
|
4642
4642
|
ble to translate between numbers and names. In particular, a pattern
|
4643
|
-
such as (?|(?<a>A)|(?<b
|
4643
|
+
such as (?|(?<a>A)|(?<b>B), where the two capturing parentheses have
|
4644
4644
|
the same number but different names, is not supported, and causes an
|
4645
4645
|
error at compile time. If it were allowed, it would not be possible to
|
4646
4646
|
distinguish which parentheses matched, because both names map to cap-
|
@@ -5028,55 +5028,56 @@ BACKSLASH
|
|
5028
5028
|
ate the appropriate EBCDIC code values. The \c escape is processed as
|
5029
5029
|
specified for Perl in the perlebcdic document. The only characters that
|
5030
5030
|
are allowed after \c are A-Z, a-z, or one of @, [, \, ], ^, _, or ?.
|
5031
|
-
Any other character provokes a
|
5032
|
-
encodes character code 0; the letters (in either case) encode
|
5033
|
-
|
5034
|
-
(hex 1B to hex 1F), and
|
5035
|
-
|
5036
|
-
|
5037
|
-
|
5038
|
-
values
|
5031
|
+
Any other character provokes a compile-time error. The sequence \c@
|
5032
|
+
encodes character code 0; after \c the letters (in either case) encode
|
5033
|
+
characters 1-26 (hex 01 to hex 1A); [, \, ], ^, and _ encode characters
|
5034
|
+
27-31 (hex 1B to hex 1F), and \c? becomes either 255 (hex FF) or 95
|
5035
|
+
(hex 5F).
|
5036
|
+
|
5037
|
+
Thus, apart from \c?, these escapes generate the same character code
|
5038
|
+
values as they do in an ASCII environment, though the meanings of the
|
5039
|
+
values mostly differ. For example, \cG always generates code value 7,
|
5039
5040
|
which is BEL in ASCII but DEL in EBCDIC.
|
5040
5041
|
|
5041
|
-
The
|
5042
|
-
but
|
5043
|
-
generate
|
5044
|
-
of
|
5045
|
-
FF),
|
5046
|
-
certain
|
5042
|
+
The sequence \c? generates DEL (127, hex 7F) in an ASCII environment,
|
5043
|
+
but because 127 is not a control character in EBCDIC, Perl makes it
|
5044
|
+
generate the APC character. Unfortunately, there are several variants
|
5045
|
+
of EBCDIC. In most of them the APC character has the value 255 (hex
|
5046
|
+
FF), but in the one Perl calls POSIX-BC its value is 95 (hex 5F). If
|
5047
|
+
certain other characters have POSIX-BC values, PCRE makes \c? generate
|
5047
5048
|
95; otherwise it generates 255.
|
5048
5049
|
|
5049
|
-
After
|
5050
|
-
than
|
5050
|
+
After \0 up to two further octal digits are read. If there are fewer
|
5051
|
+
than two digits, just those that are present are used. Thus the
|
5051
5052
|
sequence \0\x\015 specifies two binary zeros followed by a CR character
|
5052
5053
|
(code value 13). Make sure you supply two digits after the initial zero
|
5053
5054
|
if the pattern character that follows is itself an octal digit.
|
5054
5055
|
|
5055
|
-
The
|
5056
|
-
in
|
5057
|
-
recent
|
5058
|
-
points
|
5056
|
+
The escape \o must be followed by a sequence of octal digits, enclosed
|
5057
|
+
in braces. An error occurs if this is not the case. This escape is a
|
5058
|
+
recent addition to Perl; it provides way of specifying character code
|
5059
|
+
points as octal numbers greater than 0777, and it also allows octal
|
5059
5060
|
numbers and back references to be unambiguously specified.
|
5060
5061
|
|
5061
5062
|
For greater clarity and unambiguity, it is best to avoid following \ by
|
5062
5063
|
a digit greater than zero. Instead, use \o{} or \x{} to specify charac-
|
5063
|
-
ter
|
5064
|
+
ter numbers, and \g{} to specify back references. The following para-
|
5064
5065
|
graphs describe the old, ambiguous syntax.
|
5065
5066
|
|
5066
5067
|
The handling of a backslash followed by a digit other than 0 is compli-
|
5067
|
-
cated,
|
5068
|
+
cated, and Perl has changed in recent releases, causing PCRE also to
|
5068
5069
|
change. Outside a character class, PCRE reads the digit and any follow-
|
5069
|
-
ing
|
5070
|
-
there
|
5071
|
-
in
|
5072
|
-
description
|
5070
|
+
ing digits as a decimal number. If the number is less than 8, or if
|
5071
|
+
there have been at least that many previous capturing left parentheses
|
5072
|
+
in the expression, the entire sequence is taken as a back reference. A
|
5073
|
+
description of how this works is given later, following the discussion
|
5073
5074
|
of parenthesized subpatterns.
|
5074
5075
|
|
5075
|
-
Inside
|
5076
|
+
Inside a character class, or if the decimal number following \ is
|
5076
5077
|
greater than 7 and there have not been that many capturing subpatterns,
|
5077
|
-
PCRE
|
5078
|
+
PCRE handles \8 and \9 as the literal characters "8" and "9", and oth-
|
5078
5079
|
erwise re-reads up to three octal digits following the backslash, using
|
5079
|
-
them
|
5080
|
+
them to generate a data character. Any subsequent digits stand for
|
5080
5081
|
themselves. For example:
|
5081
5082
|
|
5082
5083
|
\040 is another way of writing an ASCII space
|
@@ -5094,31 +5095,31 @@ BACKSLASH
|
|
5094
5095
|
\81 is either a back reference, or the two
|
5095
5096
|
characters "8" and "1"
|
5096
5097
|
|
5097
|
-
Note
|
5098
|
-
syntax
|
5098
|
+
Note that octal values of 100 or greater that are specified using this
|
5099
|
+
syntax must not be introduced by a leading zero, because no more than
|
5099
5100
|
three octal digits are ever read.
|
5100
5101
|
|
5101
|
-
By
|
5102
|
-
decimal
|
5102
|
+
By default, after \x that is not followed by {, from zero to two hexa-
|
5103
|
+
decimal digits are read (letters can be in upper or lower case). Any
|
5103
5104
|
number of hexadecimal digits may appear between \x{ and }. If a charac-
|
5104
|
-
ter
|
5105
|
+
ter other than a hexadecimal digit appears between \x{ and }, or if
|
5105
5106
|
there is no terminating }, an error occurs.
|
5106
5107
|
|
5107
|
-
If
|
5108
|
-
is
|
5109
|
-
its.
|
5108
|
+
If the PCRE_JAVASCRIPT_COMPAT option is set, the interpretation of \x
|
5109
|
+
is as just described only when it is followed by two hexadecimal dig-
|
5110
|
+
its. Otherwise, it matches a literal "x" character. In JavaScript
|
5110
5111
|
mode, support for code points greater than 256 is provided by \u, which
|
5111
|
-
must
|
5112
|
+
must be followed by four hexadecimal digits; otherwise it matches a
|
5112
5113
|
literal "u" character.
|
5113
5114
|
|
5114
5115
|
Characters whose value is less than 256 can be defined by either of the
|
5115
|
-
two
|
5116
|
+
two syntaxes for \x (or by \u in JavaScript mode). There is no differ-
|
5116
5117
|
ence in the way they are handled. For example, \xdc is exactly the same
|
5117
5118
|
as \x{dc} (or \u00dc in JavaScript mode).
|
5118
5119
|
|
5119
5120
|
Constraints on character values
|
5120
5121
|
|
5121
|
-
Characters
|
5122
|
+
Characters that are specified using octal or hexadecimal numbers are
|
5122
5123
|
limited to certain values, as follows:
|
5123
5124
|
|
5124
5125
|
8-bit non-UTF mode less than 0x100
|
@@ -5128,44 +5129,44 @@ BACKSLASH
|
|
5128
5129
|
32-bit non-UTF mode less than 0x100000000
|
5129
5130
|
32-bit UTF-32 mode less than 0x10ffff and a valid codepoint
|
5130
5131
|
|
5131
|
-
Invalid
|
5132
|
+
Invalid Unicode codepoints are the range 0xd800 to 0xdfff (the so-
|
5132
5133
|
called "surrogate" codepoints), and 0xffef.
|
5133
5134
|
|
5134
5135
|
Escape sequences in character classes
|
5135
5136
|
|
5136
5137
|
All the sequences that define a single character value can be used both
|
5137
|
-
inside
|
5138
|
+
inside and outside character classes. In addition, inside a character
|
5138
5139
|
class, \b is interpreted as the backspace character (hex 08).
|
5139
5140
|
|
5140
|
-
\N
|
5141
|
-
inside
|
5142
|
-
they
|
5143
|
-
default,
|
5141
|
+
\N is not allowed in a character class. \B, \R, and \X are not special
|
5142
|
+
inside a character class. Like other unrecognized escape sequences,
|
5143
|
+
they are treated as the literal characters "B", "R", and "X" by
|
5144
|
+
default, but cause an error if the PCRE_EXTRA option is set. Outside a
|
5144
5145
|
character class, these sequences have different meanings.
|
5145
5146
|
|
5146
5147
|
Unsupported escape sequences
|
5147
5148
|
|
5148
|
-
In
|
5149
|
-
handler
|
5150
|
-
default,
|
5151
|
-
PCRE_JAVASCRIPT_COMPAT
|
5149
|
+
In Perl, the sequences \l, \L, \u, and \U are recognized by its string
|
5150
|
+
handler and used to modify the case of following characters. By
|
5151
|
+
default, PCRE does not support these escape sequences. However, if the
|
5152
|
+
PCRE_JAVASCRIPT_COMPAT option is set, \U matches a "U" character, and
|
5152
5153
|
\u can be used to define a character by code point, as described in the
|
5153
5154
|
previous section.
|
5154
5155
|
|
5155
5156
|
Absolute and relative back references
|
5156
5157
|
|
5157
|
-
The
|
5158
|
-
ally
|
5158
|
+
The sequence \g followed by an unsigned or a negative number, option-
|
5159
|
+
ally enclosed in braces, is an absolute or relative back reference. A
|
5159
5160
|
named back reference can be coded as \g{name}. Back references are dis-
|
5160
5161
|
cussed later, following the discussion of parenthesized subpatterns.
|
5161
5162
|
|
5162
5163
|
Absolute and relative subroutine calls
|
5163
5164
|
|
5164
|
-
For
|
5165
|
+
For compatibility with Oniguruma, the non-Perl syntax \g followed by a
|
5165
5166
|
name or a number enclosed either in angle brackets or single quotes, is
|
5166
|
-
an
|
5167
|
-
Details
|
5168
|
-
\g<...>
|
5167
|
+
an alternative syntax for referencing a subpattern as a "subroutine".
|
5168
|
+
Details are discussed later. Note that \g{...} (Perl syntax) and
|
5169
|
+
\g<...> (Oniguruma syntax) are not synonymous. The former is a back
|
5169
5170
|
reference; the latter is a subroutine call.
|
5170
5171
|
|
5171
5172
|
Generic character types
|
@@ -5184,59 +5185,59 @@ BACKSLASH
|
|
5184
5185
|
\W any "non-word" character
|
5185
5186
|
|
5186
5187
|
There is also the single sequence \N, which matches a non-newline char-
|
5187
|
-
acter.
|
5188
|
-
not
|
5188
|
+
acter. This is the same as the "." metacharacter when PCRE_DOTALL is
|
5189
|
+
not set. Perl also uses \N to match characters by name; PCRE does not
|
5189
5190
|
support this.
|
5190
5191
|
|
5191
|
-
Each
|
5192
|
-
plete
|
5193
|
-
matches
|
5194
|
-
inside
|
5195
|
-
the
|
5196
|
-
the
|
5192
|
+
Each pair of lower and upper case escape sequences partitions the com-
|
5193
|
+
plete set of characters into two disjoint sets. Any given character
|
5194
|
+
matches one, and only one, of each pair. The sequences can appear both
|
5195
|
+
inside and outside character classes. They each match one character of
|
5196
|
+
the appropriate type. If the current matching point is at the end of
|
5197
|
+
the subject string, all of them fail, because there is no character to
|
5197
5198
|
match.
|
5198
5199
|
|
5199
|
-
For
|
5200
|
-
(code
|
5201
|
-
However,
|
5202
|
-
release
|
5203
|
-
(11),
|
5200
|
+
For compatibility with Perl, \s did not used to match the VT character
|
5201
|
+
(code 11), which made it different from the the POSIX "space" class.
|
5202
|
+
However, Perl added VT at release 5.18, and PCRE followed suit at
|
5203
|
+
release 8.34. The default \s characters are now HT (9), LF (10), VT
|
5204
|
+
(11), FF (12), CR (13), and space (32), which are defined as white
|
5204
5205
|
space in the "C" locale. This list may vary if locale-specific matching
|
5205
|
-
is
|
5206
|
-
character
|
5206
|
+
is taking place. For example, in some locales the "non-breaking space"
|
5207
|
+
character (\xA0) is recognized as white space, and in others the VT
|
5207
5208
|
character is not.
|
5208
5209
|
|
5209
|
-
A
|
5210
|
-
or
|
5211
|
-
trolled
|
5212
|
-
specific
|
5213
|
-
page).
|
5214
|
-
systems,
|
5215
|
-
are
|
5210
|
+
A "word" character is an underscore or any character that is a letter
|
5211
|
+
or digit. By default, the definition of letters and digits is con-
|
5212
|
+
trolled by PCRE's low-valued character tables, and may vary if locale-
|
5213
|
+
specific matching is taking place (see "Locale support" in the pcreapi
|
5214
|
+
page). For example, in a French locale such as "fr_FR" in Unix-like
|
5215
|
+
systems, or "french" in Windows, some character codes greater than 127
|
5216
|
+
are used for accented letters, and these are then matched by \w. The
|
5216
5217
|
use of locales with Unicode is discouraged.
|
5217
5218
|
|
5218
|
-
By
|
5219
|
+
By default, characters whose code points are greater than 127 never
|
5219
5220
|
match \d, \s, or \w, and always match \D, \S, and \W, although this may
|
5220
|
-
vary
|
5221
|
-
is
|
5222
|
-
from
|
5223
|
-
sons.
|
5224
|
-
PCRE_UCP
|
5221
|
+
vary for characters in the range 128-255 when locale-specific matching
|
5222
|
+
is happening. These escape sequences retain their original meanings
|
5223
|
+
from before Unicode support was available, mainly for efficiency rea-
|
5224
|
+
sons. If PCRE is compiled with Unicode property support, and the
|
5225
|
+
PCRE_UCP option is set, the behaviour is changed so that Unicode prop-
|
5225
5226
|
erties are used to determine character types, as follows:
|
5226
5227
|
|
5227
5228
|
\d any character that matches \p{Nd} (decimal digit)
|
5228
5229
|
\s any character that matches \p{Z} or \h or \v
|
5229
5230
|
\w any character that matches \p{L} or \p{N}, plus underscore
|
5230
5231
|
|
5231
|
-
The
|
5232
|
-
\d
|
5233
|
-
as
|
5234
|
-
affects
|
5232
|
+
The upper case escapes match the inverse sets of characters. Note that
|
5233
|
+
\d matches only decimal digits, whereas \w matches any Unicode digit,
|
5234
|
+
as well as any Unicode letter, and underscore. Note also that PCRE_UCP
|
5235
|
+
affects \b, and \B because they are defined in terms of \w and \W.
|
5235
5236
|
Matching these sequences is noticeably slower when PCRE_UCP is set.
|
5236
5237
|
|
5237
|
-
The
|
5238
|
-
at
|
5239
|
-
ASCII
|
5238
|
+
The sequences \h, \H, \v, and \V are features that were added to Perl
|
5239
|
+
at release 5.10. In contrast to the other sequences, which match only
|
5240
|
+
ASCII characters by default, these always match certain high-valued
|
5240
5241
|
code points, whether or not PCRE_UCP is set. The horizontal space char-
|
5241
5242
|
acters are:
|
5242
5243
|
|
@@ -5275,110 +5276,110 @@ BACKSLASH
|
|
5275
5276
|
|
5276
5277
|
Newline sequences
|
5277
5278
|
|
5278
|
-
Outside
|
5279
|
-
any
|
5279
|
+
Outside a character class, by default, the escape sequence \R matches
|
5280
|
+
any Unicode newline sequence. In 8-bit non-UTF-8 mode \R is equivalent
|
5280
5281
|
to the following:
|
5281
5282
|
|
5282
5283
|
(?>\r\n|\n|\x0b|\f|\r|\x85)
|
5283
5284
|
|
5284
|
-
This
|
5285
|
+
This is an example of an "atomic group", details of which are given
|
5285
5286
|
below. This particular group matches either the two-character sequence
|
5286
|
-
CR
|
5287
|
-
U+000A),
|
5288
|
-
riage
|
5287
|
+
CR followed by LF, or one of the single characters LF (linefeed,
|
5288
|
+
U+000A), VT (vertical tab, U+000B), FF (form feed, U+000C), CR (car-
|
5289
|
+
riage return, U+000D), or NEL (next line, U+0085). The two-character
|
5289
5290
|
sequence is treated as a single unit that cannot be split.
|
5290
5291
|
|
5291
|
-
In
|
5292
|
+
In other modes, two additional characters whose codepoints are greater
|
5292
5293
|
than 255 are added: LS (line separator, U+2028) and PS (paragraph sepa-
|
5293
|
-
rator,
|
5294
|
+
rator, U+2029). Unicode character property support is not needed for
|
5294
5295
|
these characters to be recognized.
|
5295
5296
|
|
5296
5297
|
It is possible to restrict \R to match only CR, LF, or CRLF (instead of
|
5297
|
-
the
|
5298
|
+
the complete set of Unicode line endings) by setting the option
|
5298
5299
|
PCRE_BSR_ANYCRLF either at compile time or when the pattern is matched.
|
5299
5300
|
(BSR is an abbrevation for "backslash R".) This can be made the default
|
5300
|
-
when
|
5301
|
-
requested
|
5302
|
-
specify
|
5301
|
+
when PCRE is built; if this is the case, the other behaviour can be
|
5302
|
+
requested via the PCRE_BSR_UNICODE option. It is also possible to
|
5303
|
+
specify these settings by starting a pattern string with one of the
|
5303
5304
|
following sequences:
|
5304
5305
|
|
5305
5306
|
(*BSR_ANYCRLF) CR, LF, or CRLF only
|
5306
5307
|
(*BSR_UNICODE) any Unicode newline sequence
|
5307
5308
|
|
5308
5309
|
These override the default and the options given to the compiling func-
|
5309
|
-
tion,
|
5310
|
-
matching
|
5311
|
-
Perl-compatible,
|
5312
|
-
and
|
5313
|
-
present,
|
5310
|
+
tion, but they can themselves be overridden by options given to a
|
5311
|
+
matching function. Note that these special settings, which are not
|
5312
|
+
Perl-compatible, are recognized only at the very start of a pattern,
|
5313
|
+
and that they must be in upper case. If more than one of them is
|
5314
|
+
present, the last one is used. They can be combined with a change of
|
5314
5315
|
newline convention; for example, a pattern can start with:
|
5315
5316
|
|
5316
5317
|
(*ANY)(*BSR_ANYCRLF)
|
5317
5318
|
|
5318
|
-
They
|
5319
|
+
They can also be combined with the (*UTF8), (*UTF16), (*UTF32), (*UTF)
|
5319
5320
|
or (*UCP) special sequences. Inside a character class, \R is treated as
|
5320
|
-
an
|
5321
|
+
an unrecognized escape sequence, and so matches the letter "R" by
|
5321
5322
|
default, but causes an error if PCRE_EXTRA is set.
|
5322
5323
|
|
5323
5324
|
Unicode character properties
|
5324
5325
|
|
5325
5326
|
When PCRE is built with Unicode character property support, three addi-
|
5326
|
-
tional
|
5327
|
-
are
|
5328
|
-
course
|
5327
|
+
tional escape sequences that match characters with specific properties
|
5328
|
+
are available. When in 8-bit non-UTF-8 mode, these sequences are of
|
5329
|
+
course limited to testing characters whose codepoints are less than
|
5329
5330
|
256, but they do work in this mode. The extra escape sequences are:
|
5330
5331
|
|
5331
5332
|
\p{xx} a character with the xx property
|
5332
5333
|
\P{xx} a character without the xx property
|
5333
5334
|
\X a Unicode extended grapheme cluster
|
5334
5335
|
|
5335
|
-
The
|
5336
|
+
The property names represented by xx above are limited to the Unicode
|
5336
5337
|
script names, the general category properties, "Any", which matches any
|
5337
|
-
character
|
5338
|
-
(described
|
5339
|
-
sicalSymbols"
|
5338
|
+
character (including newline), and some special PCRE properties
|
5339
|
+
(described in the next section). Other Perl properties such as "InMu-
|
5340
|
+
sicalSymbols" are not currently supported by PCRE. Note that \P{Any}
|
5340
5341
|
does not match any characters, so always causes a match failure.
|
5341
5342
|
|
5342
5343
|
Sets of Unicode characters are defined as belonging to certain scripts.
|
5343
|
-
A
|
5344
|
+
A character from one of these sets can be matched using a script name.
|
5344
5345
|
For example:
|
5345
5346
|
|
5346
5347
|
\p{Greek}
|
5347
5348
|
\P{Han}
|
5348
5349
|
|
5349
|
-
Those
|
5350
|
+
Those that are not part of an identified script are lumped together as
|
5350
5351
|
"Common". The current list of scripts is:
|
5351
5352
|
|
5352
|
-
Arabic,
|
5353
|
-
Bopomofo,
|
5353
|
+
Arabic, Armenian, Avestan, Balinese, Bamum, Bassa_Vah, Batak, Bengali,
|
5354
|
+
Bopomofo, Brahmi, Braille, Buginese, Buhid, Canadian_Aboriginal, Car-
|
5354
5355
|
ian, Caucasian_Albanian, Chakma, Cham, Cherokee, Common, Coptic, Cunei-
|
5355
5356
|
form, Cypriot, Cyrillic, Deseret, Devanagari, Duployan, Egyptian_Hiero-
|
5356
5357
|
glyphs, Elbasan, Ethiopic, Georgian, Glagolitic, Gothic, Grantha,
|
5357
|
-
Greek,
|
5358
|
-
Imperial_Aramaic,
|
5359
|
-
tional_Parthian,
|
5360
|
-
Kharoshthi,
|
5361
|
-
ear_A,
|
5362
|
-
Manichaean,
|
5363
|
-
Meroitic_Hieroglyphs,
|
5364
|
-
New_Tai_Lue,
|
5358
|
+
Greek, Gujarati, Gurmukhi, Han, Hangul, Hanunoo, Hebrew, Hiragana,
|
5359
|
+
Imperial_Aramaic, Inherited, Inscriptional_Pahlavi, Inscrip-
|
5360
|
+
tional_Parthian, Javanese, Kaithi, Kannada, Katakana, Kayah_Li,
|
5361
|
+
Kharoshthi, Khmer, Khojki, Khudawadi, Lao, Latin, Lepcha, Limbu, Lin-
|
5362
|
+
ear_A, Linear_B, Lisu, Lycian, Lydian, Mahajani, Malayalam, Mandaic,
|
5363
|
+
Manichaean, Meetei_Mayek, Mende_Kikakui, Meroitic_Cursive,
|
5364
|
+
Meroitic_Hieroglyphs, Miao, Modi, Mongolian, Mro, Myanmar, Nabataean,
|
5365
|
+
New_Tai_Lue, Nko, Ogham, Ol_Chiki, Old_Italic, Old_North_Arabian,
|
5365
5366
|
Old_Permic, Old_Persian, Old_South_Arabian, Old_Turkic, Oriya, Osmanya,
|
5366
5367
|
Pahawh_Hmong, Palmyrene, Pau_Cin_Hau, Phags_Pa, Phoenician,
|
5367
|
-
Psalter_Pahlavi,
|
5368
|
-
vian,
|
5369
|
-
Tagalog,
|
5370
|
-
Thaana,
|
5368
|
+
Psalter_Pahlavi, Rejang, Runic, Samaritan, Saurashtra, Sharada, Sha-
|
5369
|
+
vian, Siddham, Sinhala, Sora_Sompeng, Sundanese, Syloti_Nagri, Syriac,
|
5370
|
+
Tagalog, Tagbanwa, Tai_Le, Tai_Tham, Tai_Viet, Takri, Tamil, Telugu,
|
5371
|
+
Thaana, Thai, Tibetan, Tifinagh, Tirhuta, Ugaritic, Vai, Warang_Citi,
|
5371
5372
|
Yi.
|
5372
5373
|
|
5373
5374
|
Each character has exactly one Unicode general category property, spec-
|
5374
|
-
ified
|
5375
|
-
tion
|
5376
|
-
brace
|
5375
|
+
ified by a two-letter abbreviation. For compatibility with Perl, nega-
|
5376
|
+
tion can be specified by including a circumflex between the opening
|
5377
|
+
brace and the property name. For example, \p{^Lu} is the same as
|
5377
5378
|
\P{Lu}.
|
5378
5379
|
|
5379
5380
|
If only one letter is specified with \p or \P, it includes all the gen-
|
5380
|
-
eral
|
5381
|
-
the
|
5381
|
+
eral category properties that start with that letter. In this case, in
|
5382
|
+
the absence of negation, the curly brackets in the escape sequence are
|
5382
5383
|
optional; these two examples have the same effect:
|
5383
5384
|
|
5384
5385
|
\p{L}
|
@@ -5430,73 +5431,73 @@ BACKSLASH
|
|
5430
5431
|
Zp Paragraph separator
|
5431
5432
|
Zs Space separator
|
5432
5433
|
|
5433
|
-
The
|
5434
|
-
has
|
5434
|
+
The special property L& is also supported: it matches a character that
|
5435
|
+
has the Lu, Ll, or Lt property, in other words, a letter that is not
|
5435
5436
|
classified as a modifier or "other".
|
5436
5437
|
|
5437
|
-
The
|
5438
|
-
U+D800
|
5439
|
-
so
|
5438
|
+
The Cs (Surrogate) property applies only to characters in the range
|
5439
|
+
U+D800 to U+DFFF. Such characters are not valid in Unicode strings and
|
5440
|
+
so cannot be tested by PCRE, unless UTF validity checking has been
|
5440
5441
|
turned off (see the discussion of PCRE_NO_UTF8_CHECK,
|
5441
|
-
PCRE_NO_UTF16_CHECK
|
5442
|
+
PCRE_NO_UTF16_CHECK and PCRE_NO_UTF32_CHECK in the pcreapi page). Perl
|
5442
5443
|
does not support the Cs property.
|
5443
5444
|
|
5444
|
-
The
|
5445
|
-
\p{Letter})
|
5445
|
+
The long synonyms for property names that Perl supports (such as
|
5446
|
+
\p{Letter}) are not supported by PCRE, nor is it permitted to prefix
|
5446
5447
|
any of these properties with "Is".
|
5447
5448
|
|
5448
5449
|
No character that is in the Unicode table has the Cn (unassigned) prop-
|
5449
5450
|
erty. Instead, this property is assumed for any code point that is not
|
5450
5451
|
in the Unicode table.
|
5451
5452
|
|
5452
|
-
Specifying
|
5453
|
-
For
|
5453
|
+
Specifying caseless matching does not affect these escape sequences.
|
5454
|
+
For example, \p{Lu} always matches only upper case letters. This is
|
5454
5455
|
different from the behaviour of current versions of Perl.
|
5455
5456
|
|
5456
|
-
Matching
|
5457
|
-
to
|
5457
|
+
Matching characters by Unicode property is not fast, because PCRE has
|
5458
|
+
to do a multistage table lookup in order to find a character's prop-
|
5458
5459
|
erty. That is why the traditional escape sequences such as \d and \w do
|
5459
5460
|
not use Unicode properties in PCRE by default, though you can make them
|
5460
|
-
do
|
5461
|
+
do so by setting the PCRE_UCP option or by starting the pattern with
|
5461
5462
|
(*UCP).
|
5462
5463
|
|
5463
5464
|
Extended grapheme clusters
|
5464
5465
|
|
5465
|
-
The
|
5466
|
+
The \X escape matches any number of Unicode characters that form an
|
5466
5467
|
"extended grapheme cluster", and treats the sequence as an atomic group
|
5467
|
-
(see
|
5468
|
+
(see below). Up to and including release 8.31, PCRE matched an ear-
|
5468
5469
|
lier, simpler definition that was equivalent to
|
5469
5470
|
|
5470
5471
|
(?>\PM\pM*)
|
5471
5472
|
|
5472
|
-
That
|
5473
|
-
by
|
5474
|
-
the
|
5473
|
+
That is, it matched a character without the "mark" property, followed
|
5474
|
+
by zero or more characters with the "mark" property. Characters with
|
5475
|
+
the "mark" property are typically non-spacing accents that affect the
|
5475
5476
|
preceding character.
|
5476
5477
|
|
5477
|
-
This
|
5478
|
-
cated
|
5479
|
-
breaking
|
5480
|
-
define
|
5478
|
+
This simple definition was extended in Unicode to include more compli-
|
5479
|
+
cated kinds of composite character by giving each character a grapheme
|
5480
|
+
breaking property, and creating rules that use these properties to
|
5481
|
+
define the boundaries of extended grapheme clusters. In releases of
|
5481
5482
|
PCRE later than 8.31, \X matches one of these clusters.
|
5482
5483
|
|
5483
|
-
\X
|
5484
|
+
\X always matches at least one character. Then it decides whether to
|
5484
5485
|
add additional characters according to the following rules for ending a
|
5485
5486
|
cluster:
|
5486
5487
|
|
5487
5488
|
1. End at the end of the subject string.
|
5488
5489
|
|
5489
|
-
2.
|
5490
|
+
2. Do not end between CR and LF; otherwise end after any control char-
|
5490
5491
|
acter.
|
5491
5492
|
|
5492
|
-
3.
|
5493
|
-
characters
|
5494
|
-
be
|
5493
|
+
3. Do not break Hangul (a Korean script) syllable sequences. Hangul
|
5494
|
+
characters are of five types: L, V, T, LV, and LVT. An L character may
|
5495
|
+
be followed by an L, V, LV, or LVT character; an LV or V character may
|
5495
5496
|
be followed by a V or T character; an LVT or T character may be follwed
|
5496
5497
|
only by a T character.
|
5497
5498
|
|
5498
|
-
4.
|
5499
|
-
with
|
5499
|
+
4. Do not end before extending characters or spacing marks. Characters
|
5500
|
+
with the "mark" property always have the "extend" grapheme breaking
|
5500
5501
|
property.
|
5501
5502
|
|
5502
5503
|
5. Do not end after prepend characters.
|
@@ -5505,9 +5506,9 @@ BACKSLASH
|
|
5505
5506
|
|
5506
5507
|
PCRE's additional properties
|
5507
5508
|
|
5508
|
-
As
|
5509
|
-
ports
|
5510
|
-
sequences
|
5509
|
+
As well as the standard Unicode properties described above, PCRE sup-
|
5510
|
+
ports four more that make it possible to convert traditional escape
|
5511
|
+
sequences such as \w and \s to use Unicode properties. PCRE uses these
|
5511
5512
|
non-standard, non-Perl properties internally when PCRE_UCP is set. How-
|
5512
5513
|
ever, they may also be used explicitly. These properties are:
|
5513
5514
|
|
@@ -5516,54 +5517,54 @@ BACKSLASH
|
|
5516
5517
|
Xsp Any Perl space character
|
5517
5518
|
Xwd Any Perl "word" character
|
5518
5519
|
|
5519
|
-
Xan
|
5520
|
-
ber)
|
5521
|
-
form
|
5522
|
-
(separator)
|
5523
|
-
tical
|
5524
|
-
lowed
|
5520
|
+
Xan matches characters that have either the L (letter) or the N (num-
|
5521
|
+
ber) property. Xps matches the characters tab, linefeed, vertical tab,
|
5522
|
+
form feed, or carriage return, and any other character that has the Z
|
5523
|
+
(separator) property. Xsp is the same as Xps; it used to exclude ver-
|
5524
|
+
tical tab, for Perl compatibility, but Perl changed, and so PCRE fol-
|
5525
|
+
lowed at release 8.34. Xwd matches the same characters as Xan, plus
|
5525
5526
|
underscore.
|
5526
5527
|
|
5527
|
-
There
|
5528
|
-
ter
|
5529
|
-
other
|
5530
|
-
accent),
|
5531
|
-
equal
|
5532
|
-
most
|
5533
|
-
are
|
5528
|
+
There is another non-standard property, Xuc, which matches any charac-
|
5529
|
+
ter that can be represented by a Universal Character Name in C++ and
|
5530
|
+
other programming languages. These are the characters $, @, ` (grave
|
5531
|
+
accent), and all characters with Unicode code points greater than or
|
5532
|
+
equal to U+00A0, except for the surrogates U+D800 to U+DFFF. Note that
|
5533
|
+
most base (ASCII) characters are excluded. (Universal Character Names
|
5534
|
+
are of the form \uHHHH or \UHHHHHHHH where H is a hexadecimal digit.
|
5534
5535
|
Note that the Xuc property does not match these sequences but the char-
|
5535
5536
|
acters that they represent.)
|
5536
5537
|
|
5537
5538
|
Resetting the match start
|
5538
5539
|
|
5539
|
-
The
|
5540
|
+
The escape sequence \K causes any previously matched characters not to
|
5540
5541
|
be included in the final matched sequence. For example, the pattern:
|
5541
5542
|
|
5542
5543
|
foo\Kbar
|
5543
5544
|
|
5544
|
-
matches
|
5545
|
-
is
|
5546
|
-
this
|
5547
|
-
to
|
5548
|
-
not
|
5545
|
+
matches "foobar", but reports that it has matched "bar". This feature
|
5546
|
+
is similar to a lookbehind assertion (described below). However, in
|
5547
|
+
this case, the part of the subject before the real match does not have
|
5548
|
+
to be of fixed length, as lookbehind assertions do. The use of \K does
|
5549
|
+
not interfere with the setting of captured substrings. For example,
|
5549
5550
|
when the pattern
|
5550
5551
|
|
5551
5552
|
(foo)\Kbar
|
5552
5553
|
|
5553
5554
|
matches "foobar", the first substring is still set to "foo".
|
5554
5555
|
|
5555
|
-
Perl
|
5556
|
-
defined".
|
5557
|
-
assertions,
|
5558
|
-
pattern
|
5556
|
+
Perl documents that the use of \K within assertions is "not well
|
5557
|
+
defined". In PCRE, \K is acted upon when it occurs inside positive
|
5558
|
+
assertions, but is ignored in negative assertions. Note that when a
|
5559
|
+
pattern such as (?=ab\K) matches, the reported start of the match can
|
5559
5560
|
be greater than the end of the match.
|
5560
5561
|
|
5561
5562
|
Simple assertions
|
5562
5563
|
|
5563
|
-
The
|
5564
|
-
tion
|
5565
|
-
a
|
5566
|
-
use
|
5564
|
+
The final use of backslash is for certain simple assertions. An asser-
|
5565
|
+
tion specifies a condition that has to be met at a particular point in
|
5566
|
+
a match, without consuming any characters from the subject string. The
|
5567
|
+
use of subpatterns for more complicated assertions is described below.
|
5567
5568
|
The backslashed assertions are:
|
5568
5569
|
|
5569
5570
|
\b matches at a word boundary
|
@@ -5574,161 +5575,161 @@ BACKSLASH
|
|
5574
5575
|
\z matches only at the end of the subject
|
5575
5576
|
\G matches at the first matching position in the subject
|
5576
5577
|
|
5577
|
-
Inside
|
5578
|
-
backspace
|
5579
|
-
character
|
5578
|
+
Inside a character class, \b has a different meaning; it matches the
|
5579
|
+
backspace character. If any other of these assertions appears in a
|
5580
|
+
character class, by default it matches the corresponding literal char-
|
5580
5581
|
acter (for example, \B matches the letter B). However, if the
|
5581
|
-
PCRE_EXTRA
|
5582
|
+
PCRE_EXTRA option is set, an "invalid escape sequence" error is gener-
|
5582
5583
|
ated instead.
|
5583
5584
|
|
5584
|
-
A
|
5585
|
-
character
|
5586
|
-
one
|
5587
|
-
string
|
5588
|
-
UTF
|
5589
|
-
PCRE_UCP
|
5590
|
-
PCRE
|
5591
|
-
quence.
|
5585
|
+
A word boundary is a position in the subject string where the current
|
5586
|
+
character and the previous character do not both match \w or \W (i.e.
|
5587
|
+
one matches \w and the other matches \W), or the start or end of the
|
5588
|
+
string if the first or last character matches \w, respectively. In a
|
5589
|
+
UTF mode, the meanings of \w and \W can be changed by setting the
|
5590
|
+
PCRE_UCP option. When this is done, it also affects \b and \B. Neither
|
5591
|
+
PCRE nor Perl has a separate "start of word" or "end of word" metase-
|
5592
|
+
quence. However, whatever follows \b normally determines which it is.
|
5592
5593
|
For example, the fragment \ba matches "a" at the start of a word.
|
5593
5594
|
|
5594
|
-
The
|
5595
|
+
The \A, \Z, and \z assertions differ from the traditional circumflex
|
5595
5596
|
and dollar (described in the next section) in that they only ever match
|
5596
|
-
at
|
5597
|
-
set.
|
5597
|
+
at the very start and end of the subject string, whatever options are
|
5598
|
+
set. Thus, they are independent of multiline mode. These three asser-
|
5598
5599
|
tions are not affected by the PCRE_NOTBOL or PCRE_NOTEOL options, which
|
5599
|
-
affect
|
5600
|
-
However,
|
5600
|
+
affect only the behaviour of the circumflex and dollar metacharacters.
|
5601
|
+
However, if the startoffset argument of pcre_exec() is non-zero, indi-
|
5601
5602
|
cating that matching is to start at a point other than the beginning of
|
5602
|
-
the
|
5603
|
+
the subject, \A can never match. The difference between \Z and \z is
|
5603
5604
|
that \Z matches before a newline at the end of the string as well as at
|
5604
5605
|
the very end, whereas \z matches only at the end.
|
5605
5606
|
|
5606
|
-
The
|
5607
|
-
the
|
5608
|
-
of
|
5609
|
-
non-zero.
|
5607
|
+
The \G assertion is true only when the current matching position is at
|
5608
|
+
the start point of the match, as specified by the startoffset argument
|
5609
|
+
of pcre_exec(). It differs from \A when the value of startoffset is
|
5610
|
+
non-zero. By calling pcre_exec() multiple times with appropriate argu-
|
5610
5611
|
ments, you can mimic Perl's /g option, and it is in this kind of imple-
|
5611
5612
|
mentation where \G can be useful.
|
5612
5613
|
|
5613
|
-
Note,
|
5614
|
+
Note, however, that PCRE's interpretation of \G, as the start of the
|
5614
5615
|
current match, is subtly different from Perl's, which defines it as the
|
5615
|
-
end
|
5616
|
-
previously
|
5616
|
+
end of the previous match. In Perl, these can be different when the
|
5617
|
+
previously matched string was empty. Because PCRE does just one match
|
5617
5618
|
at a time, it cannot reproduce this behaviour.
|
5618
5619
|
|
5619
|
-
If
|
5620
|
+
If all the alternatives of a pattern begin with \G, the expression is
|
5620
5621
|
anchored to the starting match position, and the "anchored" flag is set
|
5621
5622
|
in the compiled regular expression.
|
5622
5623
|
|
5623
5624
|
|
5624
5625
|
CIRCUMFLEX AND DOLLAR
|
5625
5626
|
|
5626
|
-
The
|
5627
|
-
That
|
5627
|
+
The circumflex and dollar metacharacters are zero-width assertions.
|
5628
|
+
That is, they test for a particular condition being true without con-
|
5628
5629
|
suming any characters from the subject string.
|
5629
5630
|
|
5630
5631
|
Outside a character class, in the default matching mode, the circumflex
|
5631
|
-
character
|
5632
|
-
point
|
5633
|
-
ment
|
5634
|
-
PCRE_MULTILINE
|
5632
|
+
character is an assertion that is true only if the current matching
|
5633
|
+
point is at the start of the subject string. If the startoffset argu-
|
5634
|
+
ment of pcre_exec() is non-zero, circumflex can never match if the
|
5635
|
+
PCRE_MULTILINE option is unset. Inside a character class, circumflex
|
5635
5636
|
has an entirely different meaning (see below).
|
5636
5637
|
|
5637
|
-
Circumflex
|
5638
|
-
of
|
5639
|
-
alternative
|
5640
|
-
branch.
|
5641
|
-
if
|
5642
|
-
ject,
|
5638
|
+
Circumflex need not be the first character of the pattern if a number
|
5639
|
+
of alternatives are involved, but it should be the first thing in each
|
5640
|
+
alternative in which it appears if the pattern is ever to match that
|
5641
|
+
branch. If all possible alternatives start with a circumflex, that is,
|
5642
|
+
if the pattern is constrained to match only at the start of the sub-
|
5643
|
+
ject, it is said to be an "anchored" pattern. (There are also other
|
5643
5644
|
constructs that can cause a pattern to be anchored.)
|
5644
5645
|
|
5645
|
-
The
|
5646
|
-
matching
|
5647
|
-
before
|
5648
|
-
that
|
5646
|
+
The dollar character is an assertion that is true only if the current
|
5647
|
+
matching point is at the end of the subject string, or immediately
|
5648
|
+
before a newline at the end of the string (by default). Note, however,
|
5649
|
+
that it does not actually match the newline. Dollar need not be the
|
5649
5650
|
last character of the pattern if a number of alternatives are involved,
|
5650
|
-
but
|
5651
|
+
but it should be the last item in any branch in which it appears. Dol-
|
5651
5652
|
lar has no special meaning in a character class.
|
5652
5653
|
|
5653
|
-
The
|
5654
|
-
very
|
5654
|
+
The meaning of dollar can be changed so that it matches only at the
|
5655
|
+
very end of the string, by setting the PCRE_DOLLAR_ENDONLY option at
|
5655
5656
|
compile time. This does not affect the \Z assertion.
|
5656
5657
|
|
5657
5658
|
The meanings of the circumflex and dollar characters are changed if the
|
5658
|
-
PCRE_MULTILINE
|
5659
|
-
matches
|
5660
|
-
the
|
5661
|
-
string.
|
5662
|
-
at
|
5663
|
-
as
|
5659
|
+
PCRE_MULTILINE option is set. When this is the case, a circumflex
|
5660
|
+
matches immediately after internal newlines as well as at the start of
|
5661
|
+
the subject string. It does not match after a newline that ends the
|
5662
|
+
string. A dollar matches before any newlines in the string, as well as
|
5663
|
+
at the very end, when PCRE_MULTILINE is set. When newline is specified
|
5664
|
+
as the two-character sequence CRLF, isolated CR and LF characters do
|
5664
5665
|
not indicate newlines.
|
5665
5666
|
|
5666
|
-
For
|
5667
|
-
(where
|
5668
|
-
Consequently,
|
5669
|
-
all
|
5670
|
-
match
|
5671
|
-
pcre_exec()
|
5667
|
+
For example, the pattern /^abc$/ matches the subject string "def\nabc"
|
5668
|
+
(where \n represents a newline) in multiline mode, but not otherwise.
|
5669
|
+
Consequently, patterns that are anchored in single line mode because
|
5670
|
+
all branches start with ^ are not anchored in multiline mode, and a
|
5671
|
+
match for circumflex is possible when the startoffset argument of
|
5672
|
+
pcre_exec() is non-zero. The PCRE_DOLLAR_ENDONLY option is ignored if
|
5672
5673
|
PCRE_MULTILINE is set.
|
5673
5674
|
|
5674
|
-
Note
|
5675
|
-
and
|
5676
|
-
start
|
5675
|
+
Note that the sequences \A, \Z, and \z can be used to match the start
|
5676
|
+
and end of the subject in both modes, and if all branches of a pattern
|
5677
|
+
start with \A it is always anchored, whether or not PCRE_MULTILINE is
|
5677
5678
|
set.
|
5678
5679
|
|
5679
5680
|
|
5680
5681
|
FULL STOP (PERIOD, DOT) AND \N
|
5681
5682
|
|
5682
5683
|
Outside a character class, a dot in the pattern matches any one charac-
|
5683
|
-
ter
|
5684
|
+
ter in the subject string except (by default) a character that signi-
|
5684
5685
|
fies the end of a line.
|
5685
5686
|
|
5686
|
-
When
|
5687
|
-
that
|
5688
|
-
not
|
5689
|
-
matches
|
5690
|
-
code
|
5687
|
+
When a line ending is defined as a single character, dot never matches
|
5688
|
+
that character; when the two-character sequence CRLF is used, dot does
|
5689
|
+
not match CR if it is immediately followed by LF, but otherwise it
|
5690
|
+
matches all characters (including isolated CRs and LFs). When any Uni-
|
5691
|
+
code line endings are being recognized, dot does not match CR or LF or
|
5691
5692
|
any of the other line ending characters.
|
5692
5693
|
|
5693
|
-
The
|
5694
|
-
PCRE_DOTALL
|
5694
|
+
The behaviour of dot with regard to newlines can be changed. If the
|
5695
|
+
PCRE_DOTALL option is set, a dot matches any one character, without
|
5695
5696
|
exception. If the two-character sequence CRLF is present in the subject
|
5696
5697
|
string, it takes two dots to match it.
|
5697
5698
|
|
5698
|
-
The
|
5699
|
-
flex
|
5699
|
+
The handling of dot is entirely independent of the handling of circum-
|
5700
|
+
flex and dollar, the only relationship being that they both involve
|
5700
5701
|
newlines. Dot has no special meaning in a character class.
|
5701
5702
|
|
5702
|
-
The
|
5703
|
-
affected
|
5704
|
-
character
|
5703
|
+
The escape sequence \N behaves like a dot, except that it is not
|
5704
|
+
affected by the PCRE_DOTALL option. In other words, it matches any
|
5705
|
+
character except one that signifies the end of a line. Perl also uses
|
5705
5706
|
\N to match characters by name; PCRE does not support this.
|
5706
5707
|
|
5707
5708
|
|
5708
5709
|
MATCHING A SINGLE DATA UNIT
|
5709
5710
|
|
5710
|
-
Outside
|
5711
|
-
unit,
|
5712
|
-
unit
|
5713
|
-
32-bit
|
5714
|
-
line-ending
|
5711
|
+
Outside a character class, the escape sequence \C matches any one data
|
5712
|
+
unit, whether or not a UTF mode is set. In the 8-bit library, one data
|
5713
|
+
unit is one byte; in the 16-bit library it is a 16-bit unit; in the
|
5714
|
+
32-bit library it is a 32-bit unit. Unlike a dot, \C always matches
|
5715
|
+
line-ending characters. The feature is provided in Perl in order to
|
5715
5716
|
match individual bytes in UTF-8 mode, but it is unclear how it can use-
|
5716
|
-
fully
|
5717
|
-
units,
|
5717
|
+
fully be used. Because \C breaks up characters into individual data
|
5718
|
+
units, matching one unit with \C in a UTF mode means that the rest of
|
5718
5719
|
the string may start with a malformed UTF character. This has undefined
|
5719
5720
|
results, because PCRE assumes that it is dealing with valid UTF strings
|
5720
|
-
(and
|
5721
|
-
PCRE_NO_UTF8_CHECK,
|
5721
|
+
(and by default it checks this at the start of processing unless the
|
5722
|
+
PCRE_NO_UTF8_CHECK, PCRE_NO_UTF16_CHECK or PCRE_NO_UTF32_CHECK option
|
5722
5723
|
is used).
|
5723
5724
|
|
5724
|
-
PCRE
|
5725
|
-
below)
|
5725
|
+
PCRE does not allow \C to appear in lookbehind assertions (described
|
5726
|
+
below) in a UTF mode, because this would make it impossible to calcu-
|
5726
5727
|
late the length of the lookbehind.
|
5727
5728
|
|
5728
5729
|
In general, the \C escape sequence is best avoided. However, one way of
|
5729
|
-
using
|
5730
|
-
a
|
5731
|
-
tern,
|
5730
|
+
using it that avoids the problem of malformed UTF characters is to use
|
5731
|
+
a lookahead to check the length of the next character, as in this pat-
|
5732
|
+
tern, which could be used with a UTF-8 string (ignore white space and
|
5732
5733
|
line breaks):
|
5733
5734
|
|
5734
5735
|
(?| (?=[\x00-\x7f])(\C) |
|
@@ -5736,11 +5737,11 @@ MATCHING A SINGLE DATA UNIT
|
|
5736
5737
|
(?=[\x{800}-\x{ffff}])(\C)(\C)(\C) |
|
5737
5738
|
(?=[\x{10000}-\x{1fffff}])(\C)(\C)(\C)(\C))
|
5738
5739
|
|
5739
|
-
A
|
5740
|
-
in
|
5741
|
-
assertions
|
5742
|
-
for
|
5743
|
-
character's
|
5740
|
+
A group that starts with (?| resets the capturing parentheses numbers
|
5741
|
+
in each alternative (see "Duplicate Subpattern Numbers" below). The
|
5742
|
+
assertions at the start of each branch check the next UTF-8 character
|
5743
|
+
for values whose encoding uses 1, 2, 3, or 4 bytes, respectively. The
|
5744
|
+
character's individual bytes are then captured by the appropriate num-
|
5744
5745
|
ber of groups.
|
5745
5746
|
|
5746
5747
|
|
@@ -5750,109 +5751,109 @@ SQUARE BRACKETS AND CHARACTER CLASSES
|
|
5750
5751
|
closing square bracket. A closing square bracket on its own is not spe-
|
5751
5752
|
cial by default. However, if the PCRE_JAVASCRIPT_COMPAT option is set,
|
5752
5753
|
a lone closing square bracket causes a compile-time error. If a closing
|
5753
|
-
square
|
5754
|
-
first
|
5754
|
+
square bracket is required as a member of the class, it should be the
|
5755
|
+
first data character in the class (after an initial circumflex, if
|
5755
5756
|
present) or escaped with a backslash.
|
5756
5757
|
|
5757
|
-
A
|
5758
|
-
mode,
|
5758
|
+
A character class matches a single character in the subject. In a UTF
|
5759
|
+
mode, the character may be more than one data unit long. A matched
|
5759
5760
|
character must be in the set of characters defined by the class, unless
|
5760
|
-
the
|
5761
|
+
the first character in the class definition is a circumflex, in which
|
5761
5762
|
case the subject character must not be in the set defined by the class.
|
5762
|
-
If
|
5763
|
+
If a circumflex is actually required as a member of the class, ensure
|
5763
5764
|
it is not the first character, or escape it with a backslash.
|
5764
5765
|
|
5765
|
-
For
|
5766
|
-
while
|
5766
|
+
For example, the character class [aeiou] matches any lower case vowel,
|
5767
|
+
while [^aeiou] matches any character that is not a lower case vowel.
|
5767
5768
|
Note that a circumflex is just a convenient notation for specifying the
|
5768
|
-
characters
|
5769
|
-
class
|
5770
|
-
sumes
|
5769
|
+
characters that are in the class by enumerating those that are not. A
|
5770
|
+
class that starts with a circumflex is not an assertion; it still con-
|
5771
|
+
sumes a character from the subject string, and therefore it fails if
|
5771
5772
|
the current pointer is at the end of the string.
|
5772
5773
|
|
5773
5774
|
In UTF-8 (UTF-16, UTF-32) mode, characters with values greater than 255
|
5774
|
-
(0xffff)
|
5775
|
+
(0xffff) can be included in a class as a literal string of data units,
|
5775
5776
|
or by using the \x{ escaping mechanism.
|
5776
5777
|
|
5777
|
-
When
|
5778
|
-
their
|
5779
|
-
[aeiou]
|
5780
|
-
match
|
5781
|
-
understands
|
5782
|
-
than
|
5783
|
-
higher
|
5784
|
-
with
|
5785
|
-
caseless
|
5786
|
-
ensure
|
5778
|
+
When caseless matching is set, any letters in a class represent both
|
5779
|
+
their upper case and lower case versions, so for example, a caseless
|
5780
|
+
[aeiou] matches "A" as well as "a", and a caseless [^aeiou] does not
|
5781
|
+
match "A", whereas a caseful version would. In a UTF mode, PCRE always
|
5782
|
+
understands the concept of case for characters whose values are less
|
5783
|
+
than 128, so caseless matching is always possible. For characters with
|
5784
|
+
higher values, the concept of case is supported if PCRE is compiled
|
5785
|
+
with Unicode property support, but not otherwise. If you want to use
|
5786
|
+
caseless matching in a UTF mode for characters 128 and above, you must
|
5787
|
+
ensure that PCRE is compiled with Unicode property support as well as
|
5787
5788
|
with UTF support.
|
5788
5789
|
|
5789
|
-
Characters
|
5790
|
-
special
|
5791
|
-
sequence
|
5790
|
+
Characters that might indicate line breaks are never treated in any
|
5791
|
+
special way when matching character classes, whatever line-ending
|
5792
|
+
sequence is in use, and whatever setting of the PCRE_DOTALL and
|
5792
5793
|
PCRE_MULTILINE options is used. A class such as [^a] always matches one
|
5793
5794
|
of these characters.
|
5794
5795
|
|
5795
|
-
The
|
5796
|
-
ters
|
5797
|
-
between
|
5798
|
-
class,
|
5799
|
-
where
|
5796
|
+
The minus (hyphen) character can be used to specify a range of charac-
|
5797
|
+
ters in a character class. For example, [d-m] matches any letter
|
5798
|
+
between d and m, inclusive. If a minus character is required in a
|
5799
|
+
class, it must be escaped with a backslash or appear in a position
|
5800
|
+
where it cannot be interpreted as indicating a range, typically as the
|
5800
5801
|
first or last character in the class, or immediately after a range. For
|
5801
|
-
example,
|
5802
|
+
example, [b-d-z] matches letters in the range b to d, a hyphen charac-
|
5802
5803
|
ter, or z.
|
5803
5804
|
|
5804
5805
|
It is not possible to have the literal character "]" as the end charac-
|
5805
|
-
ter
|
5806
|
-
two
|
5807
|
-
would
|
5808
|
-
backslash
|
5809
|
-
preted
|
5810
|
-
The
|
5806
|
+
ter of a range. A pattern such as [W-]46] is interpreted as a class of
|
5807
|
+
two characters ("W" and "-") followed by a literal string "46]", so it
|
5808
|
+
would match "W46]" or "-46]". However, if the "]" is escaped with a
|
5809
|
+
backslash it is interpreted as the end of range, so [W-\]46] is inter-
|
5810
|
+
preted as a class containing a range followed by two other characters.
|
5811
|
+
The octal or hexadecimal representation of "]" can also be used to end
|
5811
5812
|
a range.
|
5812
5813
|
|
5813
|
-
An
|
5814
|
-
escape
|
5815
|
-
at
|
5814
|
+
An error is generated if a POSIX character class (see below) or an
|
5815
|
+
escape sequence other than one that defines a single character appears
|
5816
|
+
at a point where a range ending character is expected. For example,
|
5816
5817
|
[z-\xff] is valid, but [A-\d] and [A-[:digit:]] are not.
|
5817
5818
|
|
5818
|
-
Ranges
|
5819
|
-
also
|
5820
|
-
[\000-\037].
|
5819
|
+
Ranges operate in the collating sequence of character values. They can
|
5820
|
+
also be used for characters specified numerically, for example
|
5821
|
+
[\000-\037]. Ranges can include any characters that are valid for the
|
5821
5822
|
current mode.
|
5822
5823
|
|
5823
5824
|
If a range that includes letters is used when caseless matching is set,
|
5824
5825
|
it matches the letters in either case. For example, [W-c] is equivalent
|
5825
|
-
to
|
5826
|
-
character
|
5827
|
-
accented
|
5828
|
-
concept
|
5826
|
+
to [][\\^_`wxyzabc], matched caselessly, and in a non-UTF mode, if
|
5827
|
+
character tables for a French locale are in use, [\xc8-\xcb] matches
|
5828
|
+
accented E characters in both cases. In UTF modes, PCRE supports the
|
5829
|
+
concept of case for characters with values greater than 128 only when
|
5829
5830
|
it is compiled with Unicode property support.
|
5830
5831
|
|
5831
|
-
The
|
5832
|
+
The character escape sequences \d, \D, \h, \H, \p, \P, \s, \S, \v, \V,
|
5832
5833
|
\w, and \W may appear in a character class, and add the characters that
|
5833
|
-
they
|
5834
|
-
mal
|
5835
|
-
\d,
|
5836
|
-
appear
|
5834
|
+
they match to the class. For example, [\dABCDEF] matches any hexadeci-
|
5835
|
+
mal digit. In UTF modes, the PCRE_UCP option affects the meanings of
|
5836
|
+
\d, \s, \w and their upper case partners, just as it does when they
|
5837
|
+
appear outside a character class, as described in the section entitled
|
5837
5838
|
"Generic character types" above. The escape sequence \b has a different
|
5838
|
-
meaning
|
5839
|
-
The
|
5840
|
-
class.
|
5841
|
-
as
|
5839
|
+
meaning inside a character class; it matches the backspace character.
|
5840
|
+
The sequences \B, \N, \R, and \X are not special inside a character
|
5841
|
+
class. Like any other unrecognized escape sequences, they are treated
|
5842
|
+
as the literal characters "B", "N", "R", and "X" by default, but cause
|
5842
5843
|
an error if the PCRE_EXTRA option is set.
|
5843
5844
|
|
5844
|
-
A
|
5845
|
-
types
|
5846
|
-
lower
|
5845
|
+
A circumflex can conveniently be used with the upper case character
|
5846
|
+
types to specify a more restricted set of characters than the matching
|
5847
|
+
lower case type. For example, the class [^\W_] matches any letter or
|
5847
5848
|
digit, but not underscore, whereas [\w] includes underscore. A positive
|
5848
5849
|
character class should be read as "something OR something OR ..." and a
|
5849
5850
|
negative class as "NOT something AND NOT something AND NOT ...".
|
5850
5851
|
|
5851
|
-
The
|
5852
|
-
backslash,
|
5853
|
-
range),
|
5854
|
-
when
|
5855
|
-
special
|
5852
|
+
The only metacharacters that are recognized in character classes are
|
5853
|
+
backslash, hyphen (only where it can be interpreted as specifying a
|
5854
|
+
range), circumflex (only at the start), opening square bracket (only
|
5855
|
+
when it can be interpreted as introducing a POSIX class name, or for a
|
5856
|
+
special compatibility feature - see the next two sections), and the
|
5856
5857
|
terminating closing square bracket. However, escaping other non-
|
5857
5858
|
alphanumeric characters does no harm.
|
5858
5859
|
|
@@ -5860,7 +5861,7 @@ SQUARE BRACKETS AND CHARACTER CLASSES
|
|
5860
5861
|
POSIX CHARACTER CLASSES
|
5861
5862
|
|
5862
5863
|
Perl supports the POSIX notation for character classes. This uses names
|
5863
|
-
enclosed
|
5864
|
+
enclosed by [: and :] within the enclosing square brackets. PCRE also
|
5864
5865
|
supports this notation. For example,
|
5865
5866
|
|
5866
5867
|
[01[:alpha:]%]
|
@@ -5883,28 +5884,28 @@ POSIX CHARACTER CLASSES
|
|
5883
5884
|
word "word" characters (same as \w)
|
5884
5885
|
xdigit hexadecimal digits
|
5885
5886
|
|
5886
|
-
The
|
5887
|
-
CR
|
5888
|
-
the
|
5887
|
+
The default "space" characters are HT (9), LF (10), VT (11), FF (12),
|
5888
|
+
CR (13), and space (32). If locale-specific matching is taking place,
|
5889
|
+
the list of space characters may be different; there may be fewer or
|
5889
5890
|
more of them. "Space" used to be different to \s, which did not include
|
5890
5891
|
VT, for Perl compatibility. However, Perl changed at release 5.18, and
|
5891
|
-
PCRE
|
5892
|
+
PCRE followed at release 8.34. "Space" and \s now match the same set
|
5892
5893
|
of characters.
|
5893
5894
|
|
5894
|
-
The
|
5895
|
-
from
|
5895
|
+
The name "word" is a Perl extension, and "blank" is a GNU extension
|
5896
|
+
from Perl 5.8. Another Perl extension is negation, which is indicated
|
5896
5897
|
by a ^ character after the colon. For example,
|
5897
5898
|
|
5898
5899
|
[12[:^digit:]]
|
5899
5900
|
|
5900
|
-
matches
|
5901
|
+
matches "1", "2", or any non-digit. PCRE (and Perl) also recognize the
|
5901
5902
|
POSIX syntax [.ch.] and [=ch=] where "ch" is a "collating element", but
|
5902
5903
|
these are not supported, and an error is given if they are encountered.
|
5903
5904
|
|
5904
5905
|
By default, characters with values greater than 128 do not match any of
|
5905
|
-
the
|
5906
|
-
to
|
5907
|
-
character
|
5906
|
+
the POSIX character classes. However, if the PCRE_UCP option is passed
|
5907
|
+
to pcre_compile(), some of the classes are changed so that Unicode
|
5908
|
+
character properties are used. This is achieved by replacing certain
|
5908
5909
|
POSIX classes by other sequences, as follows:
|
5909
5910
|
|
5910
5911
|
[:alnum:] becomes \p{Xan}
|
@@ -5916,10 +5917,10 @@ POSIX CHARACTER CLASSES
|
|
5916
5917
|
[:upper:] becomes \p{Lu}
|
5917
5918
|
[:word:] becomes \p{Xwd}
|
5918
5919
|
|
5919
|
-
Negated
|
5920
|
+
Negated versions, such as [:^alpha:] use \P instead of \p. Three other
|
5920
5921
|
POSIX classes are handled specially in UCP mode:
|
5921
5922
|
|
5922
|
-
[:graph:] This
|
5923
|
+
[:graph:] This matches characters that have glyphs that mark the page
|
5923
5924
|
when printed. In Unicode property terms, it matches all char-
|
5924
5925
|
acters with the L, M, N, P, S, or Cf properties, except for:
|
5925
5926
|
|
@@ -5928,58 +5929,58 @@ POSIX CHARACTER CLASSES
|
|
5928
5929
|
U+2066 - U+2069 Various "isolate"s
|
5929
5930
|
|
5930
5931
|
|
5931
|
-
[:print:] This
|
5932
|
-
characters
|
5932
|
+
[:print:] This matches the same characters as [:graph:] plus space
|
5933
|
+
characters that are not controls, that is, characters with
|
5933
5934
|
the Zs property.
|
5934
5935
|
|
5935
5936
|
[:punct:] This matches all characters that have the Unicode P (punctua-
|
5936
|
-
tion)
|
5937
|
+
tion) property, plus those characters whose code points are
|
5937
5938
|
less than 128 that have the S (Symbol) property.
|
5938
5939
|
|
5939
|
-
The
|
5940
|
+
The other POSIX classes are unchanged, and match only characters with
|
5940
5941
|
code points less than 128.
|
5941
5942
|
|
5942
5943
|
|
5943
5944
|
COMPATIBILITY FEATURE FOR WORD BOUNDARIES
|
5944
5945
|
|
5945
|
-
In
|
5946
|
-
ugly
|
5946
|
+
In the POSIX.2 compliant library that was included in 4.4BSD Unix, the
|
5947
|
+
ugly syntax [[:<:]] and [[:>:]] is used for matching "start of word"
|
5947
5948
|
and "end of word". PCRE treats these items as follows:
|
5948
5949
|
|
5949
5950
|
[[:<:]] is converted to \b(?=\w)
|
5950
5951
|
[[:>:]] is converted to \b(?<=\w)
|
5951
5952
|
|
5952
5953
|
Only these exact character sequences are recognized. A sequence such as
|
5953
|
-
[a[:<:]b]
|
5954
|
-
support
|
5954
|
+
[a[:<:]b] provokes error for an unrecognized POSIX class name. This
|
5955
|
+
support is not compatible with Perl. It is provided to help migrations
|
5955
5956
|
from other environments, and is best not used in any new patterns. Note
|
5956
|
-
that
|
5957
|
-
tions"
|
5958
|
-
character
|
5959
|
-
assertions
|
5957
|
+
that \b matches at the start and the end of a word (see "Simple asser-
|
5958
|
+
tions" above), and in a Perl-style pattern the preceding or following
|
5959
|
+
character normally shows which is wanted, without the need for the
|
5960
|
+
assertions that are used above in order to give exactly the POSIX be-
|
5960
5961
|
haviour.
|
5961
5962
|
|
5962
5963
|
|
5963
5964
|
VERTICAL BAR
|
5964
5965
|
|
5965
|
-
Vertical
|
5966
|
+
Vertical bar characters are used to separate alternative patterns. For
|
5966
5967
|
example, the pattern
|
5967
5968
|
|
5968
5969
|
gilbert|sullivan
|
5969
5970
|
|
5970
|
-
matches
|
5971
|
-
appear,
|
5971
|
+
matches either "gilbert" or "sullivan". Any number of alternatives may
|
5972
|
+
appear, and an empty alternative is permitted (matching the empty
|
5972
5973
|
string). The matching process tries each alternative in turn, from left
|
5973
|
-
to
|
5974
|
-
are
|
5974
|
+
to right, and the first one that succeeds is used. If the alternatives
|
5975
|
+
are within a subpattern (defined below), "succeeds" means matching the
|
5975
5976
|
rest of the main pattern as well as the alternative in the subpattern.
|
5976
5977
|
|
5977
5978
|
|
5978
5979
|
INTERNAL OPTION SETTING
|
5979
5980
|
|
5980
|
-
The
|
5981
|
-
PCRE_EXTENDED
|
5982
|
-
within
|
5981
|
+
The settings of the PCRE_CASELESS, PCRE_MULTILINE, PCRE_DOTALL, and
|
5982
|
+
PCRE_EXTENDED options (which are Perl-compatible) can be changed from
|
5983
|
+
within the pattern by a sequence of Perl option letters enclosed
|
5983
5984
|
between "(?" and ")". The option letters are
|
5984
5985
|
|
5985
5986
|
i for PCRE_CASELESS
|
@@ -5989,51 +5990,47 @@ INTERNAL OPTION SETTING
|
|
5989
5990
|
|
5990
5991
|
For example, (?im) sets caseless, multiline matching. It is also possi-
|
5991
5992
|
ble to unset these options by preceding the letter with a hyphen, and a
|
5992
|
-
combined
|
5993
|
-
LESS
|
5994
|
-
is
|
5993
|
+
combined setting and unsetting such as (?im-sx), which sets PCRE_CASE-
|
5994
|
+
LESS and PCRE_MULTILINE while unsetting PCRE_DOTALL and PCRE_EXTENDED,
|
5995
|
+
is also permitted. If a letter appears both before and after the
|
5995
5996
|
hyphen, the option is unset.
|
5996
5997
|
|
5997
|
-
The
|
5998
|
-
can
|
5998
|
+
The PCRE-specific options PCRE_DUPNAMES, PCRE_UNGREEDY, and PCRE_EXTRA
|
5999
|
+
can be changed in the same way as the Perl-compatible options by using
|
5999
6000
|
the characters J, U and X respectively.
|
6000
6001
|
|
6001
|
-
When
|
6002
|
-
inside
|
6003
|
-
the
|
6004
|
-
|
6005
|
-
|
6006
|
-
|
6007
|
-
An option change within a subpattern (see below for a description of
|
6008
|
-
subpatterns) affects only that part of the subpattern that follows it,
|
6009
|
-
so
|
6002
|
+
When one of these option changes occurs at top level (that is, not
|
6003
|
+
inside subpattern parentheses), the change applies to the remainder of
|
6004
|
+
the pattern that follows. An option change within a subpattern (see
|
6005
|
+
below for a description of subpatterns) affects only that part of the
|
6006
|
+
subpattern that follows it, so
|
6010
6007
|
|
6011
6008
|
(a(?i)b)c
|
6012
6009
|
|
6013
6010
|
matches abc and aBc and no other strings (assuming PCRE_CASELESS is not
|
6014
|
-
used).
|
6015
|
-
in
|
6016
|
-
do
|
6011
|
+
used). By this means, options can be made to have different settings
|
6012
|
+
in different parts of the pattern. Any changes made in one alternative
|
6013
|
+
do carry on into subsequent branches within the same subpattern. For
|
6017
6014
|
example,
|
6018
6015
|
|
6019
6016
|
(a(?i)b|c)
|
6020
6017
|
|
6021
|
-
matches
|
6022
|
-
first
|
6023
|
-
the
|
6018
|
+
matches "ab", "aB", "c", and "C", even though when matching "C" the
|
6019
|
+
first branch is abandoned before the option setting. This is because
|
6020
|
+
the effects of option settings happen at compile time. There would be
|
6024
6021
|
some very weird behaviour otherwise.
|
6025
6022
|
|
6026
|
-
Note:
|
6027
|
-
application
|
6028
|
-
some
|
6029
|
-
(*CRLF)
|
6030
|
-
defaulted.
|
6031
|
-
sequences"
|
6032
|
-
(*UCP)
|
6033
|
-
erty
|
6034
|
-
PCRE_UTF32
|
6035
|
-
is
|
6036
|
-
ever,
|
6023
|
+
Note: There are other PCRE-specific options that can be set by the
|
6024
|
+
application when the compiling or matching functions are called. In
|
6025
|
+
some cases the pattern can contain special leading sequences such as
|
6026
|
+
(*CRLF) to override what the application has set or what has been
|
6027
|
+
defaulted. Details are given in the section entitled "Newline
|
6028
|
+
sequences" above. There are also the (*UTF8), (*UTF16),(*UTF32), and
|
6029
|
+
(*UCP) leading sequences that can be used to set UTF and Unicode prop-
|
6030
|
+
erty modes; they are equivalent to setting the PCRE_UTF8, PCRE_UTF16,
|
6031
|
+
PCRE_UTF32 and the PCRE_UCP options, respectively. The (*UTF) sequence
|
6032
|
+
is a generic version that can be used with any of the libraries. How-
|
6033
|
+
ever, the application can set the PCRE_NEVER_UTF option, which locks
|
6037
6034
|
out the use of the (*UTF) sequences.
|
6038
6035
|
|
6039
6036
|
|
@@ -6046,18 +6043,18 @@ SUBPATTERNS
|
|
6046
6043
|
|
6047
6044
|
cat(aract|erpillar|)
|
6048
6045
|
|
6049
|
-
matches
|
6046
|
+
matches "cataract", "caterpillar", or "cat". Without the parentheses,
|
6050
6047
|
it would match "cataract", "erpillar" or an empty string.
|
6051
6048
|
|
6052
|
-
2.
|
6053
|
-
that,
|
6049
|
+
2. It sets up the subpattern as a capturing subpattern. This means
|
6050
|
+
that, when the whole pattern matches, that portion of the subject
|
6054
6051
|
string that matched the subpattern is passed back to the caller via the
|
6055
|
-
ovector
|
6056
|
-
traditional
|
6052
|
+
ovector argument of the matching function. (This applies only to the
|
6053
|
+
traditional matching functions; the DFA matching functions do not sup-
|
6057
6054
|
port capturing.)
|
6058
6055
|
|
6059
6056
|
Opening parentheses are counted from left to right (starting from 1) to
|
6060
|
-
obtain
|
6057
|
+
obtain numbers for the capturing subpatterns. For example, if the
|
6061
6058
|
string "the red king" is matched against the pattern
|
6062
6059
|
|
6063
6060
|
the ((red|white) (king|queen))
|
@@ -6065,12 +6062,12 @@ SUBPATTERNS
|
|
6065
6062
|
the captured substrings are "red king", "red", and "king", and are num-
|
6066
6063
|
bered 1, 2, and 3, respectively.
|
6067
6064
|
|
6068
|
-
The
|
6069
|
-
helpful.
|
6070
|
-
without
|
6071
|
-
by
|
6072
|
-
ing,
|
6073
|
-
capturing
|
6065
|
+
The fact that plain parentheses fulfil two functions is not always
|
6066
|
+
helpful. There are often times when a grouping subpattern is required
|
6067
|
+
without a capturing requirement. If an opening parenthesis is followed
|
6068
|
+
by a question mark and a colon, the subpattern does not do any captur-
|
6069
|
+
ing, and is not counted when computing the number of any subsequent
|
6070
|
+
capturing subpatterns. For example, if the string "the white queen" is
|
6074
6071
|
matched against the pattern
|
6075
6072
|
|
6076
6073
|
the ((?:red|white) (king|queen))
|
@@ -6078,37 +6075,37 @@ SUBPATTERNS
|
|
6078
6075
|
the captured substrings are "white queen" and "queen", and are numbered
|
6079
6076
|
1 and 2. The maximum number of capturing subpatterns is 65535.
|
6080
6077
|
|
6081
|
-
As
|
6082
|
-
start
|
6078
|
+
As a convenient shorthand, if any option settings are required at the
|
6079
|
+
start of a non-capturing subpattern, the option letters may appear
|
6083
6080
|
between the "?" and the ":". Thus the two patterns
|
6084
6081
|
|
6085
6082
|
(?i:saturday|sunday)
|
6086
6083
|
(?:(?i)saturday|sunday)
|
6087
6084
|
|
6088
6085
|
match exactly the same set of strings. Because alternative branches are
|
6089
|
-
tried
|
6090
|
-
the
|
6091
|
-
subsequent
|
6086
|
+
tried from left to right, and options are not reset until the end of
|
6087
|
+
the subpattern is reached, an option setting in one branch does affect
|
6088
|
+
subsequent branches, so the above patterns match "SUNDAY" as well as
|
6092
6089
|
"Saturday".
|
6093
6090
|
|
6094
6091
|
|
6095
6092
|
DUPLICATE SUBPATTERN NUMBERS
|
6096
6093
|
|
6097
6094
|
Perl 5.10 introduced a feature whereby each alternative in a subpattern
|
6098
|
-
uses
|
6099
|
-
starts
|
6095
|
+
uses the same numbers for its capturing parentheses. Such a subpattern
|
6096
|
+
starts with (?| and is itself a non-capturing subpattern. For example,
|
6100
6097
|
consider this pattern:
|
6101
6098
|
|
6102
6099
|
(?|(Sat)ur|(Sun))day
|
6103
6100
|
|
6104
|
-
Because
|
6105
|
-
turing
|
6106
|
-
you
|
6107
|
-
matched.
|
6101
|
+
Because the two alternatives are inside a (?| group, both sets of cap-
|
6102
|
+
turing parentheses are numbered one. Thus, when the pattern matches,
|
6103
|
+
you can look at captured substring number one, whichever alternative
|
6104
|
+
matched. This construct is useful when you want to capture part, but
|
6108
6105
|
not all, of one of a number of alternatives. Inside a (?| group, paren-
|
6109
|
-
theses
|
6110
|
-
each
|
6111
|
-
subpattern
|
6106
|
+
theses are numbered as usual, but the number is reset at the start of
|
6107
|
+
each branch. The numbers of any capturing parentheses that follow the
|
6108
|
+
subpattern start after the highest number used in any branch. The fol-
|
6112
6109
|
lowing example is taken from the Perl documentation. The numbers under-
|
6113
6110
|
neath show in which buffer the captured content will be stored.
|
6114
6111
|
|
@@ -6116,58 +6113,58 @@ DUPLICATE SUBPATTERN NUMBERS
|
|
6116
6113
|
/ ( a ) (?| x ( y ) z | (p (q) r) | (t) u (v) ) ( z ) /x
|
6117
6114
|
# 1 2 2 3 2 3 4
|
6118
6115
|
|
6119
|
-
A
|
6120
|
-
that
|
6116
|
+
A back reference to a numbered subpattern uses the most recent value
|
6117
|
+
that is set for that number by any subpattern. The following pattern
|
6121
6118
|
matches "abcabc" or "defdef":
|
6122
6119
|
|
6123
6120
|
/(?|(abc)|(def))\1/
|
6124
6121
|
|
6125
|
-
In
|
6126
|
-
to
|
6122
|
+
In contrast, a subroutine call to a numbered subpattern always refers
|
6123
|
+
to the first one in the pattern with the given number. The following
|
6127
6124
|
pattern matches "abcabc" or "defabc":
|
6128
6125
|
|
6129
6126
|
/(?|(abc)|(def))(?1)/
|
6130
6127
|
|
6131
|
-
If
|
6132
|
-
unique
|
6128
|
+
If a condition test for a subpattern's having matched refers to a non-
|
6129
|
+
unique number, the test is true if any of the subpatterns of that num-
|
6133
6130
|
ber have matched.
|
6134
6131
|
|
6135
|
-
An
|
6132
|
+
An alternative approach to using this "branch reset" feature is to use
|
6136
6133
|
duplicate named subpatterns, as described in the next section.
|
6137
6134
|
|
6138
6135
|
|
6139
6136
|
NAMED SUBPATTERNS
|
6140
6137
|
|
6141
|
-
Identifying
|
6142
|
-
very
|
6143
|
-
sions.
|
6144
|
-
change.
|
6138
|
+
Identifying capturing parentheses by number is simple, but it can be
|
6139
|
+
very hard to keep track of the numbers in complicated regular expres-
|
6140
|
+
sions. Furthermore, if an expression is modified, the numbers may
|
6141
|
+
change. To help with this difficulty, PCRE supports the naming of sub-
|
6145
6142
|
patterns. This feature was not added to Perl until release 5.10. Python
|
6146
|
-
had
|
6147
|
-
the
|
6148
|
-
tax.
|
6143
|
+
had the feature earlier, and PCRE introduced it at release 4.0, using
|
6144
|
+
the Python syntax. PCRE now supports both the Perl and the Python syn-
|
6145
|
+
tax. Perl allows identically numbered subpatterns to have different
|
6149
6146
|
names, but PCRE does not.
|
6150
6147
|
|
6151
|
-
In
|
6152
|
-
or
|
6153
|
-
to
|
6154
|
-
references,
|
6148
|
+
In PCRE, a subpattern can be named in one of three ways: (?<name>...)
|
6149
|
+
or (?'name'...) as in Perl, or (?P<name>...) as in Python. References
|
6150
|
+
to capturing parentheses from other parts of the pattern, such as back
|
6151
|
+
references, recursion, and conditions, can be made by name as well as
|
6155
6152
|
by number.
|
6156
6153
|
|
6157
|
-
Names
|
6158
|
-
must
|
6159
|
-
allocated
|
6160
|
-
present.
|
6161
|
-
to-number
|
6154
|
+
Names consist of up to 32 alphanumeric characters and underscores, but
|
6155
|
+
must start with a non-digit. Named capturing parentheses are still
|
6156
|
+
allocated numbers as well as names, exactly as if the names were not
|
6157
|
+
present. The PCRE API provides function calls for extracting the name-
|
6158
|
+
to-number translation table from a compiled pattern. There is also a
|
6162
6159
|
convenience function for extracting a captured substring by name.
|
6163
6160
|
|
6164
|
-
By
|
6161
|
+
By default, a name must be unique within a pattern, but it is possible
|
6165
6162
|
to relax this constraint by setting the PCRE_DUPNAMES option at compile
|
6166
|
-
time.
|
6167
|
-
the
|
6168
|
-
cate
|
6169
|
-
named
|
6170
|
-
weekday,
|
6163
|
+
time. (Duplicate names are also always permitted for subpatterns with
|
6164
|
+
the same number, set up as described in the previous section.) Dupli-
|
6165
|
+
cate names can be useful for patterns where only one instance of the
|
6166
|
+
named parentheses can match. Suppose you want to match the name of a
|
6167
|
+
weekday, either as a 3-letter abbreviation or as the full name, and in
|
6171
6168
|
both cases you want to extract the abbreviation. This pattern (ignoring
|
6172
6169
|
the line breaks) does the job:
|
6173
6170
|
|
@@ -6177,18 +6174,18 @@ NAMED SUBPATTERNS
|
|
6177
6174
|
(?<DN>Thu)(?:rsday)?|
|
6178
6175
|
(?<DN>Sat)(?:urday)?
|
6179
6176
|
|
6180
|
-
There
|
6177
|
+
There are five capturing substrings, but only one is ever set after a
|
6181
6178
|
match. (An alternative way of solving this problem is to use a "branch
|
6182
6179
|
reset" subpattern, as described in the previous section.)
|
6183
6180
|
|
6184
|
-
The
|
6185
|
-
substring
|
6186
|
-
that
|
6181
|
+
The convenience function for extracting the data by name returns the
|
6182
|
+
substring for the first (and in this example, the only) subpattern of
|
6183
|
+
that name that matched. This saves searching to find which numbered
|
6187
6184
|
subpattern it was.
|
6188
6185
|
|
6189
|
-
If
|
6190
|
-
elsewhere
|
6191
|
-
checked
|
6186
|
+
If you make a back reference to a non-unique named subpattern from
|
6187
|
+
elsewhere in the pattern, the subpatterns to which the name refers are
|
6188
|
+
checked in the order in which they appear in the overall pattern. The
|
6192
6189
|
first one that is set is used for the reference. For example, this pat-
|
6193
6190
|
tern matches both "foofoo" and "barbar" but not "foobar" or "barfoo":
|
6194
6191
|
|
@@ -6196,29 +6193,29 @@ NAMED SUBPATTERNS
|
|
6196
6193
|
|
6197
6194
|
|
6198
6195
|
If you make a subroutine call to a non-unique named subpattern, the one
|
6199
|
-
that
|
6196
|
+
that corresponds to the first occurrence of the name is used. In the
|
6200
6197
|
absence of duplicate numbers (see the previous section) this is the one
|
6201
6198
|
with the lowest number.
|
6202
6199
|
|
6203
6200
|
If you use a named reference in a condition test (see the section about
|
6204
6201
|
conditions below), either to check whether a subpattern has matched, or
|
6205
|
-
to
|
6206
|
-
If
|
6207
|
-
true.
|
6208
|
-
details
|
6202
|
+
to check for recursion, all subpatterns with the same name are tested.
|
6203
|
+
If the condition is true for any one of them, the overall condition is
|
6204
|
+
true. This is the same behaviour as testing by number. For further
|
6205
|
+
details of the interfaces for handling named subpatterns, see the
|
6209
6206
|
pcreapi documentation.
|
6210
6207
|
|
6211
6208
|
Warning: You cannot use different names to distinguish between two sub-
|
6212
|
-
patterns
|
6209
|
+
patterns with the same number because PCRE uses only the numbers when
|
6213
6210
|
matching. For this reason, an error is given at compile time if differ-
|
6214
|
-
ent
|
6211
|
+
ent names are given to subpatterns with the same number. However, you
|
6215
6212
|
can always give the same name to subpatterns with the same number, even
|
6216
6213
|
when PCRE_DUPNAMES is not set.
|
6217
6214
|
|
6218
6215
|
|
6219
6216
|
REPETITION
|
6220
6217
|
|
6221
|
-
Repetition
|
6218
|
+
Repetition is specified by quantifiers, which can follow any of the
|
6222
6219
|
following items:
|
6223
6220
|
|
6224
6221
|
a literal data character
|
@@ -6232,17 +6229,17 @@ REPETITION
|
|
6232
6229
|
a parenthesized subpattern (including assertions)
|
6233
6230
|
a subroutine call to a subpattern (recursive or otherwise)
|
6234
6231
|
|
6235
|
-
The
|
6236
|
-
ber
|
6237
|
-
(braces),
|
6232
|
+
The general repetition quantifier specifies a minimum and maximum num-
|
6233
|
+
ber of permitted matches, by giving the two numbers in curly brackets
|
6234
|
+
(braces), separated by a comma. The numbers must be less than 65536,
|
6238
6235
|
and the first must be less than or equal to the second. For example:
|
6239
6236
|
|
6240
6237
|
z{2,4}
|
6241
6238
|
|
6242
|
-
matches
|
6243
|
-
special
|
6244
|
-
present,
|
6245
|
-
are
|
6239
|
+
matches "zz", "zzz", or "zzzz". A closing brace on its own is not a
|
6240
|
+
special character. If the second number is omitted, but the comma is
|
6241
|
+
present, there is no upper limit; if the second number and the comma
|
6242
|
+
are both omitted, the quantifier specifies an exact number of required
|
6246
6243
|
matches. Thus
|
6247
6244
|
|
6248
6245
|
[aeiou]{3,}
|
@@ -6251,50 +6248,50 @@ REPETITION
|
|
6251
6248
|
|
6252
6249
|
\d{8}
|
6253
6250
|
|
6254
|
-
matches
|
6255
|
-
position
|
6256
|
-
the
|
6251
|
+
matches exactly 8 digits. An opening curly bracket that appears in a
|
6252
|
+
position where a quantifier is not allowed, or one that does not match
|
6253
|
+
the syntax of a quantifier, is taken as a literal character. For exam-
|
6257
6254
|
ple, {,6} is not a quantifier, but a literal string of four characters.
|
6258
6255
|
|
6259
6256
|
In UTF modes, quantifiers apply to characters rather than to individual
|
6260
|
-
data
|
6257
|
+
data units. Thus, for example, \x{100}{2} matches two characters, each
|
6261
6258
|
of which is represented by a two-byte sequence in a UTF-8 string. Simi-
|
6262
|
-
larly,
|
6263
|
-
which
|
6259
|
+
larly, \X{3} matches three Unicode extended grapheme clusters, each of
|
6260
|
+
which may be several data units long (and they may be of different
|
6264
6261
|
lengths).
|
6265
6262
|
|
6266
6263
|
The quantifier {0} is permitted, causing the expression to behave as if
|
6267
6264
|
the previous item and the quantifier were not present. This may be use-
|
6268
|
-
ful
|
6265
|
+
ful for subpatterns that are referenced as subroutines from elsewhere
|
6269
6266
|
in the pattern (but see also the section entitled "Defining subpatterns
|
6270
|
-
for
|
6267
|
+
for use by reference only" below). Items other than subpatterns that
|
6271
6268
|
have a {0} quantifier are omitted from the compiled pattern.
|
6272
6269
|
|
6273
|
-
For
|
6270
|
+
For convenience, the three most common quantifiers have single-charac-
|
6274
6271
|
ter abbreviations:
|
6275
6272
|
|
6276
6273
|
* is equivalent to {0,}
|
6277
6274
|
+ is equivalent to {1,}
|
6278
6275
|
? is equivalent to {0,1}
|
6279
6276
|
|
6280
|
-
It
|
6277
|
+
It is possible to construct infinite loops by following a subpattern
|
6281
6278
|
that can match no characters with a quantifier that has no upper limit,
|
6282
6279
|
for example:
|
6283
6280
|
|
6284
6281
|
(a?)*
|
6285
6282
|
|
6286
6283
|
Earlier versions of Perl and PCRE used to give an error at compile time
|
6287
|
-
for
|
6288
|
-
useful,
|
6289
|
-
subpattern
|
6284
|
+
for such patterns. However, because there are cases where this can be
|
6285
|
+
useful, such patterns are now accepted, but if any repetition of the
|
6286
|
+
subpattern does in fact match no characters, the loop is forcibly bro-
|
6290
6287
|
ken.
|
6291
6288
|
|
6292
|
-
By
|
6293
|
-
as
|
6294
|
-
causing
|
6289
|
+
By default, the quantifiers are "greedy", that is, they match as much
|
6290
|
+
as possible (up to the maximum number of permitted times), without
|
6291
|
+
causing the rest of the pattern to fail. The classic example of where
|
6295
6292
|
this gives problems is in trying to match comments in C programs. These
|
6296
|
-
appear
|
6297
|
-
characters
|
6293
|
+
appear between /* and */ and within the comment, individual * and /
|
6294
|
+
characters may appear. An attempt to match C comments by applying the
|
6298
6295
|
pattern
|
6299
6296
|
|
6300
6297
|
/\*.*\*/
|
@@ -6303,19 +6300,19 @@ REPETITION
|
|
6303
6300
|
|
6304
6301
|
/* first comment */ not comment /* second comment */
|
6305
6302
|
|
6306
|
-
fails,
|
6303
|
+
fails, because it matches the entire string owing to the greediness of
|
6307
6304
|
the .* item.
|
6308
6305
|
|
6309
|
-
However,
|
6306
|
+
However, if a quantifier is followed by a question mark, it ceases to
|
6310
6307
|
be greedy, and instead matches the minimum number of times possible, so
|
6311
6308
|
the pattern
|
6312
6309
|
|
6313
6310
|
/\*.*?\*/
|
6314
6311
|
|
6315
|
-
does
|
6316
|
-
quantifiers
|
6317
|
-
matches.
|
6318
|
-
quantifier
|
6312
|
+
does the right thing with the C comments. The meaning of the various
|
6313
|
+
quantifiers is not otherwise changed, just the preferred number of
|
6314
|
+
matches. Do not confuse this use of question mark with its use as a
|
6315
|
+
quantifier in its own right. Because it has two uses, it can sometimes
|
6319
6316
|
appear doubled, as in
|
6320
6317
|
|
6321
6318
|
\d??\d
|
@@ -6323,45 +6320,45 @@ REPETITION
|
|
6323
6320
|
which matches one digit by preference, but can match two if that is the
|
6324
6321
|
only way the rest of the pattern matches.
|
6325
6322
|
|
6326
|
-
If
|
6327
|
-
Perl),
|
6328
|
-
can
|
6323
|
+
If the PCRE_UNGREEDY option is set (an option that is not available in
|
6324
|
+
Perl), the quantifiers are not greedy by default, but individual ones
|
6325
|
+
can be made greedy by following them with a question mark. In other
|
6329
6326
|
words, it inverts the default behaviour.
|
6330
6327
|
|
6331
|
-
When
|
6332
|
-
count
|
6333
|
-
required
|
6328
|
+
When a parenthesized subpattern is quantified with a minimum repeat
|
6329
|
+
count that is greater than 1 or with a limited maximum, more memory is
|
6330
|
+
required for the compiled pattern, in proportion to the size of the
|
6334
6331
|
minimum or maximum.
|
6335
6332
|
|
6336
6333
|
If a pattern starts with .* or .{0,} and the PCRE_DOTALL option (equiv-
|
6337
|
-
alent
|
6338
|
-
the
|
6339
|
-
tried
|
6340
|
-
is
|
6341
|
-
first.
|
6334
|
+
alent to Perl's /s) is set, thus allowing the dot to match newlines,
|
6335
|
+
the pattern is implicitly anchored, because whatever follows will be
|
6336
|
+
tried against every character position in the subject string, so there
|
6337
|
+
is no point in retrying the overall match at any position after the
|
6338
|
+
first. PCRE normally treats such a pattern as though it were preceded
|
6342
6339
|
by \A.
|
6343
6340
|
|
6344
|
-
In
|
6345
|
-
lines,
|
6341
|
+
In cases where it is known that the subject string contains no new-
|
6342
|
+
lines, it is worth setting PCRE_DOTALL in order to obtain this opti-
|
6346
6343
|
mization, or alternatively using ^ to indicate anchoring explicitly.
|
6347
6344
|
|
6348
|
-
However,
|
6345
|
+
However, there are some cases where the optimization cannot be used.
|
6349
6346
|
When .* is inside capturing parentheses that are the subject of a back
|
6350
6347
|
reference elsewhere in the pattern, a match at the start may fail where
|
6351
6348
|
a later one succeeds. Consider, for example:
|
6352
6349
|
|
6353
6350
|
(.*)abc\1
|
6354
6351
|
|
6355
|
-
If
|
6352
|
+
If the subject is "xyz123abc123" the match point is the fourth charac-
|
6356
6353
|
ter. For this reason, such a pattern is not implicitly anchored.
|
6357
6354
|
|
6358
|
-
Another
|
6359
|
-
ing
|
6355
|
+
Another case where implicit anchoring is not applied is when the lead-
|
6356
|
+
ing .* is inside an atomic group. Once again, a match at the start may
|
6360
6357
|
fail where a later one succeeds. Consider this pattern:
|
6361
6358
|
|
6362
6359
|
(?>.*?a)b
|
6363
6360
|
|
6364
|
-
It
|
6361
|
+
It matches "ab" in the subject "aab". The use of the backtracking con-
|
6365
6362
|
trol verbs (*PRUNE) and (*SKIP) also disable this optimization.
|
6366
6363
|
|
6367
6364
|
When a capturing subpattern is repeated, the value captured is the sub-
|
@@ -6370,8 +6367,8 @@ REPETITION
|
|
6370
6367
|
(tweedle[dume]{3}\s*)+
|
6371
6368
|
|
6372
6369
|
has matched "tweedledum tweedledee" the value of the captured substring
|
6373
|
-
is
|
6374
|
-
the
|
6370
|
+
is "tweedledee". However, if there are nested capturing subpatterns,
|
6371
|
+
the corresponding captured values may have been set in previous itera-
|
6375
6372
|
tions. For example, after
|
6376
6373
|
|
6377
6374
|
/(a|(b))+/
|
@@ -6381,53 +6378,53 @@ REPETITION
|
|
6381
6378
|
|
6382
6379
|
ATOMIC GROUPING AND POSSESSIVE QUANTIFIERS
|
6383
6380
|
|
6384
|
-
With
|
6385
|
-
repetition,
|
6386
|
-
to
|
6387
|
-
rest
|
6388
|
-
either
|
6389
|
-
than
|
6381
|
+
With both maximizing ("greedy") and minimizing ("ungreedy" or "lazy")
|
6382
|
+
repetition, failure of what follows normally causes the repeated item
|
6383
|
+
to be re-evaluated to see if a different number of repeats allows the
|
6384
|
+
rest of the pattern to match. Sometimes it is useful to prevent this,
|
6385
|
+
either to change the nature of the match, or to cause it fail earlier
|
6386
|
+
than it otherwise might, when the author of the pattern knows there is
|
6390
6387
|
no point in carrying on.
|
6391
6388
|
|
6392
|
-
Consider,
|
6389
|
+
Consider, for example, the pattern \d+foo when applied to the subject
|
6393
6390
|
line
|
6394
6391
|
|
6395
6392
|
123456bar
|
6396
6393
|
|
6397
6394
|
After matching all 6 digits and then failing to match "foo", the normal
|
6398
|
-
action
|
6399
|
-
\d+
|
6400
|
-
"Atomic
|
6401
|
-
the
|
6395
|
+
action of the matcher is to try again with only 5 digits matching the
|
6396
|
+
\d+ item, and then with 4, and so on, before ultimately failing.
|
6397
|
+
"Atomic grouping" (a term taken from Jeffrey Friedl's book) provides
|
6398
|
+
the means for specifying that once a subpattern has matched, it is not
|
6402
6399
|
to be re-evaluated in this way.
|
6403
6400
|
|
6404
|
-
If
|
6405
|
-
up
|
6401
|
+
If we use atomic grouping for the previous example, the matcher gives
|
6402
|
+
up immediately on failing to match "foo" the first time. The notation
|
6406
6403
|
is a kind of special parenthesis, starting with (?> as in this example:
|
6407
6404
|
|
6408
6405
|
(?>\d+)foo
|
6409
6406
|
|
6410
|
-
This
|
6411
|
-
tains
|
6412
|
-
prevented
|
6407
|
+
This kind of parenthesis "locks up" the part of the pattern it con-
|
6408
|
+
tains once it has matched, and a failure further into the pattern is
|
6409
|
+
prevented from backtracking into it. Backtracking past it to previous
|
6413
6410
|
items, however, works as normal.
|
6414
6411
|
|
6415
|
-
An
|
6416
|
-
the
|
6412
|
+
An alternative description is that a subpattern of this type matches
|
6413
|
+
the string of characters that an identical standalone pattern would
|
6417
6414
|
match, if anchored at the current point in the subject string.
|
6418
6415
|
|
6419
6416
|
Atomic grouping subpatterns are not capturing subpatterns. Simple cases
|
6420
6417
|
such as the above example can be thought of as a maximizing repeat that
|
6421
|
-
must
|
6422
|
-
pared
|
6418
|
+
must swallow everything it can. So, while both \d+ and \d+? are pre-
|
6419
|
+
pared to adjust the number of digits they match in order to make the
|
6423
6420
|
rest of the pattern match, (?>\d+) can only match an entire sequence of
|
6424
6421
|
digits.
|
6425
6422
|
|
6426
|
-
Atomic
|
6427
|
-
subpatterns,
|
6423
|
+
Atomic groups in general can of course contain arbitrarily complicated
|
6424
|
+
subpatterns, and can be nested. However, when the subpattern for an
|
6428
6425
|
atomic group is just a single repeated item, as in the example above, a
|
6429
|
-
simpler
|
6430
|
-
consists
|
6426
|
+
simpler notation, called a "possessive quantifier" can be used. This
|
6427
|
+
consists of an additional + character following a quantifier. Using
|
6431
6428
|
this notation, the previous example can be rewritten as
|
6432
6429
|
|
6433
6430
|
\d++foo
|
@@ -6437,45 +6434,45 @@ ATOMIC GROUPING AND POSSESSIVE QUANTIFIERS
|
|
6437
6434
|
|
6438
6435
|
(abc|xyz){2,3}+
|
6439
6436
|
|
6440
|
-
Possessive
|
6437
|
+
Possessive quantifiers are always greedy; the setting of the
|
6441
6438
|
PCRE_UNGREEDY option is ignored. They are a convenient notation for the
|
6442
|
-
simpler
|
6443
|
-
meaning
|
6444
|
-
though
|
6439
|
+
simpler forms of atomic group. However, there is no difference in the
|
6440
|
+
meaning of a possessive quantifier and the equivalent atomic group,
|
6441
|
+
though there may be a performance difference; possessive quantifiers
|
6445
6442
|
should be slightly faster.
|
6446
6443
|
|
6447
|
-
The
|
6448
|
-
tax.
|
6444
|
+
The possessive quantifier syntax is an extension to the Perl 5.8 syn-
|
6445
|
+
tax. Jeffrey Friedl originated the idea (and the name) in the first
|
6449
6446
|
edition of his book. Mike McCloskey liked it, so implemented it when he
|
6450
|
-
built
|
6447
|
+
built Sun's Java package, and PCRE copied it from there. It ultimately
|
6451
6448
|
found its way into Perl at release 5.10.
|
6452
6449
|
|
6453
6450
|
PCRE has an optimization that automatically "possessifies" certain sim-
|
6454
|
-
ple
|
6455
|
-
A++B
|
6451
|
+
ple pattern constructs. For example, the sequence A+B is treated as
|
6452
|
+
A++B because there is no point in backtracking into a sequence of A's
|
6456
6453
|
when B must follow.
|
6457
6454
|
|
6458
|
-
When
|
6459
|
-
can
|
6460
|
-
atomic
|
6455
|
+
When a pattern contains an unlimited repeat inside a subpattern that
|
6456
|
+
can itself be repeated an unlimited number of times, the use of an
|
6457
|
+
atomic group is the only way to avoid some failing matches taking a
|
6461
6458
|
very long time indeed. The pattern
|
6462
6459
|
|
6463
6460
|
(\D+|<\d+>)*[!?]
|
6464
6461
|
|
6465
|
-
matches
|
6466
|
-
digits,
|
6462
|
+
matches an unlimited number of substrings that either consist of non-
|
6463
|
+
digits, or digits enclosed in <>, followed by either ! or ?. When it
|
6467
6464
|
matches, it runs quickly. However, if it is applied to
|
6468
6465
|
|
6469
6466
|
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
|
6470
6467
|
|
6471
|
-
it
|
6472
|
-
string
|
6473
|
-
*
|
6474
|
-
example
|
6475
|
-
both
|
6476
|
-
when
|
6477
|
-
ter
|
6478
|
-
in
|
6468
|
+
it takes a long time before reporting failure. This is because the
|
6469
|
+
string can be divided between the internal \D+ repeat and the external
|
6470
|
+
* repeat in a large number of ways, and all have to be tried. (The
|
6471
|
+
example uses [!?] rather than a single character at the end, because
|
6472
|
+
both PCRE and Perl have an optimization that allows for fast failure
|
6473
|
+
when a single character is used. They remember the last single charac-
|
6474
|
+
ter that is required for a match, and fail early if it is not present
|
6475
|
+
in the string.) If the pattern is changed so that it uses an atomic
|
6479
6476
|
group, like this:
|
6480
6477
|
|
6481
6478
|
((?>\D+)|<\d+>)*[!?]
|
@@ -6487,28 +6484,28 @@ BACK REFERENCES
|
|
6487
6484
|
|
6488
6485
|
Outside a character class, a backslash followed by a digit greater than
|
6489
6486
|
0 (and possibly further digits) is a back reference to a capturing sub-
|
6490
|
-
pattern
|
6487
|
+
pattern earlier (that is, to its left) in the pattern, provided there
|
6491
6488
|
have been that many previous capturing left parentheses.
|
6492
6489
|
|
6493
6490
|
However, if the decimal number following the backslash is less than 10,
|
6494
|
-
it
|
6495
|
-
there
|
6496
|
-
tern.
|
6497
|
-
to
|
6498
|
-
reference"
|
6499
|
-
and
|
6491
|
+
it is always taken as a back reference, and causes an error only if
|
6492
|
+
there are not that many capturing left parentheses in the entire pat-
|
6493
|
+
tern. In other words, the parentheses that are referenced need not be
|
6494
|
+
to the left of the reference for numbers less than 10. A "forward back
|
6495
|
+
reference" of this type can make sense when a repetition is involved
|
6496
|
+
and the subpattern to the right has participated in an earlier itera-
|
6500
6497
|
tion.
|
6501
6498
|
|
6502
|
-
It
|
6503
|
-
subpattern
|
6504
|
-
sequence
|
6499
|
+
It is not possible to have a numerical "forward back reference" to a
|
6500
|
+
subpattern whose number is 10 or more using this syntax because a
|
6501
|
+
sequence such as \50 is interpreted as a character defined in octal.
|
6505
6502
|
See the subsection entitled "Non-printing characters" above for further
|
6506
|
-
details
|
6507
|
-
such
|
6503
|
+
details of the handling of digits following a backslash. There is no
|
6504
|
+
such problem when named parentheses are used. A back reference to any
|
6508
6505
|
subpattern is possible using named parentheses (see below).
|
6509
6506
|
|
6510
|
-
Another
|
6511
|
-
following
|
6507
|
+
Another way of avoiding the ambiguity inherent in the use of digits
|
6508
|
+
following a backslash is to use the \g escape sequence. This escape
|
6512
6509
|
must be followed by an unsigned number or a negative number, optionally
|
6513
6510
|
enclosed in braces. These examples are all identical:
|
6514
6511
|
|
@@ -6516,7 +6513,7 @@ BACK REFERENCES
|
|
6516
6513
|
(ring), \g1
|
6517
6514
|
(ring), \g{1}
|
6518
6515
|
|
6519
|
-
An
|
6516
|
+
An unsigned number specifies an absolute reference without the ambigu-
|
6520
6517
|
ity that is present in the older syntax. It is also useful when literal
|
6521
6518
|
digits follow the reference. A negative number is a relative reference.
|
6522
6519
|
Consider this example:
|
@@ -6525,33 +6522,33 @@ BACK REFERENCES
|
|
6525
6522
|
|
6526
6523
|
The sequence \g{-1} is a reference to the most recently started captur-
|
6527
6524
|
ing subpattern before \g, that is, is it equivalent to \2 in this exam-
|
6528
|
-
ple.
|
6529
|
-
references
|
6530
|
-
are
|
6525
|
+
ple. Similarly, \g{-2} would be equivalent to \1. The use of relative
|
6526
|
+
references can be helpful in long patterns, and also in patterns that
|
6527
|
+
are created by joining together fragments that contain references
|
6531
6528
|
within themselves.
|
6532
6529
|
|
6533
|
-
A
|
6534
|
-
pattern
|
6530
|
+
A back reference matches whatever actually matched the capturing sub-
|
6531
|
+
pattern in the current subject string, rather than anything matching
|
6535
6532
|
the subpattern itself (see "Subpatterns as subroutines" below for a way
|
6536
6533
|
of doing that). So the pattern
|
6537
6534
|
|
6538
6535
|
(sens|respons)e and \1ibility
|
6539
6536
|
|
6540
|
-
matches
|
6541
|
-
not
|
6542
|
-
time
|
6537
|
+
matches "sense and sensibility" and "response and responsibility", but
|
6538
|
+
not "sense and responsibility". If caseful matching is in force at the
|
6539
|
+
time of the back reference, the case of letters is relevant. For exam-
|
6543
6540
|
ple,
|
6544
6541
|
|
6545
6542
|
((?i)rah)\s+\1
|
6546
6543
|
|
6547
|
-
matches
|
6544
|
+
matches "rah rah" and "RAH RAH", but not "RAH rah", even though the
|
6548
6545
|
original capturing subpattern is matched caselessly.
|
6549
6546
|
|
6550
|
-
There
|
6551
|
-
subpatterns.
|
6552
|
-
\k'name'
|
6547
|
+
There are several different ways of writing back references to named
|
6548
|
+
subpatterns. The .NET syntax \k{name} and the Perl syntax \k<name> or
|
6549
|
+
\k'name' are supported, as is the Python syntax (?P=name). Perl 5.10's
|
6553
6550
|
unified back reference syntax, in which \g can be used for both numeric
|
6554
|
-
and
|
6551
|
+
and named references, is also supported. We could rewrite the above
|
6555
6552
|
example in any of the following ways:
|
6556
6553
|
|
6557
6554
|
(?<p1>(?i)rah)\s+\k<p1>
|
@@ -6559,84 +6556,92 @@ BACK REFERENCES
|
|
6559
6556
|
(?P<p1>(?i)rah)\s+(?P=p1)
|
6560
6557
|
(?<p1>(?i)rah)\s+\g{p1}
|
6561
6558
|
|
6562
|
-
A
|
6559
|
+
A subpattern that is referenced by name may appear in the pattern
|
6563
6560
|
before or after the reference.
|
6564
6561
|
|
6565
|
-
There
|
6566
|
-
subpattern
|
6562
|
+
There may be more than one back reference to the same subpattern. If a
|
6563
|
+
subpattern has not actually been used in a particular match, any back
|
6567
6564
|
references to it always fail by default. For example, the pattern
|
6568
6565
|
|
6569
6566
|
(a|(bc))\2
|
6570
6567
|
|
6571
|
-
always
|
6568
|
+
always fails if it starts to match "a" rather than "bc". However, if
|
6572
6569
|
the PCRE_JAVASCRIPT_COMPAT option is set at compile time, a back refer-
|
6573
6570
|
ence to an unset value matches an empty string.
|
6574
6571
|
|
6575
|
-
Because
|
6576
|
-
its
|
6577
|
-
ence
|
6578
|
-
delimiter
|
6579
|
-
PCRE_EXTENDED
|
6572
|
+
Because there may be many capturing parentheses in a pattern, all dig-
|
6573
|
+
its following a backslash are taken as part of a potential back refer-
|
6574
|
+
ence number. If the pattern continues with a digit character, some
|
6575
|
+
delimiter must be used to terminate the back reference. If the
|
6576
|
+
PCRE_EXTENDED option is set, this can be white space. Otherwise, the
|
6580
6577
|
\g{ syntax or an empty comment (see "Comments" below) can be used.
|
6581
6578
|
|
6582
6579
|
Recursive back references
|
6583
6580
|
|
6584
|
-
A
|
6585
|
-
fails
|
6586
|
-
matches.
|
6581
|
+
A back reference that occurs inside the parentheses to which it refers
|
6582
|
+
fails when the subpattern is first used, so, for example, (a\1) never
|
6583
|
+
matches. However, such references can be useful inside repeated sub-
|
6587
6584
|
patterns. For example, the pattern
|
6588
6585
|
|
6589
6586
|
(a|b\1)+
|
6590
6587
|
|
6591
6588
|
matches any number of "a"s and also "aba", "ababbaa" etc. At each iter-
|
6592
|
-
ation
|
6593
|
-
string
|
6594
|
-
work,
|
6595
|
-
to
|
6589
|
+
ation of the subpattern, the back reference matches the character
|
6590
|
+
string corresponding to the previous iteration. In order for this to
|
6591
|
+
work, the pattern must be such that the first iteration does not need
|
6592
|
+
to match the back reference. This can be done using alternation, as in
|
6596
6593
|
the example above, or by a quantifier with a minimum of zero.
|
6597
6594
|
|
6598
|
-
Back
|
6599
|
-
treated
|
6600
|
-
subsequent
|
6595
|
+
Back references of this type cause the group that they reference to be
|
6596
|
+
treated as an atomic group. Once the whole group has been matched, a
|
6597
|
+
subsequent matching failure cannot cause backtracking into the middle
|
6601
6598
|
of the group.
|
6602
6599
|
|
6603
6600
|
|
6604
6601
|
ASSERTIONS
|
6605
6602
|
|
6606
|
-
An
|
6607
|
-
current
|
6608
|
-
The
|
6603
|
+
An assertion is a test on the characters following or preceding the
|
6604
|
+
current matching point that does not actually consume any characters.
|
6605
|
+
The simple assertions coded as \b, \B, \A, \G, \Z, \z, ^ and $ are
|
6609
6606
|
described above.
|
6610
6607
|
|
6611
|
-
More
|
6612
|
-
kinds:
|
6613
|
-
string,
|
6614
|
-
matched
|
6608
|
+
More complicated assertions are coded as subpatterns. There are two
|
6609
|
+
kinds: those that look ahead of the current position in the subject
|
6610
|
+
string, and those that look behind it. An assertion subpattern is
|
6611
|
+
matched in the normal way, except that it does not cause the current
|
6615
6612
|
matching position to be changed.
|
6616
6613
|
|
6617
|
-
Assertion
|
6618
|
-
tion
|
6619
|
-
the
|
6620
|
-
tern.
|
6614
|
+
Assertion subpatterns are not capturing subpatterns. If such an asser-
|
6615
|
+
tion contains capturing subpatterns within it, these are counted for
|
6616
|
+
the purposes of numbering the capturing subpatterns in the whole pat-
|
6617
|
+
tern. However, substring capturing is carried out only for positive
|
6621
6618
|
assertions. (Perl sometimes, but not always, does do capturing in nega-
|
6622
6619
|
tive assertions.)
|
6623
6620
|
|
6624
|
-
|
6625
|
-
|
6626
|
-
|
6621
|
+
WARNING: If a positive assertion containing one or more capturing sub-
|
6622
|
+
patterns succeeds, but failure to match later in the pattern causes
|
6623
|
+
backtracking over this assertion, the captures within the assertion are
|
6624
|
+
reset only if no higher numbered captures are already set. This is,
|
6625
|
+
unfortunately, a fundamental limitation of the current implementation,
|
6626
|
+
and as PCRE1 is now in maintenance-only status, it is unlikely ever to
|
6627
|
+
change.
|
6628
|
+
|
6629
|
+
For compatibility with Perl, assertion subpatterns may be repeated;
|
6630
|
+
though it makes no sense to assert the same thing several times, the
|
6631
|
+
side effect of capturing parentheses may occasionally be useful. In
|
6627
6632
|
practice, there only three cases:
|
6628
6633
|
|
6629
|
-
(1)
|
6630
|
-
matching.
|
6634
|
+
(1) If the quantifier is {0}, the assertion is never obeyed during
|
6635
|
+
matching. However, it may contain internal capturing parenthesized
|
6631
6636
|
groups that are called from elsewhere via the subroutine mechanism.
|
6632
6637
|
|
6633
|
-
(2)
|
6634
|
-
as
|
6638
|
+
(2) If quantifier is {0,n} where n is greater than zero, it is treated
|
6639
|
+
as if it were {0,1}. At run time, the rest of the pattern match is
|
6635
6640
|
tried with and without the assertion, the order depending on the greed-
|
6636
6641
|
iness of the quantifier.
|
6637
6642
|
|
6638
|
-
(3)
|
6639
|
-
ignored.
|
6643
|
+
(3) If the minimum repetition is greater than zero, the quantifier is
|
6644
|
+
ignored. The assertion is obeyed just once when encountered during
|
6640
6645
|
matching.
|
6641
6646
|
|
6642
6647
|
Lookahead assertions
|
@@ -6646,38 +6651,38 @@ ASSERTIONS
|
|
6646
6651
|
|
6647
6652
|
\w+(?=;)
|
6648
6653
|
|
6649
|
-
matches
|
6654
|
+
matches a word followed by a semicolon, but does not include the semi-
|
6650
6655
|
colon in the match, and
|
6651
6656
|
|
6652
6657
|
foo(?!bar)
|
6653
6658
|
|
6654
|
-
matches
|
6659
|
+
matches any occurrence of "foo" that is not followed by "bar". Note
|
6655
6660
|
that the apparently similar pattern
|
6656
6661
|
|
6657
6662
|
(?!foo)bar
|
6658
6663
|
|
6659
|
-
does
|
6660
|
-
other
|
6664
|
+
does not find an occurrence of "bar" that is preceded by something
|
6665
|
+
other than "foo"; it finds any occurrence of "bar" whatsoever, because
|
6661
6666
|
the assertion (?!foo) is always true when the next three characters are
|
6662
6667
|
"bar". A lookbehind assertion is needed to achieve the other effect.
|
6663
6668
|
|
6664
6669
|
If you want to force a matching failure at some point in a pattern, the
|
6665
|
-
most
|
6666
|
-
always
|
6670
|
+
most convenient way to do it is with (?!) because an empty string
|
6671
|
+
always matches, so an assertion that requires there not to be an empty
|
6667
6672
|
string must always fail. The backtracking control verb (*FAIL) or (*F)
|
6668
6673
|
is a synonym for (?!).
|
6669
6674
|
|
6670
6675
|
Lookbehind assertions
|
6671
6676
|
|
6672
|
-
Lookbehind
|
6677
|
+
Lookbehind assertions start with (?<= for positive assertions and (?<!
|
6673
6678
|
for negative assertions. For example,
|
6674
6679
|
|
6675
6680
|
(?<!foo)bar
|
6676
6681
|
|
6677
|
-
does
|
6678
|
-
contents
|
6682
|
+
does find an occurrence of "bar" that is not preceded by "foo". The
|
6683
|
+
contents of a lookbehind assertion are restricted such that all the
|
6679
6684
|
strings it matches must have a fixed length. However, if there are sev-
|
6680
|
-
eral
|
6685
|
+
eral top-level alternatives, they do not all have to have the same
|
6681
6686
|
fixed length. Thus
|
6682
6687
|
|
6683
6688
|
(?<=bullock|donkey)
|
@@ -6686,62 +6691,62 @@ ASSERTIONS
|
|
6686
6691
|
|
6687
6692
|
(?<!dogs?|cats?)
|
6688
6693
|
|
6689
|
-
causes
|
6690
|
-
strings
|
6694
|
+
causes an error at compile time. Branches that match different length
|
6695
|
+
strings are permitted only at the top level of a lookbehind assertion.
|
6691
6696
|
This is an extension compared with Perl, which requires all branches to
|
6692
6697
|
match the same length of string. An assertion such as
|
6693
6698
|
|
6694
6699
|
(?<=ab(c|de))
|
6695
6700
|
|
6696
|
-
is
|
6701
|
+
is not permitted, because its single top-level branch can match two
|
6697
6702
|
different lengths, but it is acceptable to PCRE if rewritten to use two
|
6698
6703
|
top-level branches:
|
6699
6704
|
|
6700
6705
|
(?<=abc|abde)
|
6701
6706
|
|
6702
|
-
In
|
6707
|
+
In some cases, the escape sequence \K (see above) can be used instead
|
6703
6708
|
of a lookbehind assertion to get round the fixed-length restriction.
|
6704
6709
|
|
6705
|
-
The
|
6706
|
-
to
|
6710
|
+
The implementation of lookbehind assertions is, for each alternative,
|
6711
|
+
to temporarily move the current position back by the fixed length and
|
6707
6712
|
then try to match. If there are insufficient characters before the cur-
|
6708
6713
|
rent position, the assertion fails.
|
6709
6714
|
|
6710
|
-
In
|
6711
|
-
gle
|
6712
|
-
because
|
6713
|
-
hind.
|
6715
|
+
In a UTF mode, PCRE does not allow the \C escape (which matches a sin-
|
6716
|
+
gle data unit even in a UTF mode) to appear in lookbehind assertions,
|
6717
|
+
because it makes it impossible to calculate the length of the lookbe-
|
6718
|
+
hind. The \X and \R escapes, which can match different numbers of data
|
6714
6719
|
units, are also not permitted.
|
6715
6720
|
|
6716
|
-
"Subroutine"
|
6717
|
-
lookbehinds,
|
6721
|
+
"Subroutine" calls (see below) such as (?2) or (?&X) are permitted in
|
6722
|
+
lookbehinds, as long as the subpattern matches a fixed-length string.
|
6718
6723
|
Recursion, however, is not supported.
|
6719
6724
|
|
6720
|
-
Possessive
|
6725
|
+
Possessive quantifiers can be used in conjunction with lookbehind
|
6721
6726
|
assertions to specify efficient matching of fixed-length strings at the
|
6722
6727
|
end of subject strings. Consider a simple pattern such as
|
6723
6728
|
|
6724
6729
|
abcd$
|
6725
6730
|
|
6726
|
-
when
|
6731
|
+
when applied to a long string that does not match. Because matching
|
6727
6732
|
proceeds from left to right, PCRE will look for each "a" in the subject
|
6728
|
-
and
|
6733
|
+
and then see if what follows matches the rest of the pattern. If the
|
6729
6734
|
pattern is specified as
|
6730
6735
|
|
6731
6736
|
^.*abcd$
|
6732
6737
|
|
6733
|
-
the
|
6738
|
+
the initial .* matches the entire string at first, but when this fails
|
6734
6739
|
(because there is no following "a"), it backtracks to match all but the
|
6735
|
-
last
|
6736
|
-
again
|
6740
|
+
last character, then all but the last two characters, and so on. Once
|
6741
|
+
again the search for "a" covers the entire string, from right to left,
|
6737
6742
|
so we are no better off. However, if the pattern is written as
|
6738
6743
|
|
6739
6744
|
^.*+(?<=abcd)
|
6740
6745
|
|
6741
|
-
there
|
6742
|
-
entire
|
6743
|
-
on
|
6744
|
-
For
|
6746
|
+
there can be no backtracking for the .*+ item; it can match only the
|
6747
|
+
entire string. The subsequent lookbehind assertion does a single test
|
6748
|
+
on the last four characters. If it fails, the match fails immediately.
|
6749
|
+
For long strings, this approach makes a significant difference to the
|
6745
6750
|
processing time.
|
6746
6751
|
|
6747
6752
|
Using multiple assertions
|
@@ -6750,18 +6755,18 @@ ASSERTIONS
|
|
6750
6755
|
|
6751
6756
|
(?<=\d{3})(?<!999)foo
|
6752
6757
|
|
6753
|
-
matches
|
6754
|
-
each
|
6755
|
-
the
|
6756
|
-
characters
|
6758
|
+
matches "foo" preceded by three digits that are not "999". Notice that
|
6759
|
+
each of the assertions is applied independently at the same point in
|
6760
|
+
the subject string. First there is a check that the previous three
|
6761
|
+
characters are all digits, and then there is a check that the same
|
6757
6762
|
three characters are not "999". This pattern does not match "foo" pre-
|
6758
|
-
ceded
|
6759
|
-
three
|
6763
|
+
ceded by six characters, the first of which are digits and the last
|
6764
|
+
three of which are not "999". For example, it doesn't match "123abc-
|
6760
6765
|
foo". A pattern to do that is
|
6761
6766
|
|
6762
6767
|
(?<=\d{3}...)(?<!999)foo
|
6763
6768
|
|
6764
|
-
This
|
6769
|
+
This time the first assertion looks at the preceding six characters,
|
6765
6770
|
checking that the first three are digits, and then the second assertion
|
6766
6771
|
checks that the preceding three characters are not "999".
|
6767
6772
|
|
@@ -6769,29 +6774,29 @@ ASSERTIONS
|
|
6769
6774
|
|
6770
6775
|
(?<=(?<!foo)bar)baz
|
6771
6776
|
|
6772
|
-
matches
|
6777
|
+
matches an occurrence of "baz" that is preceded by "bar" which in turn
|
6773
6778
|
is not preceded by "foo", while
|
6774
6779
|
|
6775
6780
|
(?<=\d{3}(?!999)...)foo
|
6776
6781
|
|
6777
|
-
is
|
6782
|
+
is another pattern that matches "foo" preceded by three digits and any
|
6778
6783
|
three characters that are not "999".
|
6779
6784
|
|
6780
6785
|
|
6781
6786
|
CONDITIONAL SUBPATTERNS
|
6782
6787
|
|
6783
|
-
It
|
6784
|
-
ditionally
|
6785
|
-
on
|
6786
|
-
tern
|
6788
|
+
It is possible to cause the matching process to obey a subpattern con-
|
6789
|
+
ditionally or to choose between two alternative subpatterns, depending
|
6790
|
+
on the result of an assertion, or whether a specific capturing subpat-
|
6791
|
+
tern has already been matched. The two possible forms of conditional
|
6787
6792
|
subpattern are:
|
6788
6793
|
|
6789
6794
|
(?(condition)yes-pattern)
|
6790
6795
|
(?(condition)yes-pattern|no-pattern)
|
6791
6796
|
|
6792
|
-
If
|
6793
|
-
no-pattern
|
6794
|
-
tives
|
6797
|
+
If the condition is satisfied, the yes-pattern is used; otherwise the
|
6798
|
+
no-pattern (if present) is used. If there are more than two alterna-
|
6799
|
+
tives in the subpattern, a compile-time error occurs. Each of the two
|
6795
6800
|
alternatives may itself contain nested subpatterns of any form, includ-
|
6796
6801
|
ing conditional subpatterns; the restriction to two alternatives
|
6797
6802
|
applies only at the level of the condition. This pattern fragment is an
|
@@ -6800,68 +6805,68 @@ CONDITIONAL SUBPATTERNS
|
|
6800
6805
|
(?(1) (A|B|C) | (D | (?(2)E|F) | E) )
|
6801
6806
|
|
6802
6807
|
|
6803
|
-
There
|
6808
|
+
There are four kinds of condition: references to subpatterns, refer-
|
6804
6809
|
ences to recursion, a pseudo-condition called DEFINE, and assertions.
|
6805
6810
|
|
6806
6811
|
Checking for a used subpattern by number
|
6807
6812
|
|
6808
|
-
If
|
6813
|
+
If the text between the parentheses consists of a sequence of digits,
|
6809
6814
|
the condition is true if a capturing subpattern of that number has pre-
|
6810
|
-
viously
|
6811
|
-
the
|
6812
|
-
numbers),
|
6813
|
-
native
|
6814
|
-
this
|
6815
|
-
most
|
6816
|
-
most
|
6815
|
+
viously matched. If there is more than one capturing subpattern with
|
6816
|
+
the same number (see the earlier section about duplicate subpattern
|
6817
|
+
numbers), the condition is true if any of them have matched. An alter-
|
6818
|
+
native notation is to precede the digits with a plus or minus sign. In
|
6819
|
+
this case, the subpattern number is relative rather than absolute. The
|
6820
|
+
most recently opened parentheses can be referenced by (?(-1), the next
|
6821
|
+
most recent by (?(-2), and so on. Inside loops it can also make sense
|
6817
6822
|
to refer to subsequent groups. The next parentheses to be opened can be
|
6818
|
-
referenced
|
6823
|
+
referenced as (?(+1), and so on. (The value zero in any of these forms
|
6819
6824
|
is not used; it provokes a compile-time error.)
|
6820
6825
|
|
6821
|
-
Consider
|
6826
|
+
Consider the following pattern, which contains non-significant white
|
6822
6827
|
space to make it more readable (assume the PCRE_EXTENDED option) and to
|
6823
6828
|
divide it into three parts for ease of discussion:
|
6824
6829
|
|
6825
6830
|
( \( )? [^()]+ (?(1) \) )
|
6826
6831
|
|
6827
|
-
The
|
6832
|
+
The first part matches an optional opening parenthesis, and if that
|
6828
6833
|
character is present, sets it as the first captured substring. The sec-
|
6829
|
-
ond
|
6830
|
-
third
|
6831
|
-
first
|
6832
|
-
started
|
6833
|
-
yes-pattern
|
6834
|
-
wise,
|
6835
|
-
In
|
6834
|
+
ond part matches one or more characters that are not parentheses. The
|
6835
|
+
third part is a conditional subpattern that tests whether or not the
|
6836
|
+
first set of parentheses matched. If they did, that is, if subject
|
6837
|
+
started with an opening parenthesis, the condition is true, and so the
|
6838
|
+
yes-pattern is executed and a closing parenthesis is required. Other-
|
6839
|
+
wise, since no-pattern is not present, the subpattern matches nothing.
|
6840
|
+
In other words, this pattern matches a sequence of non-parentheses,
|
6836
6841
|
optionally enclosed in parentheses.
|
6837
6842
|
|
6838
|
-
If
|
6843
|
+
If you were embedding this pattern in a larger one, you could use a
|
6839
6844
|
relative reference:
|
6840
6845
|
|
6841
6846
|
...other stuff... ( \( )? [^()]+ (?(-1) \) ) ...
|
6842
6847
|
|
6843
|
-
This
|
6848
|
+
This makes the fragment independent of the parentheses in the larger
|
6844
6849
|
pattern.
|
6845
6850
|
|
6846
6851
|
Checking for a used subpattern by name
|
6847
6852
|
|
6848
|
-
Perl
|
6849
|
-
used
|
6850
|
-
PCRE,
|
6853
|
+
Perl uses the syntax (?(<name>)...) or (?('name')...) to test for a
|
6854
|
+
used subpattern by name. For compatibility with earlier versions of
|
6855
|
+
PCRE, which had this facility before Perl, the syntax (?(name)...) is
|
6851
6856
|
also recognized.
|
6852
6857
|
|
6853
6858
|
Rewriting the above example to use a named subpattern gives this:
|
6854
6859
|
|
6855
6860
|
(?<OPEN> \( )? [^()]+ (?(<OPEN>) \) )
|
6856
6861
|
|
6857
|
-
If
|
6858
|
-
is
|
6862
|
+
If the name used in a condition of this kind is a duplicate, the test
|
6863
|
+
is applied to all subpatterns of the same name, and is true if any one
|
6859
6864
|
of them has matched.
|
6860
6865
|
|
6861
6866
|
Checking for pattern recursion
|
6862
6867
|
|
6863
6868
|
If the condition is the string (R), and there is no subpattern with the
|
6864
|
-
name
|
6869
|
+
name R, the condition is true if a recursive call to the whole pattern
|
6865
6870
|
or any subpattern has been made. If digits or a name preceded by amper-
|
6866
6871
|
sand follow the letter R, for example:
|
6867
6872
|
|
@@ -6869,51 +6874,51 @@ CONDITIONAL SUBPATTERNS
|
|
6869
6874
|
|
6870
6875
|
the condition is true if the most recent recursion is into a subpattern
|
6871
6876
|
whose number or name is given. This condition does not check the entire
|
6872
|
-
recursion
|
6877
|
+
recursion stack. If the name used in a condition of this kind is a
|
6873
6878
|
duplicate, the test is applied to all subpatterns of the same name, and
|
6874
6879
|
is true if any one of them is the most recent recursion.
|
6875
6880
|
|
6876
|
-
At
|
6881
|
+
At "top level", all these recursion test conditions are false. The
|
6877
6882
|
syntax for recursive patterns is described below.
|
6878
6883
|
|
6879
6884
|
Defining subpatterns for use by reference only
|
6880
6885
|
|
6881
|
-
If
|
6882
|
-
with
|
6883
|
-
there
|
6884
|
-
skipped
|
6885
|
-
DEFINE
|
6886
|
-
enced
|
6887
|
-
example,
|
6886
|
+
If the condition is the string (DEFINE), and there is no subpattern
|
6887
|
+
with the name DEFINE, the condition is always false. In this case,
|
6888
|
+
there may be only one alternative in the subpattern. It is always
|
6889
|
+
skipped if control reaches this point in the pattern; the idea of
|
6890
|
+
DEFINE is that it can be used to define subroutines that can be refer-
|
6891
|
+
enced from elsewhere. (The use of subroutines is described below.) For
|
6892
|
+
example, a pattern to match an IPv4 address such as "192.168.23.245"
|
6888
6893
|
could be written like this (ignore white space and line breaks):
|
6889
6894
|
|
6890
6895
|
(?(DEFINE) (?<byte> 2[0-4]\d | 25[0-5] | 1\d\d | [1-9]?\d) )
|
6891
6896
|
\b (?&byte) (\.(?&byte)){3} \b
|
6892
6897
|
|
6893
|
-
The
|
6894
|
-
group
|
6895
|
-
an
|
6896
|
-
this
|
6897
|
-
condition.
|
6898
|
-
to
|
6898
|
+
The first part of the pattern is a DEFINE group inside which a another
|
6899
|
+
group named "byte" is defined. This matches an individual component of
|
6900
|
+
an IPv4 address (a number less than 256). When matching takes place,
|
6901
|
+
this part of the pattern is skipped because DEFINE acts like a false
|
6902
|
+
condition. The rest of the pattern uses references to the named group
|
6903
|
+
to match the four dot-separated components of an IPv4 address, insist-
|
6899
6904
|
ing on a word boundary at each end.
|
6900
6905
|
|
6901
6906
|
Assertion conditions
|
6902
6907
|
|
6903
|
-
If
|
6904
|
-
assertion.
|
6905
|
-
assertion.
|
6908
|
+
If the condition is not in any of the above formats, it must be an
|
6909
|
+
assertion. This may be a positive or negative lookahead or lookbehind
|
6910
|
+
assertion. Consider this pattern, again containing non-significant
|
6906
6911
|
white space, and with the two alternatives on the second line:
|
6907
6912
|
|
6908
6913
|
(?(?=[^a-z]*[a-z])
|
6909
6914
|
\d{2}-[a-z]{3}-\d{2} | \d{2}-\d{2}-\d{2} )
|
6910
6915
|
|
6911
|
-
The
|
6912
|
-
optional
|
6913
|
-
it
|
6914
|
-
letter
|
6915
|
-
otherwise
|
6916
|
-
strings
|
6916
|
+
The condition is a positive lookahead assertion that matches an
|
6917
|
+
optional sequence of non-letters followed by a letter. In other words,
|
6918
|
+
it tests for the presence of at least one letter in the subject. If a
|
6919
|
+
letter is found, the subject is matched against the first alternative;
|
6920
|
+
otherwise it is matched against the second. This pattern matches
|
6921
|
+
strings in one of the two forms dd-aaa-dd or dd-dd-dd, where aaa are
|
6917
6922
|
letters and dd are digits.
|
6918
6923
|
|
6919
6924
|
|
@@ -6922,41 +6927,41 @@ COMMENTS
|
|
6922
6927
|
There are two ways of including comments in patterns that are processed
|
6923
6928
|
by PCRE. In both cases, the start of the comment must not be in a char-
|
6924
6929
|
acter class, nor in the middle of any other sequence of related charac-
|
6925
|
-
ters
|
6930
|
+
ters such as (?: or a subpattern name or number. The characters that
|
6926
6931
|
make up a comment play no part in the pattern matching.
|
6927
6932
|
|
6928
|
-
The
|
6929
|
-
next
|
6933
|
+
The sequence (?# marks the start of a comment that continues up to the
|
6934
|
+
next closing parenthesis. Nested parentheses are not permitted. If the
|
6930
6935
|
PCRE_EXTENDED option is set, an unescaped # character also introduces a
|
6931
|
-
comment,
|
6932
|
-
newline
|
6936
|
+
comment, which in this case continues to immediately after the next
|
6937
|
+
newline character or character sequence in the pattern. Which charac-
|
6933
6938
|
ters are interpreted as newlines is controlled by the options passed to
|
6934
|
-
a
|
6939
|
+
a compiling function or by a special sequence at the start of the pat-
|
6935
6940
|
tern, as described in the section entitled "Newline conventions" above.
|
6936
6941
|
Note that the end of this type of comment is a literal newline sequence
|
6937
|
-
in
|
6938
|
-
not
|
6942
|
+
in the pattern; escape sequences that happen to represent a newline do
|
6943
|
+
not count. For example, consider this pattern when PCRE_EXTENDED is
|
6939
6944
|
set, and the default newline convention is in force:
|
6940
6945
|
|
6941
6946
|
abc #comment \n still comment
|
6942
6947
|
|
6943
|
-
On
|
6944
|
-
for
|
6945
|
-
stage,
|
6948
|
+
On encountering the # character, pcre_compile() skips along, looking
|
6949
|
+
for a newline in the pattern. The sequence \n is still literal at this
|
6950
|
+
stage, so it does not terminate the comment. Only an actual character
|
6946
6951
|
with the code value 0x0a (the default newline) does so.
|
6947
6952
|
|
6948
6953
|
|
6949
6954
|
RECURSIVE PATTERNS
|
6950
6955
|
|
6951
|
-
Consider
|
6952
|
-
unlimited
|
6953
|
-
that
|
6954
|
-
depth
|
6956
|
+
Consider the problem of matching a string in parentheses, allowing for
|
6957
|
+
unlimited nested parentheses. Without the use of recursion, the best
|
6958
|
+
that can be done is to use a pattern that matches up to some fixed
|
6959
|
+
depth of nesting. It is not possible to handle an arbitrary nesting
|
6955
6960
|
depth.
|
6956
6961
|
|
6957
6962
|
For some time, Perl has provided a facility that allows regular expres-
|
6958
|
-
sions
|
6959
|
-
Perl
|
6963
|
+
sions to recurse (amongst other things). It does this by interpolating
|
6964
|
+
Perl code in the expression at run time, and the code can refer to the
|
6960
6965
|
expression itself. A Perl pattern using code interpolation to solve the
|
6961
6966
|
parentheses problem can be created like this:
|
6962
6967
|
|
@@ -6966,201 +6971,201 @@ RECURSIVE PATTERNS
|
|
6966
6971
|
refers recursively to the pattern in which it appears.
|
6967
6972
|
|
6968
6973
|
Obviously, PCRE cannot support the interpolation of Perl code. Instead,
|
6969
|
-
it
|
6970
|
-
also
|
6971
|
-
PCRE
|
6974
|
+
it supports special syntax for recursion of the entire pattern, and
|
6975
|
+
also for individual subpattern recursion. After its introduction in
|
6976
|
+
PCRE and Python, this kind of recursion was subsequently introduced
|
6972
6977
|
into Perl at release 5.10.
|
6973
6978
|
|
6974
|
-
A
|
6975
|
-
zero
|
6976
|
-
subpattern
|
6977
|
-
subpattern.
|
6978
|
-
described
|
6979
|
+
A special item that consists of (? followed by a number greater than
|
6980
|
+
zero and a closing parenthesis is a recursive subroutine call of the
|
6981
|
+
subpattern of the given number, provided that it occurs inside that
|
6982
|
+
subpattern. (If not, it is a non-recursive subroutine call, which is
|
6983
|
+
described in the next section.) The special item (?R) or (?0) is a
|
6979
6984
|
recursive call of the entire regular expression.
|
6980
6985
|
|
6981
|
-
This
|
6986
|
+
This PCRE pattern solves the nested parentheses problem (assume the
|
6982
6987
|
PCRE_EXTENDED option is set so that white space is ignored):
|
6983
6988
|
|
6984
6989
|
\( ( [^()]++ | (?R) )* \)
|
6985
6990
|
|
6986
|
-
First
|
6987
|
-
substrings
|
6988
|
-
recursive
|
6991
|
+
First it matches an opening parenthesis. Then it matches any number of
|
6992
|
+
substrings which can either be a sequence of non-parentheses, or a
|
6993
|
+
recursive match of the pattern itself (that is, a correctly parenthe-
|
6989
6994
|
sized substring). Finally there is a closing parenthesis. Note the use
|
6990
6995
|
of a possessive quantifier to avoid backtracking into sequences of non-
|
6991
6996
|
parentheses.
|
6992
6997
|
|
6993
|
-
If
|
6998
|
+
If this were part of a larger pattern, you would not want to recurse
|
6994
6999
|
the entire pattern, so instead you could use this:
|
6995
7000
|
|
6996
7001
|
( \( ( [^()]++ | (?1) )* \) )
|
6997
7002
|
|
6998
|
-
We
|
7003
|
+
We have put the pattern into parentheses, and caused the recursion to
|
6999
7004
|
refer to them instead of the whole pattern.
|
7000
7005
|
|
7001
|
-
In
|
7002
|
-
tricky.
|
7006
|
+
In a larger pattern, keeping track of parenthesis numbers can be
|
7007
|
+
tricky. This is made easier by the use of relative references. Instead
|
7003
7008
|
of (?1) in the pattern above you can write (?-2) to refer to the second
|
7004
|
-
most
|
7005
|
-
words,
|
7009
|
+
most recently opened parentheses preceding the recursion. In other
|
7010
|
+
words, a negative number counts capturing parentheses leftwards from
|
7006
7011
|
the point at which it is encountered.
|
7007
7012
|
|
7008
|
-
It
|
7009
|
-
writing
|
7010
|
-
because
|
7011
|
-
enced.
|
7013
|
+
It is also possible to refer to subsequently opened parentheses, by
|
7014
|
+
writing references such as (?+2). However, these cannot be recursive
|
7015
|
+
because the reference is not inside the parentheses that are refer-
|
7016
|
+
enced. They are always non-recursive subroutine calls, as described in
|
7012
7017
|
the next section.
|
7013
7018
|
|
7014
|
-
An
|
7015
|
-
syntax
|
7019
|
+
An alternative approach is to use named parentheses instead. The Perl
|
7020
|
+
syntax for this is (?&name); PCRE's earlier syntax (?P>name) is also
|
7016
7021
|
supported. We could rewrite the above example as follows:
|
7017
7022
|
|
7018
7023
|
(?<pn> \( ( [^()]++ | (?&pn) )* \) )
|
7019
7024
|
|
7020
|
-
If
|
7025
|
+
If there is more than one subpattern with the same name, the earliest
|
7021
7026
|
one is used.
|
7022
7027
|
|
7023
|
-
This
|
7028
|
+
This particular example pattern that we have been looking at contains
|
7024
7029
|
nested unlimited repeats, and so the use of a possessive quantifier for
|
7025
7030
|
matching strings of non-parentheses is important when applying the pat-
|
7026
|
-
tern
|
7031
|
+
tern to strings that do not match. For example, when this pattern is
|
7027
7032
|
applied to
|
7028
7033
|
|
7029
7034
|
(aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa()
|
7030
7035
|
|
7031
|
-
it
|
7032
|
-
not
|
7033
|
-
so
|
7036
|
+
it yields "no match" quickly. However, if a possessive quantifier is
|
7037
|
+
not used, the match runs for a very long time indeed because there are
|
7038
|
+
so many different ways the + and * repeats can carve up the subject,
|
7034
7039
|
and all have to be tested before failure can be reported.
|
7035
7040
|
|
7036
|
-
At
|
7037
|
-
from
|
7038
|
-
callout
|
7041
|
+
At the end of a match, the values of capturing parentheses are those
|
7042
|
+
from the outermost level. If you want to obtain intermediate values, a
|
7043
|
+
callout function can be used (see below and the pcrecallout documenta-
|
7039
7044
|
tion). If the pattern above is matched against
|
7040
7045
|
|
7041
7046
|
(ab(cd)ef)
|
7042
7047
|
|
7043
|
-
the
|
7044
|
-
which
|
7045
|
-
pattern
|
7046
|
-
unset,
|
7048
|
+
the value for the inner capturing parentheses (numbered 2) is "ef",
|
7049
|
+
which is the last value taken on at the top level. If a capturing sub-
|
7050
|
+
pattern is not matched at the top level, its final captured value is
|
7051
|
+
unset, even if it was (temporarily) set at a deeper level during the
|
7047
7052
|
matching process.
|
7048
7053
|
|
7049
|
-
If
|
7050
|
-
to
|
7054
|
+
If there are more than 15 capturing parentheses in a pattern, PCRE has
|
7055
|
+
to obtain extra memory to store data during a recursion, which it does
|
7051
7056
|
by using pcre_malloc, freeing it via pcre_free afterwards. If no memory
|
7052
7057
|
can be obtained, the match fails with the PCRE_ERROR_NOMEMORY error.
|
7053
7058
|
|
7054
|
-
Do
|
7055
|
-
recursion.
|
7056
|
-
ets,
|
7057
|
-
brackets
|
7059
|
+
Do not confuse the (?R) item with the condition (R), which tests for
|
7060
|
+
recursion. Consider this pattern, which matches text in angle brack-
|
7061
|
+
ets, allowing for arbitrary nesting. Only digits are allowed in nested
|
7062
|
+
brackets (that is, when recursing), whereas any characters are permit-
|
7058
7063
|
ted at the outer level.
|
7059
7064
|
|
7060
7065
|
< (?: (?(R) \d++ | [^<>]*+) | (?R)) * >
|
7061
7066
|
|
7062
|
-
In
|
7063
|
-
two
|
7067
|
+
In this pattern, (?(R) is the start of a conditional subpattern, with
|
7068
|
+
two different alternatives for the recursive and non-recursive cases.
|
7064
7069
|
The (?R) item is the actual recursive call.
|
7065
7070
|
|
7066
7071
|
Differences in recursion processing between PCRE and Perl
|
7067
7072
|
|
7068
|
-
Recursion
|
7069
|
-
In
|
7073
|
+
Recursion processing in PCRE differs from Perl in two important ways.
|
7074
|
+
In PCRE (like Python, but unlike Perl), a recursive subpattern call is
|
7070
7075
|
always treated as an atomic group. That is, once it has matched some of
|
7071
7076
|
the subject string, it is never re-entered, even if it contains untried
|
7072
|
-
alternatives
|
7073
|
-
illustrated
|
7074
|
-
dromic
|
7077
|
+
alternatives and there is a subsequent matching failure. This can be
|
7078
|
+
illustrated by the following pattern, which purports to match a palin-
|
7079
|
+
dromic string that contains an odd number of characters (for example,
|
7075
7080
|
"a", "aba", "abcba", "abcdcba"):
|
7076
7081
|
|
7077
7082
|
^(.|(.)(?1)\2)$
|
7078
7083
|
|
7079
7084
|
The idea is that it either matches a single character, or two identical
|
7080
|
-
characters
|
7081
|
-
in
|
7085
|
+
characters surrounding a sub-palindrome. In Perl, this pattern works;
|
7086
|
+
in PCRE it does not if the pattern is longer than three characters.
|
7082
7087
|
Consider the subject string "abcba":
|
7083
7088
|
|
7084
|
-
At
|
7089
|
+
At the top level, the first character is matched, but as it is not at
|
7085
7090
|
the end of the string, the first alternative fails; the second alterna-
|
7086
7091
|
tive is taken and the recursion kicks in. The recursive call to subpat-
|
7087
|
-
tern
|
7092
|
+
tern 1 successfully matches the next character ("b"). (Note that the
|
7088
7093
|
beginning and end of line tests are not part of the recursion).
|
7089
7094
|
|
7090
|
-
Back
|
7091
|
-
subpattern
|
7092
|
-
is
|
7093
|
-
and
|
7094
|
-
enter
|
7095
|
+
Back at the top level, the next character ("c") is compared with what
|
7096
|
+
subpattern 2 matched, which was "a". This fails. Because the recursion
|
7097
|
+
is treated as an atomic group, there are now no backtracking points,
|
7098
|
+
and so the entire match fails. (Perl is able, at this point, to re-
|
7099
|
+
enter the recursion and try the second alternative.) However, if the
|
7095
7100
|
pattern is written with the alternatives in the other order, things are
|
7096
7101
|
different:
|
7097
7102
|
|
7098
7103
|
^((.)(?1)\2|.)$
|
7099
7104
|
|
7100
|
-
This
|
7101
|
-
recurse
|
7102
|
-
fails.
|
7103
|
-
higher
|
7105
|
+
This time, the recursing alternative is tried first, and continues to
|
7106
|
+
recurse until it runs out of characters, at which point the recursion
|
7107
|
+
fails. But this time we do have another alternative to try at the
|
7108
|
+
higher level. That is the big difference: in the previous case the
|
7104
7109
|
remaining alternative is at a deeper recursion level, which PCRE cannot
|
7105
7110
|
use.
|
7106
7111
|
|
7107
|
-
To
|
7108
|
-
just
|
7112
|
+
To change the pattern so that it matches all palindromic strings, not
|
7113
|
+
just those with an odd number of characters, it is tempting to change
|
7109
7114
|
the pattern to this:
|
7110
7115
|
|
7111
7116
|
^((.)(?1)\2|.?)$
|
7112
7117
|
|
7113
|
-
Again,
|
7114
|
-
When
|
7115
|
-
entered
|
7116
|
-
separate
|
7118
|
+
Again, this works in Perl, but not in PCRE, and for the same reason.
|
7119
|
+
When a deeper recursion has matched a single character, it cannot be
|
7120
|
+
entered again in order to match an empty string. The solution is to
|
7121
|
+
separate the two cases, and write out the odd and even cases as alter-
|
7117
7122
|
natives at the higher level:
|
7118
7123
|
|
7119
7124
|
^(?:((.)(?1)\2|)|((.)(?3)\4|.))
|
7120
7125
|
|
7121
|
-
If
|
7126
|
+
If you want to match typical palindromic phrases, the pattern has to
|
7122
7127
|
ignore all non-word characters, which can be done like this:
|
7123
7128
|
|
7124
7129
|
^\W*+(?:((.)\W*+(?1)\W*+\2|)|((.)\W*+(?3)\W*+\4|\W*+.\W*+))\W*+$
|
7125
7130
|
|
7126
7131
|
If run with the PCRE_CASELESS option, this pattern matches phrases such
|
7127
7132
|
as "A man, a plan, a canal: Panama!" and it works well in both PCRE and
|
7128
|
-
Perl.
|
7129
|
-
ing
|
7130
|
-
great
|
7133
|
+
Perl. Note the use of the possessive quantifier *+ to avoid backtrack-
|
7134
|
+
ing into sequences of non-word characters. Without this, PCRE takes a
|
7135
|
+
great deal longer (ten times or more) to match typical phrases, and
|
7131
7136
|
Perl takes so long that you think it has gone into a loop.
|
7132
7137
|
|
7133
|
-
WARNING:
|
7134
|
-
ject
|
7135
|
-
entire
|
7136
|
-
the
|
7137
|
-
then
|
7138
|
-
Once
|
7138
|
+
WARNING: The palindrome-matching patterns above work only if the sub-
|
7139
|
+
ject string does not start with a palindrome that is shorter than the
|
7140
|
+
entire string. For example, although "abcba" is correctly matched, if
|
7141
|
+
the subject is "ababa", PCRE finds the palindrome "aba" at the start,
|
7142
|
+
then fails at top level because the end of the string does not follow.
|
7143
|
+
Once again, it cannot jump back into the recursion to try other alter-
|
7139
7144
|
natives, so the entire match fails.
|
7140
7145
|
|
7141
|
-
The
|
7142
|
-
cessing
|
7143
|
-
tern
|
7144
|
-
it
|
7145
|
-
sion,
|
7146
|
+
The second way in which PCRE and Perl differ in their recursion pro-
|
7147
|
+
cessing is in the handling of captured values. In Perl, when a subpat-
|
7148
|
+
tern is called recursively or as a subpattern (see the next section),
|
7149
|
+
it has no access to any values that were captured outside the recur-
|
7150
|
+
sion, whereas in PCRE these values can be referenced. Consider this
|
7146
7151
|
pattern:
|
7147
7152
|
|
7148
7153
|
^(.)(\1|a(?2))
|
7149
7154
|
|
7150
|
-
In
|
7151
|
-
match
|
7152
|
-
to
|
7153
|
-
the
|
7154
|
-
In
|
7155
|
+
In PCRE, this pattern matches "bab". The first capturing parentheses
|
7156
|
+
match "b", then in the second group, when the back reference \1 fails
|
7157
|
+
to match "b", the second alternative matches "a" and then recurses. In
|
7158
|
+
the recursion, \1 does now match "b" and so the whole match succeeds.
|
7159
|
+
In Perl, the pattern fails to match because inside the recursive call
|
7155
7160
|
\1 cannot access the externally set value.
|
7156
7161
|
|
7157
7162
|
|
7158
7163
|
SUBPATTERNS AS SUBROUTINES
|
7159
7164
|
|
7160
|
-
If
|
7161
|
-
name)
|
7162
|
-
like
|
7163
|
-
be
|
7165
|
+
If the syntax for a recursive subpattern call (either by number or by
|
7166
|
+
name) is used outside the parentheses to which it refers, it operates
|
7167
|
+
like a subroutine in a programming language. The called subpattern may
|
7168
|
+
be defined before or after the reference. A numbered reference can be
|
7164
7169
|
absolute or relative, as in these examples:
|
7165
7170
|
|
7166
7171
|
(...(absolute)...)...(?2)...
|
@@ -7171,79 +7176,79 @@ SUBPATTERNS AS SUBROUTINES
|
|
7171
7176
|
|
7172
7177
|
(sens|respons)e and \1ibility
|
7173
7178
|
|
7174
|
-
matches
|
7179
|
+
matches "sense and sensibility" and "response and responsibility", but
|
7175
7180
|
not "sense and responsibility". If instead the pattern
|
7176
7181
|
|
7177
7182
|
(sens|respons)e and (?1)ibility
|
7178
7183
|
|
7179
|
-
is
|
7180
|
-
two
|
7184
|
+
is used, it does match "sense and responsibility" as well as the other
|
7185
|
+
two strings. Another example is given in the discussion of DEFINE
|
7181
7186
|
above.
|
7182
7187
|
|
7183
|
-
All
|
7184
|
-
atomic
|
7188
|
+
All subroutine calls, whether recursive or not, are always treated as
|
7189
|
+
atomic groups. That is, once a subroutine has matched some of the sub-
|
7185
7190
|
ject string, it is never re-entered, even if it contains untried alter-
|
7186
|
-
natives
|
7187
|
-
parentheses
|
7191
|
+
natives and there is a subsequent matching failure. Any capturing
|
7192
|
+
parentheses that are set during the subroutine call revert to their
|
7188
7193
|
previous values afterwards.
|
7189
7194
|
|
7190
|
-
Processing
|
7191
|
-
tern
|
7195
|
+
Processing options such as case-independence are fixed when a subpat-
|
7196
|
+
tern is defined, so if it is used as a subroutine, such options cannot
|
7192
7197
|
be changed for different calls. For example, consider this pattern:
|
7193
7198
|
|
7194
7199
|
(abc)(?i:(?-1))
|
7195
7200
|
|
7196
|
-
It
|
7201
|
+
It matches "abcabc". It does not match "abcABC" because the change of
|
7197
7202
|
processing option does not affect the called subpattern.
|
7198
7203
|
|
7199
7204
|
|
7200
7205
|
ONIGURUMA SUBROUTINE SYNTAX
|
7201
7206
|
|
7202
|
-
For
|
7207
|
+
For compatibility with Oniguruma, the non-Perl syntax \g followed by a
|
7203
7208
|
name or a number enclosed either in angle brackets or single quotes, is
|
7204
|
-
an
|
7205
|
-
possibly
|
7209
|
+
an alternative syntax for referencing a subpattern as a subroutine,
|
7210
|
+
possibly recursively. Here are two of the examples used above, rewrit-
|
7206
7211
|
ten using this syntax:
|
7207
7212
|
|
7208
7213
|
(?<pn> \( ( (?>[^()]+) | \g<pn> )* \) )
|
7209
7214
|
(sens|respons)e and \g'1'ibility
|
7210
7215
|
|
7211
|
-
PCRE
|
7216
|
+
PCRE supports an extension to Oniguruma: if a number is preceded by a
|
7212
7217
|
plus or a minus sign it is taken as a relative reference. For example:
|
7213
7218
|
|
7214
7219
|
(abc)(?i:\g<-1>)
|
7215
7220
|
|
7216
|
-
Note
|
7217
|
-
synonymous.
|
7221
|
+
Note that \g{...} (Perl syntax) and \g<...> (Oniguruma syntax) are not
|
7222
|
+
synonymous. The former is a back reference; the latter is a subroutine
|
7218
7223
|
call.
|
7219
7224
|
|
7220
7225
|
|
7221
7226
|
CALLOUTS
|
7222
7227
|
|
7223
7228
|
Perl has a feature whereby using the sequence (?{...}) causes arbitrary
|
7224
|
-
Perl
|
7229
|
+
Perl code to be obeyed in the middle of matching a regular expression.
|
7225
7230
|
This makes it possible, amongst other things, to extract different sub-
|
7226
7231
|
strings that match the same pair of parentheses when there is a repeti-
|
7227
7232
|
tion.
|
7228
7233
|
|
7229
7234
|
PCRE provides a similar feature, but of course it cannot obey arbitrary
|
7230
7235
|
Perl code. The feature is called "callout". The caller of PCRE provides
|
7231
|
-
an
|
7232
|
-
pcre_callout
|
7233
|
-
library).
|
7236
|
+
an external function by putting its entry point in the global variable
|
7237
|
+
pcre_callout (8-bit library) or pcre[16|32]_callout (16-bit or 32-bit
|
7238
|
+
library). By default, this variable contains NULL, which disables all
|
7234
7239
|
calling out.
|
7235
7240
|
|
7236
|
-
Within
|
7237
|
-
external
|
7238
|
-
callout
|
7239
|
-
The
|
7241
|
+
Within a regular expression, (?C) indicates the points at which the
|
7242
|
+
external function is to be called. If you want to identify different
|
7243
|
+
callout points, you can put a number less than 256 after the letter C.
|
7244
|
+
The default value is zero. For example, this pattern has two callout
|
7240
7245
|
points:
|
7241
7246
|
|
7242
7247
|
(?C1)abc(?C2)def
|
7243
7248
|
|
7244
|
-
If
|
7245
|
-
outs
|
7246
|
-
are
|
7249
|
+
If the PCRE_AUTO_CALLOUT flag is passed to a compiling function, call-
|
7250
|
+
outs are automatically installed before each item in the pattern. They
|
7251
|
+
are all numbered 255. If there is a conditional group in the pattern
|
7247
7252
|
whose condition is an assertion, an additional callout is inserted just
|
7248
7253
|
before the condition. An explicit callout may also be set at this posi-
|
7249
7254
|
tion, as in this example:
|
@@ -7253,120 +7258,120 @@ CALLOUTS
|
|
7253
7258
|
Note that this applies only to assertion conditions, not to other types
|
7254
7259
|
of condition.
|
7255
7260
|
|
7256
|
-
During
|
7257
|
-
tion
|
7258
|
-
position
|
7259
|
-
supplied
|
7261
|
+
During matching, when PCRE reaches a callout point, the external func-
|
7262
|
+
tion is called. It is provided with the number of the callout, the
|
7263
|
+
position in the pattern, and, optionally, one item of data originally
|
7264
|
+
supplied by the caller of the matching function. The callout function
|
7260
7265
|
may cause matching to proceed, to backtrack, or to fail altogether.
|
7261
7266
|
|
7262
|
-
By
|
7263
|
-
and
|
7264
|
-
skipped.
|
7265
|
-
options
|
7266
|
-
complete
|
7267
|
+
By default, PCRE implements a number of optimizations at compile time
|
7268
|
+
and matching time, and one side-effect is that sometimes callouts are
|
7269
|
+
skipped. If you need all possible callouts to happen, you need to set
|
7270
|
+
options that disable the relevant optimizations. More details, and a
|
7271
|
+
complete description of the interface to the callout function, are
|
7267
7272
|
given in the pcrecallout documentation.
|
7268
7273
|
|
7269
7274
|
|
7270
7275
|
BACKTRACKING CONTROL
|
7271
7276
|
|
7272
|
-
Perl
|
7273
|
-
which
|
7274
|
-
and
|
7275
|
-
on
|
7276
|
-
problems
|
7277
|
+
Perl 5.10 introduced a number of "Special Backtracking Control Verbs",
|
7278
|
+
which are still described in the Perl documentation as "experimental
|
7279
|
+
and subject to change or removal in a future version of Perl". It goes
|
7280
|
+
on to say: "Their usage in production code should be noted to avoid
|
7281
|
+
problems during upgrades." The same remarks apply to the PCRE features
|
7277
7282
|
described in this section.
|
7278
7283
|
|
7279
|
-
The
|
7284
|
+
The new verbs make use of what was previously invalid syntax: an open-
|
7280
7285
|
ing parenthesis followed by an asterisk. They are generally of the form
|
7281
|
-
(*VERB)
|
7282
|
-
differently
|
7286
|
+
(*VERB) or (*VERB:NAME). Some may take either form, possibly behaving
|
7287
|
+
differently depending on whether or not a name is present. A name is
|
7283
7288
|
any sequence of characters that does not include a closing parenthesis.
|
7284
7289
|
The maximum length of name is 255 in the 8-bit library and 65535 in the
|
7285
|
-
16-bit
|
7286
|
-
closing
|
7287
|
-
the
|
7290
|
+
16-bit and 32-bit libraries. If the name is empty, that is, if the
|
7291
|
+
closing parenthesis immediately follows the colon, the effect is as if
|
7292
|
+
the colon were not there. Any number of these verbs may occur in a
|
7288
7293
|
pattern.
|
7289
7294
|
|
7290
|
-
Since
|
7291
|
-
them
|
7292
|
-
the
|
7293
|
-
algorithm.
|
7294
|
-
negative
|
7295
|
+
Since these verbs are specifically related to backtracking, most of
|
7296
|
+
them can be used only when the pattern is to be matched using one of
|
7297
|
+
the traditional matching functions, because these use a backtracking
|
7298
|
+
algorithm. With the exception of (*FAIL), which behaves like a failing
|
7299
|
+
negative assertion, the backtracking control verbs cause an error if
|
7295
7300
|
encountered by a DFA matching function.
|
7296
7301
|
|
7297
|
-
The
|
7302
|
+
The behaviour of these verbs in repeated groups, assertions, and in
|
7298
7303
|
subpatterns called as subroutines (whether or not recursively) is docu-
|
7299
7304
|
mented below.
|
7300
7305
|
|
7301
7306
|
Optimizations that affect backtracking verbs
|
7302
7307
|
|
7303
|
-
PCRE
|
7308
|
+
PCRE contains some optimizations that are used to speed up matching by
|
7304
7309
|
running some checks at the start of each match attempt. For example, it
|
7305
|
-
may
|
7310
|
+
may know the minimum length of matching subject, or that a particular
|
7306
7311
|
character must be present. When one of these optimizations bypasses the
|
7307
|
-
running
|
7312
|
+
running of a match, any included backtracking verbs will not, of
|
7308
7313
|
course, be processed. You can suppress the start-of-match optimizations
|
7309
|
-
by
|
7314
|
+
by setting the PCRE_NO_START_OPTIMIZE option when calling pcre_com-
|
7310
7315
|
pile() or pcre_exec(), or by starting the pattern with (*NO_START_OPT).
|
7311
7316
|
There is more discussion of this option in the section entitled "Option
|
7312
7317
|
bits for pcre_exec()" in the pcreapi documentation.
|
7313
7318
|
|
7314
|
-
Experiments
|
7319
|
+
Experiments with Perl suggest that it too has similar optimizations,
|
7315
7320
|
sometimes leading to anomalous results.
|
7316
7321
|
|
7317
7322
|
Verbs that act immediately
|
7318
7323
|
|
7319
|
-
The
|
7324
|
+
The following verbs act as soon as they are encountered. They may not
|
7320
7325
|
be followed by a name.
|
7321
7326
|
|
7322
7327
|
(*ACCEPT)
|
7323
7328
|
|
7324
|
-
This
|
7325
|
-
of
|
7326
|
-
as
|
7329
|
+
This verb causes the match to end successfully, skipping the remainder
|
7330
|
+
of the pattern. However, when it is inside a subpattern that is called
|
7331
|
+
as a subroutine, only that subpattern is ended successfully. Matching
|
7327
7332
|
then continues at the outer level. If (*ACCEPT) in triggered in a posi-
|
7328
|
-
tive
|
7333
|
+
tive assertion, the assertion succeeds; in a negative assertion, the
|
7329
7334
|
assertion fails.
|
7330
7335
|
|
7331
|
-
If
|
7336
|
+
If (*ACCEPT) is inside capturing parentheses, the data so far is cap-
|
7332
7337
|
tured. For example:
|
7333
7338
|
|
7334
7339
|
A((?:A|B(*ACCEPT)|C)D)
|
7335
7340
|
|
7336
|
-
This
|
7341
|
+
This matches "AB", "AAD", or "ACD"; when it matches "AB", "B" is cap-
|
7337
7342
|
tured by the outer parentheses.
|
7338
7343
|
|
7339
7344
|
(*FAIL) or (*F)
|
7340
7345
|
|
7341
|
-
This
|
7342
|
-
is
|
7343
|
-
that
|
7344
|
-
Those
|
7345
|
-
nearest
|
7346
|
+
This verb causes a matching failure, forcing backtracking to occur. It
|
7347
|
+
is equivalent to (?!) but easier to read. The Perl documentation notes
|
7348
|
+
that it is probably useful only when combined with (?{}) or (??{}).
|
7349
|
+
Those are, of course, Perl features that are not present in PCRE. The
|
7350
|
+
nearest equivalent is the callout feature, as for example in this pat-
|
7346
7351
|
tern:
|
7347
7352
|
|
7348
7353
|
a+(?C)(*FAIL)
|
7349
7354
|
|
7350
|
-
A
|
7355
|
+
A match with the string "aaaa" always fails, but the callout is taken
|
7351
7356
|
before each backtrack happens (in this example, 10 times).
|
7352
7357
|
|
7353
7358
|
Recording which path was taken
|
7354
7359
|
|
7355
|
-
There
|
7356
|
-
arrived
|
7360
|
+
There is one verb whose main purpose is to track how a match was
|
7361
|
+
arrived at, though it also has a secondary use in conjunction with
|
7357
7362
|
advancing the match starting point (see (*SKIP) below).
|
7358
7363
|
|
7359
7364
|
(*MARK:NAME) or (*:NAME)
|
7360
7365
|
|
7361
|
-
A
|
7362
|
-
instances
|
7366
|
+
A name is always required with this verb. There may be as many
|
7367
|
+
instances of (*MARK) as you like in a pattern, and their names do not
|
7363
7368
|
have to be unique.
|
7364
7369
|
|
7365
|
-
When
|
7366
|
-
(*PRUNE:NAME),
|
7367
|
-
the
|
7368
|
-
pcre_exec()"
|
7369
|
-
pcretest
|
7370
|
+
When a match succeeds, the name of the last-encountered (*MARK:NAME),
|
7371
|
+
(*PRUNE:NAME), or (*THEN:NAME) on the matching path is passed back to
|
7372
|
+
the caller as described in the section entitled "Extra data for
|
7373
|
+
pcre_exec()" in the pcreapi documentation. Here is an example of
|
7374
|
+
pcretest output, where the /K modifier requests the retrieval and out-
|
7370
7375
|
putting of (*MARK) data:
|
7371
7376
|
|
7372
7377
|
re> /X(*MARK:A)Y|X(*MARK:B)Z/K
|
@@ -7378,73 +7383,73 @@ BACKTRACKING CONTROL
|
|
7378
7383
|
MK: B
|
7379
7384
|
|
7380
7385
|
The (*MARK) name is tagged with "MK:" in this output, and in this exam-
|
7381
|
-
ple
|
7382
|
-
efficient
|
7386
|
+
ple it indicates which of the two alternatives matched. This is a more
|
7387
|
+
efficient way of obtaining this information than putting each alterna-
|
7383
7388
|
tive in its own capturing parentheses.
|
7384
7389
|
|
7385
|
-
If
|
7386
|
-
true,
|
7390
|
+
If a verb with a name is encountered in a positive assertion that is
|
7391
|
+
true, the name is recorded and passed back if it is the last-encoun-
|
7387
7392
|
tered. This does not happen for negative assertions or failing positive
|
7388
7393
|
assertions.
|
7389
7394
|
|
7390
|
-
After
|
7395
|
+
After a partial match or a failed match, the last encountered name in
|
7391
7396
|
the entire match process is returned. For example:
|
7392
7397
|
|
7393
7398
|
re> /X(*MARK:A)Y|X(*MARK:B)Z/K
|
7394
7399
|
data> XP
|
7395
7400
|
No match, mark = B
|
7396
7401
|
|
7397
|
-
Note
|
7402
|
+
Note that in this unanchored example the mark is retained from the
|
7398
7403
|
match attempt that started at the letter "X" in the subject. Subsequent
|
7399
7404
|
match attempts starting at "P" and then with an empty string do not get
|
7400
7405
|
as far as the (*MARK) item, but nevertheless do not reset it.
|
7401
7406
|
|
7402
|
-
If
|
7403
|
-
should
|
7407
|
+
If you are interested in (*MARK) values after failed matches, you
|
7408
|
+
should probably set the PCRE_NO_START_OPTIMIZE option (see above) to
|
7404
7409
|
ensure that the match is always attempted.
|
7405
7410
|
|
7406
7411
|
Verbs that act after backtracking
|
7407
7412
|
|
7408
7413
|
The following verbs do nothing when they are encountered. Matching con-
|
7409
|
-
tinues
|
7410
|
-
a
|
7411
|
-
cannot
|
7414
|
+
tinues with what follows, but if there is no subsequent match, causing
|
7415
|
+
a backtrack to the verb, a failure is forced. That is, backtracking
|
7416
|
+
cannot pass to the left of the verb. However, when one of these verbs
|
7412
7417
|
appears inside an atomic group or an assertion that is true, its effect
|
7413
|
-
is
|
7414
|
-
there
|
7415
|
-
ing
|
7416
|
-
tion.
|
7418
|
+
is confined to that group, because once the group has been matched,
|
7419
|
+
there is never any backtracking into it. In this situation, backtrack-
|
7420
|
+
ing can "jump back" to the left of the entire atomic group or asser-
|
7421
|
+
tion. (Remember also, as stated above, that this localization also
|
7417
7422
|
applies in subroutine calls.)
|
7418
7423
|
|
7419
|
-
These
|
7420
|
-
tracking
|
7421
|
-
when
|
7424
|
+
These verbs differ in exactly what kind of failure occurs when back-
|
7425
|
+
tracking reaches them. The behaviour described below is what happens
|
7426
|
+
when the verb is not in a subroutine or an assertion. Subsequent sec-
|
7422
7427
|
tions cover these special cases.
|
7423
7428
|
|
7424
7429
|
(*COMMIT)
|
7425
7430
|
|
7426
|
-
This
|
7431
|
+
This verb, which may not be followed by a name, causes the whole match
|
7427
7432
|
to fail outright if there is a later matching failure that causes back-
|
7428
|
-
tracking
|
7433
|
+
tracking to reach it. Even if the pattern is unanchored, no further
|
7429
7434
|
attempts to find a match by advancing the starting point take place. If
|
7430
|
-
(*COMMIT)
|
7435
|
+
(*COMMIT) is the only backtracking verb that is encountered, once it
|
7431
7436
|
has been passed pcre_exec() is committed to finding a match at the cur-
|
7432
7437
|
rent starting point, or not at all. For example:
|
7433
7438
|
|
7434
7439
|
a+(*COMMIT)b
|
7435
7440
|
|
7436
|
-
This
|
7441
|
+
This matches "xxaab" but not "aacaab". It can be thought of as a kind
|
7437
7442
|
of dynamic anchor, or "I've started, so I must finish." The name of the
|
7438
|
-
most
|
7443
|
+
most recently passed (*MARK) in the path is passed back when (*COMMIT)
|
7439
7444
|
forces a match failure.
|
7440
7445
|
|
7441
|
-
If
|
7442
|
-
one
|
7446
|
+
If there is more than one backtracking verb in a pattern, a different
|
7447
|
+
one that follows (*COMMIT) may be triggered first, so merely passing
|
7443
7448
|
(*COMMIT) during a match does not always guarantee that a match must be
|
7444
7449
|
at this starting point.
|
7445
7450
|
|
7446
|
-
Note
|
7447
|
-
anchor,
|
7451
|
+
Note that (*COMMIT) at the start of a pattern is not the same as an
|
7452
|
+
anchor, unless PCRE's start-of-match optimizations are turned off, as
|
7448
7453
|
shown in this output from pcretest:
|
7449
7454
|
|
7450
7455
|
re> /(*COMMIT)abc/
|
@@ -7455,207 +7460,207 @@ BACKTRACKING CONTROL
|
|
7455
7460
|
|
7456
7461
|
For this pattern, PCRE knows that any match must start with "a", so the
|
7457
7462
|
optimization skips along the subject to "a" before applying the pattern
|
7458
|
-
to
|
7459
|
-
ond
|
7460
|
-
program.
|
7463
|
+
to the first set of data. The match attempt then succeeds. In the sec-
|
7464
|
+
ond set of data, the escape sequence \Y is interpreted by the pcretest
|
7465
|
+
program. It causes the PCRE_NO_START_OPTIMIZE option to be set when
|
7461
7466
|
pcre_exec() is called. This disables the optimization that skips along
|
7462
7467
|
to the first character. The pattern is now applied starting at "x", and
|
7463
|
-
so
|
7468
|
+
so the (*COMMIT) causes the match to fail without trying any other
|
7464
7469
|
starting points.
|
7465
7470
|
|
7466
7471
|
(*PRUNE) or (*PRUNE:NAME)
|
7467
7472
|
|
7468
|
-
This
|
7473
|
+
This verb causes the match to fail at the current starting position in
|
7469
7474
|
the subject if there is a later matching failure that causes backtrack-
|
7470
|
-
ing
|
7471
|
-
advance
|
7472
|
-
occur
|
7473
|
-
matching
|
7474
|
-
right,
|
7475
|
-
(*PRUNE)
|
7475
|
+
ing to reach it. If the pattern is unanchored, the normal "bumpalong"
|
7476
|
+
advance to the next starting character then happens. Backtracking can
|
7477
|
+
occur as usual to the left of (*PRUNE), before it is reached, or when
|
7478
|
+
matching to the right of (*PRUNE), but if there is no match to the
|
7479
|
+
right, backtracking cannot cross (*PRUNE). In simple cases, the use of
|
7480
|
+
(*PRUNE) is just an alternative to an atomic group or possessive quan-
|
7476
7481
|
tifier, but there are some uses of (*PRUNE) that cannot be expressed in
|
7477
|
-
any
|
7482
|
+
any other way. In an anchored pattern (*PRUNE) has the same effect as
|
7478
7483
|
(*COMMIT).
|
7479
7484
|
|
7480
7485
|
The behaviour of (*PRUNE:NAME) is the not the same as
|
7481
|
-
(*MARK:NAME)(*PRUNE).
|
7482
|
-
remembered
|
7486
|
+
(*MARK:NAME)(*PRUNE). It is like (*MARK:NAME) in that the name is
|
7487
|
+
remembered for passing back to the caller. However, (*SKIP:NAME)
|
7483
7488
|
searches only for names set with (*MARK).
|
7484
7489
|
|
7485
7490
|
(*SKIP)
|
7486
7491
|
|
7487
|
-
This
|
7488
|
-
the
|
7492
|
+
This verb, when given without a name, is like (*PRUNE), except that if
|
7493
|
+
the pattern is unanchored, the "bumpalong" advance is not to the next
|
7489
7494
|
character, but to the position in the subject where (*SKIP) was encoun-
|
7490
|
-
tered.
|
7495
|
+
tered. (*SKIP) signifies that whatever text was matched leading up to
|
7491
7496
|
it cannot be part of a successful match. Consider:
|
7492
7497
|
|
7493
7498
|
a+(*SKIP)b
|
7494
7499
|
|
7495
|
-
If
|
7496
|
-
(starting
|
7500
|
+
If the subject is "aaaac...", after the first match attempt fails
|
7501
|
+
(starting at the first character in the string), the starting point
|
7497
7502
|
skips on to start the next attempt at "c". Note that a possessive quan-
|
7498
|
-
tifer
|
7499
|
-
suppress
|
7500
|
-
attempt
|
7503
|
+
tifer does not have the same effect as this example; although it would
|
7504
|
+
suppress backtracking during the first match attempt, the second
|
7505
|
+
attempt would start at the second character instead of skipping on to
|
7501
7506
|
"c".
|
7502
7507
|
|
7503
7508
|
(*SKIP:NAME)
|
7504
7509
|
|
7505
7510
|
When (*SKIP) has an associated name, its behaviour is modified. When it
|
7506
7511
|
is triggered, the previous path through the pattern is searched for the
|
7507
|
-
most
|
7512
|
+
most recent (*MARK) that has the same name. If one is found, the
|
7508
7513
|
"bumpalong" advance is to the subject position that corresponds to that
|
7509
7514
|
(*MARK) instead of to where (*SKIP) was encountered. If no (*MARK) with
|
7510
7515
|
a matching name is found, the (*SKIP) is ignored.
|
7511
7516
|
|
7512
|
-
Note
|
7517
|
+
Note that (*SKIP:NAME) searches only for names set by (*MARK:NAME). It
|
7513
7518
|
ignores names that are set by (*PRUNE:NAME) or (*THEN:NAME).
|
7514
7519
|
|
7515
7520
|
(*THEN) or (*THEN:NAME)
|
7516
7521
|
|
7517
|
-
This
|
7518
|
-
tracking
|
7519
|
-
within
|
7522
|
+
This verb causes a skip to the next innermost alternative when back-
|
7523
|
+
tracking reaches it. That is, it cancels any further backtracking
|
7524
|
+
within the current alternative. Its name comes from the observation
|
7520
7525
|
that it can be used for a pattern-based if-then-else block:
|
7521
7526
|
|
7522
7527
|
( COND1 (*THEN) FOO | COND2 (*THEN) BAR | COND3 (*THEN) BAZ ) ...
|
7523
7528
|
|
7524
|
-
If
|
7525
|
-
after
|
7526
|
-
skips
|
7527
|
-
into
|
7528
|
-
quently
|
7529
|
-
track
|
7529
|
+
If the COND1 pattern matches, FOO is tried (and possibly further items
|
7530
|
+
after the end of the group if FOO succeeds); on failure, the matcher
|
7531
|
+
skips to the second alternative and tries COND2, without backtracking
|
7532
|
+
into COND1. If that succeeds and BAR fails, COND3 is tried. If subse-
|
7533
|
+
quently BAZ fails, there are no more alternatives, so there is a back-
|
7534
|
+
track to whatever came before the entire group. If (*THEN) is not
|
7530
7535
|
inside an alternation, it acts like (*PRUNE).
|
7531
7536
|
|
7532
|
-
The
|
7533
|
-
(*MARK:NAME)(*THEN).
|
7534
|
-
remembered
|
7537
|
+
The behaviour of (*THEN:NAME) is the not the same as
|
7538
|
+
(*MARK:NAME)(*THEN). It is like (*MARK:NAME) in that the name is
|
7539
|
+
remembered for passing back to the caller. However, (*SKIP:NAME)
|
7535
7540
|
searches only for names set with (*MARK).
|
7536
7541
|
|
7537
|
-
A
|
7538
|
-
enclosing
|
7539
|
-
alternative.
|
7540
|
-
the
|
7541
|
-
complex
|
7542
|
+
A subpattern that does not contain a | character is just a part of the
|
7543
|
+
enclosing alternative; it is not a nested alternation with only one
|
7544
|
+
alternative. The effect of (*THEN) extends beyond such a subpattern to
|
7545
|
+
the enclosing alternative. Consider this pattern, where A, B, etc. are
|
7546
|
+
complex pattern fragments that do not contain any | characters at this
|
7542
7547
|
level:
|
7543
7548
|
|
7544
7549
|
A (B(*THEN)C) | D
|
7545
7550
|
|
7546
|
-
If
|
7551
|
+
If A and B are matched, but there is a failure in C, matching does not
|
7547
7552
|
backtrack into A; instead it moves to the next alternative, that is, D.
|
7548
|
-
However,
|
7553
|
+
However, if the subpattern containing (*THEN) is given an alternative,
|
7549
7554
|
it behaves differently:
|
7550
7555
|
|
7551
7556
|
A (B(*THEN)C | (*FAIL)) | D
|
7552
7557
|
|
7553
|
-
The
|
7558
|
+
The effect of (*THEN) is now confined to the inner subpattern. After a
|
7554
7559
|
failure in C, matching moves to (*FAIL), which causes the whole subpat-
|
7555
|
-
tern
|
7560
|
+
tern to fail because there are no more alternatives to try. In this
|
7556
7561
|
case, matching does now backtrack into A.
|
7557
7562
|
|
7558
|
-
Note
|
7559
|
-
alternatives,
|
7563
|
+
Note that a conditional subpattern is not considered as having two
|
7564
|
+
alternatives, because only one is ever used. In other words, the |
|
7560
7565
|
character in a conditional subpattern has a different meaning. Ignoring
|
7561
7566
|
white space, consider:
|
7562
7567
|
|
7563
7568
|
^.*? (?(?=a) a | b(*THEN)c )
|
7564
7569
|
|
7565
|
-
If
|
7566
|
-
ungreedy,
|
7567
|
-
then
|
7568
|
-
point,
|
7569
|
-
from
|
7570
|
+
If the subject is "ba", this pattern does not match. Because .*? is
|
7571
|
+
ungreedy, it initially matches zero characters. The condition (?=a)
|
7572
|
+
then fails, the character "b" is matched, but "c" is not. At this
|
7573
|
+
point, matching does not backtrack to .*? as might perhaps be expected
|
7574
|
+
from the presence of the | character. The conditional subpattern is
|
7570
7575
|
part of the single alternative that comprises the whole pattern, and so
|
7571
|
-
the
|
7576
|
+
the match fails. (If there was a backtrack into .*?, allowing it to
|
7572
7577
|
match "b", the match would succeed.)
|
7573
7578
|
|
7574
|
-
The
|
7579
|
+
The verbs just described provide four different "strengths" of control
|
7575
7580
|
when subsequent matching fails. (*THEN) is the weakest, carrying on the
|
7576
|
-
match
|
7577
|
-
at
|
7578
|
-
character
|
7581
|
+
match at the next alternative. (*PRUNE) comes next, failing the match
|
7582
|
+
at the current starting position, but allowing an advance to the next
|
7583
|
+
character (for an unanchored pattern). (*SKIP) is similar, except that
|
7579
7584
|
the advance may be more than one character. (*COMMIT) is the strongest,
|
7580
7585
|
causing the entire match to fail.
|
7581
7586
|
|
7582
7587
|
More than one backtracking verb
|
7583
7588
|
|
7584
|
-
If
|
7585
|
-
that
|
7589
|
+
If more than one backtracking verb is present in a pattern, the one
|
7590
|
+
that is backtracked onto first acts. For example, consider this pat-
|
7586
7591
|
tern, where A, B, etc. are complex pattern fragments:
|
7587
7592
|
|
7588
7593
|
(A(*COMMIT)B(*THEN)C|ABD)
|
7589
7594
|
|
7590
|
-
If
|
7595
|
+
If A matches but B fails, the backtrack to (*COMMIT) causes the entire
|
7591
7596
|
match to fail. However, if A and B match, but C fails, the backtrack to
|
7592
|
-
(*THEN)
|
7593
|
-
is
|
7594
|
-
two
|
7597
|
+
(*THEN) causes the next alternative (ABD) to be tried. This behaviour
|
7598
|
+
is consistent, but is not always the same as Perl's. It means that if
|
7599
|
+
two or more backtracking verbs appear in succession, all the the last
|
7595
7600
|
of them has no effect. Consider this example:
|
7596
7601
|
|
7597
7602
|
...(*COMMIT)(*PRUNE)...
|
7598
7603
|
|
7599
7604
|
If there is a matching failure to the right, backtracking onto (*PRUNE)
|
7600
|
-
causes
|
7605
|
+
causes it to be triggered, and its action is taken. There can never be
|
7601
7606
|
a backtrack onto (*COMMIT).
|
7602
7607
|
|
7603
7608
|
Backtracking verbs in repeated groups
|
7604
7609
|
|
7605
|
-
PCRE
|
7610
|
+
PCRE differs from Perl in its handling of backtracking verbs in
|
7606
7611
|
repeated groups. For example, consider:
|
7607
7612
|
|
7608
7613
|
/(a(*COMMIT)b)+ac/
|
7609
7614
|
|
7610
|
-
If
|
7615
|
+
If the subject is "abac", Perl matches, but PCRE fails because the
|
7611
7616
|
(*COMMIT) in the second repeat of the group acts.
|
7612
7617
|
|
7613
7618
|
Backtracking verbs in assertions
|
7614
7619
|
|
7615
|
-
(*FAIL)
|
7620
|
+
(*FAIL) in an assertion has its normal effect: it forces an immediate
|
7616
7621
|
backtrack.
|
7617
7622
|
|
7618
7623
|
(*ACCEPT) in a positive assertion causes the assertion to succeed with-
|
7619
|
-
out
|
7624
|
+
out any further processing. In a negative assertion, (*ACCEPT) causes
|
7620
7625
|
the assertion to fail without any further processing.
|
7621
7626
|
|
7622
|
-
The
|
7623
|
-
in
|
7624
|
-
alternative
|
7627
|
+
The other backtracking verbs are not treated specially if they appear
|
7628
|
+
in a positive assertion. In particular, (*THEN) skips to the next
|
7629
|
+
alternative in the innermost enclosing group that has alternations,
|
7625
7630
|
whether or not this is within the assertion.
|
7626
7631
|
|
7627
|
-
Negative
|
7628
|
-
changing
|
7632
|
+
Negative assertions are, however, different, in order to ensure that
|
7633
|
+
changing a positive assertion into a negative assertion changes its
|
7629
7634
|
result. Backtracking into (*COMMIT), (*SKIP), or (*PRUNE) causes a neg-
|
7630
7635
|
ative assertion to be true, without considering any further alternative
|
7631
7636
|
branches in the assertion. Backtracking into (*THEN) causes it to skip
|
7632
|
-
to
|
7633
|
-
haviour),
|
7637
|
+
to the next enclosing alternative within the assertion (the normal be-
|
7638
|
+
haviour), but if the assertion does not have such an alternative,
|
7634
7639
|
(*THEN) behaves like (*PRUNE).
|
7635
7640
|
|
7636
7641
|
Backtracking verbs in subroutines
|
7637
7642
|
|
7638
|
-
These
|
7643
|
+
These behaviours occur whether or not the subpattern is called recur-
|
7639
7644
|
sively. Perl's treatment of subroutines is different in some cases.
|
7640
7645
|
|
7641
|
-
(*FAIL)
|
7646
|
+
(*FAIL) in a subpattern called as a subroutine has its normal effect:
|
7642
7647
|
it forces an immediate backtrack.
|
7643
7648
|
|
7644
|
-
(*ACCEPT)
|
7645
|
-
match
|
7649
|
+
(*ACCEPT) in a subpattern called as a subroutine causes the subroutine
|
7650
|
+
match to succeed without any further processing. Matching then contin-
|
7646
7651
|
ues after the subroutine call.
|
7647
7652
|
|
7648
7653
|
(*COMMIT), (*SKIP), and (*PRUNE) in a subpattern called as a subroutine
|
7649
7654
|
cause the subroutine match to fail.
|
7650
7655
|
|
7651
|
-
(*THEN)
|
7652
|
-
within
|
7656
|
+
(*THEN) skips to the next alternative in the innermost enclosing group
|
7657
|
+
within the subpattern that has alternatives. If there is no such group
|
7653
7658
|
within the subpattern, (*THEN) causes the subroutine match to fail.
|
7654
7659
|
|
7655
7660
|
|
7656
7661
|
SEE ALSO
|
7657
7662
|
|
7658
|
-
pcreapi(3),
|
7663
|
+
pcreapi(3), pcrecallout(3), pcrematching(3), pcresyntax(3), pcre(3),
|
7659
7664
|
pcre16(3), pcre32(3).
|
7660
7665
|
|
7661
7666
|
|
@@ -7668,8 +7673,8 @@ AUTHOR
|
|
7668
7673
|
|
7669
7674
|
REVISION
|
7670
7675
|
|
7671
|
-
Last updated:
|
7672
|
-
Copyright (c) 1997-
|
7676
|
+
Last updated: 23 October 2016
|
7677
|
+
Copyright (c) 1997-2016 University of Cambridge.
|
7673
7678
|
------------------------------------------------------------------------------
|
7674
7679
|
|
7675
7680
|
|
@@ -8360,7 +8365,11 @@ AVAILABILITY OF JIT SUPPORT
|
|
8360
8365
|
If your program may sometimes be linked with versions of PCRE that are
|
8361
8366
|
older than 8.20, but you want to use JIT when it is available, you can
|
8362
8367
|
test the values of PCRE_MAJOR and PCRE_MINOR, or the existence of a JIT
|
8363
|
-
macro such as PCRE_CONFIG_JIT, for compile-time control of
|
8368
|
+
macro such as PCRE_CONFIG_JIT, for compile-time control of your code.
|
8369
|
+
Also beware that the pcre_jit_exec() function was not available at all
|
8370
|
+
before 8.32, and may not be available at all if PCRE isn't compiled
|
8371
|
+
with --enable-jit. See the "JIT FAST PATH API" section below for
|
8372
|
+
details.
|
8364
8373
|
|
8365
8374
|
|
8366
8375
|
SIMPLE USE OF JIT
|
@@ -8402,6 +8411,18 @@ SIMPLE USE OF JIT
|
|
8402
8411
|
PCRE_STUDY_JIT_PARTIAL_HARD_COMPILE
|
8403
8412
|
PCRE_STUDY_JIT_PARTIAL_SOFT_COMPILE
|
8404
8413
|
|
8414
|
+
If using pcre_jit_exec() and supporting a pre-8.32 version of PCRE, you
|
8415
|
+
can insert:
|
8416
|
+
|
8417
|
+
#if PCRE_MAJOR >= 8 && PCRE_MINOR >= 32
|
8418
|
+
pcre_jit_exec(...);
|
8419
|
+
#else
|
8420
|
+
pcre_exec(...)
|
8421
|
+
#endif
|
8422
|
+
|
8423
|
+
but as described in the "JIT FAST PATH API" section below this assumes
|
8424
|
+
version 8.32 and later are compiled with --enable-jit, which may break.
|
8425
|
+
|
8405
8426
|
The JIT compiler generates different optimized code for each of the
|
8406
8427
|
three modes (normal, soft partial, hard partial). When pcre_exec() is
|
8407
8428
|
called, the appropriate code is run if it is available. Otherwise, the
|
@@ -8691,6 +8712,33 @@ JIT FAST PATH API
|
|
8691
8712
|
Bypassing the sanity checks and the pcre_exec() wrapping can give
|
8692
8713
|
speedups of more than 10%.
|
8693
8714
|
|
8715
|
+
Note that the pcre_jit_exec() function is not available in versions of
|
8716
|
+
PCRE before 8.32 (released in November 2012). If you need to support
|
8717
|
+
versions that old you must either use the slower pcre_exec(), or switch
|
8718
|
+
between the two codepaths by checking the values of PCRE_MAJOR and
|
8719
|
+
PCRE_MINOR.
|
8720
|
+
|
8721
|
+
Due to an unfortunate implementation oversight, even in versions 8.32
|
8722
|
+
and later there will be no pcre_jit_exec() stub function defined when
|
8723
|
+
PCRE is compiled with --disable-jit, which is the default, and there's
|
8724
|
+
no way to detect whether PCRE was compiled with --enable-jit via a
|
8725
|
+
macro.
|
8726
|
+
|
8727
|
+
If you need to support versions older than 8.32, or versions that may
|
8728
|
+
not build with --enable-jit, you must either use the slower
|
8729
|
+
pcre_exec(), or switch between the two codepaths by checking the values
|
8730
|
+
of PCRE_MAJOR and PCRE_MINOR.
|
8731
|
+
|
8732
|
+
Switching between the two by checking the version assumes that all the
|
8733
|
+
versions being targeted are built with --enable-jit. To also support
|
8734
|
+
builds that may use --disable-jit either pcre_exec() must be used, or a
|
8735
|
+
compile-time check for JIT via pcre_config() (which assumes the runtime
|
8736
|
+
environment will be the same), or as the Git project decided to do,
|
8737
|
+
simply assume that pcre_jit_exec() is present in 8.32 or later unless a
|
8738
|
+
compile-time flag is provided, see the "grep: un-break building with
|
8739
|
+
PCRE >= 8.32 without --enable-jit" commit in git.git for an example of
|
8740
|
+
that.
|
8741
|
+
|
8694
8742
|
|
8695
8743
|
SEE ALSO
|
8696
8744
|
|
@@ -8706,8 +8754,8 @@ AUTHOR
|
|
8706
8754
|
|
8707
8755
|
REVISION
|
8708
8756
|
|
8709
|
-
Last updated:
|
8710
|
-
Copyright (c) 1997-
|
8757
|
+
Last updated: 05 July 2017
|
8758
|
+
Copyright (c) 1997-2017 University of Cambridge.
|
8711
8759
|
------------------------------------------------------------------------------
|
8712
8760
|
|
8713
8761
|
|