X7ROOT File Manager
Current Path:
/usr/include
usr
/
include
/
📁
..
📄
FlexLexer.h
(6.73 KB)
📄
GeoIP.h
(17.42 KB)
📄
GeoIPCity.h
(2.24 KB)
📄
a.out.h
(4.25 KB)
📄
aio.h
(7.28 KB)
📄
aliases.h
(1.98 KB)
📄
alloca.h
(1.17 KB)
📄
ar.h
(1.69 KB)
📄
argp.h
(24.82 KB)
📄
argz.h
(5.91 KB)
📁
arpa
📁
asm
📁
asm-generic
📄
assert.h
(4.45 KB)
📁
bits
📁
bsock
📄
byteswap.h
(1.37 KB)
📁
c++
📄
com_err.h
(2.07 KB)
📄
complex.h
(7 KB)
📄
cpio.h
(2.21 KB)
📄
cpuidle.h
(844 B)
📁
criu
📄
crypt.h
(8.9 KB)
📄
ctype.h
(10.71 KB)
📁
curl
📄
dirent.h
(12.19 KB)
📄
dlfcn.h
(7.07 KB)
📁
drm
📄
elf.h
(170.73 KB)
📄
endian.h
(3.11 KB)
📄
envz.h
(2.8 KB)
📄
err.h
(2.16 KB)
📄
errno.h
(1.64 KB)
📄
error.h
(1.99 KB)
📁
et
📄
execinfo.h
(1.49 KB)
📄
expat.h
(42.66 KB)
📄
expat_config.h
(3.43 KB)
📄
expat_external.h
(5.4 KB)
📄
fcntl.h
(10.7 KB)
📄
features.h
(15.69 KB)
📄
fenv.h
(5.72 KB)
📁
finclude
📄
fmtmsg.h
(3.16 KB)
📄
fnmatch.h
(2.24 KB)
📄
fpu_control.h
(3.5 KB)
📄
fstab.h
(3.04 KB)
📄
fts.h
(8.18 KB)
📄
ftw.h
(5.13 KB)
📄
gconv.h
(4.31 KB)
📁
gdb
📄
gelf.h
(11.14 KB)
📄
getopt.h
(1.43 KB)
📄
glob.h
(6.46 KB)
📁
gnu
📄
gnu-versions.h
(2.29 KB)
📄
gnumake.h
(2.84 KB)
📄
grp.h
(6.53 KB)
📄
gshadow.h
(4.42 KB)
📁
gssapi
📄
gssapi.h
(181 B)
📁
gssrpc
📄
iconv.h
(1.81 KB)
📄
idn2.h
(13.57 KB)
📄
ieee754.h
(4.79 KB)
📄
ifaddrs.h
(2.77 KB)
📄
inttypes.h
(11.61 KB)
📁
kadm5
📄
kdb.h
(67.66 KB)
📄
keyutils.h
(7.52 KB)
📄
krad.h
(8.72 KB)
📁
krb5
📄
krb5.h
(402 B)
📄
langinfo.h
(17.43 KB)
📄
lastlog.h
(126 B)
📄
lauxlib.h
(8.43 KB)
📄
libelf.h
(19.84 KB)
📄
libgen.h
(1.35 KB)
📄
libintl.h
(4.47 KB)
📄
liblsapi-sha1.h
(569 B)
📄
libpsl.h
(5.44 KB)
📁
libxml2
📄
limits.h
(5.29 KB)
📄
link.h
(7.05 KB)
📁
linux
📄
locale.h
(7.49 KB)
📄
lsapidef.h
(4.6 KB)
📄
lscapi.h
(24.21 KB)
📄
lscapi_config.h
(599 B)
📄
lua.h
(14.49 KB)
📄
lua.hpp
(191 B)
📄
luaconf-x86_64.h
(21.11 KB)
📄
luaconf.h
(1.62 KB)
📄
lualib.h
(1.27 KB)
📁
lzma
📄
lzma.h
(9.59 KB)
📄
malloc.h
(5.96 KB)
📄
math.h
(52.07 KB)
📄
mcheck.h
(2.38 KB)
📄
memory.h
(955 B)
📁
misc
📄
mntent.h
(3.28 KB)
📄
monetary.h
(1.76 KB)
📄
mqueue.h
(3.67 KB)
📁
mtd
📁
mysql
📁
net
📁
netash
📁
netatalk
📁
netax25
📄
netdb.h
(27.44 KB)
📁
neteconet
📁
netinet
📁
netipx
📁
netiucv
📁
netpacket
📁
netrom
📁
netrose
📁
nfs
📁
nghttp2
📄
nl_types.h
(1.71 KB)
📄
nlist.h
(1.56 KB)
📄
nss.h
(1.83 KB)
📄
obstack.h
(20.81 KB)
📁
openssl
📄
paths.h
(2.91 KB)
📄
pcre.h
(30.97 KB)
📄
pcre2.h
(43.75 KB)
📄
pcre2posix.h
(5.67 KB)
📄
pcre_scanner.h
(6.45 KB)
📄
pcre_stringpiece.h
(6.16 KB)
📄
pcrecpp.h
(25.91 KB)
📄
pcrecpparg.h
(6.62 KB)
📄
pcreposix.h
(5.32 KB)
📁
perf
📄
poll.h
(22 B)
📄
printf.h
(6.64 KB)
📄
proc_service.h
(3.39 KB)
📄
profile.h
(11.87 KB)
📁
protocols
📄
pthread.h
(40.3 KB)
📄
pty.h
(1.53 KB)
📄
pwd.h
(6.01 KB)
📁
python2.7
📁
python3.6m
📁
python3.8
📁
rdma
📄
re_comp.h
(962 B)
📄
regex.h
(24.14 KB)
📄
regexp.h
(1.41 KB)
📄
resolv.h
(11.87 KB)
📁
rpc
📁
sasl
📄
sched.h
(4.62 KB)
📁
scsi
📄
search.h
(5.1 KB)
📁
selinux
📄
semaphore.h
(2.34 KB)
📁
sepol
📄
setjmp.h
(3.58 KB)
📄
sgtty.h
(1.31 KB)
📄
shadow.h
(5.34 KB)
📄
signal.h
(11.96 KB)
📁
sound
📄
spawn.h
(6.53 KB)
📄
stab.h
(264 B)
📄
stdc-predef.h
(2.24 KB)
📄
stdint.h
(8.27 KB)
📄
stdio.h
(29.46 KB)
📄
stdio_ext.h
(2.73 KB)
📄
stdlib.h
(34.82 KB)
📄
string.h
(17.17 KB)
📄
strings.h
(4.64 KB)
📁
sys
📄
syscall.h
(25 B)
📄
sysexits.h
(5.11 KB)
📄
syslog.h
(24 B)
📄
tar.h
(3.7 KB)
📄
termio.h
(214 B)
📄
termios.h
(3.51 KB)
📄
tgmath.h
(30.75 KB)
📄
thread_db.h
(15.65 KB)
📄
threads.h
(6.5 KB)
📄
time.h
(10.12 KB)
📄
ttyent.h
(2.44 KB)
📄
uchar.h
(1.95 KB)
📄
ucontext.h
(1.99 KB)
📄
ulimit.h
(1.55 KB)
📄
unistd.h
(41.74 KB)
📄
utime.h
(1.47 KB)
📄
utmp.h
(3.15 KB)
📄
utmpx.h
(4 KB)
📄
values.h
(1.91 KB)
📄
verto-module.h
(6.48 KB)
📄
verto.h
(18.98 KB)
📁
video
📄
wait.h
(22 B)
📄
wchar.h
(30.38 KB)
📄
wctype.h
(5.42 KB)
📄
wordexp.h
(2.44 KB)
📁
xen
📄
zbuff.h
(11.23 KB)
📄
zconf.h
(15.88 KB)
📄
zdict.h
(16.8 KB)
📄
zlib.h
(94 KB)
📄
zstd.h
(117.16 KB)
📄
zstd_errors.h
(3.66 KB)
Editing: pcre_scanner.h
// Copyright (c) 2005, Google Inc. // All rights reserved. // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are // met: // // * Redistributions of source code must retain the above copyright // notice, this list of conditions and the following disclaimer. // * Redistributions in binary form must reproduce the above // copyright notice, this list of conditions and the following disclaimer // in the documentation and/or other materials provided with the // distribution. // * Neither the name of Google Inc. nor the names of its // contributors may be used to endorse or promote products derived from // this software without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // // Author: Sanjay Ghemawat // // Regular-expression based scanner for parsing an input stream. // // Example 1: parse a sequence of "var = number" entries from input: // // Scanner scanner(input); // string var; // int number; // scanner.SetSkipExpression("\\s+"); // Skip any white space we encounter // while (scanner.Consume("(\\w+) = (\\d+)", &var, &number)) { // ...; // } #ifndef _PCRE_SCANNER_H #define _PCRE_SCANNER_H #include <assert.h> #include <string> #include <vector> #include <pcrecpp.h> #include <pcre_stringpiece.h> namespace pcrecpp { class PCRECPP_EXP_DEFN Scanner { public: Scanner(); explicit Scanner(const std::string& input); ~Scanner(); // Return current line number. The returned line-number is // one-based. I.e. it returns 1 + the number of consumed newlines. // // Note: this method may be slow. It may take time proportional to // the size of the input. int LineNumber() const; // Return the byte-offset that the scanner is looking in the // input data; int Offset() const; // Return true iff the start of the remaining input matches "re" bool LookingAt(const RE& re) const; // Return true iff all of the following are true // a. the start of the remaining input matches "re", // b. if any arguments are supplied, matched sub-patterns can be // parsed and stored into the arguments. // If it returns true, it skips over the matched input and any // following input that matches the "skip" regular expression. bool Consume(const RE& re, const Arg& arg0 = RE::no_arg, const Arg& arg1 = RE::no_arg, const Arg& arg2 = RE::no_arg // TODO: Allow more arguments? ); // Set the "skip" regular expression. If after consuming some data, // a prefix of the input matches this RE, it is automatically // skipped. For example, a programming language scanner would use // a skip RE that matches white space and comments. // // scanner.SetSkipExpression("\\s+|//.*|/[*](.|\n)*?[*]/"); // // Skipping repeats as long as it succeeds. We used to let people do // this by writing "(...)*" in the regular expression, but that added // up to lots of recursive calls within the pcre library, so now we // control repetition explicitly via the function call API. // // You can pass NULL for "re" if you do not want any data to be skipped. void Skip(const char* re); // DEPRECATED; does *not* repeat void SetSkipExpression(const char* re); // Temporarily pause "skip"ing. This // Skip("Foo"); code ; DisableSkip(); code; EnableSkip() // is similar to // Skip("Foo"); code ; Skip(NULL); code ; Skip("Foo"); // but avoids creating/deleting new RE objects. void DisableSkip(); // Reenable previously paused skipping. Any prefix of the input // that matches the skip pattern is immediately dropped. void EnableSkip(); /***** Special wrappers around SetSkip() for some common idioms *****/ // Arranges to skip whitespace, C comments, C++ comments. // The overall RE is a disjunction of the following REs: // \\s whitespace // //.*\n C++ comment // /[*](.|\n)*?[*]/ C comment (x*? means minimal repetitions of x) // We get repetition via the semantics of SetSkipExpression, not by using * void SkipCXXComments() { SetSkipExpression("\\s|//.*\n|/[*](?:\n|.)*?[*]/"); } void set_save_comments(bool comments) { save_comments_ = comments; } bool save_comments() { return save_comments_; } // Append to vector ranges the comments found in the // byte range [start,end] (inclusive) of the input data. // Only comments that were extracted entirely within that // range are returned: no range splitting of atomically-extracted // comments is performed. void GetComments(int start, int end, std::vector<StringPiece> *ranges); // Append to vector ranges the comments added // since the last time this was called. This // functionality is provided for efficiency when // interleaving scanning with parsing. void GetNextComments(std::vector<StringPiece> *ranges); private: std::string data_; // All the input data StringPiece input_; // Unprocessed input RE* skip_; // If non-NULL, RE for skipping input bool should_skip_; // If true, use skip_ bool skip_repeat_; // If true, repeat skip_ as long as it works bool save_comments_; // If true, aggregate the skip expression // the skipped comments // TODO: later consider requiring that the StringPieces be added // in order by their start position std::vector<StringPiece> *comments_; // the offset into comments_ that has been returned by GetNextComments int comments_offset_; // helper function to consume *skip_ and honour // save_comments_ void ConsumeSkip(); }; } // namespace pcrecpp #endif /* _PCRE_SCANNER_H */
Upload File
Create Folder