gfx/harfbuzz/src/hb-blob.h

Fri, 16 Jan 2015 18:13:44 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Fri, 16 Jan 2015 18:13:44 +0100
branch
TOR_BUG_9701
changeset 14
925c144e1f1f
permissions
-rw-r--r--

Integrate suggestion from review to improve consistency with existing code.

     1 /*
     2  * Copyright © 2009  Red Hat, Inc.
     3  *
     4  *  This is part of HarfBuzz, a text shaping library.
     5  *
     6  * Permission is hereby granted, without written agreement and without
     7  * license or royalty fees, to use, copy, modify, and distribute this
     8  * software and its documentation for any purpose, provided that the
     9  * above copyright notice and the following two paragraphs appear in
    10  * all copies of this software.
    11  *
    12  * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
    13  * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
    14  * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
    15  * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
    16  * DAMAGE.
    17  *
    18  * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
    19  * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
    20  * FITNESS FOR A PARTICULAR PURPOSE.  THE SOFTWARE PROVIDED HEREUNDER IS
    21  * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
    22  * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
    23  *
    24  * Red Hat Author(s): Behdad Esfahbod
    25  */
    27 #ifndef HB_H_IN
    28 #error "Include <hb.h> instead."
    29 #endif
    31 #ifndef HB_BLOB_H
    32 #define HB_BLOB_H
    34 #include "hb-common.h"
    36 HB_BEGIN_DECLS
    39 /*
    40  * Note re various memory-modes:
    41  *
    42  * - In no case shall the HarfBuzz client modify memory
    43  *   that is passed to HarfBuzz in a blob.  If there is
    44  *   any such possibility, MODE_DUPLICATE should be used
    45  *   such that HarfBuzz makes a copy immediately,
    46  *
    47  * - Use MODE_READONLY otherse, unless you really really
    48  *   really know what you are doing,
    49  *
    50  * - MODE_WRITABLE is appropriate if you relaly made a
    51  *   copy of data solely for the purpose of passing to
    52  *   HarfBuzz and doing that just once (no reuse!),
    53  *
    54  * - If the font is mmap()ed, it's ok to use
    55  *   READONLY_MAY_MAKE_WRITABLE, however, there were
    56  *   design problems with that mode, so HarfBuzz do not
    57  *   really use it anymore.  If not sure, use MODE_READONLY.
    58  */
    59 typedef enum {
    60   HB_MEMORY_MODE_DUPLICATE,
    61   HB_MEMORY_MODE_READONLY,
    62   HB_MEMORY_MODE_WRITABLE,
    63   HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITABLE
    64 } hb_memory_mode_t;
    66 typedef struct hb_blob_t hb_blob_t;
    68 hb_blob_t *
    69 hb_blob_create (const char        *data,
    70 		unsigned int       length,
    71 		hb_memory_mode_t   mode,
    72 		void              *user_data,
    73 		hb_destroy_func_t  destroy);
    75 /* Always creates with MEMORY_MODE_READONLY.
    76  * Even if the parent blob is writable, we don't
    77  * want the user of the sub-blob to be able to
    78  * modify the parent data as that data may be
    79  * shared among multiple sub-blobs.
    80  */
    81 hb_blob_t *
    82 hb_blob_create_sub_blob (hb_blob_t    *parent,
    83 			 unsigned int  offset,
    84 			 unsigned int  length);
    86 hb_blob_t *
    87 hb_blob_get_empty (void);
    89 hb_blob_t *
    90 hb_blob_reference (hb_blob_t *blob);
    92 void
    93 hb_blob_destroy (hb_blob_t *blob);
    95 hb_bool_t
    96 hb_blob_set_user_data (hb_blob_t          *blob,
    97 		       hb_user_data_key_t *key,
    98 		       void *              data,
    99 		       hb_destroy_func_t   destroy,
   100 		       hb_bool_t           replace);
   103 void *
   104 hb_blob_get_user_data (hb_blob_t          *blob,
   105 		       hb_user_data_key_t *key);
   108 void
   109 hb_blob_make_immutable (hb_blob_t *blob);
   111 hb_bool_t
   112 hb_blob_is_immutable (hb_blob_t *blob);
   115 unsigned int
   116 hb_blob_get_length (hb_blob_t *blob);
   118 const char *
   119 hb_blob_get_data (hb_blob_t *blob, unsigned int *length);
   121 char *
   122 hb_blob_get_data_writable (hb_blob_t *blob, unsigned int *length);
   125 HB_END_DECLS
   127 #endif /* HB_BLOB_H */

mercurial