<html>
<head>
<base href="https://bugs.freedesktop.org/">
</head>
<body>
<p>
<div>
<b><a class="bz_bug_link
bz_status_NEW "
title="NEW - Enumerate PDF named destinations"
href="https://bugs.freedesktop.org/show_bug.cgi?id=97262#c48">Comment # 48</a>
on <a class="bz_bug_link
bz_status_NEW "
title="NEW - Enumerate PDF named destinations"
href="https://bugs.freedesktop.org/show_bug.cgi?id=97262">bug 97262</a>
from <span class="vcard"><a class="email" href="mailto:carlosgc@gnome.org" title="Carlos Garcia Campos <carlosgc@gnome.org>"> <span class="fn">Carlos Garcia Campos</span></a>
</span></b>
<pre>(In reply to Adrian Johnson from <a href="show_bug.cgi?id=97262#c35">comment #35</a>)
<span class="quote">> (In reply to Masamichi Hosoda from <a href="show_bug.cgi?id=97262#c31">comment #31</a>)
> > > Internally, the functions should combine the Name Tree dests and dict dests
> > > into one list.
> >
> > Name Tree is recorded in Catalog::destNameTree.
> > It has GooString for its name.
> > So getDestName() can return the pointer of GooString.
> > The return value should not be deleted.
> >
> > Dests Dict is recoded in Catalog::dests.
> > However, it does not have GooString for its name.
> > It has only char* for its name.
> > So getDestName() have to construct GooString from char*.
> > The return value should be deleted.
>
> Ok leave it as two separate sets of functions.
>
> In the longer term I would like to read all the names into a map or hash.
> The current implementation that reads the nameTree (which should already be
> sorted except for when it isn't) then runs qsort on it is not ideal. But
> that can be the topic of another bug.
>
> > > 1) A list of just the names. The user can use poppler_document_find_dest()
> > > to get the dests.
> >
> > Is is something like
> > GList *poppler_document_build_dests_namelist()
> > ?
> > It returns the pointer of GList which contains GBytes for destination name.
> > If you would like it, I'll create a patch.
> >
> > However, unfortunately, if the name contains \0,
> > poppler_document_find_dest() cannot find it.
>
> If you escape the \0 as per <a href="show_bug.cgi?id=97262#c33">comment 33</a> it should work.
>
> >
> > > or
> > > 2) A binary tree of names and dests. This has the advantage that iterating
> > > the names is in alphabetical order instead of the the random order of the
> > > hash table.
> >
> > I'd like this.
>
> Carlos, do you have an opinion on whether to return a GList of names or
> binary tree of names/LinkDests?</span >
I guess we could return a GTree, but I'm not sure I understand exactly what we
want. Do we need the list to be in a specific order? Do they have an order in
the PDF document that we should respect or alphabetical is what want?
<span class="quote">> > Almost UTF-16 strings contains \0.
>
> Isn't the glib API UTF-8 based?</span >
Yes, which means that strings passed to public api methods are expected to be
UTF-8 and string returned by public api methods should also be UTF-8.</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are the assignee for the bug.</li>
</ul>
</body>
</html>