From: Hans Hagen <j.hagen@xs4all.nl>
To: mailing list for ConTeXt users <ntg-context@ntg.nl>,
Gerben Wierda <gerben.wierda@rna.nl>
Subject: Re: lmt_followtext crashes while standard followtext itself works
Date: Mon, 4 May 2020 10:30:43 +0200 [thread overview]
Message-ID: <69ff9b05-f4e9-4fe1-3461-c9855bc63000@xs4all.nl> (raw)
In-Reply-To: <EBC0F989-EED1-4249-B72D-D2C199B6775E@rna.nl>
On 5/3/2020 11:47 PM, Gerben Wierda wrote:
> The following example has been extracted from my automatically generated
> MP code.
>
> \starttext
>
> \startMPpage
>
> string texstring;
> texstring := "{\colored [r=0.00, g=0.00, b=0.00]{\definebodyfont
> [9.0pt][rm][default=Regular at 9.0pt]\switchtobodyfont
> [9.0pt]\setupinterlinespace [9.9pt]\tf E.g. publish/ subscribe}}";
> path parpath;
> parpath :=
> (238,-167.00010681152344)..controls (238,-167.00010681152344) and
> (238,-167.00010681152344)
> ..(238,-167.00010681152344)..controls (238,-166.60010673470143) and
> (238,-166.20010665787942)
> ..(238,-165.80010658105741)..controls (238,-165.40010643392299) and
> (238,-165.00010628678857)
> ..(238,-164.60010613965414)..controls (238,-164.2001060472048) and
> (238,-163.80010595475545)
> ..(238,-163.40010586230611)..controls (238,-155.56353466513065) and
> (231.9683162849897,-149)
> ..(224.2552179837387,-149)..controls (223.85521783436539,-149) and
> (223.45521768499208,-149)
> ..(223.05521753561877,-149)..controls (222.65521740514737,-149) and
> (222.255217274676,-149)
> ..(221.8552171442046,-149)..controls (221.45521705001735,-149) and
> (221.0552169558301,-149)
> ..(220.65521686164286,-149)..controls (220.25521665589685,-149) and
> (219.85521645015083,-149)
> ..(219.45521624440482,-149)..controls (219.05521631807508,-149) and
> (218.65521639174534,-149)
> ..(218.2552164654156,-149)..controls (217.85521724037432,-149) and
> (217.45521801533303,-149)
> ..(217.05521879029175,-149)..controls (216.6552203077878,-149) and
> (216.25522182528385,-149)
> ..(215.85522334277991,-149)..controls (215.45522405083273,-149) and
> (215.05522475888554,-149)
> ..(214.65522546693836,-149)..controls (214.25522550518758,-149) and
> (213.8552255434368,-149)
> ..(213.45522558168602,-149)..controls (213.0552253720042,-149) and
> (212.65522516232238,-149)
> ..(212.25522495264056,-149)..controls (211.8552248680295,-149) and
> (211.45522478341843,-149)
> ..(211.05522469880736,-149)..controls (210.65522456100436,-149) and
> (210.25522442320135,-149)
> ..(209.85522428539835,-149)..controls (209.45522414149036,-149) and
> (209.05522399758237,-149)
> ..(208.65522385367439,-149)..controls (200.95716230583835,-149) and
> (195,-155.63452868682958)
> ..(195,-163.48966401016395)..controls (195,-163.88966411101083) and
> (195,-164.28966421185771)
> ..(195,-164.68966431270459)..controls (195,-165.08966445890775) and
> (195,-165.4896646051109)
> ..(195,-165.88966475131406)..controls (195,-166.25981210471718) and
> (195,-166.62995945812031)
> ..(195,-167.00010681152344);
> picture pic;
> pic := lmt_followtext [
> text = texstring,
> path = parpath,
> spread = false,
> ];
>
>
> \stopMPpage
> \stoptext
>
> lmt_followtext crashes on this code with:
>
> metapost log > ! angle(0,0) is taken as zero.
> metapost log > <for(1)> ...0)]shifted(-wid/2,0)rotated(angle(ad))
> metapost log >
> shifted.ap;draw.pic[(EXPR0...
> metapost log > <argument> ...caled0.5pt.withcolor.green;fi;endfor
> metapost log >
> ;if((autoscaleupfollowtext...
> metapost log >
> metapost log > image->...ture;currentpicture:=nullpicture;(TEXT3)
> metapost log >
> ;currentpicture.if.str(SUF...
> metapost log >
> metapost log > followtext->...b_n;setbounds.currentpicture.to.b;)
> metapost log > endgroup
> metapost log > <argument> ...parameter"path"),getparameter"text")
> metapost log >
> ;popparameters;
> metapost log > image->...ture;currentpicture:=nullpicture;(TEXT3)
> metapost log >
> ;currentpicture.if.str(SUF...
> metapost log >
> metapost log > lmt_do_followtext->...meter"text");popparameters;)
> metapost log > endgroup
> metapost log > <scantokens> lmt_do_followtext
> metapost log >
> metapost log > <*> ...exstring, path = parpath, spread = false, ]
> metapost log > ; ;
>
>
> When I adapt the parameters that create parpath in my code, other uses
> of lmt_followtext crash. The same combinations of text and path so far
> haven’t crashed basic followtext().
>
> I’ve run into comparable situations in my own code where I had to add
> code to handle the existence of a (0,0) direction (e.g. when I had two
> identical points on a path, but that is not the case here). The above
> minimal example triggers the failure.
we can patch this
if ad <> origin : rotated(angle(ad)) fi
in mp-blob.mpiv but I expect you to test if all still works then
Hans
-----------------------------------------------------------------
Hans Hagen | PRAGMA ADE
Ridderstraat 27 | 8061 GH Hasselt | The Netherlands
tel: 038 477 53 69 | www.pragma-ade.nl | www.pragma-pod.nl
-----------------------------------------------------------------
___________________________________________________________________________________
If your question is of interest to others as well, please add an entry to the Wiki!
maillist : ntg-context@ntg.nl / http://www.ntg.nl/mailman/listinfo/ntg-context
webpage : http://www.pragma-ade.nl / http://context.aanhet.net
archive : https://bitbucket.org/phg/context-mirror/commits/
wiki : http://contextgarden.net
___________________________________________________________________________________
next prev parent reply other threads:[~2020-05-04 8:30 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-05-03 21:47 Gerben Wierda
2020-05-04 8:30 ` Hans Hagen [this message]
2020-05-04 9:20 ` Gerben Wierda
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=69ff9b05-f4e9-4fe1-3461-c9855bc63000@xs4all.nl \
--to=j.hagen@xs4all.nl \
--cc=gerben.wierda@rna.nl \
--cc=ntg-context@ntg.nl \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).