[repacker] optimize AnchorMatrix::clone.
Previous runtime is O(n^2) reduced to O(n).
This commit is contained in:
parent
29e3b2467e
commit
6f5c52b604
|
@ -91,26 +91,31 @@ struct AnchorMatrix : public OT::Layout::GPOS_impl::AnchorMatrix
|
||||||
AnchorMatrix* prime = (AnchorMatrix*) c.graph.object (prime_id).head;
|
AnchorMatrix* prime = (AnchorMatrix*) c.graph.object (prime_id).head;
|
||||||
prime->rows = base_count;
|
prime->rows = base_count;
|
||||||
|
|
||||||
for (unsigned base = 0; base < base_count; base++)
|
auto& o = c.graph.vertices_[this_index].obj;
|
||||||
|
int num_links = o.real_links.length;
|
||||||
|
for (int i = 0; i < num_links; i++)
|
||||||
{
|
{
|
||||||
for (unsigned klass = start; klass < end; klass++)
|
const auto& link = o.real_links[i];
|
||||||
{
|
unsigned old_index = (link.position - 2) / OT::Offset16::static_size;
|
||||||
unsigned new_klass = klass - start;
|
unsigned klass = old_index % class_count;
|
||||||
|
if (klass < start || klass >= end) continue;
|
||||||
|
|
||||||
unsigned old_index = base * class_count + klass;
|
unsigned base = old_index / class_count;
|
||||||
unsigned new_index = base * new_class_count + new_klass;
|
unsigned new_klass = klass - start;
|
||||||
|
unsigned new_index = base * new_class_count + new_klass;
|
||||||
|
|
||||||
unsigned offset_pos = (char*) &(this->matrixZ[old_index]) -
|
|
||||||
(char*) this;
|
unsigned child_idx = link.objidx;
|
||||||
unsigned* objidx;
|
c.graph.add_link (&(prime->matrixZ[new_index]),
|
||||||
if (pos_to_index.has (offset_pos, &objidx))
|
prime_id,
|
||||||
// TODO(garretrieger): move_child is O(n) (n is number of children), can use the pos_to_index
|
child_idx);
|
||||||
// map to speed it up.
|
|
||||||
c.graph.move_child (this_index,
|
auto& child = c.graph.vertices_[child_idx];
|
||||||
&(this->matrixZ[old_index]),
|
child.remove_parent (this_index);
|
||||||
prime_id,
|
|
||||||
&(prime->matrixZ[new_index]));
|
o.real_links.remove (i);
|
||||||
}
|
num_links--;
|
||||||
|
i--;
|
||||||
}
|
}
|
||||||
|
|
||||||
return prime_id;
|
return prime_id;
|
||||||
|
|
Loading…
Reference in New Issue