-
Notifications
You must be signed in to change notification settings - Fork 4
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add schema for existing typst dictionaries #45
Comments
Rethinking this, I think it would probably be a lot easier to instead have Typst type argument validators instead. E.g., to validate the args to a Box vs a Block. That would be a fair amount of work though. I would be interested in your opinion of both of these. Perhaps later in the year when I am off university, I can make a pull request with this second idea, should you not have the time or interest. Let me know and I can make a new feature request. |
When trying to answer this, I ran into a few issues with the built-in schemas, mainly that I want to preface this with, if you pass this down to With that said, here's how you can write it today: #import "@preview/valkyrie:0.2.1" as z
#let func(inset: (:)) = {
// see the above mentioned issue, the same applies for `z.either(optional: true, ...)` when one of the inner schemas doesn't allow `none`
let segment = z.base-type.with(
default: none,
optional: true,
name: "relative",
types: (relative, length, ratio, type(none)),
)
let schema = z.dictionary(
// if it's a single value turn it into a dictionary
pre-transform: (ctx, it) => if type(it) != dictionary { (rest: it) } else { it },
// remove all `none` values they are just sentinels
// could also implement the fallback from `top -> y -> rest` and `left -> x -> rest` here
post-transform: (ctx, it) => it.pairs().fold((:), (acc, (k, v)) => acc + if v != none { ((k): v) }),
(
left: segment(),
right: segment(),
top: segment(),
bottom: segment(),
x: segment(),
y: segment(),
rest: segment(),
)
)
let parsed = z.parse(inset, schema)
block(inset: parsed, stroke: red, height: 50pt, width: 50pt, [content])
}
#func()
#func(inset: 1pt + 10%)
#func(inset: (x: 20pt, rest: 10pt)) One major downside is, that this accepts cc: @Jamesxx |
@tingerrr Thanks for your reply. Your approach is thankfully very similar to my own. My reason for this idea is that I am working on a package that applies a theme to the document. I want to allow the user to provide certain configurations, so that I can extend my package into a more fully-featured template, along with provided defaults that style other elements like tables, code blocks, and so forth. I want to validate to allow for configurations to be explicitly verified sooner, rather than later so that the user can be informed of any errors, rather than needing to chance down any issues that aren't nicely reported (which can happen if they do their own styling on top!).
Yeah, I have experienced this issue when implementing my own validation in the past. Having the ability to not only set a value as optional but also allow it to remain absent would be a very powerful addition to the package. |
Yeah, as noted above, we might need to fundamentally change how valkyrie handles absent values. I personally think we should just leave them absent when declared as Specifically, #import "@preview/valkyrie:0.2.1" as z
#let schema = z.dictionary((
foo: z.stroke(optional: true),
))
#z.parse((:), schema) // returns (foo: none) Here |
That sounds pretty reasonable. It is how I originally interpreted the docs when learning. I feel that things will become much less rigid! |
I don't think it would be a difficult thing to implement but I'm currently focusing on another project that I'll need to typeset my thesis so I won't have time to contribute here - very open to PRs |
Oop, I forgot to reply to this! I would be more than happy to open a PR, but I will have to wait until after my uni semester has ended. I have a few projects I want to work on when I have free time, so my time is a bit limited, too. If this isn't closed before then, I will take a look after the semester, if I am able :) |
I want to write configurations that accept
inset
andoutset
. I am certain there is some docs on what these are, but I cannot seem to find them.I eventually dived into the source to see that what I effectively want is something like
It would be very helpful for template and package developers to have access to basic known dictionaries, where "dictionary" effectively has its own schema known to Typst.
Edit: The main difficulty is that the actual values (the
...
) are generic in the source, and vary in each use case. You could set it toz.Any()
, but that would not be a great idea.The text was updated successfully, but these errors were encountered: