[pango/pango2: 43/63] Clean up private utils
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [pango/pango2: 43/63] Clean up private utils
- Date: Fri, 10 Jun 2022 03:41:34 +0000 (UTC)
commit 5a0bd3b3a57ad14ce7eae77e93999fc5027458ab
Author: Matthias Clasen <mclasen redhat com>
Date: Tue Jun 7 21:30:00 2022 -0400
Clean up private utils
Drop pango-utils-internal.h.
pango/itemize.c | 1 +
pango/meson.build | 2 +-
pango/pango-bidi-private.h | 32 +++++++++++++++++
pango/{pango-bidi-type.c => pango-bidi.c} | 60 +++++++++++++++----------------
pango/pango-color.c | 2 +-
pango/pango-font-description-private.h | 13 +++++++
pango/pango-font-description.c | 11 +++---
pango/pango-line-breaker.c | 2 +-
pango/pango-markup.c | 2 +-
pango/pango-utils-internal.h | 45 -----------------------
pango/pango-utils.c | 1 -
pango/pango-utils.h | 7 ----
pango/serializer.c | 1 -
tests/test-bidi.c | 4 +++
14 files changed, 88 insertions(+), 95 deletions(-)
---
diff --git a/pango/itemize.c b/pango/itemize.c
index f2510537..7dc00446 100644
--- a/pango/itemize.c
+++ b/pango/itemize.c
@@ -33,6 +33,7 @@
#include "pango-emoji-private.h"
#include "pango-attr-iterator-private.h"
#include "pango-item-private.h"
+#include "pango-bidi-private.h"
#include <hb-ot.h>
diff --git a/pango/meson.build b/pango/meson.build
index 2238d68c..62d0cdd6 100644
--- a/pango/meson.build
+++ b/pango/meson.build
@@ -7,7 +7,7 @@ pango_sources = [
'pango-attr-list.c',
'pango-attr-iterator.c',
'pango-attributes.c',
- 'pango-bidi-type.c',
+ 'pango-bidi.c',
'pango-color.c',
'pango-context.c',
'pango-coverage.c',
diff --git a/pango/pango-bidi-private.h b/pango/pango-bidi-private.h
new file mode 100644
index 00000000..014d9bb8
--- /dev/null
+++ b/pango/pango-bidi-private.h
@@ -0,0 +1,32 @@
+/*
+ * Copyright (C) 2000 Red Hat Software
+ *
+ * SPDX-License-Identifier: LGPL-2.1-or-later
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library 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
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, see <http://www.gnu.org/licenses/>.
+ */
+
+#pragma once
+
+#include <stdio.h>
+#include <glib.h>
+#include <pango/pango-font.h>
+#include <pango/pango-direction.h>
+
+guint8 * pango_log2vis_get_embedding_levels (const char *text,
+ int length,
+ PangoDirection *pbase_dir);
+
+PangoDirection pango_find_base_dir (const char *text,
+ int length);
diff --git a/pango/pango-bidi-type.c b/pango/pango-bidi.c
similarity index 81%
rename from pango/pango-bidi-type.c
rename to pango/pango-bidi.c
index 3862c7ca..84137794 100644
--- a/pango/pango-bidi-type.c
+++ b/pango/pango-bidi.c
@@ -10,7 +10,7 @@
*
* This library 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
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
@@ -25,12 +25,12 @@
#include <fribidi.h>
+#include "pango-bidi-private.h"
#include "pango-utils.h"
-#include "pango-utils-internal.h"
/* Some bidi-related functions */
-/**
+/*< private >
* pango_log2vis_get_embedding_levels:
* @text: the text to itemize.
* @length: the number of bytes (not characters) to process, or -1
@@ -49,13 +49,13 @@
* character (not byte), that should be freed using [func GLib free].
*/
guint8 *
-pango_log2vis_get_embedding_levels (const gchar *text,
- int length,
- PangoDirection *pbase_dir)
+pango_log2vis_get_embedding_levels (const char *text,
+ int length,
+ PangoDirection *pbase_dir)
{
glong n_chars, i;
guint8 *embedding_levels_list;
- const gchar *p;
+ const char *p;
FriBidiParType fribidi_base_dir;
FriBidiCharType *bidi_types;
FriBidiBracketType *bracket_types;
@@ -128,17 +128,17 @@ pango_log2vis_get_embedding_levels (const gchar *text,
* o there are letters, and base_dir is weak.
*/
if (!FRIBIDI_IS_ISOLATE (ored_types) &&
- !FRIBIDI_IS_RTL (ored_types) &&
- !FRIBIDI_IS_ARABIC (ored_types) &&
- (!FRIBIDI_IS_RTL (fribidi_base_dir) ||
- (FRIBIDI_IS_WEAK (fribidi_base_dir) &&
- FRIBIDI_IS_LETTER (ored_types))
- ))
+ !FRIBIDI_IS_RTL (ored_types) &&
+ !FRIBIDI_IS_ARABIC (ored_types) &&
+ (!FRIBIDI_IS_RTL (fribidi_base_dir) ||
+ (FRIBIDI_IS_WEAK (fribidi_base_dir) &&
+ FRIBIDI_IS_LETTER (ored_types))
+ ))
{
/* all LTR */
- fribidi_base_dir = FRIBIDI_PAR_LTR;
- memset (embedding_levels_list, 0, n_chars);
- goto resolved;
+ fribidi_base_dir = FRIBIDI_PAR_LTR;
+ memset (embedding_levels_list, 0, n_chars);
+ goto resolved;
}
/* The case that all resolved levels will be RTL is much more complex.
* No isolates, no numbers, all strongs are RTL, and one of
@@ -148,23 +148,23 @@ pango_log2vis_get_embedding_levels (const gchar *text,
* o there are letters, and base_dir is weak.
*/
else if (!FRIBIDI_IS_ISOLATE (ored_types) &&
- !FRIBIDI_IS_NUMBER (ored_types) &&
- FRIBIDI_IS_RTL (anded_strongs) &&
- (FRIBIDI_IS_RTL (fribidi_base_dir) ||
- (FRIBIDI_IS_WEAK (fribidi_base_dir) &&
- FRIBIDI_IS_LETTER (ored_types))
- ))
+ !FRIBIDI_IS_NUMBER (ored_types) &&
+ FRIBIDI_IS_RTL (anded_strongs) &&
+ (FRIBIDI_IS_RTL (fribidi_base_dir) ||
+ (FRIBIDI_IS_WEAK (fribidi_base_dir) &&
+ FRIBIDI_IS_LETTER (ored_types))
+ ))
{
/* all RTL */
- fribidi_base_dir = FRIBIDI_PAR_RTL;
- memset (embedding_levels_list, 1, n_chars);
- goto resolved;
+ fribidi_base_dir = FRIBIDI_PAR_RTL;
+ memset (embedding_levels_list, 1, n_chars);
+ goto resolved;
}
max_level = fribidi_get_par_embedding_levels_ex (bidi_types, bracket_types, n_chars,
- &fribidi_base_dir,
- (FriBidiLevel*)embedding_levels_list);
+ &fribidi_base_dir,
+ (FriBidiLevel*)embedding_levels_list);
if (G_UNLIKELY(max_level == 0))
{
@@ -199,11 +199,11 @@ pango_unichar_direction (gunichar ch)
}
PangoDirection
-pango_find_base_dir (const gchar *text,
- gint length)
+pango_find_base_dir (const char *text,
+ int length)
{
PangoDirection dir = PANGO_DIRECTION_NEUTRAL;
- const gchar *p;
+ const char *p;
g_return_val_if_fail (text != NULL || length == 0, PANGO_DIRECTION_NEUTRAL);
diff --git a/pango/pango-color.c b/pango/pango-color.c
index 6d7f70dc..8d67f62c 100644
--- a/pango/pango-color.c
+++ b/pango/pango-color.c
@@ -26,7 +26,7 @@
#include "pango-attributes.h"
#include "pango-impl-utils.h"
-#include "pango-utils-internal.h"
+
G_DEFINE_BOXED_TYPE (PangoColor, pango_color,
pango_color_copy,
diff --git a/pango/pango-font-description-private.h b/pango/pango-font-description-private.h
index 0a276413..353cdd92 100644
--- a/pango/pango-font-description-private.h
+++ b/pango/pango-font-description-private.h
@@ -28,3 +28,16 @@ gboolean pango_font_description_is_similar (const PangoFontDescription *a,
int pango_font_description_compute_distance (const PangoFontDescription *a,
const PangoFontDescription *b);
+gboolean pango_parse_style (const char *str,
+ PangoStyle *style,
+ gboolean warn);
+gboolean pango_parse_variant (const char *str,
+ PangoVariant *variant,
+ gboolean warn);
+gboolean pango_parse_weight (const char *str,
+ PangoWeight *weight,
+ gboolean warn);
+gboolean pango_parse_stretch (const char *str,
+ PangoStretch *stretch,
+ gboolean warn);
+
diff --git a/pango/pango-font-description.c b/pango/pango-font-description.c
index 3aac7d66..485a641a 100644
--- a/pango/pango-font-description.c
+++ b/pango/pango-font-description.c
@@ -23,9 +23,6 @@
#include "pango-font-description-private.h"
-#include "pango-utils-internal.h"
-
-
struct _PangoFontDescription
{
char *family_name;
@@ -1636,7 +1633,7 @@ parse_field (const char *what,
#define FIELD(NAME, MASK) \
parse_field (G_STRINGIFY (NAME), NAME##_map, G_N_ELEMENTS (NAME##_map), str, (int *)(void *)NAME, warn)
-/**
+/*< private >
* pango_parse_style:
* @str: a string to parse.
* @style: (out): a `PangoStyle` to store the result in.
@@ -1658,7 +1655,7 @@ pango_parse_style (const char *str,
return FIELD (style, PANGO_FONT_MASK_STYLE);
}
-/**
+/*< private >
* pango_parse_variant:
* @str: a string to parse.
* @variant: (out): a `PangoVariant` to store the result in.
@@ -1680,7 +1677,7 @@ pango_parse_variant (const char *str,
return FIELD (variant, PANGO_FONT_MASK_VARIANT);
}
-/**
+/*< private >
* pango_parse_weight:
* @str: a string to parse.
* @weight: (out): a `PangoWeight` to store the result in.
@@ -1702,7 +1699,7 @@ pango_parse_weight (const char *str,
return FIELD (weight, PANGO_FONT_MASK_WEIGHT);
}
-/**
+/*< private >
* pango_parse_stretch:
* @str: a string to parse.
* @stretch: (out): a `PangoStretch` to store the result in.
diff --git a/pango/pango-line-breaker.c b/pango/pango-line-breaker.c
index a4674a69..16b1962d 100644
--- a/pango/pango-line-breaker.c
+++ b/pango/pango-line-breaker.c
@@ -9,7 +9,7 @@
#include "pango-attr-list-private.h"
#include "pango-attr-iterator-private.h"
#include "pango-item-private.h"
-#include "pango-utils-internal.h"
+#include "pango-bidi-private.h"
#include <locale.h>
diff --git a/pango/pango-markup.c b/pango/pango-markup.c
index b9dee89e..aea2c3ca 100644
--- a/pango/pango-markup.c
+++ b/pango/pango-markup.c
@@ -30,7 +30,7 @@
#include "pango-font.h"
#include "pango-enum-types.h"
#include "pango-impl-utils.h"
-#include "pango-utils-internal.h"
+#include "pango-font-description-private.h"
/* FIXME */
#define _(x) x
diff --git a/pango/pango-utils.c b/pango/pango-utils.c
index 863414dc..d759d2ac 100644
--- a/pango/pango-utils.c
+++ b/pango/pango-utils.c
@@ -29,7 +29,6 @@
#include "pango-font.h"
#include "pango-features.h"
#include "pango-impl-utils.h"
-#include "pango-utils-internal.h"
#include <glib/gstdio.h>
diff --git a/pango/pango-utils.h b/pango/pango-utils.h
index d93f5c9a..75c082d3 100644
--- a/pango/pango-utils.h
+++ b/pango/pango-utils.h
@@ -25,13 +25,6 @@
G_BEGIN_DECLS
-/* A routine from fribidi that we either wrap or provide ourselves.
- */
-PANGO_AVAILABLE_IN_ALL
-guint8 * pango_log2vis_get_embedding_levels (const gchar *text,
- int length,
- PangoDirection *pbase_dir);
-
/* Unicode characters that are zero-width and should not be rendered
* normally.
*/
diff --git a/pango/serializer.c b/pango/serializer.c
index c5796881..2ad0d422 100644
--- a/pango/serializer.c
+++ b/pango/serializer.c
@@ -26,7 +26,6 @@
#include <pango/pango-enum-types.h>
#include <pango/pango-font-private.h>
#include <pango/pango-line-private.h>
-#include <pango/pango-utils-internal.h>
#include <pango/pango-hbface.h>
#include <pango/pango-attributes.h>
#include <pango/pango-attr-private.h>
diff --git a/tests/test-bidi.c b/tests/test-bidi.c
index 3fa7dd53..6332edf8 100644
--- a/tests/test-bidi.c
+++ b/tests/test-bidi.c
@@ -25,6 +25,7 @@
static PangoContext *context;
+#if 0
static void
test_bidi_embedding_levels (void)
{
@@ -72,6 +73,7 @@ test_bidi_embedding_levels (void)
g_free (levels);
}
}
+#endif
/* Some basic tests for pango_layout_move_cursor inside
* a single PangoLine:
@@ -381,7 +383,9 @@ main (int argc, char *argv[])
g_test_init (&argc, &argv, NULL);
+#if 0
g_test_add_func ("/bidi/embedding-levels", test_bidi_embedding_levels);
+#endif
g_test_add_func ("/bidi/move-cursor-line", test_move_cursor_line);
g_test_add_func ("/bidi/move-cursor-para", test_move_cursor_para);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]