[pango/break-tailoring: 15/19] break: Cosmetics




commit 0be23a795b1ef62e5e7c55a61de8cf37021f39b6
Author: Matthias Clasen <mclasen redhat com>
Date:   Sat Aug 21 23:54:03 2021 -0400

    break: Cosmetics
    
    Rearrange the code in break_attr() slightly,
    to prepare for handling more attributes.

 pango/break.c | 84 ++++++++++++++++++++++++++++++++---------------------------
 1 file changed, 45 insertions(+), 39 deletions(-)
---
diff --git a/pango/break.c b/pango/break.c
index c55d5f22..826271db 100644
--- a/pango/break.c
+++ b/pango/break.c
@@ -1632,58 +1632,64 @@ break_attrs (const char   *text,
              PangoLogAttr *log_attrs,
              int           log_attrs_len)
 {
-  PangoAttrList list;
-  PangoAttrIterator iter;
+  PangoAttrList allow_breaks;
   GSList *l;
+  gboolean tailored = FALSE;
+
+  _pango_attr_list_init (&allow_breaks);
 
-  _pango_attr_list_init (&list);
   for (l = attributes; l; l = l->next)
     {
       PangoAttribute *attr = l->data;
 
       if (attr->klass->type == PANGO_ATTR_ALLOW_BREAKS)
-        pango_attr_list_insert (&list, pango_attribute_copy (attr));
+        pango_attr_list_insert (&allow_breaks, pango_attribute_copy (attr));
     }
 
-  if (!_pango_attr_list_has_attributes (&list))
+  if (_pango_attr_list_has_attributes (&allow_breaks))
     {
-      _pango_attr_list_destroy (&list);
-      return FALSE;
-    }
+      PangoAttrIterator iter;
 
-  _pango_attr_list_get_iterator (&list, &iter);
-  do {
-    const PangoAttribute *attr = pango_attr_iterator_get (&iter, PANGO_ATTR_ALLOW_BREAKS);
+      _pango_attr_list_get_iterator (&allow_breaks, &iter);
+      do
+        {
+          const PangoAttribute *attr = pango_attr_iterator_get (&iter, PANGO_ATTR_ALLOW_BREAKS);
+
+          if (attr && ((PangoAttrInt*)attr)->value == 0)
+            {
+              int start, end;
+              int start_pos, end_pos;
+              int pos;
+
+              start = attr->start_index;
+              end = attr->end_index;
+              if (start < offset)
+                start_pos = 0;
+              else
+                start_pos = g_utf8_pointer_to_offset (text, text + start - offset);
+              if (end >= offset + length)
+                end_pos = log_attrs_len;
+              else
+                end_pos = g_utf8_pointer_to_offset (text, text + end - offset);
+
+              for (pos = start_pos + 1; pos < end_pos; pos++)
+                {
+                  log_attrs[pos].is_mandatory_break = FALSE;
+                  log_attrs[pos].is_line_break = FALSE;
+                  log_attrs[pos].is_char_break = FALSE;
+
+                  tailored = TRUE;
+                }
+            }
+        }
+      while (pango_attr_iterator_next (&iter));
 
-    if (attr && ((PangoAttrInt*)attr)->value == 0)
-      {
-        int start, end;
-        int start_pos, end_pos;
-        int pos;
-
-        pango_attr_iterator_range (&iter, &start, &end);
-        if (start < offset)
-          start_pos = 0;
-        else
-          start_pos = g_utf8_pointer_to_offset (text, text + start - offset);
-        if (end >= offset + length)
-          end_pos = log_attrs_len;
-        else
-          end_pos = g_utf8_pointer_to_offset (text, text + end - offset);
-
-        for (pos = start_pos + 1; pos < end_pos; pos++)
-          {
-            log_attrs[pos].is_mandatory_break = FALSE;
-            log_attrs[pos].is_line_break = FALSE;
-            log_attrs[pos].is_char_break = FALSE;
-          }
-      }
-  } while (pango_attr_iterator_next (&iter));
+      _pango_attr_iterator_destroy (&iter);
+    }
 
-  _pango_attr_iterator_destroy (&iter);
-  _pango_attr_list_destroy (&list);
+  _pango_attr_list_destroy (&allow_breaks);
 
-  return TRUE;
+  return tailored;
 }
 
 /* }}} */
@@ -1927,6 +1933,6 @@ pango_get_log_attrs (const char    *text,
                attrs_len);
 }
 
- /* }}} */
+/* }}} */
 
 /* vim:set foldmethod=marker expandtab: */


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]