[cl-pdf-devel] Unicode issue
Marc Battyani
marc.battyani at fractalconcept.com
Thu Jan 31 09:24:20 UTC 2008
Hi Andrey,
I'm sorry but are you sure to have the current version?
The fixes were in pdf/pdf-base, not in cl-typesetting and I don't find
the code related to your patch in pdf-base.lisp.
Marc
Andrey Moskvitin wrote:
> Hi Marc
>
> I have the problem with unbalanced parentheses when use cl-pdf library
> (in revision 159).
> This problem is solved in the cl-typesetting library (stroke.lisp):
> (when (find char "\\()" :test #'char=)
> (push #\\ string))
> No, that decision is wrong. The problem is in the cl-pdf library and
> should be resolved there.
>
>
> 2008/1/20, Marc Battyani <marc.battyani at fractalconcept.com
> <mailto:marc.battyani at fractalconcept.com>>:
>
> Andrey Moskvitin wrote:
> > >>/ The example uses a unicode font and simply puts a string
> into the
> > />>/ output document which contains #\Space #\( #\) and a few other
> > />>/ characters. Both parenthesis and space are needed to
> produce the wrong
> >
> > />>/ pdf./
> >
> > > Unfortunately, the unicode integration is still in an alpha
> state as
> > > I've never found the time to continue it :(
> > > I will look at your example to see if I can make a fix for it.
> >
> >
> > I encountered the same problem with unbalanced parentheses in text.
> >
> > Sample code (Gentoo Linux, sbcl-1.0.12):
> >
> > (pdf:load-ttu-font #P"/usr/local/fonts/arial.ufm"
> #P"/usr/local/fonts/arial.ttf")
> >
> >
> > (with-open-file (out #P"/tmp/bad.pdf" :direction :output
> :if-exists :supersede :element-type :default :external-format
> :latin-1)
> > (pdf:with-document ()
> > (pdf:with-page ()
> > (pdf:in-text-mode
> >
> > (pdf:move-text 20 20)
> > (pdf:set-font (pdf:get-font "ArialMT") 12)
> > (pdf::show-text "hello (")))
> > (pdf:write-document out)))
> >
> > The problem in the function of write-cid-string. I change it and
> solved the problem:
> >
> >
> > ---
> /usr/share/common-lisp/source/cl-pdf/pdf-base.lisp 2007-10-10
> 12:50:45.000000000 +0000
> > +++ pdf-base.lisp 2007-12-29 16:38:18.000000000 +0000
> > @@ -25,11 +25,14 @@
> > (write-char #\( *page-stream*)
> >
> > (if (and *font* (typep (font-metrics *font*) 'ttu-font-metrics))
> > (loop for c across string do
> > - (let* ((code (char-code c))
> > - (hi (ldb (byte 8 8) code))
> > - (lo (ldb (byte 8 0) code)))
> >
> > - (write-char (code-char hi) *page-stream*)
> > - (write-char (code-char lo) *page-stream*)))
> > + (let* ((code (char-code c))
> > + (hi (ldb (byte 8 8) code))
> > + (lo (ldb (byte 8 0) code))
> >
> > + (is-bracket (or (eql c #\() (eql c #\)))))
> > + (if is-bracket (write-char #\\ *page-stream*))
> > + (write-char (code-char hi) *page-stream*)
> > + (if is-bracket (write-char #\\ *page-stream*))
> >
> > + (write-char (code-char lo) *page-stream*)))
> > (princ string *page-stream*))
> > (write-string ") " *page-stream*))
> >
> >
> Hi Andrey,
>
> Thanks for this.
> IIRC, I corrected this in revision 152 (october 14). Is this fix a
> complement to that fix or an alternative fix?
>
> Marc
>
>
>
> ------------------------------------------------------------------------
>
> _______________________________________________
> cl-pdf-devel site list
> cl-pdf-devel at common-lisp.net
> http://common-lisp.net/mailman/listinfo/cl-pdf-devel
More information about the cl-pdf-devel
mailing list