Compare commits
10 Commits
fab45bd8ab
...
feat/issue
| Author | SHA1 | Date | |
|---|---|---|---|
|
03b7fa1157
|
|||
|
e01d180445
|
|||
|
57269ae983
|
|||
| 01d930bfd5 | |||
|
f33fe8f932
|
|||
|
7da39889d4
|
|||
|
a46bb8534b
|
|||
|
00d52fe83f
|
|||
|
47e9f42d5f
|
|||
|
a815037f24
|
@@ -14,7 +14,7 @@ jobs:
|
|||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Install tytanic
|
- name: Install tytanic
|
||||||
run: cargo binstall tytanic@0.2.2
|
run: cargo binstall tytanic@0.3.3
|
||||||
|
|
||||||
- name: Run test suite
|
- name: Run test suite
|
||||||
run: tt run
|
run: tt run
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ This package lets you render sequence diagrams directly in Typst. The following
|
|||||||
<td>
|
<td>
|
||||||
|
|
||||||
```typst
|
```typst
|
||||||
#import "@preview/chronos:0.2.2"
|
#import "@preview/chronos:0.3.0"
|
||||||
#chronos.diagram({
|
#chronos.diagram({
|
||||||
import chronos: *
|
import chronos: *
|
||||||
_par("Alice")
|
_par("Alice")
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
#chronos.diagram({
|
#chronos.diagram({
|
||||||
import chronos: *
|
import chronos: *
|
||||||
_seq("User", "A", comment: "DoWork", enable-dst: true)
|
_seq("User", "A", comment: "DoWork", enable-dst: true)
|
||||||
_seq("A", "B", comment: [#sym.quote.angle.l createRequest #sym.quote.angle.r], enable-dst: true)
|
_seq("A", "B", comment: [#sym.quote.chevron.l createRequest #sym.quote.chevron.r], enable-dst: true)
|
||||||
_seq("B", "C", comment: "DoWork", enable-dst: true)
|
_seq("B", "C", comment: "DoWork", enable-dst: true)
|
||||||
_seq("C", "B", comment: "WorkDone", destroy-src: true, disable-src: true, dashed: true)
|
_seq("C", "B", comment: "WorkDone", destroy-src: true, disable-src: true, dashed: true)
|
||||||
_seq("B", "A", comment: "RequestCreated", disable-src: true, dashed: true)
|
_seq("B", "A", comment: "RequestCreated", disable-src: true, dashed: true)
|
||||||
@@ -15,7 +15,7 @@
|
|||||||
import chronos: *
|
import chronos: *
|
||||||
_seq("User", "A", comment: "DoWork", enable-dst: true, lifeline-style: (fill: rgb("#FFBBBB")))
|
_seq("User", "A", comment: "DoWork", enable-dst: true, lifeline-style: (fill: rgb("#FFBBBB")))
|
||||||
_seq("A", "A", comment: "Internal call", enable-dst: true, lifeline-style: (fill: rgb("#E9967A")))
|
_seq("A", "A", comment: "Internal call", enable-dst: true, lifeline-style: (fill: rgb("#E9967A")))
|
||||||
_seq("A", "B", comment: [#sym.quote.angle.l createRequest #sym.quote.angle.r], enable-dst: true)
|
_seq("A", "B", comment: [#sym.quote.chevron.l createRequest #sym.quote.chevron.r], enable-dst: true)
|
||||||
_seq("B", "A", comment: "RequestCreated", disable-src: true, disable-dst: true, dashed: true)
|
_seq("B", "A", comment: "RequestCreated", disable-src: true, disable-dst: true, dashed: true)
|
||||||
_seq("A", "User", comment: "Done", disable-src: true)
|
_seq("A", "User", comment: "Done", disable-src: true)
|
||||||
})
|
})
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 88 KiB After Width: | Height: | Size: 88 KiB |
|
Before Width: | Height: | Size: 22 KiB After Width: | Height: | Size: 22 KiB |
7
justfile
@@ -4,6 +4,13 @@
|
|||||||
gallery_dir := "./gallery"
|
gallery_dir := "./gallery"
|
||||||
set shell := ["bash", "-uc"]
|
set shell := ["bash", "-uc"]
|
||||||
|
|
||||||
|
@version:
|
||||||
|
echo $'\e[1mTypst:\e[0m'
|
||||||
|
typst --version
|
||||||
|
echo
|
||||||
|
echo $'\e[1mTytanic:\e[0m'
|
||||||
|
tt util about
|
||||||
|
|
||||||
manual:
|
manual:
|
||||||
typst c manual.typ manual.pdf
|
typst c manual.typ manual.pdf
|
||||||
|
|
||||||
|
|||||||
7777
manual.pdf
@@ -1 +1 @@
|
|||||||
#import "@preview/cetz:0.4.0": *
|
#import "@preview/cetz:0.4.2": *
|
||||||
21
src/core/draw/hide.typ
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
#import "/src/core/utils.typ": get-ctx, set-ctx
|
||||||
|
|
||||||
|
#let render(sync) = get-ctx(ctx => {
|
||||||
|
set-ctx(c => {
|
||||||
|
c.hidden = true
|
||||||
|
for i in range(c.lifelines.len()) {
|
||||||
|
c.lifelines.at(i).lines.push(("hide",))
|
||||||
|
}
|
||||||
|
return c
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
#let render-end(sync) = get-ctx(ctx => {
|
||||||
|
set-ctx(c => {
|
||||||
|
c.hidden = false
|
||||||
|
for i in range(c.lifelines.len()) {
|
||||||
|
c.lifelines.at(i).lines.push(("unhide",))
|
||||||
|
}
|
||||||
|
return c
|
||||||
|
})
|
||||||
|
})
|
||||||
@@ -320,9 +320,20 @@
|
|||||||
let destructions = ()
|
let destructions = ()
|
||||||
let lines = ()
|
let lines = ()
|
||||||
|
|
||||||
|
let hidden = false
|
||||||
|
|
||||||
// Compute lifeline rectangles + destruction positions
|
// Compute lifeline rectangles + destruction positions
|
||||||
for line in ctx.lifelines.at(p.i).lines {
|
for line in ctx.lifelines.at(p.i).lines {
|
||||||
let event = line.first()
|
let event = line.first()
|
||||||
|
if event == "hide" {
|
||||||
|
hidden = true
|
||||||
|
} else if event == "unhide" {
|
||||||
|
hidden = false
|
||||||
|
}
|
||||||
|
if hidden and event in ("create", "enable") {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
if event == "create" {
|
if event == "create" {
|
||||||
last-y = line.at(1)
|
last-y = line.at(1)
|
||||||
|
|
||||||
|
|||||||
@@ -319,7 +319,8 @@
|
|||||||
level: 0,
|
level: 0,
|
||||||
lines: ()
|
lines: ()
|
||||||
)),
|
)),
|
||||||
in-sync: false
|
in-sync: false,
|
||||||
|
hidden: false,
|
||||||
)
|
)
|
||||||
chronos-ctx.insert(
|
chronos-ctx.insert(
|
||||||
"widths",
|
"widths",
|
||||||
@@ -379,11 +380,15 @@
|
|||||||
(elmt,)
|
(elmt,)
|
||||||
} else if "draw" in elmt and elmt.type != "par" {
|
} else if "draw" in elmt and elmt.type != "par" {
|
||||||
get-ctx(ctx => {
|
get-ctx(ctx => {
|
||||||
if ctx.in-sync and elmt.type != "sync-end" {
|
let drawn = if ctx.in-sync and elmt.type != "sync-end" {
|
||||||
in-sync-render(elmt)
|
in-sync-render(elmt)
|
||||||
} else {
|
} else {
|
||||||
(elmt.draw)(elmt)
|
(elmt.draw)(elmt)
|
||||||
}
|
}
|
||||||
|
if ctx.hidden and elmt.type != "hide-end" {
|
||||||
|
drawn = draw.hide(drawn)
|
||||||
|
}
|
||||||
|
drawn
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,11 +1,17 @@
|
|||||||
#import "draw/group.typ": render-end as grp-render-end
|
#import "draw/group.typ": render-end as grp-render-end
|
||||||
|
#import "draw/hide.typ": render-end as hide-render-end
|
||||||
#import "draw/sync.typ": render-end as sync-render-end
|
#import "draw/sync.typ": render-end as sync-render-end
|
||||||
#import "utils.typ": get-group-span, is-elmt
|
#import "utils.typ": get-group-span, is-elmt, is-touying-pause
|
||||||
#import "/src/participant.typ": _exists as par-exists, _par
|
#import "/src/participant.typ": _exists as par-exists, _par
|
||||||
#import "/src/sequence.typ": _seq
|
#import "/src/sequence.typ": _seq
|
||||||
|
|
||||||
#let flatten-group(elmts, i) = {
|
#let flatten-group(elmts, i) = {
|
||||||
let group = elmts.at(i)
|
let group = elmts.at(i)
|
||||||
|
for elmt in group.elmts {
|
||||||
|
if is-touying-pause(elmt) {
|
||||||
|
panic("Cannot pause inside of a group yet")
|
||||||
|
}
|
||||||
|
}
|
||||||
elmts.at(i) = group
|
elmts.at(i) = group
|
||||||
return (
|
return (
|
||||||
elmts.slice(0, i + 1) +
|
elmts.slice(0, i + 1) +
|
||||||
@@ -21,6 +27,11 @@
|
|||||||
|
|
||||||
#let flatten-sync(elmts, i) = {
|
#let flatten-sync(elmts, i) = {
|
||||||
let sync = elmts.at(i)
|
let sync = elmts.at(i)
|
||||||
|
for elmt in sync.elmts {
|
||||||
|
if is-touying-pause(elmt) {
|
||||||
|
panic("Cannot pause inside of a sync")
|
||||||
|
}
|
||||||
|
}
|
||||||
elmts.at(i) = sync
|
elmts.at(i) = sync
|
||||||
let start = sync
|
let start = sync
|
||||||
start.remove("elmts")
|
start.remove("elmts")
|
||||||
@@ -37,6 +48,21 @@
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#let flatten-hide(elmts, i) = {
|
||||||
|
let hide = elmts.at(i)
|
||||||
|
elmts.at(i) = hide
|
||||||
|
return (
|
||||||
|
elmts.slice(0, i + 1) +
|
||||||
|
hide.elmts +
|
||||||
|
((
|
||||||
|
type: "hide-end",
|
||||||
|
draw: hide-render-end,
|
||||||
|
start-i: i
|
||||||
|
),) +
|
||||||
|
elmts.slice(i+1)
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
#let update-group-children(elmts, i) = {
|
#let update-group-children(elmts, i) = {
|
||||||
let elmts = elmts
|
let elmts = elmts
|
||||||
let group-end = elmts.at(i)
|
let group-end = elmts.at(i)
|
||||||
@@ -81,6 +107,9 @@
|
|||||||
} else if elmt.type == "sync" {
|
} else if elmt.type == "sync" {
|
||||||
elmts = flatten-sync(elmts, i)
|
elmts = flatten-sync(elmts, i)
|
||||||
|
|
||||||
|
} else if elmt.type == "hide" {
|
||||||
|
elmts = flatten-hide(elmts, i)
|
||||||
|
|
||||||
} else if elmt.type == "seq" {
|
} else if elmt.type == "seq" {
|
||||||
if elmt.enable-dst {
|
if elmt.enable-dst {
|
||||||
activation-history.push(elmt)
|
activation-history.push(elmt)
|
||||||
|
|||||||
@@ -10,6 +10,17 @@
|
|||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#let is-touying-pause(elmt) = {
|
||||||
|
if type(elmt) != content or elmt.func() != metadata {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
let kind = elmt.value.at("kind", default: "")
|
||||||
|
if type(kind) != str {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
return kind.starts-with("touying-jump")
|
||||||
|
}
|
||||||
|
|
||||||
#let normalize-units(value) = {
|
#let normalize-units(value) = {
|
||||||
if type(value) == int or type(value) == float {
|
if type(value) == int or type(value) == float {
|
||||||
return value
|
return value
|
||||||
@@ -33,6 +44,12 @@
|
|||||||
let pars-i = get-participants-i(participants)
|
let pars-i = get-participants-i(participants)
|
||||||
|
|
||||||
for elmt in group.elmts {
|
for elmt in group.elmts {
|
||||||
|
if not is-elmt(elmt) {
|
||||||
|
if is-touying-pause(elmt) {
|
||||||
|
panic("Cannot pause inside of a group yet")
|
||||||
|
}
|
||||||
|
continue
|
||||||
|
}
|
||||||
if elmt.type == "seq" {
|
if elmt.type == "seq" {
|
||||||
let i1 = pars-i.at(elmt.p1)
|
let i1 = pars-i.at(elmt.p1)
|
||||||
let i2 = pars-i.at(elmt.p2)
|
let i2 = pars-i.at(elmt.p2)
|
||||||
@@ -42,7 +59,7 @@
|
|||||||
let (i0, i1) = get-group-span(participants, elmt)
|
let (i0, i1) = get-group-span(participants, elmt)
|
||||||
min-i = calc.min(min-i, i0)
|
min-i = calc.min(min-i, i0)
|
||||||
max-i = calc.max(max-i, i1)
|
max-i = calc.max(max-i, i1)
|
||||||
} else if elmt.type == "sync" {
|
} else if elmt.type == "sync-end" {
|
||||||
let (i0, i1) = get-group-span(participants, elmt)
|
let (i0, i1) = get-group-span(participants, elmt)
|
||||||
min-i = calc.min(min-i, i0)
|
min-i = calc.min(min-i, i0)
|
||||||
max-i = calc.max(max-i, i1)
|
max-i = calc.max(max-i, i1)
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
#let version = version(0, 2, 2)
|
#let version = version(0, 3, 0)
|
||||||
#import "diagram.typ": diagram, from-plantuml
|
#import "diagram.typ": diagram, from-plantuml
|
||||||
|
|
||||||
#import "sequence.typ": _seq, _ret
|
#import "sequence.typ": _seq, _ret
|
||||||
#import "group.typ": _grp, _loop, _alt, _opt, _break
|
#import "group.typ": _grp, _loop, _alt, _opt, _break
|
||||||
#import "participant.typ": _par
|
#import "participant.typ": _par
|
||||||
#import "misc.typ": _sep, _delay, _sync, _gap, _evt, _col
|
#import "misc.typ": _sep, _delay, _sync, _gap, _evt, _col, _hide
|
||||||
#import "note.typ": _note
|
#import "note.typ": _note
|
||||||
@@ -1,5 +1,6 @@
|
|||||||
#import "core/draw/delay.typ"
|
#import "core/draw/delay.typ"
|
||||||
#import "core/draw/event.typ": render as evt-render
|
#import "core/draw/event.typ": render as evt-render
|
||||||
|
#import "core/draw/hide.typ"
|
||||||
#import "core/draw/separator.typ"
|
#import "core/draw/separator.typ"
|
||||||
#import "core/draw/sync.typ"
|
#import "core/draw/sync.typ"
|
||||||
#import "core/utils.typ": set-ctx
|
#import "core/utils.typ": set-ctx
|
||||||
@@ -63,3 +64,11 @@
|
|||||||
max-width: max-width
|
max-width: max-width
|
||||||
),)
|
),)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#let _hide(elmts) = {
|
||||||
|
return ((
|
||||||
|
type: "hide",
|
||||||
|
draw: hide.render,
|
||||||
|
elmts: elmts
|
||||||
|
),)
|
||||||
|
}
|
||||||
|
Before Width: | Height: | Size: 6.7 KiB After Width: | Height: | Size: 6.7 KiB |
|
Before Width: | Height: | Size: 33 KiB After Width: | Height: | Size: 33 KiB |
|
Before Width: | Height: | Size: 23 KiB After Width: | Height: | Size: 23 KiB |
|
Before Width: | Height: | Size: 25 KiB After Width: | Height: | Size: 26 KiB |
|
Before Width: | Height: | Size: 50 KiB After Width: | Height: | Size: 51 KiB |
|
Before Width: | Height: | Size: 29 KiB After Width: | Height: | Size: 29 KiB |
@@ -1,7 +1,7 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "chronos"
|
name = "chronos"
|
||||||
version = "0.2.2"
|
version = "0.3.0"
|
||||||
compiler = "0.13.1"
|
compiler = "0.14.2"
|
||||||
repository = "https://git.kb28.ch/HEL/chronos"
|
repository = "https://git.kb28.ch/HEL/chronos"
|
||||||
entrypoint = "src/lib.typ"
|
entrypoint = "src/lib.typ"
|
||||||
authors = [
|
authors = [
|
||||||
|
|||||||