PXAML cevovod pretvarja deklarativno UI označevanje v delujoče uporabniške vmesnike.
PXAML (označevanje) → Razčlenjevalnik → IR (JSON) → Upodabljalnik → GUI/TUI/Web
PXAML razčlenjevalnik bere XML označevanje in ustvari abstraktno sintaksno drevo (AST).
<!-- Vhod: PXAML --> <Window Title="Demo" Width="400"> <Button Content="Klikni me" Click="OnClick"/> </Window>
Naloge razčlenjevalnika:
AST se pretvori v vmesno predstavitev (IR) - vmesni format na osnovi JSON.
{
"type": "Window",
"properties": {
"Title": { "value": "Demo", "type": "string" },
"Width": { "value": 400, "type": "number" }
},
"children": [
{
"type": "Button",
"properties": {
"Content": { "value": "Klikni me", "type": "string" }
},
"events": {
"Click": { "handler": "OnClick" }
}
}
]
}
Lastnosti IR:
Podatkovne povezave se analizirajo in pretvorijo v izvršljive strukture.
<!-- PXAML s povezavo --> <TextBox Text="{Binding Path=UserName, Mode=TwoWay}"/>
{
"type": "TextBox",
"properties": {
"Text": {
"type": "binding",
"path": "UserName",
"mode": "TwoWay"
}
}
}
IR se s ciljno specifičnim upodabljalnikom prevede v naravne UI elemente.
| Upodabljalnik | Izhod | Tehnologija |
|---|---|---|
| GUI | Naravni kontrolniki | LCL/WinAPI |
| TUI | Terminalski znaki | ANSI/VT100 |
| Web | DOM elementi | HTML/CSS |
type TWvdSPxamlParser = class public function Parse(const ASource: string): TWvdSIRNode; function ParseFile(const APath: string): TWvdSIRNode; end;
type TWvdSIRNode = class NodeType: string; Properties: TWvdSPropertyMap; Children: TWvdSIRNodeList; Events: TWvdSEventMap; Bindings: TWvdSBindingList; end;
type TWvdSRenderer = class abstract public procedure Render(ARoot: TWvdSIRNode); virtual; abstract; procedure Update(AOldRoot, ANewRoot: TWvdSIRNode); virtual; abstract; end;
Cevovod podpira vroče ponovno nalaganje z razlikovanje IR:
1. Nova PXAML → Razčlenjevalnik → Nova IR 2. Diff(Stara IR, Nova IR) → Seznam popravkov 3. Renderer.ApplyPatches(Seznam popravkov)
Prednosti:
| Tip napake | Faza | Obravnava |
|---|---|---|
| XML sintaksna napaka | Razčlenjevanje | Pozicija + sporočilo |
| Neznan element | Razčlenjevanje | Opozorilo + nadomestek |
| Neveljaven tip lastnosti | IR | Prisilna pretvorba tipa + opozorilo |
| Napaka povezave | Povezovanje | Nadomestna vrednost |