2018-05-30 01:28:48 +02:00
|
|
|
/*
|
|
|
|
* Copyright © 2018 Google, Inc.
|
|
|
|
*
|
|
|
|
* This is part of HarfBuzz, a text shaping library.
|
|
|
|
*
|
|
|
|
* Permission is hereby granted, without written agreement and without
|
|
|
|
* license or royalty fees, to use, copy, modify, and distribute this
|
|
|
|
* software and its documentation for any purpose, provided that the
|
|
|
|
* above copyright notice and the following two paragraphs appear in
|
|
|
|
* all copies of this software.
|
|
|
|
*
|
|
|
|
* IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
|
|
|
|
* DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
|
|
|
|
* ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
|
|
|
|
* IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
|
|
|
|
* DAMAGE.
|
|
|
|
*
|
|
|
|
* THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
|
|
|
|
* BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
|
|
|
|
* ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
|
|
|
|
* PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
|
|
|
|
*
|
|
|
|
* Google Author(s): Behdad Esfahbod
|
|
|
|
*/
|
|
|
|
|
2021-02-10 22:37:43 +01:00
|
|
|
#if !defined(HB_H_IN) && !defined(HB_NO_SINGLE_HEADER_ERROR)
|
2018-05-30 01:28:48 +02:00
|
|
|
#error "Include <hb.h> instead."
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef HB_MAP_H
|
|
|
|
#define HB_MAP_H
|
|
|
|
|
|
|
|
#include "hb-common.h"
|
2023-01-05 19:52:12 +01:00
|
|
|
#include "hb-set.h"
|
2018-05-30 01:28:48 +02:00
|
|
|
|
|
|
|
HB_BEGIN_DECLS
|
|
|
|
|
|
|
|
|
2020-12-30 22:58:37 +01:00
|
|
|
/**
|
|
|
|
* HB_MAP_VALUE_INVALID:
|
|
|
|
*
|
|
|
|
* Unset #hb_map_t value.
|
|
|
|
*
|
2018-06-06 00:17:39 +02:00
|
|
|
* Since: 1.7.7
|
2018-05-30 01:28:48 +02:00
|
|
|
*/
|
|
|
|
#define HB_MAP_VALUE_INVALID ((hb_codepoint_t) -1)
|
|
|
|
|
2019-04-21 21:30:54 +02:00
|
|
|
/**
|
|
|
|
* hb_map_t:
|
|
|
|
*
|
|
|
|
* Data type for holding integer-to-integer hash maps.
|
|
|
|
*
|
|
|
|
**/
|
2018-05-30 01:28:48 +02:00
|
|
|
typedef struct hb_map_t hb_map_t;
|
|
|
|
|
|
|
|
|
|
|
|
HB_EXTERN hb_map_t *
|
|
|
|
hb_map_create (void);
|
|
|
|
|
|
|
|
HB_EXTERN hb_map_t *
|
|
|
|
hb_map_get_empty (void);
|
|
|
|
|
|
|
|
HB_EXTERN hb_map_t *
|
|
|
|
hb_map_reference (hb_map_t *map);
|
|
|
|
|
|
|
|
HB_EXTERN void
|
|
|
|
hb_map_destroy (hb_map_t *map);
|
|
|
|
|
|
|
|
HB_EXTERN hb_bool_t
|
|
|
|
hb_map_set_user_data (hb_map_t *map,
|
|
|
|
hb_user_data_key_t *key,
|
|
|
|
void * data,
|
|
|
|
hb_destroy_func_t destroy,
|
|
|
|
hb_bool_t replace);
|
|
|
|
|
|
|
|
HB_EXTERN void *
|
2022-07-25 18:45:55 +02:00
|
|
|
hb_map_get_user_data (const hb_map_t *map,
|
2018-05-30 01:28:48 +02:00
|
|
|
hb_user_data_key_t *key);
|
|
|
|
|
|
|
|
|
|
|
|
/* Returns false if allocation has failed before */
|
|
|
|
HB_EXTERN hb_bool_t
|
|
|
|
hb_map_allocation_successful (const hb_map_t *map);
|
|
|
|
|
2022-05-25 00:24:00 +02:00
|
|
|
HB_EXTERN hb_map_t *
|
|
|
|
hb_map_copy (const hb_map_t *map);
|
|
|
|
|
2018-05-30 02:09:17 +02:00
|
|
|
HB_EXTERN void
|
|
|
|
hb_map_clear (hb_map_t *map);
|
|
|
|
|
|
|
|
HB_EXTERN hb_bool_t
|
|
|
|
hb_map_is_empty (const hb_map_t *map);
|
|
|
|
|
|
|
|
HB_EXTERN unsigned int
|
|
|
|
hb_map_get_population (const hb_map_t *map);
|
|
|
|
|
2022-05-19 21:36:12 +02:00
|
|
|
HB_EXTERN hb_bool_t
|
|
|
|
hb_map_is_equal (const hb_map_t *map,
|
|
|
|
const hb_map_t *other);
|
|
|
|
|
2022-05-20 21:19:27 +02:00
|
|
|
HB_EXTERN unsigned int
|
|
|
|
hb_map_hash (const hb_map_t *map);
|
|
|
|
|
2018-05-30 01:44:55 +02:00
|
|
|
HB_EXTERN void
|
2018-05-30 01:28:48 +02:00
|
|
|
hb_map_set (hb_map_t *map,
|
|
|
|
hb_codepoint_t key,
|
|
|
|
hb_codepoint_t value);
|
|
|
|
|
|
|
|
HB_EXTERN hb_codepoint_t
|
|
|
|
hb_map_get (const hb_map_t *map,
|
|
|
|
hb_codepoint_t key);
|
|
|
|
|
|
|
|
HB_EXTERN void
|
|
|
|
hb_map_del (hb_map_t *map,
|
|
|
|
hb_codepoint_t key);
|
|
|
|
|
2018-05-30 02:34:35 +02:00
|
|
|
HB_EXTERN hb_bool_t
|
2018-05-30 01:28:48 +02:00
|
|
|
hb_map_has (const hb_map_t *map,
|
|
|
|
hb_codepoint_t key);
|
|
|
|
|
2023-01-04 21:58:46 +01:00
|
|
|
HB_EXTERN void
|
|
|
|
hb_map_update (hb_map_t *map,
|
|
|
|
const hb_map_t *other);
|
|
|
|
|
2023-01-04 20:55:59 +01:00
|
|
|
/* Pass -1 in for idx to get started. */
|
|
|
|
HB_EXTERN hb_bool_t
|
|
|
|
hb_map_next (const hb_map_t *map,
|
|
|
|
int *idx,
|
|
|
|
hb_codepoint_t *key,
|
|
|
|
hb_codepoint_t *value);
|
2018-05-30 01:28:48 +02:00
|
|
|
|
2023-01-05 01:12:08 +01:00
|
|
|
HB_EXTERN void
|
|
|
|
hb_map_keys (const hb_map_t *map,
|
|
|
|
hb_set_t *keys);
|
|
|
|
|
|
|
|
HB_EXTERN void
|
|
|
|
hb_map_values (const hb_map_t *map,
|
|
|
|
hb_set_t *values);
|
|
|
|
|
2018-05-30 01:28:48 +02:00
|
|
|
HB_END_DECLS
|
|
|
|
|
|
|
|
#endif /* HB_MAP_H */
|