Coverage Report

Created: 2025-07-01 07:07

/src/harfbuzz/src/graph/split-helpers.hh
Line
Count
Source (jump to first uncovered line)
1
/*
2
 * Copyright © 2022  Google, 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
 * Google Author(s): Garret Rieger
25
 */
26
27
#ifndef GRAPH_SPLIT_HELPERS_HH
28
#define GRAPH_SPLIT_HELPERS_HH
29
30
namespace graph {
31
32
template<typename Context>
33
HB_INTERNAL
34
hb_vector_t<unsigned> actuate_subtable_split (Context& split_context,
35
                                              const hb_vector_t<unsigned>& split_points)
36
4.98k
{
37
4.98k
  hb_vector_t<unsigned> new_objects;
38
4.98k
  if (!split_points)
39
3.04k
    return new_objects;
40
41
11.9k
  for (unsigned i = 0; i < split_points.length; i++)
42
10.0k
  {
43
10.0k
    unsigned start = split_points[i];
44
10.0k
    unsigned end = (i < split_points.length - 1)
45
10.0k
                   ? split_points[i + 1]
46
10.0k
                   : split_context.original_count ();
47
10.0k
    unsigned id = split_context.clone_range (start, end);
48
49
10.0k
    if (id == (unsigned) -1)
50
0
    {
51
0
      new_objects.reset ();
52
0
      new_objects.allocated = -1; // mark error
53
0
      return new_objects;
54
0
    }
55
10.0k
    new_objects.push (id);
56
10.0k
  }
57
58
1.94k
  if (!split_context.shrink (split_points[0]))
59
0
  {
60
0
    new_objects.reset ();
61
0
    new_objects.allocated = -1; // mark error
62
0
  }
63
64
1.94k
  return new_objects;
65
1.94k
}
hb_vector_t<unsigned int, false> graph::actuate_subtable_split<graph::PairPosFormat1::split_context_t>(graph::PairPosFormat1::split_context_t&, hb_vector_t<unsigned int, false> const&)
Line
Count
Source
36
4.92k
{
37
4.92k
  hb_vector_t<unsigned> new_objects;
38
4.92k
  if (!split_points)
39
2.98k
    return new_objects;
40
41
11.9k
  for (unsigned i = 0; i < split_points.length; i++)
42
10.0k
  {
43
10.0k
    unsigned start = split_points[i];
44
10.0k
    unsigned end = (i < split_points.length - 1)
45
10.0k
                   ? split_points[i + 1]
46
10.0k
                   : split_context.original_count ();
47
10.0k
    unsigned id = split_context.clone_range (start, end);
48
49
10.0k
    if (id == (unsigned) -1)
50
0
    {
51
0
      new_objects.reset ();
52
0
      new_objects.allocated = -1; // mark error
53
0
      return new_objects;
54
0
    }
55
10.0k
    new_objects.push (id);
56
10.0k
  }
57
58
1.94k
  if (!split_context.shrink (split_points[0]))
59
0
  {
60
0
    new_objects.reset ();
61
0
    new_objects.allocated = -1; // mark error
62
0
  }
63
64
1.94k
  return new_objects;
65
1.94k
}
hb_vector_t<unsigned int, false> graph::actuate_subtable_split<graph::PairPosFormat2::split_context_t>(graph::PairPosFormat2::split_context_t&, hb_vector_t<unsigned int, false> const&)
Line
Count
Source
36
57
{
37
57
  hb_vector_t<unsigned> new_objects;
38
57
  if (!split_points)
39
57
    return new_objects;
40
41
0
  for (unsigned i = 0; i < split_points.length; i++)
42
0
  {
43
0
    unsigned start = split_points[i];
44
0
    unsigned end = (i < split_points.length - 1)
45
0
                   ? split_points[i + 1]
46
0
                   : split_context.original_count ();
47
0
    unsigned id = split_context.clone_range (start, end);
48
49
0
    if (id == (unsigned) -1)
50
0
    {
51
0
      new_objects.reset ();
52
0
      new_objects.allocated = -1; // mark error
53
0
      return new_objects;
54
0
    }
55
0
    new_objects.push (id);
56
0
  }
57
58
0
  if (!split_context.shrink (split_points[0]))
59
0
  {
60
0
    new_objects.reset ();
61
0
    new_objects.allocated = -1; // mark error
62
0
  }
63
64
0
  return new_objects;
65
0
}
Unexecuted instantiation: hb_vector_t<unsigned int, false> graph::actuate_subtable_split<graph::MarkBasePosFormat1::split_context_t>(graph::MarkBasePosFormat1::split_context_t&, hb_vector_t<unsigned int, false> const&)
66
67
}
68
69
#endif  // GRAPH_SPLIT_HELPERS_HH