usr
/
include
/
Go to Home Directory
+
Upload
Create File
root@0UT1S:~$
Execute
By Order of Mr.0UT1S
[DIR] ..
N/A
[DIR] GL
N/A
[DIR] X11
N/A
[DIR] apache2
N/A
[DIR] arpa
N/A
[DIR] asm
N/A
[DIR] asm-generic
N/A
[DIR] bind9
N/A
[DIR] bits
N/A
[DIR] bsock
N/A
[DIR] c++
N/A
[DIR] criu
N/A
[DIR] curl
N/A
[DIR] drm
N/A
[DIR] e2p
N/A
[DIR] et
N/A
[DIR] event2
N/A
[DIR] ext2fs
N/A
[DIR] finclude
N/A
[DIR] fontconfig
N/A
[DIR] freetype2
N/A
[DIR] fstrm
N/A
[DIR] gdb
N/A
[DIR] gdbm
N/A
[DIR] gnu
N/A
[DIR] google
N/A
[DIR] gssapi
N/A
[DIR] gssrpc
N/A
[DIR] json-c
N/A
[DIR] kadm5
N/A
[DIR] krb5
N/A
[DIR] libdb
N/A
[DIR] libexslt
N/A
[DIR] libltdl
N/A
[DIR] libpng16
N/A
[DIR] libxml2
N/A
[DIR] libxslt
N/A
[DIR] linux
N/A
[DIR] lua-5.1
N/A
[DIR] lzma
N/A
[DIR] misc
N/A
[DIR] mtd
N/A
[DIR] mysql
N/A
[DIR] ncurses
N/A
[DIR] ncursesw
N/A
[DIR] net
N/A
[DIR] netash
N/A
[DIR] netatalk
N/A
[DIR] netax25
N/A
[DIR] neteconet
N/A
[DIR] netinet
N/A
[DIR] netipx
N/A
[DIR] netiucv
N/A
[DIR] netpacket
N/A
[DIR] netrom
N/A
[DIR] netrose
N/A
[DIR] nfs
N/A
[DIR] openssl
N/A
[DIR] perf
N/A
[DIR] protobuf-c
N/A
[DIR] protocols
N/A
[DIR] python2.7
N/A
[DIR] python3.6m
N/A
[DIR] python3.8
N/A
[DIR] rdma
N/A
[DIR] rpc
N/A
[DIR] sasl
N/A
[DIR] scsi
N/A
[DIR] security
N/A
[DIR] selinux
N/A
[DIR] sepol
N/A
[DIR] sound
N/A
[DIR] sys
N/A
[DIR] uuid
N/A
[DIR] video
N/A
[DIR] webp
N/A
[DIR] xcb
N/A
[DIR] xen
N/A
FlexLexer.h
6.73 KB
Rename
Delete
a.out.h
4.25 KB
Rename
Delete
aio.h
7.28 KB
Rename
Delete
aliases.h
1.98 KB
Rename
Delete
alloca.h
1.17 KB
Rename
Delete
ar.h
1.69 KB
Rename
Delete
argp.h
24.82 KB
Rename
Delete
argz.h
5.91 KB
Rename
Delete
assert.h
4.45 KB
Rename
Delete
autosprintf.h
2.33 KB
Rename
Delete
byteswap.h
1.37 KB
Rename
Delete
bzlib.h
6.10 KB
Rename
Delete
com_err.h
2.07 KB
Rename
Delete
complex.h
7.00 KB
Rename
Delete
cpio.h
2.21 KB
Rename
Delete
cpuidle.h
844 bytes
Rename
Delete
crypt.h
8.90 KB
Rename
Delete
ctype.h
10.71 KB
Rename
Delete
curses.h
97.29 KB
Rename
Delete
cursesapp.h
6.62 KB
Rename
Delete
cursesf.h
27.20 KB
Rename
Delete
cursesm.h
19.22 KB
Rename
Delete
cursesp.h
8.40 KB
Rename
Delete
cursesw.h
48.55 KB
Rename
Delete
cursslk.h
7.13 KB
Rename
Delete
db.h
120.22 KB
Rename
Delete
db_185.h
5.84 KB
Rename
Delete
dbm.h
1.38 KB
Rename
Delete
dirent.h
12.19 KB
Rename
Delete
dlfcn.h
7.07 KB
Rename
Delete
elf.h
170.73 KB
Rename
Delete
endian.h
3.11 KB
Rename
Delete
entities.h
4.81 KB
Rename
Delete
envz.h
2.80 KB
Rename
Delete
err.h
2.16 KB
Rename
Delete
errno.h
1.64 KB
Rename
Delete
error.h
1.99 KB
Rename
Delete
eti.h
2.82 KB
Rename
Delete
etip.h
9.47 KB
Rename
Delete
evdns.h
1.97 KB
Rename
Delete
event.h
2.68 KB
Rename
Delete
evhttp.h
1.99 KB
Rename
Delete
evrpc.h
1.97 KB
Rename
Delete
evutil.h
1.74 KB
Rename
Delete
execinfo.h
1.49 KB
Rename
Delete
expat.h
42.66 KB
Rename
Delete
expat_config.h
3.43 KB
Rename
Delete
expat_external.h
5.40 KB
Rename
Delete
fcntl.h
10.70 KB
Rename
Delete
features.h
15.69 KB
Rename
Delete
fenv.h
5.72 KB
Rename
Delete
fmtmsg.h
3.16 KB
Rename
Delete
fnmatch.h
2.24 KB
Rename
Delete
form.h
18.17 KB
Rename
Delete
fpu_control.h
3.50 KB
Rename
Delete
fstab.h
3.04 KB
Rename
Delete
fstrm.h
12.71 KB
Rename
Delete
fts.h
8.18 KB
Rename
Delete
ftw.h
5.13 KB
Rename
Delete
gconv.h
4.31 KB
Rename
Delete
gcrypt.h
68.71 KB
Rename
Delete
gd.h
56.42 KB
Rename
Delete
gd_color_map.h
478 bytes
Rename
Delete
gd_errors.h
1.47 KB
Rename
Delete
gd_io.h
3.05 KB
Rename
Delete
gdbm.h
10.10 KB
Rename
Delete
gdcache.h
2.83 KB
Rename
Delete
gdfontg.h
553 bytes
Rename
Delete
gdfontl.h
551 bytes
Rename
Delete
gdfontmb.h
519 bytes
Rename
Delete
gdfonts.h
515 bytes
Rename
Delete
gdfontt.h
546 bytes
Rename
Delete
gdfx.h
497 bytes
Rename
Delete
gdpp.h
50.94 KB
Rename
Delete
getopt.h
1.43 KB
Rename
Delete
gettext-po.h
15.17 KB
Rename
Delete
glob.h
6.46 KB
Rename
Delete
gnu-versions.h
2.29 KB
Rename
Delete
gnumake.h
2.84 KB
Rename
Delete
gpg-error.h
66.29 KB
Rename
Delete
gpgrt.h
66.29 KB
Rename
Delete
grp.h
6.53 KB
Rename
Delete
gshadow.h
4.42 KB
Rename
Delete
gssapi.h
181 bytes
Rename
Delete
iconv.h
1.81 KB
Rename
Delete
idn-free.h
2.41 KB
Rename
Delete
idn-int.h
20 bytes
Rename
Delete
idna.h
3.48 KB
Rename
Delete
ieee754.h
4.79 KB
Rename
Delete
ifaddrs.h
2.77 KB
Rename
Delete
inttypes.h
11.61 KB
Rename
Delete
jconfig-64.h
2.17 KB
Rename
Delete
jconfig.h
246 bytes
Rename
Delete
jerror.h
14.73 KB
Rename
Delete
jmorecfg.h
14.70 KB
Rename
Delete
jpegint.h
15.22 KB
Rename
Delete
jpeglib.h
48.71 KB
Rename
Delete
kdb.h
67.66 KB
Rename
Delete
keyutils.h
7.52 KB
Rename
Delete
krad.h
8.72 KB
Rename
Delete
krb5.h
402 bytes
Rename
Delete
langinfo.h
17.43 KB
Rename
Delete
lastlog.h
126 bytes
Rename
Delete
lber.h
14.95 KB
Rename
Delete
lber_types.h
1.43 KB
Rename
Delete
ldap.h
63.57 KB
Rename
Delete
ldap_cdefs.h
9.24 KB
Rename
Delete
ldap_features.h
1.77 KB
Rename
Delete
ldap_schema.h
9.23 KB
Rename
Delete
ldap_utf8.h
3.39 KB
Rename
Delete
ldif.h
4.58 KB
Rename
Delete
libaio.h
8.73 KB
Rename
Delete
libgen.h
1.35 KB
Rename
Delete
libintl.h
4.47 KB
Rename
Delete
limits.h
5.29 KB
Rename
Delete
link.h
7.05 KB
Rename
Delete
locale.h
7.49 KB
Rename
Delete
ltdl.h
5.58 KB
Rename
Delete
lzma.h
9.59 KB
Rename
Delete
magic.h
5.46 KB
Rename
Delete
malloc.h
5.96 KB
Rename
Delete
math.h
52.07 KB
Rename
Delete
mcheck.h
2.38 KB
Rename
Delete
memory.h
955 bytes
Rename
Delete
menu.h
11.91 KB
Rename
Delete
mntent.h
3.28 KB
Rename
Delete
monetary.h
1.76 KB
Rename
Delete
mqueue.h
3.67 KB
Rename
Delete
nc_tparm.h
4.10 KB
Rename
Delete
ncurses.h
97.29 KB
Rename
Delete
ncurses_dll.h
4.18 KB
Rename
Delete
ndbm.h
2.40 KB
Rename
Delete
netdb.h
27.44 KB
Rename
Delete
nl_types.h
1.71 KB
Rename
Delete
nss.h
1.83 KB
Rename
Delete
obstack.h
20.81 KB
Rename
Delete
panel.h
4.03 KB
Rename
Delete
paths.h
2.91 KB
Rename
Delete
pcre.h
30.97 KB
Rename
Delete
pcre2.h
43.75 KB
Rename
Delete
pcre2posix.h
5.67 KB
Rename
Delete
pcre_scanner.h
6.45 KB
Rename
Delete
pcre_stringpiece.h
6.16 KB
Rename
Delete
pcrecpp.h
25.91 KB
Rename
Delete
pcrecpparg.h
6.62 KB
Rename
Delete
pcreposix.h
5.32 KB
Rename
Delete
png.h
140.77 KB
Rename
Delete
pngconf.h
22.31 KB
Rename
Delete
pnglibconf.h
7.39 KB
Rename
Delete
poll.h
22 bytes
Rename
Delete
pr29.h
2.07 KB
Rename
Delete
printf.h
6.64 KB
Rename
Delete
proc_service.h
3.39 KB
Rename
Delete
profile.h
11.87 KB
Rename
Delete
pthread.h
40.30 KB
Rename
Delete
pty.h
1.53 KB
Rename
Delete
punycode.h
9.16 KB
Rename
Delete
pwd.h
6.01 KB
Rename
Delete
re_comp.h
962 bytes
Rename
Delete
regex.h
24.14 KB
Rename
Delete
regexp.h
1.41 KB
Rename
Delete
resolv.h
11.79 KB
Rename
Delete
sched.h
4.62 KB
Rename
Delete
search.h
5.10 KB
Rename
Delete
semaphore.h
2.34 KB
Rename
Delete
setjmp.h
3.58 KB
Rename
Delete
sgtty.h
1.31 KB
Rename
Delete
shadow.h
5.34 KB
Rename
Delete
signal.h
11.96 KB
Rename
Delete
slapi-plugin.h
37.45 KB
Rename
Delete
spawn.h
6.53 KB
Rename
Delete
stab.h
264 bytes
Rename
Delete
stdc-predef.h
2.24 KB
Rename
Delete
stdint.h
8.27 KB
Rename
Delete
stdio.h
29.46 KB
Rename
Delete
stdio_ext.h
2.73 KB
Rename
Delete
stdlib.h
34.82 KB
Rename
Delete
string.h
17.17 KB
Rename
Delete
stringprep.h
8.03 KB
Rename
Delete
strings.h
4.64 KB
Rename
Delete
syscall.h
25 bytes
Rename
Delete
sysexits.h
5.11 KB
Rename
Delete
syslog.h
24 bytes
Rename
Delete
tar.h
3.70 KB
Rename
Delete
term.h
40.22 KB
Rename
Delete
term_entry.h
8.55 KB
Rename
Delete
termcap.h
3.39 KB
Rename
Delete
termio.h
214 bytes
Rename
Delete
termios.h
3.51 KB
Rename
Delete
tgmath.h
30.75 KB
Rename
Delete
thread_db.h
15.65 KB
Rename
Delete
threads.h
6.50 KB
Rename
Delete
tic.h
13.32 KB
Rename
Delete
tiff.h
35.14 KB
Rename
Delete
tiffconf-64.h
3.35 KB
Rename
Delete
tiffconf.h
250 bytes
Rename
Delete
tiffio.h
22.68 KB
Rename
Delete
tiffio.hxx
1.66 KB
Rename
Delete
tiffvers.h
410 bytes
Rename
Delete
time.h
10.12 KB
Rename
Delete
tld.h
4.54 KB
Rename
Delete
ttyent.h
2.44 KB
Rename
Delete
uchar.h
1.95 KB
Rename
Delete
ucontext.h
1.99 KB
Rename
Delete
ulimit.h
1.55 KB
Rename
Delete
unctrl.h
3.03 KB
Rename
Delete
unistd.h
41.74 KB
Rename
Delete
utime.h
1.47 KB
Rename
Delete
utmp.h
3.15 KB
Rename
Delete
utmpx.h
4.00 KB
Rename
Delete
values.h
1.91 KB
Rename
Delete
verto-module.h
6.48 KB
Rename
Delete
verto.h
18.98 KB
Rename
Delete
wait.h
22 bytes
Rename
Delete
wchar.h
30.38 KB
Rename
Delete
wctype.h
5.42 KB
Rename
Delete
wordexp.h
2.44 KB
Rename
Delete
zconf.h
15.88 KB
Rename
Delete
zlib.h
94.00 KB
Rename
Delete
/* Public API for GNU gettext PO files - contained in libgettextpo. Copyright (C) 2003-2008, 2010, 2015-2016 Free Software Foundation, Inc. Written by Bruno Haible <bruno@clisp.org>, 2003. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ #ifndef _GETTEXT_PO_H #define _GETTEXT_PO_H 1 #include <stdlib.h> #ifdef __cplusplus extern "C" { #endif /* =========================== Meta Information ============================ */ /* Version number: (major<<16) + (minor<<8) + subminor */ #define LIBGETTEXTPO_VERSION 0x001308 extern int libgettextpo_version; /* ================================= Types ================================= */ /* A po_file_t represents the contents of a PO file. */ typedef struct po_file *po_file_t; /* A po_message_iterator_t represents an iterator through a domain of a PO file. */ typedef struct po_message_iterator *po_message_iterator_t; /* A po_message_t represents a message in a PO file. */ typedef struct po_message *po_message_t; /* A po_filepos_t represents a string's position within a source file. */ typedef struct po_filepos *po_filepos_t; /* A po_error_handler handles error situations. */ struct po_error_handler { /* Signal an error. The error message is built from FORMAT and the following arguments. ERRNUM, if nonzero, is an errno value. Must increment the error_message_count variable declared in error.h. Must not return if STATUS is nonzero. */ void (*error) (int status, int errnum, const char *format, ...) #if ((__GNUC__ == 3 && __GNUC_MINOR__ >= 1) || __GNUC__ > 3) && !__STRICT_ANSI__ __attribute__ ((__format__ (__printf__, 3, 4))) #endif ; /* Signal an error. The error message is built from FORMAT and the following arguments. The error location is at FILENAME line LINENO. ERRNUM, if nonzero, is an errno value. Must increment the error_message_count variable declared in error.h. Must not return if STATUS is nonzero. */ void (*error_at_line) (int status, int errnum, const char *filename, unsigned int lineno, const char *format, ...) #if ((__GNUC__ == 3 && __GNUC_MINOR__ >= 1) || __GNUC__ > 3) && !__STRICT_ANSI__ __attribute__ ((__format__ (__printf__, 5, 6))) #endif ; /* Signal a multiline warning. The PREFIX applies to all lines of the MESSAGE. Free the PREFIX and MESSAGE when done. */ void (*multiline_warning) (char *prefix, char *message); /* Signal a multiline error. The PREFIX applies to all lines of the MESSAGE. Free the PREFIX and MESSAGE when done. Must increment the error_message_count variable declared in error.h if PREFIX is non-NULL. */ void (*multiline_error) (char *prefix, char *message); }; typedef const struct po_error_handler *po_error_handler_t; /* A po_xerror_handler handles warnings, error and fatal error situations. */ #define PO_SEVERITY_WARNING 0 /* just a warning, tell the user */ #define PO_SEVERITY_ERROR 1 /* an error, the operation cannot complete */ #define PO_SEVERITY_FATAL_ERROR 2 /* an error, the operation must be aborted */ struct po_xerror_handler { /* Signal a problem of the given severity. MESSAGE and/or FILENAME + LINENO indicate where the problem occurred. If FILENAME is NULL, FILENAME and LINENO and COLUMN should be ignored. If LINENO is (size_t)(-1), LINENO and COLUMN should be ignored. If COLUMN is (size_t)(-1), it should be ignored. MESSAGE_TEXT is the problem description (if MULTILINE_P is true, multiple lines of text, each terminated with a newline, otherwise usually a single line). Must not return if SEVERITY is PO_SEVERITY_FATAL_ERROR. */ void (*xerror) (int severity, po_message_t message, const char *filename, size_t lineno, size_t column, int multiline_p, const char *message_text); /* Signal a problem that refers to two messages. Similar to two calls to xerror. If possible, a "..." can be appended to MESSAGE_TEXT1 and prepended to MESSAGE_TEXT2. */ void (*xerror2) (int severity, po_message_t message1, const char *filename1, size_t lineno1, size_t column1, int multiline_p1, const char *message_text1, po_message_t message2, const char *filename2, size_t lineno2, size_t column2, int multiline_p2, const char *message_text2); }; typedef const struct po_xerror_handler *po_xerror_handler_t; /* Memory allocation: The memory allocations performed by these functions use xmalloc(), therefore will cause a program exit if memory is exhausted. The memory allocated by po_file_read, and implicitly returned through the po_message_* functions, lasts until freed with po_file_free. */ /* ============================= po_file_t API ============================= */ /* Create an empty PO file representation in memory. */ extern po_file_t po_file_create (void); /* Read a PO file into memory. Return its contents. Upon failure, return NULL and set errno. */ #define po_file_read po_file_read_v3 extern po_file_t po_file_read (const char *filename, po_xerror_handler_t handler); /* Write an in-memory PO file to a file. Upon failure, return NULL and set errno. */ #define po_file_write po_file_write_v2 extern po_file_t po_file_write (po_file_t file, const char *filename, po_xerror_handler_t handler); /* Free a PO file from memory. */ extern void po_file_free (po_file_t file); /* Return the names of the domains covered by a PO file in memory. */ extern const char * const * po_file_domains (po_file_t file); /* =========================== Header entry API ============================ */ /* Return the header entry of a domain of a PO file in memory. The domain NULL denotes the default domain. Return NULL if there is no header entry. */ extern const char * po_file_domain_header (po_file_t file, const char *domain); /* Return the value of a field in a header entry. The return value is either a freshly allocated string, to be freed by the caller, or NULL. */ extern char * po_header_field (const char *header, const char *field); /* Return the header entry with a given field set to a given value. The field is added if necessary. The return value is a freshly allocated string. */ extern char * po_header_set_field (const char *header, const char *field, const char *value); /* ======================= po_message_iterator_t API ======================= */ /* Create an iterator for traversing a domain of a PO file in memory. The domain NULL denotes the default domain. */ extern po_message_iterator_t po_message_iterator (po_file_t file, const char *domain); /* Free an iterator. */ extern void po_message_iterator_free (po_message_iterator_t iterator); /* Return the next message, and advance the iterator. Return NULL at the end of the message list. */ extern po_message_t po_next_message (po_message_iterator_t iterator); /* Insert a message in a PO file in memory, in the domain and at the position indicated by the iterator. The iterator thereby advances past the freshly inserted message. */ extern void po_message_insert (po_message_iterator_t iterator, po_message_t message); /* =========================== po_message_t API ============================ */ /* Return a freshly constructed message. To finish initializing the message, you must set the msgid and msgstr. */ extern po_message_t po_message_create (void); /* Return the context of a message, or NULL for a message not restricted to a context. */ extern const char * po_message_msgctxt (po_message_t message); /* Change the context of a message. NULL means a message not restricted to a context. */ extern void po_message_set_msgctxt (po_message_t message, const char *msgctxt); /* Return the msgid (untranslated English string) of a message. */ extern const char * po_message_msgid (po_message_t message); /* Change the msgid (untranslated English string) of a message. */ extern void po_message_set_msgid (po_message_t message, const char *msgid); /* Return the msgid_plural (untranslated English plural string) of a message, or NULL for a message without plural. */ extern const char * po_message_msgid_plural (po_message_t message); /* Change the msgid_plural (untranslated English plural string) of a message. NULL means a message without plural. */ extern void po_message_set_msgid_plural (po_message_t message, const char *msgid_plural); /* Return the msgstr (translation) of a message. Return the empty string for an untranslated message. */ extern const char * po_message_msgstr (po_message_t message); /* Change the msgstr (translation) of a message. Use an empty string to denote an untranslated message. */ extern void po_message_set_msgstr (po_message_t message, const char *msgstr); /* Return the msgstr[index] for a message with plural handling, or NULL when the index is out of range or for a message without plural. */ extern const char * po_message_msgstr_plural (po_message_t message, int index); /* Change the msgstr[index] for a message with plural handling. Use a NULL value at the end to reduce the number of plural forms. */ extern void po_message_set_msgstr_plural (po_message_t message, int index, const char *msgstr); /* Return the comments for a message. */ extern const char * po_message_comments (po_message_t message); /* Change the comments for a message. comments should be a multiline string, ending in a newline, or empty. */ extern void po_message_set_comments (po_message_t message, const char *comments); /* Return the extracted comments for a message. */ extern const char * po_message_extracted_comments (po_message_t message); /* Change the extracted comments for a message. comments should be a multiline string, ending in a newline, or empty. */ extern void po_message_set_extracted_comments (po_message_t message, const char *comments); /* Return the i-th file position for a message, or NULL if i is out of range. */ extern po_filepos_t po_message_filepos (po_message_t message, int i); /* Remove the i-th file position from a message. The indices of all following file positions for the message are decremented by one. */ extern void po_message_remove_filepos (po_message_t message, int i); /* Add a file position to a message, if it is not already present for the message. file is the file name. start_line is the line number where the string starts, or (size_t)(-1) if no line number is available. */ extern void po_message_add_filepos (po_message_t message, const char *file, size_t start_line); /* Return the previous context of a message, or NULL for none. */ extern const char * po_message_prev_msgctxt (po_message_t message); /* Change the previous context of a message. NULL is allowed. */ extern void po_message_set_prev_msgctxt (po_message_t message, const char *prev_msgctxt); /* Return the previous msgid (untranslated English string) of a message, or NULL for none. */ extern const char * po_message_prev_msgid (po_message_t message); /* Change the previous msgid (untranslated English string) of a message. NULL is allowed. */ extern void po_message_set_prev_msgid (po_message_t message, const char *prev_msgid); /* Return the previous msgid_plural (untranslated English plural string) of a message, or NULL for none. */ extern const char * po_message_prev_msgid_plural (po_message_t message); /* Change the previous msgid_plural (untranslated English plural string) of a message. NULL is allowed. */ extern void po_message_set_prev_msgid_plural (po_message_t message, const char *prev_msgid_plural); /* Return true if the message is marked obsolete. */ extern int po_message_is_obsolete (po_message_t message); /* Change the obsolete mark of a message. */ extern void po_message_set_obsolete (po_message_t message, int obsolete); /* Return true if the message is marked fuzzy. */ extern int po_message_is_fuzzy (po_message_t message); /* Change the fuzzy mark of a message. */ extern void po_message_set_fuzzy (po_message_t message, int fuzzy); /* Return true if the message is marked as being a format string of the given type (e.g. "c-format"). */ extern int po_message_is_format (po_message_t message, const char *format_type); /* Change the format string mark for a given type of a message. */ extern void po_message_set_format (po_message_t message, const char *format_type, /*bool*/int value); /* If a numeric range of a message is set, return true and store the minimum and maximum value in *MINP and *MAXP. */ extern int po_message_is_range (po_message_t message, int *minp, int *maxp); /* Change the numeric range of a message. MIN and MAX must be non-negative, with MIN < MAX. Use MIN = MAX = -1 to remove the numeric range of a message. */ extern void po_message_set_range (po_message_t message, int min, int max); /* =========================== po_filepos_t API ============================ */ /* Return the file name. */ extern const char * po_filepos_file (po_filepos_t filepos); /* Return the line number where the string starts, or (size_t)(-1) if no line number is available. */ extern size_t po_filepos_start_line (po_filepos_t filepos); /* ============================ Format type API ============================= */ /* Return a NULL terminated array of the supported format types. */ extern const char * const * po_format_list (void); /* Return the pretty name associated with a format type. For example, for "csharp-format", return "C#". Return NULL if the argument is not a supported format type. */ extern const char * po_format_pretty_name (const char *format_type); /* ============================= Checking API ============================== */ /* Test whether an entire file PO file is valid, like msgfmt does it. If it is invalid, pass the reasons to the handler. */ extern void po_file_check_all (po_file_t file, po_xerror_handler_t handler); /* Test a single message, to be inserted in a PO file in memory, like msgfmt does it. If it is invalid, pass the reasons to the handler. The iterator is not modified by this call; it only specifies the file and the domain. */ extern void po_message_check_all (po_message_t message, po_message_iterator_t iterator, po_xerror_handler_t handler); /* Test whether the message translation is a valid format string if the message is marked as being a format string. If it is invalid, pass the reasons to the handler. */ #define po_message_check_format po_message_check_format_v2 extern void po_message_check_format (po_message_t message, po_xerror_handler_t handler); #ifdef __cplusplus } #endif #endif /* _GETTEXT_PO_H */
Save