LATEX-L Archives

Mailing list for the LaTeX3 project

LATEX-L@LISTSERV.UNI-HEIDELBERG.DE

Options: Use Classic View

Use Monospaced Font
Show Text Part by Default
Show All Mail Headers

Topic: [<< First] [< Prev] [Next >] [Last >>]

Print Reply
Joseph Wright <[log in to unmask]>
Sat, 26 Jan 2019 12:23:39 +0000
text/plain (74 lines)
On 24/01/2019 22:12, Andrew Parsloe wrote:
> Reading through the l3draw documentation various matters came to mind:

Thanks for taking the time on this: to date there's not been a lot of 
detailed feedback.

> Section 1.9 of l3draw.pdf
> Typos
> Text: \draw_transform_matrix:nnnnn
>        has a fifth "n"
> Margin: \draw_transform_xscale:n
>        the second occurrence should be \draw_transform_yscale:n and not 
> greyed out.
> Text: \draw_transform_shift:n
>        \draw_transform_xshift:n
>       delete \draw_transform_shift:n
> Margin: \draw_transform_matrix_reset
>        needs a concluding colon

All corrected for the next release.

> Clarification
> Perhaps there should be a mention under 
> \draw_transform_matrix_concat:nnnn that concatenating means matrix 
> multiplication from the left.

Perhaps, though the point below I suspect suggests a rename may be better.

> Naming
> There is \draw_transform_matrix_concat:nnnn and 
> \draw_transform_shift_concat:n. The rotate, scale, shift and slant 
> transforms are also concatenations but not so named (lack the _concat). 
> I wonder if a better naming scheme might be to drop the _concat from 
> \draw_transform_matrix_concat:nnnn and \draw_transform_shift_concat:n, 
> thus treating all the concatenating transforms similarly, and rename the 
> functions currently called \draw_transform_matrix:nnnn and 
> \draw_transform_shift:n to something else, perhaps 
> \draw_transform_matrix_set:nnnn and \draw_transform_shift_set:n?

The basic idea here was to try to split up the relative and absolute 
transformation changes. As you say, shifts and the like are relative to 
the previous transformation. The "matrix_concat" one is the relative 
case, the "matrix" alone is a replacement of the entire matrix. So 
perhaps better is to drop "concat" and have something like

     \draw_transform_replace:nnnn

     \draw_transform_absolute_matrix:nnnn

or as you say "set". The latter is a bit tricky: in general in expl3, 
"set" is used for variables where we can \<thing>_set:Nn... them. That's 
not 100% the case, but I've avoided "set" in other places in l3draw. 
(Still I think needs discussion for things like line width, etc.)

> Comma lists?
> Was consideration given to using a comma list instead of four separate 
> braced arguments for \draw_transform_matrix:nnnn? {a}{b}{c}{d} needs 
> four brace pairs, {a,b,c,d} needs only one. I have a standard US 
> keyboard (at least I think it is). The { and } characters require the 
> shift key and a (small) stretch of the little finger to type; commas on 
> the other hand are easy, no stretch, no shift key. Comma lists are 
> widely used elsewhere in l3draw for specifying coordinate pairs, e.g. 
> \draw_path_moveto:n { 1cm , 0cm }. Even {a,b}{c,d} would be better -- 
> and helpful in separating the rows of the matrix.

As the docs say, the API I've gone for is the same as pgf's if possible: 
that's well-established and works for people. For co-ordinates, it's 
very common to write them as "(x,y)" with a comma: I did consider at the 
code level requiring two arguments! However, for matrices, it's more 
common to write them as space-separated lists if written linear, at 
least in my experience. Moreover, this is a pretty low-level operation.

Joseph

ATOM RSS1 RSS2