|  |  |  | Pango Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | ||||
enum PangoCoverageLevel; #define PANGO_TYPE_COVERAGE_LEVEL PangoCoverage; PangoCoverage * pango_coverage_new (void); PangoCoverage * pango_coverage_ref (PangoCoverage *coverage); void pango_coverage_unref (PangoCoverage *coverage); PangoCoverage * pango_coverage_copy (PangoCoverage *coverage); PangoCoverageLevel pango_coverage_get (PangoCoverage *coverage,int index_); void pango_coverage_max (PangoCoverage *coverage,PangoCoverage *other); void pango_coverage_set (PangoCoverage *coverage,int index_,PangoCoverageLevel level); void pango_coverage_to_bytes (PangoCoverage *coverage,guchar **bytes,int *n_bytes); PangoCoverage * pango_coverage_from_bytes (guchar *bytes,int n_bytes);
It is often necessary in Pango to determine if a particular font can represent a particular character, and also how well it can represent that character. The PangoCoverage is a data structure that is used to represent that information.
typedef enum {
  PANGO_COVERAGE_NONE,
  PANGO_COVERAGE_FALLBACK,
  PANGO_COVERAGE_APPROXIMATE,
  PANGO_COVERAGE_EXACT
} PangoCoverageLevel;
Used to indicate how well a font can represent a particular Unicode character point for a particular script.
| The character is not representable with the font. | |
| The character is represented in a way that may be comprehensible but is not the correct graphical form. For instance, a Hangul character represented as a a sequence of Jamos, or a Latin transliteration of a Cyrillic word. | |
| The character is represented as basically the correct graphical form, but with a stylistic variant inappropriate for the current script. | |
| The character is represented as the correct graphical form. | 
#define PANGO_TYPE_COVERAGE_LEVEL (pango_coverage_level_get_type ())
The GObject type for PangoCoverageLevel.
typedef struct _PangoCoverage PangoCoverage;
The PangoCoverage structure represents a map from Unicode characters to PangoCoverageLevel. It is an opaque structure with no public fields.
PangoCoverage *     pango_coverage_new                  (void);
Create a new PangoCoverage
| Returns : | the newly allocated PangoCoverage,
initialized to PANGO_COVERAGE_NONEwith a reference count of one, which
should be freed withpango_coverage_unref(). | 
PangoCoverage *     pango_coverage_ref                  (PangoCoverage *coverage);
Increase the reference count on the PangoCoverage by one
| 
 | a PangoCoverage | 
| Returns : | coverage | 
void                pango_coverage_unref                (PangoCoverage *coverage);
Decrease the reference count on the PangoCoverage by one. If the result is zero, free the coverage and all associated memory.
| 
 | a PangoCoverage | 
PangoCoverage *     pango_coverage_copy                 (PangoCoverage *coverage);
Copy an existing PangoCoverage. (This function may now be unnecessary since we refcount the structure. File a bug if you use it.)
| 
 | a PangoCoverage | 
| Returns : | the newly allocated PangoCoverage,
with a reference count of one, which should be freed
with pango_coverage_unref(). [transfer full] | 
PangoCoverageLevel pango_coverage_get (PangoCoverage *coverage,int index_);
Determine whether a particular index is covered by coverage
| 
 | a PangoCoverage | 
| 
 | the index to check | 
| Returns : | the coverage level of coveragefor characterindex_. | 
void pango_coverage_max (PangoCoverage *coverage,PangoCoverage *other);
Set the coverage for each index in coverage to be the max (better)
value of the current coverage for the index and the coverage for
the corresponding index in other.
| 
 | a PangoCoverage | 
| 
 | another PangoCoverage | 
void pango_coverage_set (PangoCoverage *coverage,int index_,PangoCoverageLevel level);
Modify a particular index within coverage
| 
 | a PangoCoverage | 
| 
 | the index to modify | 
| 
 | the new level for index_ | 
void pango_coverage_to_bytes (PangoCoverage *coverage,guchar **bytes,int *n_bytes);
Convert a PangoCoverage structure into a flat binary format
| 
 | a PangoCoverage | 
| 
 | location to store result (must be freed with g_free()). [out][array length=n_bytes][element-type guint8] | 
| 
 | location to store size of result. [out] | 
PangoCoverage * pango_coverage_from_bytes (guchar *bytes,int n_bytes);
Convert data generated from pango_converage_to_bytes() back
to a PangoCoverage
| 
 | binary data representing a PangoCoverage. [array length=n_bytes][element-type guint8] | 
| 
 | the size of bytesin bytes | 
| Returns : | a newly allocated PangoCoverage, or NULLif the data was invalid. [transfer full] |