Top |
char ** | pango_split_file_list () |
char * | pango_trim_string () |
gint | pango_read_line () |
gboolean | pango_skip_space () |
gboolean | pango_scan_word () |
gboolean | pango_scan_string () |
gboolean | pango_scan_int () |
char * | pango_config_key_get () |
char * | pango_config_key_get_system () |
void | pango_lookup_aliases () |
gboolean | pango_parse_enum () |
gboolean | pango_parse_style () |
gboolean | pango_parse_variant () |
gboolean | pango_parse_weight () |
gboolean | pango_parse_stretch () |
const char * | pango_get_sysconf_subdirectory () |
const char * | pango_get_lib_subdirectory () |
guint8 * | pango_log2vis_get_embedding_levels () |
gboolean | pango_is_zero_width () |
void | pango_quantize_line_geometry () |
The functions and utilities in this section are mostly used from Pango backends and modules, but may be useful for other purposes too.
char **
pango_split_file_list (const char *str
);
Splits a G_SEARCHPATH_SEPARATOR
-separated list of files, stripping
white space and substituting ~/ with $HOME/.
char *
pango_trim_string (const char *str
);
Trims leading and trailing whitespace from a string.
gint pango_read_line (FILE *stream
,GString *str
);
Reads an entire line from a file into a buffer. Lines may be delimited with '\n', '\r', '\n\r', or '\r\n'. The delimiter is not written into the buffer. Text after a '#' character is treated as a comment and skipped. '\' can be used to escape a # character. '\' proceeding a line delimiter combines adjacent lines. A '\' proceeding any other character is ignored and written into the output buffer unmodified.
gboolean
pango_skip_space (const char **pos
);
Skips 0 or more characters of white space.
gboolean pango_scan_word (const char **pos
,GString *out
);
Scans a word into a GString buffer. A word consists of [A-Za-z_] followed by zero or more [A-Za-z_0-9] Leading white space is skipped.
gboolean pango_scan_string (const char **pos
,GString *out
);
Scans a string into a GString buffer. The string may either be a sequence of non-white-space characters, or a quoted string with '"'. Instead a quoted string, '\"' represents a literal quote. Leading white space outside of quotes is skipped.
gboolean pango_scan_int (const char **pos
,int *out
);
Scans an integer. Leading white space is skipped.
char *
pango_config_key_get (const char *key
);
Looks up a key in the Pango config database (pseudo-win.ini style, read from $sysconfdir/pango/pangorc, $XDG_CONFIG_HOME/pango/pangorc, and getenv (PANGO_RC_FILE).)
char *
pango_config_key_get_system (const char *key
);
Looks up a key, consulting only the Pango system config database in $sysconfdir/pango/pangorc.
void pango_lookup_aliases (const char *fontname
,char ***families
,int *n_families
);
pango_lookup_aliases
has been deprecated since version 1.32 and should not be used in newly-written code.
This function is not thread-safe.
Look up all user defined aliases for the alias fontname
.
The resulting font family names will be stored in families
,
and the number of families in n_families
.
gboolean pango_parse_enum (GType type
,const char *str
,int *value
,gboolean warn
,char **possible_values
);
Parses an enum type and stores the result in value
.
If str
does not match the nick name of any of the possible values for the
enum and is not an integer, FALSE
is returned, a warning is issued
if warn
is TRUE
, and a
string representing the list of possible values is stored in
possible_values
. The list is slash-separated, eg.
"none/start/middle/end". If failed and possible_values
is not NULL
,
returned string should be freed using g_free()
.
type |
enum type to parse, eg. |
|
str |
string to parse. May be |
[allow-none] |
value |
integer to store the result in, or |
[out][allow-none] |
warn |
if |
|
possible_values |
place to store list of possible values on failure, or |
[out][allow-none] |
Since 1.16
gboolean pango_parse_style (const char *str
,PangoStyle *style
,gboolean warn
);
Parses a font style. The allowed values are "normal", "italic" and "oblique", case variations being ignored.
str |
a string to parse. |
|
style |
a PangoStyle to store the result in. |
[out caller-allocates] |
warn |
if |
gboolean pango_parse_variant (const char *str
,PangoVariant *variant
,gboolean warn
);
Parses a font variant. The allowed values are "normal" and "smallcaps" or "small_caps", case variations being ignored.
str |
a string to parse. |
|
variant |
a PangoVariant to store the result in. |
[out caller-allocates] |
warn |
if |
gboolean pango_parse_weight (const char *str
,PangoWeight *weight
,gboolean warn
);
Parses a font weight. The allowed values are "heavy", "ultrabold", "bold", "normal", "light", "ultraleight" and integers. Case variations are ignored.
str |
a string to parse. |
|
weight |
a PangoWeight to store the result in. |
[out caller-allocates] |
warn |
if |
gboolean pango_parse_stretch (const char *str
,PangoStretch *stretch
,gboolean warn
);
Parses a font stretch. The allowed values are "ultra_condensed", "extra_condensed", "condensed", "semi_condensed", "normal", "semi_expanded", "expanded", "extra_expanded" and "ultra_expanded". Case variations are ignored and the '_' characters may be omitted.
str |
a string to parse. |
|
stretch |
a PangoStretch to store the result in. |
[out caller-allocates] |
warn |
if |
const char *
pango_get_sysconf_subdirectory (void
);
On Unix, returns the name of the "pango" subdirectory of SYSCONFDIR (which is set at compile time). On Windows, returns the etc\pango subdirectory of the Pango installation directory (which is deduced at run time from the DLL's location).
const char *
pango_get_lib_subdirectory (void
);
On Unix, returns the name of the "pango" subdirectory of LIBDIR (which is set at compile time). On Windows, returns the lib\pango subdirectory of the Pango installation directory (which is deduced at run time from the DLL's location).
guint8 * pango_log2vis_get_embedding_levels (const gchar *text
,int length
,PangoDirection *pbase_dir
);
This will return the bidirectional embedding levels of the input paragraph as defined by the Unicode Bidirectional Algorithm available at:
http://www.unicode.org/reports/tr9/
If the input base direction is a weak direction, the direction of the characters in the text will determine the final resolved direction.
text |
the text to itemize. |
|
length |
the number of bytes (not characters) to process, or -1
if |
|
pbase_dir |
input base direction, and output resolved direction. |
a newly allocated array of embedding levels, one item per character (not byte), that should be freed using g_free.
Since 1.4
gboolean
pango_is_zero_width (gunichar ch
);
Checks ch
to see if it is a character that should not be
normally rendered on the screen. This includes all Unicode characters
with "ZERO WIDTH" in their name, as well as bidi formatting characters, and
a few other ones. This is totally different from g_unichar_iszerowidth()
and is at best misnamed.
Since 1.10
void pango_quantize_line_geometry (int *thickness
,int *position
);
Quantizes the thickness and position of a line, typically an
underline or strikethrough, to whole device pixels, that is integer
multiples of PANGO_SCALE
. The purpose of this function is to avoid
such lines looking blurry.
Care is taken to make sure thickness
is at least one pixel when this
function returns, but returned position
may become zero as a result
of rounding.
thickness |
pointer to the thickness of a line, in Pango units. |
[inout] |
position |
corresponding position. |
[inout] |
Since 1.12