Summary: | Attribute::getName() returns wrong value for /N when UTF-16BE is used | ||
---|---|---|---|
Product: | poppler | Reporter: | luigi.scarso |
Component: | general | Assignee: | poppler-bugs <poppler-bugs> |
Status: | RESOLVED FIXED | QA Contact: | |
Severity: | normal | ||
Priority: | medium | ||
Version: | unspecified | ||
Hardware: | All | ||
OS: | All | ||
Whiteboard: | |||
i915 platform: | i915 features: | ||
Attachments: | A pdf where the vlaue of /N is encoded as utf-16be |
Description
luigi.scarso
2014-10-06 17:26:29 UTC
There is no compatibility in internal poppler classes. I think the class should work on GooString. Can you please work on such a patch? This seems to be ok --- StructElement.h.orig 2014-10-06 21:05:53.439147479 +0200 +++ StructElement.h 2014-10-07 07:51:25.412753215 +0200 @@ -76,6 +76,9 @@ // Creates an UserProperty attribute, with an arbitrary name and value. Attribute(const char *name, Object *value); + // Creates an UserProperty attribute, with an arbitrary name of length len and value. + Attribute(const char *name, Object *value, int len); + GBool isOk() const { return type != Unknown; } // Name, type and value can be set only on construction. @@ -86,7 +89,7 @@ Object *getValue() const { return &value; } static Object *getDefaultValue(Type type); - const char *getName() const { return type == UserProperty ? name.getCString() : getTypeName(); } + GooString *getName() const { return type == UserProperty ? name.copy() : new GooString(getTypeName()); } // The revision is optional, and defaults to zero. Guint getRevision() const { return revision; } --- StructElement.cc.orig 2014-10-06 21:05:47.551147234 +0200 +++ StructElement.cc 2014-10-06 09:13:31.000000000 +0200 @@ -690,6 +690,23 @@ valueA->copy(&value); } +Attribute::Attribute(const char *nameA, Object *valueA, int lenA): + type(UserProperty), + owner(UserProperties), + revision(0), + name(nameA,lenA), + value(), + hidden(gFalse), + formatted(NULL) +{ + assert(valueA); + valueA->copy(&value); +} + + + + + Attribute::Attribute(Type type, Object *valueA): type(type), owner(UserProperties), // TODO: Determine corresponding owner from Type @@ -785,13 +802,17 @@ return entry ? entry->type : Unknown; } + Attribute *Attribute::parseUserProperty(Dict *property) { Object obj, value; const char *name = NULL; + int len = 0 ; - if (property->lookup("N", &obj)->isString()) + if (property->lookup("N", &obj)->isString()){ name = obj.getString()->getCString(); + len = obj.getString()->getLength(); + } else if (obj.isName()) name = obj.getName(); else { @@ -807,7 +828,7 @@ return NULL; } - Attribute *attribute = new Attribute(name, &value); + Attribute *attribute = new Attribute(name, &value,len) ; value.free(); obj.free(); Can you attach a pdf where this is needed? Created attachment 107516 [details]
A pdf where the vlaue of /N is encoded as utf-16be
So are you using getName somewhere? because as far as i can see nothing in poppler is. I've commited a patch inspired by yours but that fixes a few things. |
Use of freedesktop.org services, including Bugzilla, is subject to our Code of Conduct. How we collect and use information is described in our Privacy Policy.