🐐 GOAT Shell
Current path:
usr
/
include
/
👤 Create WP Admin
⬆️
Go up: usr
✏️ Editing: fstrm.h
/* * Copyright (c) 2013-2014 by Farsight Security, Inc. * * Permission is hereby granted, free of charge, to any person obtaining * a copy of this software and associated documentation files (the * "Software"), to deal in the Software without restriction, including * without limitation the rights to use, copy, modify, merge, publish, * distribute, sublicense, and/or sell copies of the Software, and to * permit persons to whom the Software is furnished to do so, subject to * the following conditions: * * The above copyright notice and this permission notice shall be included * in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * */ /*! \file * \mainpage Introduction * * This is `fstrm`, a C implementation of the Frame Streams data transport * protocol. * * Frame Streams is a light weight, binary clean protocol that allows for the * transport of arbitrarily encoded data payload sequences with minimal framing * overhead -- just four bytes per data frame. Frame Streams does not specify an * encoding format for data frames and can be used with any data serialization * format that produces byte sequences, such as [Protocol Buffers], [XML], * [JSON], [MessagePack], [YAML], etc. Frame Streams can be used as both a * streaming transport over a reliable byte stream socket (TCP sockets, TLS * connections, `AF_UNIX` sockets, etc.) for data in motion as well as a file * format for data at rest. A "Content Type" header identifies the type of * payload being carried over an individual Frame Stream and allows cooperating * programs to determine how to interpret a given sequence of data payloads. * * `fstrm` is an optimized C implementation of Frame Streams that includes a * fast, lockless circular queue implementation and exposes library interfaces * for setting up a dedicated Frame Streams I/O thread and asynchronously * submitting data frames for transport from worker threads. It was originally * written to facilitate the addition of high speed binary logging to DNS * servers written in C using the [dnstap] log format. * * This is the API documentation for the `fstrm` library. For the project * hosting site, see <https://github.com/farsightsec/fstrm>. * * \authors Farsight Security, Inc. and the `fstrm` authors. * * \copyright 2013-2018. Licensed under the terms of the [MIT] license. * * [Protocol Buffers]: https://developers.google.com/protocol-buffers/ * [XML]: http://www.w3.org/TR/xml11/ * [JSON]: http://www.json.org/ * [MessagePack]: http://msgpack.org/ * [YAML]: http://www.yaml.org/ * [dnstap]: http://dnstap.info/ * [MIT]: https://opensource.org/licenses/MIT * * \page overview Library overview * * \section init Initializing the library * * `fstrm` has no global library state. In most cases, only a single * \ref fstrm_iothr library context object will be needed for the entire process, * which will implicitly create a background I/O serialization thread. This I/O * thread is bound to a particular output writer (for example, an `AF_UNIX` * socket) and is fully buffered -- submitted data frames will be accumulated in * an output buffer and periodically flushed, minimizing the number of system * calls that need to be performed. This frees worker threads from waiting for a * write() to complete. * * `fstrm` abstracts the actual I/O operations needed to read or write a byte * stream. File and socket I/O implementations are included in the library, but * if necessary `fstrm` can be extended to support new types of byte stream * transports. See the \ref fstrm_reader, \ref fstrm_writer, and \ref fstrm_rdwr * interfaces for details. * * The following code example shows the initialization of an `fstrm_iothr` * library context object connected to an \ref fstrm_file writer. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ const char *file_path = "/tmp/output.fs"; struct fstrm_file_options *fopt; struct fstrm_iothr *iothr; struct fstrm_writer *writer; fopt = fstrm_file_options_init(); fstrm_file_options_set_file_path(fopt, file_path); writer = fstrm_file_writer_init(fopt, NULL); if (!writer) { fprintf(stderr, "Error: fstrm_file_writer_init() failed.\n"); exit(EXIT_FAILURE); } iothr = fstrm_iothr_init(NULL, &writer); if (!iothr) { fprintf(stderr, "Error: fstrm_iothr_init() failed.\n"); exit(EXIT_FAILURE); } fstrm_file_options_destroy(&fopt); ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * Since the I/O operations are abstracted through the `fstrm_writer` interface, * the `writer` variable in the above example could instead have been * initialized with a completely different implementation. For example, * \ref fstrm_unix_writer objects can be initialized as follows: ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ const char *socket_path = "/tmp/output.sock"; struct fstrm_writer *writer; struct fstrm_unix_writer_options *uwopt; uwopt = fstrm_unix_writer_options_init(); fstrm_unix_writer_options_set_socket_path(uwopt, socket_path); writer = fstrm_unix_writer_init(uwopt, NULL); if (!writer) { fprintf(stderr, "Error: fstrm_unix_writer_init() failed.\n"); exit(EXIT_FAILURE); } ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * \section queue Getting an input queue * * After the `fstrm_iothr` object has been created with fstrm_iothr_init(), an * input queue handle can be obtained with the fstrm_iothr_get_input_queue() * function, which returns an `fstrm_iothr_queue` object. This function is * thread-safe and returns a unique queue each time it is called, up to the * number of queues specified by fstrm_iothr_options_set_num_input_queues(). * `fstrm_iothr_queue` objects belong to their parent `fstrm_iothr` object and * will be destroyed when the parent `fstrm_iothr` object is destroyed. * * The following code example shows a single `fstrm_iothr_queue` handle being * obtained from an already initialized `fstrm_iothr` library context object. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // 'iothr' is a struct fstrm_iothr * struct fstrm_iothr_queue *ioq; ioq = fstrm_iothr_get_input_queue(iothr); if (!ioq) { fprintf(stderr, "Error: fstrm_iothr_get_input_queue() failed.\n"); exit(EXIT_FAILURE); } ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * \section submit Submitting data frames * * Once the `fstrm_iothr` object has been created and an `fstrm_iothr_queue` * handle is available, data frames can be submitted for asynchronous writing * using the fstrm_iothr_submit() function. A callback is passed to this * function which will be invoked to deallocate the data frame once the I/O * thread has completed processing it. In the common case where the data frame * is dynamically allocated with `malloc()`, the deallocation callback must call * `free()`. fstrm_free_wrapper() is provided as a convenience function which * does this and can be specified as the `free_func` parameter to * fstrm_iothr_submit(). * * If space is available in the queue, fstrm_iothr_submit() will return * #fstrm_res_success, indicating that ownership of the memory allocation for the * data frame has passed from the caller to the library. The caller must not * reuse or deallocate the memory for the data frame after a successful call to * fstrm_iothr_submit(). * * Callers must check the return value of fstrm_iothr_submit(). If this function * fails, that is, it returns any result code other than #fstrm_res_success, the * caller must deallocate or otherwise dispose of memory allocated for the data * frame, in order to avoid leaking memory. fstrm_iothr_submit() can fail with * #fstrm_res_again if there is currently no space in the circular queue for an * additional frame, in which case a later call to fstrm_iothr_submit() with the * same parameters may succeed. However, if fstrm_iothr_submit() fails with * #fstrm_res_invalid, then there is a problem with the parameters and a later * call will not succeed. * * The following code example shows data frames containing a short sequence of * bytes being created and submitted repeatedly, with appropriate error * handling. Note that the data frames in this example intentionally contain * embedded unprintable characters, showing that Frame Streams is binary clean. * This example follows from the previous examples, where the `iothr` and `ioq` * variables have already been initialized. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // 'iothr' is a struct fstrm_iothr * // 'ioq' is a struct fstrm_queue * const unsigned num_frames = 100; const uint8_t frame_template[] = { 'H', 'e', 'l', 'l', 'o', 0x00, 0x01, 0x02, 0x03, 'W', 'o', 'r', 'l', 'd', 0x04, 0x05, 0x06, 0x07, }; for (unsigned i = 0; i < num_frames; i++) { // Allocate a new frame from the template. uint8_t *frame = malloc(sizeof(frame_template)); if (!frame) break; memcpy(frame, frame_template, sizeof(frame_template)); // Submit the frame for writing. for (;;) { fstrm_res res; res = fstrm_iothr_submit(iothr, ioq, frame, sizeof(frame_template), fstrm_free_wrapper, NULL); if (res == fstrm_res_success) { // Frame successfully queued. break; } else if (res == fstrm_res_again) { // Queue is full. Try again in a busy loop. // Alternatively, if loss can be tolerated we // could free the frame here and break out of // the loop. continue; } else { // Permanent failure. free(frame); fputs("fstrm_iothr_submit() failed.\n", stderr); break; } } } ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * \section shutdown Shutting down * * Calling fstrm_iothr_destroy() on the `fstrm_iothr` object will signal the I/O * thread to flush any outstanding data frames being written and will deallocate * all associated resources. This function is synchronous and does not return * until the I/O thread has terminated. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // 'iothr' is a struct fstrm_iothr * fstrm_iothr_destroy(&iothr); ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */ #ifndef FSTRM_H #define FSTRM_H #ifdef __cplusplus extern "C" { #endif #include <sys/uio.h> #include <stddef.h> #include <stdint.h> /** * \defgroup fstrm_res fstrm_res * * Library result codes. * @{ */ /** * Result codes for functions. */ typedef enum { /** Success. */ fstrm_res_success, /** Failure. */ fstrm_res_failure, /** Resource temporarily unavailable. */ fstrm_res_again, /** Parameters were invalid. */ fstrm_res_invalid, /** The end of a stream has been reached. */ fstrm_res_stop, } fstrm_res; /**@}*/ struct fstrm_control; struct fstrm_file_options; struct fstrm_iothr; struct fstrm_iothr_options; struct fstrm_iothr_queue; struct fstrm_rdwr; struct fstrm_reader_options; struct fstrm_unix_writer_options; struct fstrm_writer; struct fstrm_writer_options; #include <fstrm/control.h> #include <fstrm/file.h> #include <fstrm/iothr.h> #include <fstrm/rdwr.h> #include <fstrm/reader.h> #include <fstrm/tcp_writer.h> #include <fstrm/unix_writer.h> #include <fstrm/writer.h> #ifdef __cplusplus } #endif #endif /* FSTRM_H */
Save
📁
apache2
|
✏️ Rename
|
🗑️ Delete
📁
arpa
|
✏️ Rename
|
🗑️ Delete
📁
asm
|
✏️ Rename
|
🗑️ Delete
📁
asm-generic
|
✏️ Rename
|
🗑️ Delete
📁
bind9
|
✏️ Rename
|
🗑️ Delete
📁
bits
|
✏️ Rename
|
🗑️ Delete
📁
bsock
|
✏️ Rename
|
🗑️ Delete
📁
c++
|
✏️ Rename
|
🗑️ Delete
📁
criu
|
✏️ Rename
|
🗑️ Delete
📁
curl
|
✏️ Rename
|
🗑️ Delete
📁
drm
|
✏️ Rename
|
🗑️ Delete
📁
e2p
|
✏️ Rename
|
🗑️ Delete
📁
et
|
✏️ Rename
|
🗑️ Delete
📁
event2
|
✏️ Rename
|
🗑️ Delete
📁
ext2fs
|
✏️ Rename
|
🗑️ Delete
📁
finclude
|
✏️ Rename
|
🗑️ Delete
📁
fontconfig
|
✏️ Rename
|
🗑️ Delete
📁
freetype2
|
✏️ Rename
|
🗑️ Delete
📁
fstrm
|
✏️ Rename
|
🗑️ Delete
📁
gdb
|
✏️ Rename
|
🗑️ Delete
📁
gdbm
|
✏️ Rename
|
🗑️ Delete
📁
GL
|
✏️ Rename
|
🗑️ Delete
📁
gnu
|
✏️ Rename
|
🗑️ Delete
📁
google
|
✏️ Rename
|
🗑️ Delete
📁
gssapi
|
✏️ Rename
|
🗑️ Delete
📁
gssrpc
|
✏️ Rename
|
🗑️ Delete
📁
jemalloc
|
✏️ Rename
|
🗑️ Delete
📁
json-c
|
✏️ Rename
|
🗑️ Delete
📁
kadm5
|
✏️ Rename
|
🗑️ Delete
📁
krb5
|
✏️ Rename
|
🗑️ Delete
📁
libdb
|
✏️ Rename
|
🗑️ Delete
📁
libexslt
|
✏️ Rename
|
🗑️ Delete
📁
libltdl
|
✏️ Rename
|
🗑️ Delete
📁
libpng16
|
✏️ Rename
|
🗑️ Delete
📁
libpq
|
✏️ Rename
|
🗑️ Delete
📁
libxml2
|
✏️ Rename
|
🗑️ Delete
📁
libxslt
|
✏️ Rename
|
🗑️ Delete
📁
linux
|
✏️ Rename
|
🗑️ Delete
📁
lzma
|
✏️ Rename
|
🗑️ Delete
📁
misc
|
✏️ Rename
|
🗑️ Delete
📁
mtd
|
✏️ Rename
|
🗑️ Delete
📁
mysql
|
✏️ Rename
|
🗑️ Delete
📁
ncurses
|
✏️ Rename
|
🗑️ Delete
📁
ncursesw
|
✏️ Rename
|
🗑️ Delete
📁
net
|
✏️ Rename
|
🗑️ Delete
📁
netash
|
✏️ Rename
|
🗑️ Delete
📁
netatalk
|
✏️ Rename
|
🗑️ Delete
📁
netax25
|
✏️ Rename
|
🗑️ Delete
📁
neteconet
|
✏️ Rename
|
🗑️ Delete
📁
netinet
|
✏️ Rename
|
🗑️ Delete
📁
netipx
|
✏️ Rename
|
🗑️ Delete
📁
netiucv
|
✏️ Rename
|
🗑️ Delete
📁
netpacket
|
✏️ Rename
|
🗑️ Delete
📁
netrom
|
✏️ Rename
|
🗑️ Delete
📁
netrose
|
✏️ Rename
|
🗑️ Delete
📁
nfs
|
✏️ Rename
|
🗑️ Delete
📁
openssl
|
✏️ Rename
|
🗑️ Delete
📁
perf
|
✏️ Rename
|
🗑️ Delete
📁
pgsql
|
✏️ Rename
|
🗑️ Delete
📁
protobuf-c
|
✏️ Rename
|
🗑️ Delete
📁
protocols
|
✏️ Rename
|
🗑️ Delete
📁
python2.7
|
✏️ Rename
|
🗑️ Delete
📁
python3.6m
|
✏️ Rename
|
🗑️ Delete
📁
python3.8
|
✏️ Rename
|
🗑️ Delete
📁
rdma
|
✏️ Rename
|
🗑️ Delete
📁
rpc
|
✏️ Rename
|
🗑️ Delete
📁
sasl
|
✏️ Rename
|
🗑️ Delete
📁
scsi
|
✏️ Rename
|
🗑️ Delete
📁
security
|
✏️ Rename
|
🗑️ Delete
📁
selinux
|
✏️ Rename
|
🗑️ Delete
📁
sepol
|
✏️ Rename
|
🗑️ Delete
📁
sound
|
✏️ Rename
|
🗑️ Delete
📁
sys
|
✏️ Rename
|
🗑️ Delete
📁
uuid
|
✏️ Rename
|
🗑️ Delete
📁
video
|
✏️ Rename
|
🗑️ Delete
📁
webp
|
✏️ Rename
|
🗑️ Delete
📁
X11
|
✏️ Rename
|
🗑️ Delete
📁
xcb
|
✏️ Rename
|
🗑️ Delete
📁
xen
|
✏️ Rename
|
🗑️ Delete
📄
a.out.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
aio.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
aliases.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
alloca.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ar.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
argp.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
argz.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
assert.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
autosprintf.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
byteswap.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
bzlib.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
complex.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
com_err.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
cpio.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
cpuidle.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
crypt.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ctype.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
curses.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
cursesapp.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
cursesf.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
cursesm.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
cursesp.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
cursesw.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
cursslk.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
db.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
dbm.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
db_185.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
dirent.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
dlfcn.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
elf.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
endian.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
entities.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
envz.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
err.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
errno.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
error.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
eti.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
etip.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
evdns.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
event.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
evhttp.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
evrpc.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
evutil.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
execinfo.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
expat.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
expat_config.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
expat_external.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
fcntl.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
features.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
fenv.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
FlexLexer.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
fmtmsg.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
fnmatch.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
form.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
fpu_control.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
fstab.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
fstrm.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
fts.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ftw.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gconv.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gcrypt.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gd.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gdbm.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gdcache.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gdfontg.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gdfontl.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gdfontmb.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gdfonts.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gdfontt.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gdfx.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gdpp.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gd_color_map.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gd_errors.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gd_io.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
getopt.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gettext-po.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
glob.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gnu-versions.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gnumake.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gpg-error.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gpgrt.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
grp.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gshadow.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
gssapi.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
iconv.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
idn-free.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
idn-int.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
idna.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ieee754.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ifaddrs.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
inttypes.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
jconfig-64.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
jconfig.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
jerror.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
jmorecfg.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
jpegint.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
jpeglib.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
kdb.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
keyutils.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
krad.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
krb5.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
langinfo.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
lastlog.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
lber.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
lber_types.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ldap.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ldap_cdefs.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ldap_features.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ldap_schema.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ldap_utf8.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ldif.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
libaio.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
libgen.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
libintl.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
libpq-events.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
libpq-fe.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
limits.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
link.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
locale.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ltdl.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
lzma.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
malloc.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
math.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
mcheck.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
memory.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
menu.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
mntent.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
monetary.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
mqueue.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ncurses.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ncurses_dll.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
nc_tparm.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ndbm.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
netdb.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
nl_types.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
nss.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
obstack.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
panel.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
paths.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pcre.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pcre2.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pcre2posix.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pcrecpp.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pcrecpparg.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pcreposix.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pcre_scanner.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pcre_stringpiece.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pg_config-x86_64.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pg_config.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pg_config_ext-x86_64.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pg_config_ext.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pg_config_manual.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pg_config_os.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
png.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pngconf.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pnglibconf.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
poll.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
postgres_ext.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pr29.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
printf.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
proc_service.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
profile.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pthread.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pty.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
punycode.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
pwd.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
regex.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
regexp.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
resolv.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
re_comp.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
sched.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
search.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
semaphore.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
setjmp.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
sgtty.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
shadow.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
signal.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
slapi-plugin.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
spawn.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
stab.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
stdc-predef.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
stdint.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
stdio.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
stdio_ext.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
stdlib.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
string.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
stringprep.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
strings.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
syscall.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
sysexits.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
syslog.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
tar.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
term.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
termcap.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
termio.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
termios.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
term_entry.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
tgmath.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
threads.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
thread_db.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
tic.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
tiff.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
tiffconf-64.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
tiffconf.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
tiffio.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
tiffio.hxx
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
tiffvers.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
time.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
tld.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ttyent.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
uchar.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ucontext.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
ulimit.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
unctrl.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
unistd.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
utime.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
utmp.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
utmpx.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
values.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
verto-module.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
verto.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
wait.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
wchar.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
wctype.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
wordexp.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
zconf.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📄
zlib.h
|
✏️ Edit
|
✏️ Rename
|
🗑️ Delete
📤 Upload File
Upload
📁 Create Folder
Create Folder