-
Notifications
You must be signed in to change notification settings - Fork 2
/
bsl_tools.js
858 lines (808 loc) · 353 KB
/
bsl_tools.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
(()=>{var Fr=Object.defineProperty,Dr=Object.defineProperties;var Mr=Object.getOwnPropertyDescriptors;var xt=Object.getOwnPropertySymbols;var Nr=Object.prototype.hasOwnProperty,Hr=Object.prototype.propertyIsEnumerable;var bt=(e,r,t)=>r in e?Fr(e,r,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[r]=t,W=(e,r)=>{for(var t in r||(r={}))Nr.call(r,t)&&bt(e,t,r[t]);if(xt)for(var t of xt(r))Hr.call(r,t)&&bt(e,t,r[t]);return e},ht=(e,r)=>Dr(e,Mr(r));function Ce(e){return Y(e)||z(e)||ze(e)}function Y(e){return e.type==="Function Definition"}function z(e){return e.type==="Constant Definition"}function ze(e){return e.type==="Struct Definition"}function Ee(e){return J(e)||Z(e)||j(e)||$(e)}function J(e){return e.type==="Function Call"}function Z(e){return e.type==="Cond-Expression"}function j(e){return e.type==="Symbol"}function $(e){return e.type==="Literal Value"}function q(e){return e.type==="Struct Value"}function Et(e){return e.map(ae).join(`
`)}function ae(e){return Ce(e)?ve(e):v(e)}function ve(e){return Y(e)?`(define (${E(e.name)} ${e.args.map(E).join(" ")}) ${v(e.body)})`:z(e)?`(define ${E(e.name)} ${v(e.value)})`:ze(e)?`(define-struct ${E(e.binding)} (${e.properties.map(E).join(" ")}))`:(console.error("Invalid input to printDefinition"),"")}function v(e){return J(e)?`(${E(e.name)} ${e.args.map(v).join(" ")})`:Z(e)?`(cond ${e.options.map(ee).join(" ")})`:j(e)?E(e):$(e)?ce(e.value):(console.error("Invalid input to printE"),`<${e}>`)}function ce(e){return typeof e=="string"&&e!=="'()"?`"${e}"`:typeof e=="boolean"?e?"#true":"#false":q(e)?`<${E(e.structDef)} ${e.properties.map(v).join(" ")}>`:`${e}`}function ee(e){return`[${v(e.condition)} ${v(e.result)}]`}function E(e){return e.symbol}var Xn=[{type:"Function Definition",name:{type:"Symbol",symbol:"f"},args:[{type:"Symbol",symbol:"x"},{type:"Symbol",symbol:"y"}],body:{type:"Function Call",name:{type:"Symbol",symbol:"+"},args:[{type:"Symbol",symbol:"x"},{type:"Symbol",symbol:"y"}]}},{type:"Cond-Expression",options:[{type:"Cond-Option",condition:{type:"Function Call",name:{type:"Symbol",symbol:"="},args:[{type:"Symbol",symbol:"x"},{type:"Literal Value",value:3}]},result:{type:"Literal Value",value:"isThree"}},{type:"Cond-Option",condition:{type:"Literal Value",value:!1},result:{type:"Literal Value",value:"'()"}}]},{type:"Constant Definition",name:{type:"Symbol",symbol:"x"},value:{type:"Literal Value",value:42}},{type:"Struct Definition",binding:{type:"Symbol",symbol:"name"},properties:[{type:"Symbol",symbol:"firstName"},{type:"Symbol",symbol:"lastName"}]}];function te(e,r,t="text"){let n=[],s=0,l=0,c=0,p="",d=!1,S=!1;e.split("").forEach(f=>{if(d&&f!=='"'){p+=f;return}if(S&&f!==">"){p+=f;return}switch(f){case"(":case"[":l++;break;case")":case"]":l--;break;case'"':d=!d;break;case"<":S=t==="html";break;case">":t==="html"&&(S=!1);break;case" ":case`
`:case" ":if(!p)return;n.push({term:p,level:s}),s>c&&(c=s),p="",s=l;return}p+=f}),p!==""&&(n.push({term:p,level:s}),s>c&&(c=s));let g=t==="html"?"<br>":`
`;for(let f=c;f>0;f--){let b=[];n.forEach(h=>{h.level<f?b.push(ht(W({},h),{subterms:[]})):b[b.length-1].subterms.push(h.term)}),n=b.map(h=>{let _=h.subterms.some(D=>D.includes(g)),A=`${h.term}${h.subterms.length>0?" ":""}${h.subterms.join(" ")}`,ie=t==="html"?Or(A):A.length;if(_||ie+h.level>r){let D=h.subterms.map(N=>`${Ct(t==="html"?" ":" ",f)}${N}`);D.unshift(h.term);let le=t==="html"?"<br>":`
`;return{term:`${D.join(le)}`,level:h.level}}else return{term:A,level:h.level}})}return n.map(f=>f.term).join(g)}function Ct(e,r){let t="";for(let n=0;n<r;n++)t+=e;return t}function Or(e){let r=document.createElement("div");return r.innerHTML=e,r.textContent?r.textContent.length:0}function B(e){return e.replaceAll("<","<").replaceAll(">",">")}function re(e){return e.replaceAll("<","<").replaceAll(">",">").replaceAll(" "," ")}function w(e,r,t=!1){if(e.length===0)return[];let n=r.split("/"),s=n.shift();if(s=="")return e;let l=n.join("/"),c=[];if(s=="..")c=e.map(p=>p.parentElement).filter(p=>p);else if(s=="+")c=e.map(p=>p.nextElementSibling).filter(p=>p);else if(s.startsWith(".")){let p=s.slice(1);c=e.flatMap(d=>Array.from(d.children).filter(S=>S.classList.contains(p)))}else c=e.flatMap(p=>Array.from(p.children).filter(d=>d.tagName==s.toUpperCase()));return c.length===0&&t&&console.error(`Error traversing ${r}: No element found`),w(c,l)}function ne(e,r){if(e.tagName==r.toUpperCase())return e;{let t=e.parentElement;return t?ne(t,r):(console.error("Could not find parent element with requested tag ",r),null)}}function U(e,r){if(e.classList.contains(r))return e;{let t=e.parentElement;return t?U(t,r):(console.error("Could not find parent element with requested class ",r),null)}}var _t=`/* ######## color variables ###### */
.bsl-tools-tree {
--branch-color: #666;
--node-background: #ebf0f4; /* racket azure */
--text-grey: #444; /* like in scribble */
--hole-yellow: #fdf68d; /* pale yellow */
--highlight-border-connectors: lime;
--wrong-background: red;
--correct-background: lime;
--hole-selection-background: white;
--node-margin-x: 1em; /* horizontally */
}
/*
CSS for tree by Ross Angus
https://www.cssscript.com/clean-tree-diagram/
(Edited and extended)
*/
/* ###### parent ###### */
.bsl-tools-tree-container {
text-align: center;
overflow-y: scroll;
}
/* ###### node layout ######## */
.bsl-tools-tree,
.bsl-tools-tree ul,
.bsl-tools-tree li {
list-style: none;
margin: 0;
padding: 0;
position: relative;
white-space: nowrap;
}
.bsl-tools-tree {
margin: 0 0 1em;
text-align: center;
margin-left: auto;
margin-right: auto;
}
.bsl-tools-tree,
.bsl-tools-tree ul {
display: table;
}
.bsl-tools-tree ul {
width: 100%;
}
.bsl-tools-tree li {
display: table-cell;
padding: 0;
padding-top: 1.5em;
vertical-align: top;
}
.bsl-tools-tree code,
.bsl-tools-tree span {
border: solid .1em var(--branch-color);
border-radius: .2em;
display: inline-block;
margin-left: var(--node-margin-x);
margin-right: var(--node-margin-x);
margin-top: 1.5em;
padding: .2em .5em;
position: relative;
box-sizing: border-box;
}
/* ########### custom AST node styles ######## */
/* node */
.bsl-tools-tree span {
font-family: 'Fira-Mono', monospace;
background-color: var(--node-background);
transition: 1s background-color ease-out;
}
.bsl-tools-tree .terminal-symbol {
border-width: .2em;
border-style: double;
}
/* node label */
.bsl-tools-tree .name {
color: var(--text-grey);
font-style: italic;
font-size: 0.85em;
text-align: right;
position: absolute;
top: calc(-0.85em - 1.5em);
right: var(--edgetext-right, 50%); /* to be set dynamically */
margin-right: -1.5em;
background-color: rgba(255,255,255,0.7);
}
/* tooltip */
.bsl-tools-tree .name .tooltip {
display: none;
}
.bsl-tools-tree .name:hover .tooltip {
display: block;
position: absolute;
left: 100%;
bottom: calc(-0.5em - 1px);
background-color: var(--node-background);
border: 1px solid var(--branch-color);
text-align: left;
padding: 0.5em;
z-index: 1000;
}
/* ###### connectors ########### */
/* part above box */
.bsl-tools-tree span:before {
outline: solid 1px var(--branch-color);
content: "";
width: var(--connector-width, 0px); /* to be set dynamically */
left: var(--connector-left, 50%); /* to be set dynamically */
position: absolute;
top: -1.5em;
transform: var(--connector-transform); /* to be set dynamically */
}
.bsl-tools-tree span.terminal-symbol:before {
top: calc(-1.5em - .2em);
}
/* ####### highlight way back up from a node ###### */
/* .bsl-tools-tree li:hover > span {
border-color: var(--highlight-border-connectors);
}
.bsl-tools-tree li:hover::before {
border-color: var(--highlight-border-connectors);
z-index: 1000;
}
.bsl-tools-tree li:hover > span::before {
outline-color: var(--highlight-border-connectors);
} */
/* ######## hide connectors over root ######## */
.bsl-tools-tree>li:before,
.bsl-tools-tree>li:after,
.bsl-tools-tree>li>code:before,
.bsl-tools-tree>li>span:before {
outline: none !important;
border: none !important;
}
.bsl-tools-tree>li {
margin-top: 0;
}
/* ####### collapse nodes ######## */
/* click on span to hide/show */
.bsl-tools-tree .hole:hover {
cursor: pointer;
}
.bsl-tools-tree [data-collapsed="true"] {
display: none;
}
/* ######### holes ########## */
.bsl-tools-tree .char {
display: inline;
margin: 0;
border: none;
padding: 0;
border-radius: 0;
background-color: transparent;
transition: background-color 1s ease-out;
}
.bsl-tools-tree .char::before {
display: none;
}
.bsl-tools-tree .hole {
display: inline-block;
background-color: var(--hole-yellow);
border: 1px solid var(--text-grey);
color: var(--text-grey);
padding-left: 0.25em;
padding-right: 0.25em;
position: relative;
}
/* ########### quiz ########## */
/* quiz stages */
.bsl-tools-tree span[data-quiz-state="production"] .name,
.bsl-tools-tree span[data-quiz-state="production"] .code,
.bsl-tools-tree span[data-quiz-state="production"] .hole-marking {
display: none;
}
.bsl-tools-tree span[data-quiz-state="hole-marking"] .code,
.bsl-tools-tree span[data-quiz-state="hole-marking"] .production {
display: none;
}
.bsl-tools-tree span[data-quiz-state="done"] .production,
.bsl-tools-tree span[data-quiz-state="done"] .hole-marking {
display: none;
}
/* highlighting text by putting a div behind a textarea */
.bsl-tools-tree textarea,
.bsl-tools-tree .marker-container {
font-family: inherit;
resize: none;
font-size: calc(1em);
padding: 2px;
margin: .2em;
border: none;
box-sizing: border-box;
}
.bsl-tools-tree .textarea-container {
position: relative;
display: inline-block;
}
.bsl-tools-tree textarea {
position: relative;
background-color: transparent;
z-index: 2;
}
.bsl-tools-tree .marker-container {
text-align: left;
background-color: var(--hole-selection-background);
position: absolute;
top: 0;
left: 0;
z-index: 1;
}
.bsl-tools-tree .marker {
color: transparent;
background-color: transparent;
transition: 1s background-color ease-out;
}
/* feedback for wrong answer */
.bsl-tools-tree .wrong {
background-color: var(--wrong-background);
transition: none;
}
.bsl-tools-tree .correct {
background-color: var(--correct-background);
transition: none;
}
`;function _e(e,r,t,n=!1,s="en"){if(t||(t=jr(e)),!document.getElementById("bsl-tools-tree-style")){let l=document.createElement("style");l.innerHTML=_t,l.id="bsl-tools-tree-style",document.getElementsByTagName("head")[0].appendChild(l)}Rt.includes(s)||(console.error(`
Selected language "${s}" is not implemented, defaulting to "en".
Available language codes: ${Rt.join(", ")}
`),s="en"),r.innerHTML=`
<div class="bsl-tools-tree-container">
<ul class="bsl-tools-tree">
${n?Bt(e,s,t):$t(e,t)}
</ul>
</div>`,n&&w([r],"ul/li/ul/li").map(l=>l.setAttribute("data-collapsed","false")),Re(r)}function jr(e){let r={};return Lt(e,r),r}function Lt(e,r){r[e.production]=[],e.holes.map(t=>Lt(t.content,r))}var Rt=["en","de"],Pt={en:{"select production":"Select production","mark selected text as hole":"Mark selected text as subexpression"},de:{"select production":"Produktion ausw\xE4hlen","mark selected text as hole":"Auswahl als Teilausdruck markieren"}};function Re(e){let r=parseFloat(getComputedStyle(e).fontSize)*3;for(let t=1;;t++){let n=Array.from(e.getElementsByClassName(`hole-${t}`));if(n.length<1)return;n.map(s=>{let l=s,c=.5*(l.getBoundingClientRect().x+l.getBoundingClientRect().right);if(c==0)return;let p=ne(l,"li");!p||w([p],`ul/.child-${t}/span`).map(d=>{let S=d,g=.5*(S.getBoundingClientRect().x+S.getBoundingClientRect().right),f=c-g,b=-Math.atan2(r,f),h=Math.sqrt(f*f+r*r),_=f/2-h/2;S.style.cssText=`
--connector-width: ${h}px;
--connector-left: calc(50% + ${_}px);
--edgetext-right: calc(50% - ${f/2}px);
--connector-transform: rotate(${b}rad);
`})})}}function $t(e,r,t=-1){return`
<li class="${t>=0?`child-${t+1}`:""}"
data-collapsed="${t>=0?"true":"false"}">
<span class="${e.holes.length>0?"":"terminal-symbol"}">
${It(e,r)}
${At(e)}
</span>
${e.holes.length>0?`<ul>${e.holes.map((n,s)=>$t(n.content,r,s)).join("")}</ul>`:""}
</li>
`}function At(e){return`
<div class="code">${qr(e).map(t=>`<span class="char ${t.pos?`hole hole-${t.pos}`:""}"
${t.pos?`onclick="toggleChild(event,${t.pos})"`:""}
>${e.code.slice(t.start,t.end)}</span>`).join("")}
</div>
`}window.toggleChild=(e,r)=>{let t=e.target,n=ne(t,"li"),s=U(t,"bsl-tools-tree");if(!n||!s){console.error("toggleChild called from .hole not in .bsl-tools-tree");return}w([n],`ul/.child-${r}`).map(l=>{l.setAttribute("data-collapsed",l.getAttribute("data-collapsed")==="true"?"false":"true")}),Re(s)};function qr(e){let r=[],t=0;for(let n=0;n<e.holes.length;n++)e.holes[n].start>t&&r.push({pos:!1,start:t,end:e.holes[n].start}),r.push(W({pos:n+1},e.holes[n])),t=e.holes[n].end;return t<e.code.length&&r.push({pos:!1,start:t,end:e.code.length}),r}function It(e,r){return`
<div class="name">${B(e.production)}${r[e.production]&&r[e.production].length>0?`<div class="tooltip">::= ${r[e.production].map(B).join("<br> | ")}</div>`:""}</div>
`}function Bt(e,r,t,n=-1){return`
<li class="${n>=0?`child-${n+1}`:""}"
data-collapsed="${n>=0?"true":"false"}">
<span class="${e.holes.length>0?"":"terminal-symbol"}"
data-quiz-state="${n>=0?"production":"done"}"
data-is-terminal="${e.holes.length<=0}"
data-is-trivial-hole="${e.holes.length===1&&e.holes[0].start===0&&e.holes[0].end===e.code.length}">
${Kr(e,r,t)}
${Wr(e,r)}
${It(e,t)}
${At(e)}
</span>
${e.holes.length>0?`<ul>${e.holes.map((s,l)=>Bt(s.content,r,t,l)).join("")}</ul>`:""}
</li>
`}function Kr(e,r,t){return`
<div class="production">
<select onchange="checkProduction(event, '${e.production}')">
<option selected="true">${Pt[r]["select production"]}</option>
${Object.keys(t).map(n=>`
<option value="${n}">${B(n)}</option>
`).join("")}
</select>
</div>
`}window.checkProduction=(e,r)=>{let t=e.target;if(t.value===r){let n=ne(t,"span");if(n){n.getAttribute("data-is-terminal")==="true"?n.setAttribute("data-quiz-state","done"):n.getAttribute("data-is-trivial-hole")==="true"?(n.setAttribute("data-quiz-state","done"),w([n],"+/li",!0).map(l=>l.setAttribute("data-collapsed","false"))):n.setAttribute("data-quiz-state","hole-marking"),w([n],"../+").map(l=>l.setAttribute("data-collapsed","false"));let s=U(n,"bsl-tools-tree");s&&Re(s)}}else{Array.from(t.selectedOptions).map(s=>s.remove());let n=ne(t,"span");n&&(n.classList.add("wrong"),window.setTimeout(()=>{n.classList.remove("wrong")},100))}};function Wr(e,r){return`
<div class="hole-marking"
data-holes="${btoa(JSON.stringify(e.holes.map(t=>[t.start,t.end,!1])))}">
<div class="textarea-container">
<div class="marker-container">
${e.code.split(`
`).map(t=>t.split("").map(n=>`<span class="char marker">${n}</span>`).join("")).join('<span class="char marker"></span><br>')}
</div>
<textarea autocorrect="off"
spellcheck="false"
cols="${e.code.split(`
`).map(t=>t.length).reduce((t,n)=>t>n?t:n)}"
rows="${e.code.split(`
`).length}"
oninput="stopInput(event, '${btoa(e.code)}')">${e.code}</textarea>
</div><br>
<button onclick="checkSelection(event)">
${Pt[r]["mark selected text as hole"]}
</button>
</div>
`}window.stopInput=(e,r)=>{e.target.value=atob(r)};window.checkSelection=e=>{let r=e.target,t=U(r,"hole-marking");if(!t){console.error("checkProduction called from el. not wrapped in div.hole-marking");return}let n=JSON.parse(atob(t.getAttribute("data-holes"))),s=t.getElementsByTagName("textarea")[0],l=s.selectionStart,c=s.selectionEnd,p=l<c?l:c,d=l<c?c:l,S=-1;if(n.map((g,f)=>{g[0]===p&&g[1]===d&&(g[2]=!0,S=f)}),S>=0)t.setAttribute("data-holes",btoa(JSON.stringify(n))),w([t],".textarea-container/.marker-container/.marker",!0).slice(p,d).map(g=>g.classList.add("correct"));else{let g=w([t],".textarea-container/.marker-container/.marker",!0).slice(p,d);g.map(f=>f.classList.add("wrong")),window.setTimeout(()=>{g.map(f=>f.classList.remove("wrong"))},100)}if(n.every(g=>g[2])){let g=ne(t,"span");if(g){g.setAttribute("data-quiz-state","done"),w([g],"../ul/.child-1").map(b=>b.setAttribute("data-collapsed","false"));let f=U(g,"bsl-tools-tree");f&&Re(f)}}};function je(e,r,t){return t=t||" ",e.length>r?e:(r-=e.length,t+=t.repeat(r),e+t.slice(0,r))}var K=class extends Error{constructor(t,n,s,l){super();this.message=t,this.expected=n,this.found=s,this.location=l,this.name="SyntaxError",typeof Object.setPrototypeOf=="function"?Object.setPrototypeOf(this,K.prototype):this.__proto__=K.prototype,typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,K)}static buildMessage(t,n){function s(g){return g.charCodeAt(0).toString(16).toUpperCase()}function l(g){return g.replace(/\\/g,"\\\\").replace(/"/g,'\\"').replace(/\0/g,"\\0").replace(/\t/g,"\\t").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/[\x00-\x0F]/g,f=>"\\x0"+s(f)).replace(/[\x10-\x1F\x7F-\x9F]/g,f=>"\\x"+s(f))}function c(g){return g.replace(/\\/g,"\\\\").replace(/\]/g,"\\]").replace(/\^/g,"\\^").replace(/-/g,"\\-").replace(/\0/g,"\\0").replace(/\t/g,"\\t").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/[\x00-\x0F]/g,f=>"\\x0"+s(f)).replace(/[\x10-\x1F\x7F-\x9F]/g,f=>"\\x"+s(f))}function p(g){switch(g.type){case"literal":return'"'+l(g.text)+'"';case"class":let f=g.parts.map(b=>Array.isArray(b)?c(b[0])+"-"+c(b[1]):c(b));return"["+(g.inverted?"^":"")+f+"]";case"any":return"any character";case"end":return"end of input";case"other":return g.description}}function d(g){let f=g.map(p),b,h;if(f.sort(),f.length>0){for(b=1,h=1;b<f.length;b++)f[b-1]!==f[b]&&(f[h]=f[b],h++);f.length=h}switch(f.length){case 1:return f[0];case 2:return f[0]+" or "+f[1];default:return f.slice(0,-1).join(", ")+", or "+f[f.length-1]}}function S(g){return g?'"'+l(g)+'"':"end of input"}return"Expected "+d(t)+" but "+S(n)+" found."}format(t){let n="Error: "+this.message;if(this.location){let s=null,l;for(l=0;l<t.length;l++)if(t[l].source===this.location.source){s=t[l].text.split(/\r\n|\n|\r/g);break}let c=this.location.start,p=this.location.source+":"+c.line+":"+c.column;if(s){let d=this.location.end,S=je("",c.line.toString().length," "),g=s[c.line-1],f=c.line===d.line?d.column:g.length+1;n+=`
--> `+p+`
`+S+` |
`+c.line+" | "+g+`
`+S+" | "+je("",c.column-1," ")+je("",f-c.column,"^")}else n+=`
at `+p}return n}};function Jr(e,r){r=r!==void 0?r:{};let t={},n=r.grammarSource,s={Program:gt},l=gt,c=function(o){return o},p=/^[\t \n \r]/,d=he([" "," ",`
`," ","\r"],!1,!1),S=function(o){return o},g="(define-struct",f=I("(define-struct",!1),b="(",h=I("(",!1),_=")",A=I(")",!1),ie=function(o,a){return{type:"Struct Definition",binding:o,properties:a}},D="(define",le=I("(define",!1),Te=function(o,a,u){return{type:"Function Definition",name:o,args:a,body:u}},N=function(o,a){return{type:"Constant Definition",name:o,value:a}},V=function(o){return o},G="(cond",er=I("(cond",!1),tr=function(o){return{type:"Cond-Expression",options:o}},rr="[",nr=I("[",!1),or="]",sr=I("]",!1),ir=function(o,a){return{type:"Cond-Option",condition:o,result:a}},lr=function(o,a){return{type:"Function Call",name:o,args:a}},Ze="define",ar=I("define",!1),et=/^[^",'`()[\]{}|#\n\t\r ]/,tt=he(['"',",","'","`","(",")","[","]","{","}","|","#",`
`," ","\r"," "],!0,!1),cr=function(o){return{type:"Symbol",symbol:o.join("")}},ur=function(o){return{type:"Literal Value",value:o}},rt=/^[0-9]/,nt=he([["0","9"]],!1,!1),pr=function(){return parseInt(Cr(),10)},ot="#true",dr=I("#true",!1),st="#false",fr=I("#false",!1),it="#t",mr=I("#t",!1),lt="#f",Sr=I("#f",!1),gr=function(o){return o==="#true"||o==="#t"},at="'()",yr=I("'()",!1),Tr=function(){return"'()"},ct='"',ut=I('"',!1),pt=/^[^"]/,dt=he(['"'],!0,!1),xr=function(o){return o.join("")},br=ft("whitespace"),hr=function(){},i=0,C=0,xe=[{line:1,column:1}],H=0,Ve=[],T=0,be;if(r.startRule!==void 0){if(!(r.startRule in s))throw new Error(`Can't start parsing from rule "`+r.startRule+'".');l=s[r.startRule]}function Cr(){return e.substring(C,i)}function Kn(){return de(C,i)}function Wn(o,a){throw a=a!==void 0?a:de(C,i),St([ft(o)],e.substring(C,i),a)}function Jn(o,a){throw a=a!==void 0?a:de(C,i),vr(o,a)}function I(o,a){return{type:"literal",text:o,ignoreCase:a}}function he(o,a,u){return{type:"class",parts:o,inverted:a,ignoreCase:u}}function Gn(){return{type:"any"}}function Er(){return{type:"end"}}function ft(o){return{type:"other",description:o}}function mt(o){let a=xe[o],u;if(a)return a;for(u=o-1;!xe[u];)u--;for(a=xe[u],a={line:a.line,column:a.column};u<o;)e.charCodeAt(u)===10?(a.line++,a.column=1):a.column++,u++;return xe[o]=a,a}function de(o,a){let u=mt(o),m=mt(a);return{source:n,start:{offset:o,line:u.line,column:u.column},end:{offset:a,line:m.line,column:m.column}}}function x(o){i<H||(i>H&&(H=i,Ve=[]),Ve.push(o))}function vr(o,a){return new K(o,[],"",a)}function St(o,a,u){return new K(K.buildMessage(o,a),o,a,u)}function gt(){let o,a,u;if(o=i,a=[],u=yt(),u!==t)for(;u!==t;)a.push(u),u=yt();else a=t;return a!==t&&(C=o,a=c(a)),o=a,o}function yt(){let o,a,u,m;if(o=i,a=_r(),a===t&&(a=Q()),a!==t){if(u=[],p.test(e.charAt(i))?(m=e.charAt(i),i++):(m=t,T===0&&x(d)),m!==t)for(;m!==t;)u.push(m),p.test(e.charAt(i))?(m=e.charAt(i),i++):(m=t,T===0&&x(d));else u=t;u!==t?(C=o,a=c(a),o=a):(i=o,o=t)}else i=o,o=t;return o}function _r(){let o,a,u;return o=i,a=L(),a!==t?(u=Rr(),u===t&&(u=Lr(),u===t&&(u=Pr())),u!==t?(C=o,a=S(u),o=a):(i=o,o=t)):(i=o,o=t),o}function Rr(){let o,a,u,m,y,M,R,P,X;if(o=i,e.substr(i,14)===g?(a=g,i+=14):(a=t,T===0&&x(f)),a!==t)if(u=O(),u!==t)if(m=L(),m!==t)if(e.charCodeAt(i)===40?(y=b,i++):(y=t,T===0&&x(h)),y!==t){if(M=[],R=O(),R!==t)for(;R!==t;)M.push(R),R=O();else M=t;M!==t?(e.charCodeAt(i)===41?(R=_,i++):(R=t,T===0&&x(A)),R!==t?(P=L(),P!==t?(e.charCodeAt(i)===41?(X=_,i++):(X=t,T===0&&x(A)),X!==t?(C=o,a=ie(u,M),o=a):(i=o,o=t)):(i=o,o=t)):(i=o,o=t)):(i=o,o=t)}else i=o,o=t;else i=o,o=t;else i=o,o=t;else i=o,o=t;return o}function Lr(){let o,a,u,m,y,M,R,P,X,Oe;if(o=i,e.substr(i,7)===D?(a=D,i+=7):(a=t,T===0&&x(le)),a!==t)if(u=L(),u!==t)if(e.charCodeAt(i)===40?(m=b,i++):(m=t,T===0&&x(h)),m!==t)if(y=O(),y!==t)if(M=L(),M!==t){if(R=[],P=O(),P!==t)for(;P!==t;)R.push(P),P=O();else R=t;R!==t?(e.charCodeAt(i)===41?(P=_,i++):(P=t,T===0&&x(A)),P!==t?(X=Q(),X!==t?(e.charCodeAt(i)===41?(Oe=_,i++):(Oe=t,T===0&&x(A)),Oe!==t?(C=o,a=Te(y,R,X),o=a):(i=o,o=t)):(i=o,o=t)):(i=o,o=t)):(i=o,o=t)}else i=o,o=t;else i=o,o=t;else i=o,o=t;else i=o,o=t;else i=o,o=t;return o}function Pr(){let o,a,u,m,y;return o=i,e.substr(i,7)===D?(a=D,i+=7):(a=t,T===0&&x(le)),a!==t?(u=O(),u!==t?(m=Q(),m!==t?(e.charCodeAt(i)===41?(y=_,i++):(y=t,T===0&&x(A)),y!==t?(C=o,a=N(u,m),o=a):(i=o,o=t)):(i=o,o=t)):(i=o,o=t)):(i=o,o=t),o}function Q(){let o,a,u;return o=i,a=L(),a!==t?(u=Ir(),u===t&&(u=$r(),u===t&&(u=Ar(),u===t&&(u=O()))),u!==t?(C=o,a=V(u),o=a):(i=o,o=t)):(i=o,o=t),o}function $r(){let o,a,u,m,y;if(o=i,e.substr(i,5)===G?(a=G,i+=5):(a=t,T===0&&x(er)),a!==t){if(u=[],m=Tt(),m!==t)for(;m!==t;)u.push(m),m=Tt();else u=t;u!==t?(m=L(),m!==t?(e.charCodeAt(i)===41?(y=_,i++):(y=t,T===0&&x(A)),y!==t?(C=o,a=tr(u),o=a):(i=o,o=t)):(i=o,o=t)):(i=o,o=t)}else i=o,o=t;return o}function Tt(){let o,a,u,m,y,M,R,P;return o=i,a=L(),a!==t?(e.charCodeAt(i)===91?(u=rr,i++):(u=t,T===0&&x(nr)),u!==t?(m=L(),m!==t?(y=Q(),y!==t?(M=L(),M!==t?(R=Q(),R!==t?(e.charCodeAt(i)===93?(P=or,i++):(P=t,T===0&&x(sr)),P!==t?(C=o,a=ir(y,R),o=a):(i=o,o=t)):(i=o,o=t)):(i=o,o=t)):(i=o,o=t)):(i=o,o=t)):(i=o,o=t)):(i=o,o=t),o}function Ar(){let o,a,u,m,y;if(o=i,e.charCodeAt(i)===40?(a=b,i++):(a=t,T===0&&x(h)),a!==t)if(u=O(),u!==t){for(m=[],y=Q();y!==t;)m.push(y),y=Q();m!==t?(e.charCodeAt(i)===41?(y=_,i++):(y=t,T===0&&x(A)),y!==t?(C=o,a=lr(u,m),o=a):(i=o,o=t)):(i=o,o=t)}else i=o,o=t;else i=o,o=t;return o}function O(){let o,a,u,m,y;if(o=i,a=L(),a!==t)if(u=i,T++,e.substr(i,6)===Ze?(m=Ze,i+=6):(m=t,T===0&&x(ar)),T--,m===t?u=void 0:(i=u,u=t),u!==t){if(m=[],et.test(e.charAt(i))?(y=e.charAt(i),i++):(y=t,T===0&&x(tt)),y!==t)for(;y!==t;)m.push(y),et.test(e.charAt(i))?(y=e.charAt(i),i++):(y=t,T===0&&x(tt));else m=t;m!==t?(C=o,a=cr(m),o=a):(i=o,o=t)}else i=o,o=t;else i=o,o=t;return o}function Ir(){let o,a;return o=i,a=Br(),a===t&&(a=wr(),a===t&&(a=Ur(),a===t&&(a=kr()))),a!==t&&(C=o,a=ur(a)),o=a,o}function Br(){let o,a,u,m;if(o=i,a=L(),a!==t){if(u=[],rt.test(e.charAt(i))?(m=e.charAt(i),i++):(m=t,T===0&&x(nt)),m!==t)for(;m!==t;)u.push(m),rt.test(e.charAt(i))?(m=e.charAt(i),i++):(m=t,T===0&&x(nt));else u=t;u!==t?(C=o,a=pr(),o=a):(i=o,o=t)}else i=o,o=t;return o}function wr(){let o,a,u;return o=i,a=L(),a!==t?(e.substr(i,5)===ot?(u=ot,i+=5):(u=t,T===0&&x(dr)),u===t&&(e.substr(i,6)===st?(u=st,i+=6):(u=t,T===0&&x(fr)),u===t&&(e.substr(i,2)===it?(u=it,i+=2):(u=t,T===0&&x(mr)),u===t&&(e.substr(i,2)===lt?(u=lt,i+=2):(u=t,T===0&&x(Sr))))),u!==t?(C=o,a=gr(u),o=a):(i=o,o=t)):(i=o,o=t),o}function Ur(){let o,a,u;return o=i,a=L(),a!==t?(e.substr(i,3)===at?(u=at,i+=3):(u=t,T===0&&x(yr)),u!==t?(C=o,a=Tr(),o=a):(i=o,o=t)):(i=o,o=t),o}function kr(){let o,a,u,m,y;if(o=i,a=L(),a!==t)if(e.charCodeAt(i)===34?(u=ct,i++):(u=t,T===0&&x(ut)),u!==t){if(m=[],pt.test(e.charAt(i))?(y=e.charAt(i),i++):(y=t,T===0&&x(dt)),y!==t)for(;y!==t;)m.push(y),pt.test(e.charAt(i))?(y=e.charAt(i),i++):(y=t,T===0&&x(dt));else m=t;m!==t?(e.charCodeAt(i)===34?(y=ct,i++):(y=t,T===0&&x(ut)),y!==t?(C=o,a=xr(m),o=a):(i=o,o=t)):(i=o,o=t)}else i=o,o=t;else i=o,o=t;return o}function L(){let o,a,u;for(T++,o=i,a=[],p.test(e.charAt(i))?(u=e.charAt(i),i++):(u=t,T===0&&x(d));u!==t;)a.push(u),p.test(e.charAt(i))?(u=e.charAt(i),i++):(u=t,T===0&&x(d));return a!==t&&(C=o,a=hr()),o=a,T--,o===t&&(a=t,T===0&&x(br)),o}if(be=l(),be!==t&&i===e.length)return be;throw be!==t&&i<e.length&&x(Er()),St(Ve,H<e.length?e.charAt(H):null,H<e.length?de(H,H+1):de(H,H))}var Le=Jr;var wt=`/* css for errors */
.error-wrapper{
display:flex;
flex-direction:column;
margin:2vw;
font-size:inherit;
}
.error{
font-size:1.2em;
}
`;function Ut(){Array.from(document.getElementsByTagName("bsltree")).map(e=>{try{let r=Le(re(e.innerHTML)),t=Yr(r),n=e.getAttribute("quiz")==="true",s=e.getAttribute("lang")?e.getAttribute("lang"):void 0;_e(t,e,Xr,n,s)}catch(r){Qr(e,`${r.location.start.line}:${r.location.start.column} ${r}`)}})}function Qr(e,r){if(!document.getElementById("bsl-tools-error-style")){let d=document.createElement("style");d.innerHTML=wt,d.id="bsl-tools-error-style",document.getElementsByTagName("head")[0].appendChild(d)}let t=e.innerHTML;e.innerHTML="";let n=document.createElement("div");n.classList.add("error-wrapper"),e.appendChild(n);let s=`<p> BSL-Tree could not be parsed! </p>
<p> Input: <b style="font-size:0.9em;">${t}</b> </p>`,l=document.createElement("div");l.classList.add("origin"),l.innerHTML=s,n.appendChild(l);let c=document.createElement("pre");c.classList.add("error");let p=document.createElement("code");p.textContent=r,n.appendChild(c),c.appendChild(p)}var Xr={"<program>":["<def-or-expr>*"],"<def-or-expr>*":[],"<def-or-expr>":["<definition>","<e>"],"<definition>":["(define (<name> <name>+) <e>)","(define <name> <e>)","(define-struct <name> (<name>*))"],"<e>":["(name <e>*)","(cond {[<e>,<e>]}+)","<name>","<v>"],"<e>*":[],"{[ <e> <e> ]}+":[],"[ <e> <e> ]":[],"<name>*":[],"<name>+":[],"<name>":[],"<v>":[]};function Yr(e){let r=e.map(ae),t=[],n="";for(let s=0;s<r.length;s++){s>0&&(n=`${n}
`);let l=n.length;n=`${n}${r[s]}`;let c=n.length;t.push({start:l,end:c})}return{production:"<program>",code:n,holes:[{start:0,end:n.length,content:{production:"<def-or-expr>*",code:n,holes:t.map((s,l)=>({start:s.start,end:s.end,content:Zr(e[l])}))}}]}}function Zr(e){let r=ae(e);return{production:"<def-or-expr>",code:r,holes:[{start:0,end:r.length,content:Ce(e)?en(e):ue(e)}]}}function en(e){let r="",t=[];if(Y(e)){r="(define (";let n=r.length;r=`${r}${E(e.name)}`,t.push({start:n,end:r.length,content:oe(e.name)}),r=`${r} `,n=r.length,r=`${r}${e.args.map(E).join(" ")}`,t.push({start:n,end:r.length,content:tn(e.args)}),r=`${r}) `,n=r.length,r=`${r}${v(e.body)}`,t.push({start:n,end:r.length,content:ue(e.body)}),r=`${r})`}else if(z(e)){r="(define ";let n=r.length;r=`${r}${E(e.name)}`,t.push({start:n,end:r.length,content:oe(e.name)}),r=`${r} `,n=r.length,r=`${r}${v(e.value)}`,t.push({start:n,end:r.length,content:ue(e.value)}),r=`${r})`}else{r="(define-struct ";let n=r.length;r=`${r}${E(e.binding)}`,t.push({start:n,end:r.length,content:oe(e.binding)}),r=`${r} (`,n=r.length,r=`${r}${e.properties.map(E).join(" ")}`,t.push({start:n,end:r.length,content:rn(e.properties)}),r=`${r}))`}return{production:"<definition>",code:r,holes:t}}function ue(e){let r="",t=[];if(J(e)){r="(";let n=r.length;r=`${r}${E(e.name)}`,t.push({start:n,end:r.length,content:oe(e.name)}),r=`${r} `,n=r.length,r=`${r}${e.args.map(v).join(" ")}`,t.push({start:n,end:r.length,content:nn(e.args)}),r=`${r})`}else if(Z(e)){r="(cond ";let n=r.length;r=`${r}${e.options.map(ee).join(" ")}`,t.push({start:n,end:r.length,content:on(e.options)}),r=`${r})`}else j(e)?(r=E(e),t.push({start:0,end:r.length,content:oe(e)})):(r=v(e),t.push({start:0,end:r.length,content:ln(e)}));return{production:"<e>",code:r,holes:t}}function oe(e){return{production:"<name>",code:E(e),holes:[]}}function tn(e){e.length<1&&console.error("<name>+ but used but names are empty");let r="",t=[];for(let n=0;n<e.length;n++){let s=r.length;r=`${r}${E(e[n])}`,t.push({start:s,end:r.length,content:oe(e[n])}),n<e.length-1&&(r=`${r} `)}return{production:"<name>+",code:r,holes:t}}function rn(e){let r="",t=[];for(let n=0;n<e.length;n++){let s=r.length;r=`${r}${E(e[n])}`,t.push({start:s,end:r.length,content:oe(e[n])}),n<e.length-1&&(r=`${r} `)}return{production:"<name>*",code:r,holes:t}}function nn(e){let r="",t=[];for(let n=0;n<e.length;n++){let s=r.length;r=`${r}${v(e[n])}`,t.push({start:s,end:r.length,content:ue(e[n])}),n<e.length-1&&(r=`${r} `)}return{production:"<e>*",code:r,holes:t}}function on(e){let r="",t=[];for(let n=0;n<e.length;n++){let s=r.length;r=`${r}${ee(e[n])}`,t.push({start:s,end:r.length,content:sn(e[n])}),n<e.length-1&&(r=`${r} `)}return{production:"{[ <e> <e> ]}+",code:r,holes:t}}function sn(e){let r="",t=[];r=`${r}[`;let n=r.length;return r=`${r}${v(e.condition)}`,t.push({start:n,end:r.length,content:ue(e.condition)}),r=`${r} `,n=r.length,r=`${r}${v(e.result)}`,t.push({start:n,end:r.length,content:ue(e.result)}),r=`${r}]`,{production:"[ <e> <e> ]",code:r,holes:t}}function ln(e){return{production:"<v>",code:v(e),holes:[]}}function kt(){Array.from(document.getElementsByTagName("jsontree")).map(e=>{try{let r=an(re(e.innerHTML)),t=r.root,n=r.grammar,s=e.getAttribute("quiz")==="true",l=e.getAttribute("lang")?e.getAttribute("lang"):void 0;_e(t,e,n,s,l)}catch(r){console.error(r),e.innerHTML=`${r}`,e.style.cssText=`
padding: 2em;
color: darkred;
display: block;
`}})}function an(e){let r=JSON.parse(e.trim()),t=r.grammar;return{root:Ft(r),grammar:t}}function Ft(e){let r=e.production;if(!r||typeof r!="string")throw`${qe(e)}<br> has wrong structure, production needs to be a string`;let t=e.code;if(!t||typeof t!="string")throw`${qe(e)}<br> has wrong structure, code needs to be a string`;e.holes||(e.holes=[]);let n=t.split("|"),s="",l=[];for(let c=0;c<n.length;c++)if(s=`${s}${n[c]}`,c++,c<n.length&&n[c]){let p=s.length;s=`${s}${n[c]}`;let d=e.holes[l.length];if(!d)throw`${qe(e)}<br> has wrong structure: less holes than marked with || in the code`;l.push({start:p,end:s.length,content:Ft(d)})}return{production:r,code:s,holes:l}}function qe(e){let r=JSON.stringify(e,void 0,2);return`
<textarea rows="${r.split(`
`).length}"
cols="${r.split(`
`).map(t=>t.length).reduce((t,n)=>t>n?t:n)}"
readOnly="true"
resizable="false">${r}</textarea>
`}var Ke=(f=>(f.Add="+",f.Sub="-",f.Mul="*",f.Div="/",f.And="and",f.Or="or",f.Not="not",f.Leq="<=",f.Geq=">=",f.Lt="<",f.Gt=">",f))(Ke||{});function Pe(e){return e.type==="DefinitionStep"}function $e(e){return e.type==="EvalStep"}function me(e){return e.type==="CallRedex"}function Se(e){return e.type==="CondRedex"}function ge(e){return e.type==="NameRedex"}function Ae(e){return e.type==="Hole"}function Ie(e){return e.type==="AppContext"}function Be(e){return e.type==="CondContext"}function we(e){return e.type==="Split"}function Dt(e){return e.type==="Prim"||e.type==="PrimError"||e.type==="CondTrue"||e.type==="CondFalse"||e.type==="CondError"||e.type==="Const"||e.type==="ConstError"||e.type==="Fun"||e.type==="FunError"||e.type==="StructMake"||e.type==="StructMakeError"||e.type==="StructPredTrue"||e.type==="StructPredFalse"||e.type==="StructPredError"||e.type==="StructSelect"||e.type==="StructSelectError"}function We(e){return e.type==="Kong"}function k(e){return typeof e=="number"||typeof e=="string"||typeof e=="boolean"||e==="'()"||q(e)}function Mt(e){return e.type==="PrimDef"}function Je(e){return e.type==="FunEnv"}function Nt(e){return e.type==="StructDef"}function ye(e){return e.type==="Identifier"}function Ht(e){return e.type==="MakeFun"||e.type==="PredFun"||e.type==="SelectFun"}function Vt(e){return e.type==="MakeFun"}function Ot(e){return e.type==="PredFun"}function jt(e){let r=Tn();if(r instanceof Error)return r;let t=r,n=e.map(d=>{let S=cn(d,t);return S instanceof Error||(t=S.env),S});if(n.some(d=>d instanceof Error))return n.find(d=>d instanceof Error);let l=n.some(d=>d.result instanceof Error),c=l?n.findIndex(d=>d.result instanceof Error):-1,p=l?n.slice(0,c+1):n;return{type:"Stepper",originProgram:e,progSteps:p}}function cn(e,r){if(Ee(e)){let t=qt(e,r);if(t instanceof Error)return t;if(t.length===0)return{type:"ExprStep",env:r,evalSteps:[],originalDefOrExpr:e,result:Kt(e,r)};{let n=t[t.length-1].result;return Ee(n)?new Error("Result is not a value"):{type:"ExprStep",env:t[t.length-1].env,evalSteps:t,originalDefOrExpr:e,result:n}}}else return un(e,r)}function un(e,r){if(z(e)){let s=e.name,l=e.value;if($(l)){let c=l.value,p=se(r,s.symbol,c),d=p instanceof Error,S=d?{type:"ProgError",result:p}:{type:"Prog",result:e};return{type:"DefinitionStep",env:d?r:p,rule:S,evalSteps:[],originalDefOrExpr:e,result:d?p:e}}else{let c=qt(l,r);if(c instanceof Error)return c;let p=c[c.length-1].result;if(k(p)){let d=se(r,s.symbol,p),S=d instanceof Error,g={type:"Constant Definition",name:s,value:{type:"Literal Value",value:p}},f=S?{type:"ProgError",result:d}:{type:"Prog",result:g};return{type:"DefinitionStep",env:S?r:d,rule:f,evalSteps:c,originalDefOrExpr:e,result:g}}else return p instanceof Error?{type:"DefinitionStep",env:r,rule:{type:"ProgError",result:p},evalSteps:c,originalDefOrExpr:e,result:p}:new Error("Neither a value nor an error; Could not evaluate expression with call-by-value")}}else if(Y(e)){let s=e.name,l={type:"FunEnv",params:e.args,body:e.body},c=se(r,s.symbol,l),p=c instanceof Error,d=p?{type:"ProgError",result:c}:{type:"Prog",result:e};return{type:"DefinitionStep",env:p?r:c,rule:d,evalSteps:[],originalDefOrExpr:e,result:p?c:e}}else{let s=e.binding,l=e.properties,c={type:"StructDef",properties:l},p=se(r,s.symbol,c);if(p instanceof Error)return{type:"DefinitionStep",env:r,rule:{type:"ProgError",result:p},evalSteps:[],originalDefOrExpr:e,result:p};let d=t(s,c),S=n(p,d),g=S instanceof Error,f=g?{type:"ProgError",result:S}:{type:"Prog",result:e};return{type:"DefinitionStep",env:g?r:S,evalSteps:[],rule:f,originalDefOrExpr:e,result:g?S:e}}function t(s,l){let c=l.properties,p=`make-${s.symbol}`,d={type:"MakeFun",structDef:l},S=`${s.symbol}?`,g={type:"PredFun",structDef:l},f=[];c.map(_=>{f.push(`${s.symbol}-${_.symbol}`)});let b={type:"SelectFun",structDef:l},h=[[p,d],[S,g]];return f.forEach(_=>{h.push([_,b])}),h}function n(s,l){console.log("funDefs: ",l);let c=s;for(let p=0;p<l.length;p++){let d=l[p];if(c=se(c,d[0],d[1]),c instanceof Error)return c}return c}}function qt(e,r){let t=[],n=e;for(;!k(n);){let s=Kt(n,r);if(k(s))n=s;else if($e(s))if(s.result instanceof Error){t.push(s);break}else n=s.result,t.push(s);else return s}return t}function Kt(e,r){if($(e))return e.value;{let t=Qe(e);if(we(t)){let n=pn(t.redex,r);if(Dt(n)){let s=Wt(n,t.context,r);return $e(s),s}else return n}else return t}}function Qe(e){let r={type:"Hole"};if(J(e)){let t=e.name,n=e.args;if(n.every(S=>$(S))){let S={type:"CallRedex",name:t,args:n.map(g=>g.value)};return{type:"Split",redex:S,context:r}}let s=n.findIndex(S=>!$(S)),l=n.slice(0,s),c=n[s],p=n.slice(s+1),d=Qe(c);return we(d)?{type:"Split",redex:d.redex,context:{type:"AppContext",op:t,values:l.map(S=>S.value),ctx:d.context,args:p}}:d}else if(Z(e)){let t=e.options[0];if($(t.condition))return{type:"Split",redex:{type:"CondRedex",options:e.options},context:r};{let n=Qe(t.condition);return we(n)?{type:"Split",redex:n.redex,context:{type:"CondContext",options:e.options,ctx:n.context}}:n}}else return j(e)?{type:"Split",context:r,redex:{type:"NameRedex",symbol:e.symbol}}:Error("split: neither a call nor a cond nor name")}function pn(e,r){if(me(e))if(e.args.every(k)){let n=e.args,s=Fe(r,e.name.symbol);if(Mt(s)){let l=dn(e.name,n);return l instanceof Error?{type:"PrimError",redex:e,result:l}:{type:"Prim",redex:e,result:l}}else if(Je(s)){let l=mn(e,r);return l instanceof Error?{type:"FunError",redex:e,result:l}:{type:"Fun",redex:e,result:l}}else if(Ht(s))if(Vt(s)){let l=Sn(e.name,s,n,r);return l instanceof Error?{type:"StructMakeError",redex:e,result:l}:{type:"StructMake",redex:e,result:l}}else if(Ot(s)){let l=gn(e.name,s,n);return l instanceof Error?{type:"StructPredError",redex:e,result:l}:l?{type:"StructPredTrue",redex:e,result:l}:{type:"StructPredFalse",redex:e,result:l}}else{let l=yn(e.name,s,n);return l instanceof Error?{type:"StructSelectError",redex:e,result:l}:{type:"StructSelect",redex:e,result:l}}else return{type:"FunError",redex:e,result:Error(`function '${e.name.symbol}' is not in env`)}}else{let n=Ge(e,r);return n instanceof Error?{type:"ConstError",redex:e,result:n}:{type:"Const",redex:e,result:n}}else if(Se(e))if($(e.options[0].condition)){let t=fn(e);if(t===void 0){let n=e.options.slice(1);if(n.length<1)return{type:"CondError",redex:e,result:Error("'cond': all question results were false")};let s={type:"Cond-Expression",options:n};return{type:"CondFalse",redex:e,result:s}}else return Ee(t)||k(t)?{type:"CondTrue",redex:e,result:t}:{type:"CondError",redex:e,result:t}}else{let t=Ge(e,r);return t instanceof Error?{type:"ConstError",redex:e,result:t}:{type:"Const",redex:e,result:t}}else if(ge(e)){let t=Ge(e,r);return t instanceof Error?{type:"ConstError",redex:e,result:t}:{type:"Const",redex:e,result:t}}else return Error("step: redex is neither a call nor cond nor name")}function Wt(e,r,t){if(Ae(r))return{type:"EvalStep",env:t,rule:e,result:e.result};{let n=Wt(e,r.ctx,t);if($e(n)){if(n.result instanceof Error)return n;if(Ie(r)){let l=[r.values,n.result,r.args].flat().map(p=>k(p)?{type:"Literal Value",value:p}:ye(p)?{type:"Symbol",symbol:p.symbol}:p),c={type:"Function Call",name:r.op,args:l};return{type:"EvalStep",env:t,rule:{type:"Kong",context:r,redexRule:e},result:c}}else if(Be(r)){let s=r.options,l=k(n.result)?{type:"Literal Value",value:n.result}:n.result,p=[{type:"Cond-Option",condition:l,result:s[0].result},...s.slice(1)],d={type:"Cond-Expression",options:p};return{type:"EvalStep",env:t,rule:{type:"Kong",context:r,redexRule:e},result:d}}else return Error("plug: context is not an AppContext or CondContext")}else return n}}function dn(e,r){if(["+","*","-","/"].includes(e.symbol)&&!r.every(t=>typeof t=="number")){let t=r.find(n=>typeof n!="number");return Error(`argument '${t}' is not a number in function '${e.symbol}'`)}switch(e.symbol){case"+":return r.reduce((t,n)=>t+n);case"*":return r.reduce((t,n)=>t*n);case"-":return r.reduce((t,n)=>t-n);case"/":return r.slice(1).every(t=>t!=0)?r.reduce((t,n)=>t/n):Error(`division by zero in function '${e.symbol}'`);default:}if(["and","or","not"].includes(e.symbol)&&!r.every(t=>typeof t=="boolean")){let t=r.find(n=>typeof n!="boolean");return Error(`argument '${t}' is not a boolean in function '${e.symbol}'`)}switch(e.symbol){case"and":return r.length<2?Error(`function '${e.symbol}' needs at least two arguments`):r.every(t=>t);case"or":return r.length<2?Error(`function '${e.symbol}' needs at least two arguments`):r.some(t=>t);case"not":return r.length!==1?Error(`function '${e.symbol}' needs exactly one argument`):!r[0];default:}if(["<",">","<=",">="].includes(e.symbol)){if(r.length!==2)return Error(`function '${e.symbol}' needs exactly two arguments`);let t=r[0],n=r[1];if(typeof t!="number"||typeof n!="number")return Error(`function '${e.symbol}' needs two numbers, but received '${t}' and '${n}'`);switch(e.symbol){case"<":return t<n;case"<=":return t<=n;case">=":return t>=n;case">":return t>n;default:return!0}}else return Error(`function '${e.symbol}' is no implemented primitive function`)}function fn(e){let r=e.options[0];return $(r.condition)&&r.condition.value==!0?$(r.result)?r.result.value:r.result:$(r.condition)&&r.condition.value==!1?void 0:Error("'cond': condition is not a boolean")}function Ge(e,r){if(me(e)){let t=e.args.find(ye);if(!t)return Error("id: could not find an identifier in argument list");let n=ke(r,t.symbol);if(n instanceof Error)return n;let s=e.args.map(l=>ye(l)&&l.symbol===t.symbol?{type:"Literal Value",value:n}:ye(l)?{type:"Symbol",symbol:l.symbol}:{type:"Literal Value",value:l});return{type:"Function Call",name:e.name,args:s}}else if(Se(e)){let t=e.options[0].condition;if(!j(t))return Error("substConst: condition is not a name");let n=ke(r,t.symbol);if(n instanceof Error)return n;let s={type:"Literal Value",value:n},l={type:"Cond-Option",condition:s,result:e.options[0].result};return{type:"Cond-Expression",options:[l]}}else return ge(e)?ke(r,e.symbol):Error("substConst: redex is not a call or cond or name")}function mn(e,r){let t=xn(r,e.name.symbol);if(t instanceof Error)return t;let n=t.params;if(e.args.length!=n.length)return Error(`Arity mismatch in '${e.name.symbol}': number of arguments are not equal to number of parameters`);let s={};n.forEach((p,d)=>{let S=se(s,p.symbol,e.args[d]);if(S instanceof Error)return S;s=S});let l=t.body;return Ue(l,s)}function Sn(e,r,t,n){let s=r.structDef.properties,l=e.symbol.slice(5);return bn(n,l)instanceof Error?Error(`'${l}' not found in environment`):s.length==t.length?{type:"Struct Value",structDef:e,properties:t.map(d=>({type:"Literal Value",value:d}))}:Error(`Arity mismatch in '${e.symbol}: number of arguments does not match number of properties`)}function gn(e,r,t){let n=r.structDef.properties;if(t.length!=1)return Error(`'${e.symbol}' takes exactly one argument`);if(q(t[0])){let s=t[0],l=s.structDef.symbol.split("-")[1],c=e.symbol.split("?")[0];return l===c?n.length==s.properties.length:!1}else return!1}function yn(e,r,t){if(t.length!=1)return Error("selectStruct: number of arguments doesn't match");if(q(t[0])){let n=t[0],s=n.structDef.symbol.split("-")[1],l=e.symbol.split("-")[0],c=e.symbol.split("-")[1];if(s!==l)return Error("selectStruct: struct name doesn't match");{let p=r.structDef.properties.map(d=>d.symbol);if(p.includes(c)){let d=p.indexOf(c),S=n.properties[d];return $(S)?S.value:n.properties[d]}else return Error("selectStruct: property doesn't exist")}}else return Error("selectStruct: argument is not a struct value")}function Ue(e,r){if($(e))return e;if(j(e)){let t=ke(r,e.symbol);return t instanceof Error?t:{type:"Literal Value",value:t}}else if(J(e)){let t=e.args.map(n=>{let s=Ue(n,r);return s instanceof Error?n:s});return t.some(n=>n instanceof Error)?Error("substExpr: error in args"):{type:"Function Call",name:e.name,args:t}}else{let t=e.options.map(s=>{let l=Ue(s.condition,r),c=Ue(s.result,r);return l instanceof Error||c instanceof Error?Error("substExpr: error in cond"):{type:"Cond-Option",condition:l,result:c}});return t.some(s=>s instanceof Error)?Error("substExpr: error in cond"):{type:"Cond-Expression",options:t}}}function Tn(){let e={};return Object.entries(Ke).forEach(r=>{if(e instanceof Error)return e;e=se(e,r[1],{type:"PrimDef"})}),e===void 0?Error("initEnv: environment is undefined"):(e instanceof Error,e)}function se(e,r,t){if(e[r]===void 0){let n=W({},e);return n[r]=t,n}else return Error(`'${r}' already exists in environment`)}function Fe(e,r){return r in e?e[r]:Error(`'${r}' is not bound in environment`)}function ke(e,r){let t=Fe(e,r);return t instanceof Error||k(t)?t:Error("lookupConst: name is not bound to a Value")}function xn(e,r){let t=Fe(e,r);return t instanceof Error||Je(t)?t:Error("lookupFun: name is not bound to a Fun")}function bn(e,r){let t=Fe(e,r);return t instanceof Error||Nt(t)?t:Error("lookupStruct: name is not bound to a Struct")}var Jt=`/* ######### colors ####### */
.bsl-tools-stepper {
/* --branch-color: #666; */
--box-background: #ebf0f4; /* racket azure */
--box-border: #0d3657;
--button-border: #0d3657;
--text-grey: #444; /* like in scribble */
--hole-yellow: #fdf68d; /* pale yellow */
--hole-green: lightgreen;
--hole-red: lightpink;
--font-family-monospace: 'Fira Sans', monospace;
--font-family-rule-description: Palatino, Georgia, "Times New Roman", serif;
}
/* ####### general layout ####### */
div.bsl-tools-stepper {
text-align: center;
box-sizing: border-box;
}
/* ##### boxes ###### */
.bsl-tools-stepper .box {
text-align: left;
background-color: var(--box-background);
padding: 0.5em;
padding-top: 1em;
border: 1px solid var(--box-border);
border-radius: 0.5em;
position: relative;
margin-bottom: 1.5em;
}
.bsl-tools-stepper .boxlabel {
position: absolute;
top: -1em;
left: 0.5em;
padding: 0.25em;
border: 0px solid transparent;
border-radius: 0.25em;
background-color: var(--box-background);
color: var(--box-border);
}
/* single step */
.bsl-tools-stepper .step {
margin-bottom: 0.5em;
position: relative;
background-color: white;
padding: 0.5em;
}
/* ####### buttons ###### */
.bsl-tools-stepper .step[data-currentStep="true"] {
padding-top: 1.5em;
margin-top: 1.5em;
padding-bottom: 1.5em;
margin-bottom: 1.5em;
}
.bsl-tools-stepper .prev-button, .bsl-tools-stepper .next-button {
display: none;
}
.bsl-tools-stepper [data-currentStep="true"] .prev-button,
.bsl-tools-stepper [data-currentStep="true"] .next-button {
position: absolute;
display: inline-block;
right: 2em;
padding: 0.5em;
border: 1px solid var(--button-border);
background-color: white;
border-radius: 0.25em;
}
.bsl-tools-stepper .prev-button:hover, .bsl-tools-stepper .next-button:hover {
cursor: pointer;
}
.bsl-tools-stepper .prev-button {
top: -1em;
}
/* second child because of box label */
.bsl-tools-stepper .step:nth-child(2) .prev-button {
top: -3.5em;
}
.bsl-tools-stepper .next-button {
bottom: -1.25em;
}
.bsl-tools-stepper .step:last-child .next-button {
bottom: -3.25em;
}
.bsl-tools-stepper .step:last-child .info-toggle {
position: absolute;
right: 0;
bottom: -4em;
margin: 0;
background-color: white;
}
.bsl-tools-stepper .icon {
display: inline-block;
height: 1em;
}
.bsl-tools-stepper .split-result .icon {
opacity: 70%;
}
.bsl-tools-stepper [data-visible="false"] {
display: none;
}
/* ######### code and rules ####### */
.bsl-tools-stepper .code {
font-family: var(--font-family-monospace, monospace);
color: var(--text-grey);
}
.bsl-tools-stepper .plug-result {
position: relative;
z-index: 2;
}
.bsl-tools-stepper .hole {
display: inline-block;
background-color: var(--hole-yellow);
/* border: 1px solid var(--text-grey); */
color: var(--text-grey);
padding-left: 0.25em;
padding-right: 0.25em;
position: relative;
}
.bsl-tools-stepper .hole-result {
background-color: var(--hole-green);
}
.bsl-tools-stepper .hole-result.rule-hole {
padding: 0;
}
.bsl-tools-stepper .hole-error {
background-color: var(--hole-red);
}
.bsl-tools-stepper .rule {
display: inline-block;
position: relative;
padding-left: .5em;
width: fit-content;
white-space: nowrap;
margin-top: 1em;
margin-bottom: 1.5em;
}
.bsl-tools-stepper .kong {
position: absolute;
left: 0;
top: 0;
padding-left: 0;
background-color: rgba(255,255,255,0.5);
}
.bsl-tools-stepper .one-rule {
margin-left: var(--one-rule-margin-left, 4em);
}
.bsl-tools-stepper .rule-description {
font-family: var(--font-family-monospace, monospace);
}
/* arrow body */
.bsl-tools-stepper .left-arrowed::before {
position: absolute;
content: '';
left: 0;
top: -0.5em;
height: 2.5em;
border-left: 2px solid var(--text-grey);
z-index: -1;
}
.bsl-tools-stepper .kong::before {
left: 0.35em;
border-left: 2px dotted var(--text-grey);
}
/* arrow head */
.bsl-tools-stepper .left-arrowed::after {
position: absolute;
content: '';
left: calc(2px - 0.35em); /*-0.35em; /* ca. sqrt(2)/2 * 0.5em */
top: 1.5em;
width: 0.5em;
height: 0.5em;
border-right: 2px solid var(--text-grey);
border-bottom: 2px solid var(--text-grey);
transform: rotate(45deg);
}
.bsl-tools-stepper .kong::after {
left: 2px;
}
/* rule info */
.bsl-tools-stepper .info-toggle {
margin-top: 1em;
margin-bottom: 1.5em;
margin-left: 0.5em;
float: right;
}
.bsl-tools-stepper .info-toggle:hover {
cursor: pointer;
}
.bsl-tools-stepper .rule-info {
padding: 0.5em;
}
.bsl-tools-stepper .rule-info-rule-text {
font-family: var(--font-family-rule-description, serif);
}
.bsl-tools-stepper .rule-info-rule-text small {
vertical-align: sub;
}
.bsl-tools-stepper cap {
font-variant-caps: small-caps;
}
.bsl-tools-stepper .rule-info-rule-name {
position: absolute;
left: -6em;
top: 0;
}
.bsl-tools-stepper .rule-info-text-container {
position: relative;
margin-left: 6em;
margin-bottom: 1em;
}
/* ##### showing and hiding stuff #### */
/* hide steps that are not yet reached */
.bsl-tools-stepper .step[data-currentStep="true"] ~ .step {
display: none;
}
/* collapsing and expanding steps */
.bsl-tools-stepper .step[data-collapsed="true"] .plug-result {
display: none;
}
.bsl-tools-stepper .expander, .bsl-tools-stepper .collapser {
padding-left: 0.25em;
padding-right: 0.25em;
float: right;
}
.bsl-tools-stepper .expander:hover, .bsl-tools-stepper .collapser:hover {
cursor: pointer;
}
.bsl-tools-stepper .step[data-collapsed="true"] .collapser {
display: none;
}
.bsl-tools-stepper .step[data-collapsed="false"] .expander {
display: none;
}
/* collapsing and expanding info about the rules */
.bsl-tools-stepper .plug-result[data-info-collapsed="true"] .rule-info,
.bsl-tools-stepper .plug-result[data-info-collapsed="true"] .info-collapse {
display: none;
}
.bsl-tools-stepper .plug-result[data-info-collapsed="false"] .info-expand {
display: none;
}
`;var De="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAzODQgNTEyIj48IS0tISBGb250IEF3ZXNvbWUgUHJvIDYuMS4xIGJ5IEBmb250YXdlc29tZSAtIGh0dHBzOi8vZm9udGF3ZXNvbWUuY29tIExpY2Vuc2UgLSBodHRwczovL2ZvbnRhd2Vzb21lLmNvbS9saWNlbnNlIChDb21tZXJjaWFsIExpY2Vuc2UpIENvcHlyaWdodCAyMDIyIEZvbnRpY29ucywgSW5jLiAtLT48cGF0aCBkPSJNMzUyIDM1MmMtOC4xODggMC0xNi4zOC0zLjEyNS0yMi42Mi05LjM3NUwxOTIgMjA1LjNsLTEzNy40IDEzNy40Yy0xMi41IDEyLjUtMzIuNzUgMTIuNS00NS4yNSAwcy0xMi41LTMyLjc1IDAtNDUuMjVsMTYwLTE2MGMxMi41LTEyLjUgMzIuNzUtMTIuNSA0NS4yNSAwbDE2MCAxNjBjMTIuNSAxMi41IDEyLjUgMzIuNzUgMCA0NS4yNUMzNjguNCAzNDguOSAzNjAuMiAzNTIgMzUyIDM1MnoiLz48L3N2Zz4=";var Me="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAzODQgNTEyIj48IS0tISBGb250IEF3ZXNvbWUgUHJvIDYuMS4xIGJ5IEBmb250YXdlc29tZSAtIGh0dHBzOi8vZm9udGF3ZXNvbWUuY29tIExpY2Vuc2UgLSBodHRwczovL2ZvbnRhd2Vzb21lLmNvbS9saWNlbnNlIChDb21tZXJjaWFsIExpY2Vuc2UpIENvcHlyaWdodCAyMDIyIEZvbnRpY29ucywgSW5jLiAtLT48cGF0aCBkPSJNMTkyIDM4NGMtOC4xODggMC0xNi4zOC0zLjEyNS0yMi42Mi05LjM3NWwtMTYwLTE2MGMtMTIuNS0xMi41LTEyLjUtMzIuNzUgMC00NS4yNXMzMi43NS0xMi41IDQ1LjI1IDBMMTkyIDMwNi44bDEzNy40LTEzNy40YzEyLjUtMTIuNSAzMi43NS0xMi41IDQ1LjI1IDBzMTIuNSAzMi43NSAwIDQ1LjI1bC0xNjAgMTYwQzIwOC40IDM4MC45IDIwMC4yIDM4NCAxOTIgMzg0eiIvPjwvc3ZnPg==";var Gt="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA0NDggNTEyIj48IS0tISBGb250IEF3ZXNvbWUgUHJvIDYuMS4wIGJ5IEBmb250YXdlc29tZSAtIGh0dHBzOi8vZm9udGF3ZXNvbWUuY29tIExpY2Vuc2UgLSBodHRwczovL2ZvbnRhd2Vzb21lLmNvbS9saWNlbnNlIChDb21tZXJjaWFsIExpY2Vuc2UpIENvcHlyaWdodCAyMDIyIEZvbnRpY29ucywgSW5jLiAtLT48cGF0aCBkPSJNNDMyIDI1NmMwIDE3LjY5LTE0LjMzIDMyLjAxLTMyIDMyLjAxSDI1NnYxNDRjMCAxNy42OS0xNC4zMyAzMS45OS0zMiAzMS45OXMtMzItMTQuMy0zMi0zMS45OXYtMTQ0SDQ4Yy0xNy42NyAwLTMyLTE0LjMyLTMyLTMyLjAxczE0LjMzLTMxLjk5IDMyLTMxLjk5SDE5MnYtMTQ0YzAtMTcuNjkgMTQuMzMtMzIuMDEgMzItMzIuMDFzMzIgMTQuMzIgMzIgMzIuMDF2MTQ0aDE0NEM0MTcuNyAyMjQgNDMyIDIzOC4zIDQzMiAyNTZ6Ii8+PC9zdmc+";var Qt="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA0NDggNTEyIj48IS0tISBGb250IEF3ZXNvbWUgUHJvIDYuMS4wIGJ5IEBmb250YXdlc29tZSAtIGh0dHBzOi8vZm9udGF3ZXNvbWUuY29tIExpY2Vuc2UgLSBodHRwczovL2ZvbnRhd2Vzb21lLmNvbS9saWNlbnNlIChDb21tZXJjaWFsIExpY2Vuc2UpIENvcHlyaWdodCAyMDIyIEZvbnRpY29ucywgSW5jLiAtLT48cGF0aCBkPSJNNDAwIDI4OGgtMzUyYy0xNy42OSAwLTMyLTE0LjMyLTMyLTMyLjAxczE0LjMxLTMxLjk5IDMyLTMxLjk5aDM1MmMxNy42OSAwIDMyIDE0LjMgMzIgMzEuOTlTNDE3LjcgMjg4IDQwMCAyODh6Ii8+PC9zdmc+";var Ne="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA1MTIgNTEyIj48IS0tISBGb250IEF3ZXNvbWUgUHJvIDYuMS4yIGJ5IEBmb250YXdlc29tZSAtIGh0dHBzOi8vZm9udGF3ZXNvbWUuY29tIExpY2Vuc2UgLSBodHRwczovL2ZvbnRhd2Vzb21lLmNvbS9saWNlbnNlIChDb21tZXJjaWFsIExpY2Vuc2UpIENvcHlyaWdodCAyMDIyIEZvbnRpY29ucywgSW5jLiAtLT48cGF0aCBkPSJNMjU2IDBDMTE0LjYgMCAwIDExNC42IDAgMjU2czExNC42IDI1NiAyNTYgMjU2czI1Ni0xMTQuNiAyNTYtMjU2UzM5Ny40IDAgMjU2IDB6TTI1NiAxMjhjMTcuNjcgMCAzMiAxNC4zMyAzMiAzMmMwIDE3LjY3LTE0LjMzIDMyLTMyIDMyUzIyNCAxNzcuNyAyMjQgMTYwQzIyNCAxNDIuMyAyMzguMyAxMjggMjU2IDEyOHpNMjk2IDM4NGgtODBDMjAyLjggMzg0IDE5MiAzNzMuMyAxOTIgMzYwczEwLjc1LTI0IDI0LTI0aDE2di02NEgyMjRjLTEzLjI1IDAtMjQtMTAuNzUtMjQtMjRTMjEwLjggMjI0IDIyNCAyMjRoMzJjMTMuMjUgMCAyNCAxMC43NSAyNCAyNHY4OGgxNmMxMy4yNSAwIDI0IDEwLjc1IDI0IDI0UzMwOS4zIDM4NCAyOTYgMzg0eiIvPjwvc3ZnPg==";var He="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA1MTIgNTEyIj48IS0tISBGb250IEF3ZXNvbWUgUHJvIDYuMS4yIGJ5IEBmb250YXdlc29tZSAtIGh0dHBzOi8vZm9udGF3ZXNvbWUuY29tIExpY2Vuc2UgLSBodHRwczovL2ZvbnRhd2Vzb21lLmNvbS9saWNlbnNlIChDb21tZXJjaWFsIExpY2Vuc2UpIENvcHlyaWdodCAyMDIyIEZvbnRpY29ucywgSW5jLiAtLT48cGF0aCBkPSJNMCAyNTZDMCAxMTQuNiAxMTQuNiAwIDI1NiAwQzM5Ny40IDAgNTEyIDExNC42IDUxMiAyNTZDNTEyIDM5Ny40IDM5Ny40IDUxMiAyNTYgNTEyQzExNC42IDUxMiAwIDM5Ny40IDAgMjU2ek0xNzUgMjA4LjFMMjIyLjEgMjU1LjFMMTc1IDMwM0MxNjUuNyAzMTIuNCAxNjUuNyAzMjcuNiAxNzUgMzM2LjFDMTg0LjQgMzQ2LjMgMTk5LjYgMzQ2LjMgMjA4LjEgMzM2LjFMMjU1LjEgMjg5LjlMMzAzIDMzNi4xQzMxMi40IDM0Ni4zIDMyNy42IDM0Ni4zIDMzNi4xIDMzNi4xQzM0Ni4zIDMyNy42IDM0Ni4zIDMxMi40IDMzNi4xIDMwM0wyODkuOSAyNTUuMUwzMzYuMSAyMDguMUMzNDYuMyAxOTkuNiAzNDYuMyAxODQuNCAzMzYuMSAxNzVDMzI3LjYgMTY1LjcgMzEyLjQgMTY1LjcgMzAzIDE3NUwyNTUuMSAyMjIuMUwyMDguMSAxNzVDMTk5LjYgMTY1LjcgMTg0LjQgMTY1LjcgMTc1IDE3NUMxNjUuNyAxODQuNCAxNjUuNyAxOTkuNiAxNzUgMjA4LjFWMjA4LjF6Ii8+PC9zdmc+";function Yt(){Array.from(document.getElementsByTagName("stepper")).map(e=>{try{let r=Le(re(e.innerHTML));console.log(r),$n(r,e)}catch(r){Pn(r,e)}})}function Pn(e,r){console.error(e);let t=e?`${e}`:"Unknown Error";r.innerHTML=`
<h3>Error turning Program into Stepper</h3>
<div>${r.innerHTML}</div>
<div>${t}</div>
`,r.style.cssText=`
padding: 2em;
color: darkred;
display: block;
`}function $n(e,r){An();let t=jt(e);if(console.log(te(Et(e),30)),console.log(t),t instanceof Error)throw t;let n=In(r),s=Bn(r);r.innerHTML=wn(t,n,s)}function An(){if(!document.getElementById("bsl-tools-stepper-style")){let e=document.createElement("style");e.innerHTML=Jt,e.id="bsl-tools-stepper-style",document.getElementsByTagName("head")[0].appendChild(e)}}function In(e){let r=e.getAttribute("lang");if(r){if(!Xt.includes(r))return console.error(`
Language ${r} is not implemented for this module,
you can choose from ${Xt.join(",")}.
Defaulting to 'en'.
`),"en"}else return"en";return r}function Bn(e){let r="Loading...";e.innerHTML=`
<div class="bsl-tools-stepper" style="width: 100%;">
<div class="box">
<div class="step code"
data-currentStep="true">
<p style="display: inline-block;">${r}</p>
</div>
</div>
</div>
`;let t=e.getElementsByTagName("p")[0],n=e.getElementsByClassName("bsl-tools-stepper")[0];if(!t||!n)return console.error("failed to inject measuring HTML into",e),{charWidth:12,maxChars:80};let s=t.clientWidth/r.length,c=Math.round(.9*n.clientWidth/s);return{charWidth:s,maxChars:c}}var Xt=["en","de"],F={en:{"current evaluation":"Current Evaluation","next step":"Next Step","previous step":"Previous Step",environment:"Environment","remaining program":"Remaining Program","start evaluation":"Start Evaluation","evaluation finished":"Evaluation Finished","go back":"Go Back"},de:{"current evaluation":"Aktuelle Auswertung","next step":"N\xE4chster Schritt","previous step":"Vorheriger Schritt",environment:"Umgebung","remaining program":"Verbleibendes Programm","start evaluation":"Auswertung Starten","evaluation finished":"Auswertung Beendet","go back":"Schritt zur\xFCck"}};function wn(e,r,t){let n=e.progSteps;return`
<div class="bsl-tools-stepper">
<div class="box environment">
<div class="boxlabel">${F[r].environment}</div>
${n.map((s,l)=>Un(s,l,t)).join("")}
</div>
<div class="box eval-steps"
data-progstep="-1"
data-visible="true">
<div class="boxlabel">${F[r]["current evaluation"]}</div>
<div class="step"
data-currentStep="true">
<div class="next-button"
onclick="takeProgSteps(event, 1)">
<cap>Prog</cap>: ${F[r]["start evaluation"]} <img class="icon" src="${Me}">
</div>
<div class="plug-result code"
data-info-collapsed="true">
<img class="icon info-toggle info-expand"
src="${Ne}"
onclick="expandInfo(event)">
<img class="icon info-toggle info-collapse"
src="${He}"
onclick="collapseInfo(event)">
${Ye("Prog",!1)}
</div>
</div>
</div>
${n.map((s,l)=>Fn(s,l,r,t)).join("")}
<div class="box eval-steps"
data-progstep="${n.length}"
data-visible="false">
<div class="boxlabel">${F[r]["current evaluation"]}</div>
<div class="step"
data-currentStep="true">
<div class="code">${F[r]["evaluation finished"]}</div>
<div class="prev-button"
onclick="takeProgSteps(event, -1)">
${F[r]["go back"]} <img class="icon" src="${De}">
</div>
</div>
</div>
<div class="box program">
<div class="boxlabel">${F[r]["remaining program"]}</div>
${e.originProgram.map((s,l)=>kn(s,l,t)).join("")}
</div>
</div>`}window.takeProgSteps=(e,r)=>{Xe(e,r)};function Un(e,r,t){return!Pe(e)||e.result instanceof Error?"":`
<div class="step code"
data-progstep="${r}"
data-visible="false">
${te(B(ve(e.result)),t.maxChars,"html")}
</div>
`}function kn(e,r,t){return`
<div class="step code"
data-progstep="${r}"
data-visible="true">
${te(B(ae(e)),t.maxChars,"html")}
</div>
`}function Fn(e,r,t,n){let s=Pe(e)&&z(e.originalDefOrExpr)?{left:`(define ${e.originalDefOrExpr.name.symbol} `,right:")"}:{left:"",right:""};return`
<div class="box eval-steps"
data-progstep="${r}"
data-visible="false">
<div class="boxlabel">${F[t]["current evaluation"]}</div>
${e.evalSteps.map((l,c)=>On(c,l,t,W({},s),n)).join("")}
${Dn(e,t,n)}
</div>
`}function Dn(e,r,t){return`
<div class="step"
data-step="${e.evalSteps.length}"
data-currentStep="${e.evalSteps.length===0?"true":"false"}"
data-collapsed="false">
<div class="prev-button"
onclick="prevStep(event)">
${F[r]["previous step"]} <img class="icon" src="${De}">
</div>
<div class="next-button"
onclick="nextStep(event)">
<cap>Prog</cap>: ${F[r]["next step"]} <img class="icon" src="${Me}">
</div>
<div class="plug-result code"
data-info-collapsed="true">
${te(B(Pe(e)&&!(e.result instanceof Error)?ve(e.result):`${e.result instanceof Error?e.result:ce(e.result)}`),t.maxChars)}
<img class="icon info-toggle info-expand"
src="${Ne}"
onclick="expandInfo(event)">
<img class="icon info-toggle info-collapse"
src="${He}"
onclick="collapseInfo(event)">
${Ye("Prog",!1)}
</div>
</div>
`}function Xe(e,r){let t=e.target,n=t.getBoundingClientRect().y,s=U(t,"eval-steps");if(!s){console.error("found no parent with class .eval-steps",t);return}let l=s.getAttribute("data-progstep");if(!l){console.error("div with class .eval-steps has no data-progstep attribute",s);return}let p=parseInt(l)+r;if(p<-1){console.error(`cannot navigate to progStep ${p}: does not exist`);return}let d=s.parentElement;if(!d)return;Mn(d,p),Nn(d,p);let S=Hn(d,p);Vn(S,n,r>0)}function Mn(e,r){w([e],".environment/div").forEach(t=>{let n=t.getAttribute("data-progstep");n&&t.setAttribute("data-visible",parseInt(n)<r?"true":"false")})}function Nn(e,r){w([e],".program/div").forEach(t=>{let n=t.getAttribute("data-progstep");n&&t.setAttribute("data-visible",parseInt(n)>r?"true":"false")})}function Hn(e,r){return w([e],".eval-steps").filter(t=>{let n=t.getAttribute("data-progstep"),s=n&&parseInt(n)===r;return t.setAttribute("data-visible",s?"true":"false"),s})[0]}function Vn(e,r,t){let n=Array.from(e.children).filter(c=>c.getAttribute("data-currentstep")==="true")[0];if(!n)return;let s=n.querySelector(t?".next-button":".prev-button");if(!s)return;let l=s.getBoundingClientRect().y;window.scrollBy(0,l-r)}function On(e,r,t,n={left:"",right:""},s){let l=We(r.rule)?Zt(r.rule.context,n):n,c=We(r.rule)?r.rule.redexRule:r.rule,p=B(jn(c.redex));function d(N){if(k(N)){let V=ce(N);return{html:`${l.left}<span class="hole hole-result">${B(V)}</span>${l.right}`,redex:V}}else if(N instanceof Error){let V=`${N}`,G=`<span class="hole hole-result hole-error">"${N}"</span>`;return{redex:V,html:G}}else{let V=v(N),G=`${l.left}<span class="hole hole-result">${B(V)}</span>${l.right}`;return{redex:V,html:G}}}let S=d(c.result),g=c.type,f=te(`${l.left}<span class="hole">${p}</span>${l.right}`,s.maxChars,"html"),b=te(S.html,s.maxChars,"html"),h=b.slice(0,b.indexOf('<span class="hole hole-result')).split("<br>").reverse()[0],_=h?re(h).length:0,A=4,ie=l.left.length>0&&_<A?A:_,D=pe[g].name.replaceAll("<cap>","").replaceAll("</cap>",""),le=s.maxChars-ie-D.length-5,Te=p.length+S.redex.length<=le;return`
<div class="step"
data-step="${e}"
data-currentStep="${e===0?"true":"false"}"
data-collapsed="false">
<div class="prev-button"
onclick="prevStep(event)">
${F[t]["previous step"]} <img class="icon" src="${De}">
</div>
<div class="next-button"
onclick="nextStep(event)">
${F[t]["next step"]} <img class="icon" src="${Me}">
</div>
<div class="split-result code">${f}<img class="icon expander"
src="${Gt}"
onclick="expand(event)"
><img class="icon collapser"
src="${Qt}"
onclick="collapse(event)"
></div>
<div class="plug-result code"
data-info-collapsed="true">
<div>
${l.left!==""?`<span class="rule rule-name left-arrowed kong">
${pe.Kong.name}
</span>`:""}
<span class="rule left-arrowed one-rule"
style="--one-rule-margin-left: ${ie*s.charWidth}px">
<span class="rule-name">${pe[g].name}</span>${Te?`:
<span class="rule-description">
<span class="hole rule-hole">${p}</span> \u2192
<span class="hole hole-result rule-hole">${B(S.redex)}</span>
</span>`:""}
</span>
<img src="${Ne}"
class="icon info-toggle info-expand"
onclick="expandInfo(event)">
<img src="${He}"
class="icon info-toggle info-collapse"
onclick="collapseInfo(event)">
</div>
${Ye(g,l.left!=="")}
<div>${b}</div>
</div>
</div>
`}window.nextStep=e=>{let r=e.target,t=r.getBoundingClientRect().y,n=U(r,"step");if(!n)return;let s=n.nextElementSibling;if(!s){Xe(e,1);return}n.setAttribute("data-currentStep","false"),n.setAttribute("data-collapsed","true"),s.setAttribute("data-currentStep","true"),s.setAttribute("data-collapsed","false");let l=s.querySelector(".next-button");if(!l)return;let c=l.getBoundingClientRect().y;window.scrollBy(0,c-t)};window.prevStep=e=>{let r=e.target,t=r.getBoundingClientRect().y,n=U(r,"step");if(!n){console.error("prevStep not called from within an element of the .step class");return}if(n.getAttribute("data-step")==="0"){Xe(e,-1);return}let l=n.previousElementSibling;if(!l){console.error("prevStep called on a step with no previous html element");return}n.setAttribute("data-currentStep","false"),n.setAttribute("data-collapsed","true"),l.setAttribute("data-currentStep","true"),l.setAttribute("data-collapsed","false");let c=l.querySelector(".prev-button");if(!c)return;let p=c.getBoundingClientRect().y;window.scrollBy(0,p-t)};window.collapse=e=>{let r=e.target,t=U(r,"step");t&&t.setAttribute("data-collapsed","true")};window.expand=e=>{let r=e.target,t=U(r,"step");t&&t.setAttribute("data-collapsed","false")};function Zt(e,r={left:"",right:""}){if(Ae(e))return{left:B(r.left),right:B(r.right)};if(Ie(e)){let t=[E(e.op),...e.values.map(n=>q(n)?ce(n):`${n}`)];r.left=`${r.left}(${t.join(" ")} `,r.right=e.args.length>0?` ${e.args.map(v).join(" ")})${r.right}`:`)${r.right}`}else if(Be(e)){r.left=`${r.left}(cond [`;let t=[`${v(e.options[0].result)}]`,...e.options.slice(1).map(ee)];r.right=` ${t.join(" ")})${r.right}`}else throw console.error("Printing this context is not implemented yet",e),`Printing ${e.type} context is not implemented yet!`;return Zt(e.ctx,r)}function zn(e){return k(e)?ce(e):qn(e)}function jn(e){if(me(e))return`(${E(e.name)} ${e.args.map(zn).join(" ")})`;if(Se(e))return`(cond ${e.options.map(ee).join(" ")})`;if(ge(e))return e.symbol;throw"Invalid Input to printRedex"}function qn(e){return e.symbol}function Ye(e,r){let t=pe[e];return`<div class="rule-info">${r?`
<div class="rule-info-text-container">
<div class="rule-info-rule-name">${pe.Kong.name}</div>
<div class="rule-info-rule-text">${pe.Kong.text}</div>
</div>
`:""}
<div class="rule-info-text-container">
<div class="rule-info-rule-name">${t.name}</div>
<div class="rule-info-rule-text">${t.text}</div>
</div>
</div>`}window.expandInfo=e=>{let r=e.target,t=U(r,"plug-result");!t||t.setAttribute("data-info-collapsed","false")};window.collapseInfo=e=>{let r=e.target,t=U(r,"plug-result");t&&t.setAttribute("data-info-collapsed","true")};var pe={Kong:{name:"<cap>Kong</cap>",text:`
<em>E[e<small>1</small>] \u2192 E[e<small>2</small>] falls e<small>1</small> \u2192 e<small>2</small></em><br>
<em>\u2039E\u203A ::= []<br>
| (\u2039name\u203A \u2039v\u203A* \u2039E\u203A \u2039e\u203A*)<br>
| (<strong>cond</strong> [\u2039E\u203A \u2039e\u203A ]{[ \u2039e\u203A \u2039e\u203A]}*)</em>
`},Fun:{name:"<cap>Fun</cap>",text:`
<em>(name v<small>1</small> \u2026 v<small>n</small>) \u2192
e[name<small>1</small> := v<small>1</small> \u2026 name<small>n</small> := v<small>n</small> ]</em>
falls
<em>(</em> <strong>define</strong> <em>(name name<small>1</small> \u2026 name<small>n</small>) e)</em> in Umgebung
`},FunError:{name:"<cap>FunError</cap>",text:`
<em>(name v<small>1</small> \u2026 v<small>n</small>) \u2192 Error</em>
falls
<em>(</em> <strong>define</strong> <em>(name name<small>1</small> \u2026 name<small>n</small>) e)</em> nicht in Umgebung.
`},Prim:{name:"<cap>Prim</cap>",text:`
<em>(name v<small>1</small> \u2026 v<small>n</small>) \u2192 v</em> falls
<em>name</em> eine primitive Funktion <em>f</em> ist und
<em>f(v<small>1</small> \u2026 v<small>n</small>) = v</em>
`},PrimError:{name:"<cap>Prim</cap>-Error",text:`
<em>(name v<small>1</small> \u2026 v<small>n</small>) \u2192 Error</em> falls
<em>name</em> eine primitive Funktion <em>f</em> ist und
<em>f(v<small>1</small> \u2026 v<small>n</small>) = Error</em>
`},Const:{name:"<cap>Const</cap>",text:`
<em>name \u2192 v</em> falls <em>(<strong>define</strong> name v)</em> in Umgebung.
`},ConstError:{name:"<cap>Const</cap>-Error",text:`
<em>name \u2192 Error</em> falls <em>(<strong>define</strong> name v)</em>
nicht in Umgebung.
`},CondTrue:{name:"<cap>Cond</cap>-True",text:`
<em>(<strong>cond</strong> [<strong>#true</strong> e] \u2026) \u2192 e</em>
`},CondFalse:{name:"<cap>Cond</cap>-False",text:`
<em>(<strong>cond</strong> [<strong>#false</strong> e<small>1</small>]
[e<small>2</small> e<small>3</small>] \u2026) \u2192
(<strong>cond</strong> [e<small>2</small> e<small>3</small>] \u2026)</em>
`},CondError:{name:"<cap>Cond</cap>-Error",text:`
<em>(<strong>cond</strong> [e<small>1</small> e<small>2</small>] \u2026) \u2192
(<strong>error</strong> "cond: all conditions false")</em>
`},StructMake:{name:"<cap>Struct</cap>-make",text:`
<em>(<strong>make</strong>-name v<small>1</small> \u2026 v<small>n</small>) \u2192
<<strong>make</strong>-name v<small>1</small> \u2026 v<small>n</small>></em>
falls <em>(<strong>define-struct</strong> name (name<small>1</small> \u2026 name<small>n</small>))</em> in Umgebung
`},StructMakeError:{name:"<cap>Struct</cap>-make-Error",text:""},StructSelect:{name:"<cap>Struct</cap>-select",text:`
<em>(name-name<small>i</small> <<strong>make</strong>-name
v<small>1</small> \u2026 v<small>n</small>>) \u2192 v<small>i</small></em>
falls <em>(<strong>define-struct</strong> name
(name<small>1</small> \u2026 name<small>n</small>))</em> in Umgebung
`},StructSelectError:{name:"<cap>Struct</cap>-select-Error",text:""},StructPredTrue:{name:"<cap>Struct</cap>-predtrue",text:`
<em>(name? <<strong>make</strong>-name \u2026>) \u2192 <strong>#true</strong></em>
`},StructPredFalse:{name:"<cap>Struct</cap>-predfalse",text:`
<em>(name? v) \u2192 <strong>#false</strong></em> falls <em>v</em> nicht
<em><<strong>make</strong>-name \u2026></em> ist
`},StructPredError:{name:"<cap>Struct</cap>-prederror",text:""},Prog:{name:"<cap>Prog</cap>",text:`
Ein Programm wird von links nach rechts ausgef\xFChrt und startet mit der
leeren Umgebung. Ist das n\xE4chste Programmelement eine Funktions- oder
Strukturdefinition, so wird diese Definition in die Umgebung aufgenommen
und die Ausf\xFChrung mit dem n\xE4chsten Programmelement in der erweiterten
Umgebung fortgesetzt. Ist das n\xE4chste Programmelement ein Ausdruck, so
wird dieser gem\xE4\xDF der unten stehenden Regeln in der aktuellen Umgebung zu
einem Wert ausgewert. Ist das n\xE4chste Programmelement eine
Konstantendefinition <em>(<strong>define</strong> x e)</em>, so wird in
der aktuellen Umgebung zun\xE4chst <em>e</em> zu einem Wert <em>v</em>
ausgewertet und dann <em>(<strong>define</strong> x v)</em> zur aktuellen
Umgebung hinzugef\xFCgt.
`},ProgError:{name:"<cap>Prog</cap>-Error",text:`
Ein Programm wird von links nach rechts ausgef\xFChrt und startet mit der
leeren Umgebung. Ist das n\xE4chste Programmelement eine Funktions- oder
Strukturdefinition, so wird diese Definition in die Umgebung aufgenommen
und die Ausf\xFChrung mit dem n\xE4chsten Programmelement in der erweiterten
Umgebung fortgesetzt. Sofern die Definition allerdings schon in der Umgebung
vorhanden ist, wird ein Fehler ausgegeben.
`}};window.addEventListener("load",()=>{Ut(),kt(),Yt()});})();
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/BSL_AST.ts", "../src/BSL_Print.ts", "../src/DOM_Helpers.ts", "../src/Production_Tree.ts", "../src/BSL_Parser.ts", "../src/BSL_Tree.ts", "../src/JSON_Tree.ts", "../src/SI_STRUCT.ts", "../src/SI.ts", "../src/SI_Renderer.ts", "../src/bsl_tools.ts"],
  "sourcesContent": ["export enum Production {\n  FunctionDefinition = 'Function Definition',\n  ConstantDefinition = 'Constant Definition',\n  StructDefinition = 'Struct Definition',\n  FunctionCall = 'Function Call',\n  CondExpression = 'Cond-Expression',\n  CondOption = 'Cond-Option',\n  Symbol = 'Symbol',\n  Literal = 'Literal Value',\n  StructValue = 'Struct Value',\n  Number = 'Number'\n}\n\nexport type program = defOrExpr[];\n\nexport type defOrExpr = definition | expr;\nexport type definition = FunDef | ConstDef | StructDef;\n\nexport interface FunDef{\n    type: Production.FunctionDefinition;\n    name: Name;\n    args: Name[];\n    body: expr;\n}\nexport interface ConstDef{\n    type: Production.ConstantDefinition;\n    name: Name;\n    value: expr;\n}\nexport interface StructDef{\n    type: Production.StructDefinition;\n    binding: Name;\n    properties: Name[];\n};\nexport interface StructValue{\n    type: Production.StructValue;\n    structDef: Name;\n    properties: Literal[];\n};\n\nexport type expr = Call | Cond | Name | Literal;\n\nexport interface Call{\n    type: Production.FunctionCall;\n    name: Name;\n    args: expr[];\n};\nexport interface Clause{\n    type: Production.CondOption,\n    condition: expr;\n    result: expr;\n}\nexport interface Cond{\n    type: Production.CondExpression;\n    options: Clause[]\n}\nexport interface Name{\n    type: Production.Symbol;\n    symbol:string;\n};\nexport interface Literal {\n    type: Production.Literal,\n    value: boolean | string | number | `'()` | StructValue;\n}\n\n// runtime type checking\nexport function isDefinition(obj: any): obj is definition {\n  return isFunDef(obj) || isConstDef(obj) || isStructDef(obj);\n}\nexport function isFunDef(obj: any): obj is FunDef {\n  return obj.type === Production.FunctionDefinition;\n}\nexport function isConstDef(obj: any): obj is ConstDef {\n  return obj.type === Production.ConstantDefinition;\n}\nexport function isStructDef(obj: any): obj is StructDef {\n  return obj.type === Production.StructDefinition;\n}\n\nexport function isExpr(obj: any): obj is expr {\n  return isCall(obj) || isCond(obj) || isName(obj) || isLiteral(obj);\n}\nexport function isCall(obj: any): obj is Call {\n  return obj.type === Production.FunctionCall;\n}\nexport function isCond(obj: any): obj is Cond {\n  return obj.type === Production.CondExpression;\n}\nexport function isName(obj: any): obj is Name {\n  return obj.type === Production.Symbol;\n}\nexport function isLiteral(obj: any): obj is Literal {\n  return obj.type === Production.Literal;\n}\nexport function isNumber(obj: any): obj is number {\n  return obj.type === Production.Number;\n}\nexport function isStructValue(obj: any): obj is StructValue {\n  return obj.type === Production.StructValue;\n}", "import * as BSL_AST from \"./BSL_AST\";\n\nexport function pprint(p: BSL_AST.program): string {\n  return p.map(printDefOrExpr).join(\"\\n\");\n}\nexport function printDefOrExpr(eod: BSL_AST.defOrExpr) {\n  if (BSL_AST.isDefinition(eod)) {\n    return printDefinition(eod);\n  } else {\n    return printE(eod);\n  }\n}\nexport function printDefinition(d: BSL_AST.definition): string {\n  if (BSL_AST.isFunDef(d)) {\n    return `(define (${printName(d.name)} ${d.args\n      .map(printName)\n      .join(\" \")}) ${printE(d.body)})`;\n  } else if (BSL_AST.isConstDef(d)) {\n    return `(define ${printName(d.name)} ${printE(d.value)})`;\n  } else if (BSL_AST.isStructDef(d)) {\n    return `(define-struct ${printName(d.binding)} (${d.properties\n      .map(printName)\n      .join(\" \")}))`;\n  } else {\n    console.error(\"Invalid input to printDefinition\");\n    return \"\";\n  }\n}\nexport function printE(e: BSL_AST.expr): string {\n  if (BSL_AST.isCall(e)) {\n    return `(${printName(e.name)} ${e.args.map(printE).join(\" \")})`;\n  } else if (BSL_AST.isCond(e)) {\n    return `(cond ${e.options.map(printOption).join(\" \")})`;\n  } else if (BSL_AST.isName(e)) {\n    return printName(e);\n  } else if (BSL_AST.isLiteral(e)) {\n      return printValue(e.value);\n  } else {\n    console.error(\"Invalid input to printE\");\n    return `<${e}>`;\n  }\n}\n\nexport function printValue(val: boolean | string | number | BSL_AST.StructValue) {\n  if (typeof val === \"string\" && val !== `'()`) {\n    return `\"${val}\"`;\n  } else if (typeof val === \"boolean\") {\n    return val ? \"#true\" : \"#false\";\n  }\n  if (BSL_AST.isStructValue(val)) {\n  return `<${printName(val.structDef)} ${val.properties.map(printE).join(\" \")}>`;\n}\n  else {\n    return `${val}`;\n  }\n}\n\nexport function printOption(o: BSL_AST.Clause) {\n  return `[${printE(o.condition)} ${printE(o.result)}]`;\n}\n\nexport function printName(s: BSL_AST.Name): string {\n  return s.symbol;\n}\n\nexport const testprogram: BSL_AST.program = [\n  {\n    type: BSL_AST.Production.FunctionDefinition,\n    name: {\n      type: BSL_AST.Production.Symbol,\n      symbol: \"f\",\n    },\n    args: [\n      {\n        type: BSL_AST.Production.Symbol,\n        symbol: \"x\",\n      },\n      {\n        type: BSL_AST.Production.Symbol,\n        symbol: \"y\",\n      },\n    ],\n    body: {\n      type: BSL_AST.Production.FunctionCall,\n      name: {\n        type: BSL_AST.Production.Symbol,\n        symbol: \"+\",\n      },\n      args: [\n        {\n          type: BSL_AST.Production.Symbol,\n          symbol: \"x\",\n        },\n        {\n          type: BSL_AST.Production.Symbol,\n          symbol: \"y\",\n        },\n      ],\n    },\n  },\n  {\n    type: BSL_AST.Production.CondExpression,\n    options: [\n      {\n        type: BSL_AST.Production.CondOption,\n        condition: {\n          type: BSL_AST.Production.FunctionCall,\n          name: {\n            type: BSL_AST.Production.Symbol,\n            symbol: \"=\",\n          },\n          args: [\n            {\n              type: BSL_AST.Production.Symbol,\n              symbol: \"x\",\n            },\n            {\n              type: BSL_AST.Production.Literal,\n              value: 3,\n            },\n          ],\n        },\n        result: {\n          type: BSL_AST.Production.Literal,\n          value: \"isThree\",\n        },\n      },\n      {\n        type: BSL_AST.Production.CondOption,\n        condition: {\n          type: BSL_AST.Production.Literal,\n          value: false,\n        },\n        result: {\n          type: BSL_AST.Production.Literal,\n          value: `'()`,\n        },\n      },\n    ],\n  },\n  {\n    type: BSL_AST.Production.ConstantDefinition,\n    name: {\n      type: BSL_AST.Production.Symbol,\n      symbol: \"x\",\n    },\n    value: {\n      type: BSL_AST.Production.Literal,\n      value: 42,\n    },\n  },\n  {\n    type: BSL_AST.Production.StructDefinition,\n    binding: {\n      type: BSL_AST.Production.Symbol,\n      symbol: \"name\",\n    },\n    properties: [\n      {\n        type: BSL_AST.Production.Symbol,\n        symbol: \"firstName\",\n      },\n      {\n        type: BSL_AST.Production.Symbol,\n        symbol: \"lastName\",\n      },\n    ],\n  },\n];\n\n// indent code that is wider than maxLength characters\nexport function indent(\n  code: string,\n  maxWidth: number,\n  mode: \"html\" | \"text\" = \"text\"\n): string {\n  // console.log('Code before indentation', code);\n  // extract terms and their theoretical indentation level\n  let terms: { term: string; level: number }[] = [];\n  let level = 0;\n  let nextLevel = 0;\n  let maxLevel = 0;\n  let acc = \"\";\n  let inString = false;\n  let inTag = false;\n  code.split(\"\").forEach((char) => {\n    if (inString && char !== '\"') {\n      acc += char;\n      return;\n    }\n    if (inTag && char !== \">\") {\n      acc += char;\n      return;\n    }\n    switch (char) {\n      case \"(\":\n      case \"[\":\n        nextLevel++;\n        break;\n      case \")\":\n      case \"]\":\n        nextLevel--;\n        break;\n      case '\"':\n        inString = !inString;\n        break;\n      case \"<\":\n        inTag = mode === \"html\";\n        break;\n      case \">\":\n        if (mode === \"html\") inTag = false;\n        break;\n      case \" \":\n      case \"\\n\":\n      case \"\\t\":\n        if (!acc) return;\n        terms.push({ term: acc, level: level });\n        if (level > maxLevel) maxLevel = level;\n        acc = \"\";\n        level = nextLevel;\n        return;\n    }\n    acc += char;\n    return;\n  });\n  if (acc !== \"\") {\n    terms.push({ term: acc, level: level });\n    if (level > maxLevel) maxLevel = level;\n  }\n  // console.log(terms);\n  // append terms starting from the inside\n  const joiner =\n    mode === \"html\"\n      ? \"<br>\"\n      : `\n`;\n  for (let level = maxLevel; level > 0; level--) {\n    // group terms\n    const newTerms: { term: string; level: number; subterms: string[] }[] = [];\n    terms.forEach((t) => {\n      if (t.level < level) {\n        newTerms.push({ ...t, subterms: [] });\n      } else {\n        newTerms[newTerms.length - 1].subterms.push(t.term);\n      }\n    });\n    // append and check if we need to start indenting\n    terms = newTerms.map((t) => {\n      const alreadyIndenting = t.subterms.some((s) => s.includes(joiner));\n      const unindented = `${t.term}${\n        t.subterms.length > 0 ? \" \" : \"\"\n      }${t.subterms.join(\" \")}`;\n      const unindentedLength =\n        mode === \"html\" ? htmlIgnoringLength(unindented) : unindented.length;\n      if (alreadyIndenting || unindentedLength + t.level > maxWidth) {\n        const parts = t.subterms.map(\n          (s) =>\n            `${\n              mode === \"html\" ? repeat(\"&nbsp;\", level) : repeat(\" \", level)\n            }${s}`\n        );\n        parts.unshift(t.term);\n        const joiner =\n          mode === \"html\"\n            ? \"<br>\"\n            : `\n`; // literal newline to be safe\n        const all = `${parts.join(joiner)}`;\n        return { term: all, level: t.level };\n      } else {\n        return { term: unindented, level: t.level };\n      }\n    });\n    // console.log(terms);\n  }\n  // now there should be only top level terms left\n  return terms.map((t) => t.term).join(joiner);\n}\n\n// repeat a string s n times\nfunction repeat(s: string, n: number): string {\n  let acc = \"\";\n  for (let i = 0; i < n; i++) {\n    acc += s;\n  }\n  return acc;\n}\n// measure the length of a string while ignoring html\nfunction htmlIgnoringLength(s: string): number {\n  const testDiv: HTMLElement = document.createElement(\"div\");\n  testDiv.innerHTML = s;\n  return testDiv.textContent ? testDiv.textContent.length : 0;\n}\n\n// #### preventing problems with brackets\nexport function sanitize(s: string): string {\n  return s.replaceAll(\"<\", \"&lt;\").replaceAll(\">\", \"&gt;\");\n}\nexport function dirtify(s: string): string {\n  return s\n    .replaceAll(\"&lt;\", \"<\")\n    .replaceAll(\"&gt;\", \">\")\n    .replaceAll(\"&nbsp;\", \" \");\n}\n", "// navigate the DOM using path notation\n// .. -> parent\n// +  -> next sibling\n// .class -> all children with a class\n// tag -> all children of a certain tag\n// divided by /\nexport function navigateDOM(positions: HTMLElement[], path: string, strict: boolean = false): HTMLElement[] {\n  if (positions.length === 0) return [];\n  const steps = path.split('/');\n  const currStep = steps.shift() as string;\n  if (currStep == '') return positions;\n  const restSteps = steps.join('/');\n\n  let newPositions = [];\n  if (currStep == '..') {\n    // navigate up\n    newPositions = positions.map(p => p.parentElement).filter(p => p);\n  } else if (currStep == '+') {\n    // navigate sideways\n    newPositions = positions.map(p => p.nextElementSibling).filter(p => p);\n  } else if (currStep.startsWith('.')) {\n    // navigate down + filter for class\n    const className = currStep.slice(1);\n    newPositions = positions.flatMap(p => Array.from(p.children).filter(c => c.classList.contains(className)));\n  } else {\n    // navigate down + filter for tag\n    newPositions = positions.flatMap(p => Array.from(p.children).filter(c => c.tagName == currStep.toUpperCase()));\n  }\n  if (newPositions.length === 0 && strict) {\n    console.error(`Error traversing ${path}: No element found`);\n  }\n  return navigateDOM(newPositions as HTMLElement[], restSteps);\n}\n\n// getParentTagRecursive from a child element\n// if element has TagName\n// return;\n// else: retry with parentElement\nexport function getParentTagRecursive(el: HTMLElement, tag: string): HTMLElement | null {\n  if (el.tagName == tag.toUpperCase()) {\n    return el;\n  }\n  else {\n    let parent = el.parentElement;\n    if (!parent) {\n      console.error('Could not find parent element with requested tag ', tag);\n      return null;\n    }\n    return getParentTagRecursive(parent, tag) as HTMLElement;\n  }\n}\n\n// getParentClassRecursive from a child element\n// if element has class\n// return;\n// else: retry with parentElement\nexport function getParentClassRecursive(el: HTMLElement, c: string): HTMLElement | null {\n  if (el.classList.contains(c)) {\n    return el;\n  }\n  else {\n    let parent = el.parentElement;\n    if (!parent) {\n      console.error('Could not find parent element with requested class ', c);\n      return null;\n    }\n    return getParentClassRecursive(parent, c);\n  }\n}\n", "import {navigateDOM, getParentTagRecursive, getParentClassRecursive} from \"./DOM_Helpers\";\nimport {default as tree_css} from './ressources/tree.css';\nimport {sanitize} from './BSL_Print';\n\n// #### main api #####\n// simple helper structure representing a printed tree\nexport interface node {\n  production: string;\n  code: string;\n  holes: {start:number, end:number, content:node}[];\n}\n// object representing a grammar\nexport type grammar = {[key: string]: string[]};\n\n// add production tree to html element\nexport function productionTree(\n  root: node,\n  target: HTMLElement,\n  grammar: grammar | undefined,\n  quiz=false,\n  lang='en'){\n  // infer grammar if necessary\n  if(!grammar) grammar = extractProductions(root);\n  // add css if necessary\n  if(!document.getElementById('bsl-tools-tree-style')) {\n    const styleNode = document.createElement('style');\n    styleNode.innerHTML = tree_css;\n    styleNode.id = 'bsl-tools-tree-style';\n    document.getElementsByTagName('head')[0].appendChild(styleNode);\n  }\n  // check language availability\n  if (!implementedLanguages.includes(lang)) {\n    console.error(`\n      Selected language \"${lang}\" is not implemented, defaulting to \"en\".\n      Available language codes: ${implementedLanguages.join(', ')}\n    `);\n    lang = 'en';\n  }\n  // render HTML\n  target.innerHTML = `\n  <div class=\"bsl-tools-tree-container\">\n    <ul class=\"bsl-tools-tree\">\n      ${quiz\n        ? renderQuizNode(root, lang as implementedLanguage, grammar as grammar)\n        : renderNode(root, grammar as grammar)}\n    </ul>\n  </div>`;\n  if (quiz) {\n    // show first quiz node\n    navigateDOM([target],'ul/li/ul/li').map(c =>\n      c.setAttribute('data-collapsed','false'));\n  }\n  // align connectors horizontally\n  adjustConnectors(target);\n}\n\n// ### traverse tree to get all occurring productions\nfunction extractProductions(n: node): grammar {\n  const productions = {};\n  extractProductionsRecursive(n, productions);\n  return productions;\n}\nfunction extractProductionsRecursive(n: node, p: grammar) {\n  p[n.production] = [];\n  n.holes.map(h => extractProductionsRecursive(h.content, p));\n}\n\n// ###### internationalization for this module #####\n// mainly for quiz, currently\ntype implementedLanguage = 'en' | 'de';\nconst implementedLanguages = ['en', 'de'];\n\nconst dictionary = {\n  'en': {\n    'select production': 'Select production',\n    'mark selected text as hole': 'Mark selected text as subexpression',\n  },\n  'de': {\n    'select production': 'Produktion ausw\u00E4hlen',\n    'mark selected text as hole': 'Auswahl als Teilausdruck markieren',\n  },\n};\n\n// ###### layout helper ########\n// dynamically compute dimensions of connectors between nodes\n// such that they point to the correct \"hole\"\n// https://developer.mozilla.org/en-US/docs/Web/API/CSS_Object_Model/Determining_the_dimensions_of_elements\n// https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/offsetLeft\nfunction adjustConnectors(tree: HTMLElement) {\n  const ydiff = parseFloat(getComputedStyle(tree).fontSize) * 3; // 3em\n  for(let i = 1; ;i++) {\n    const holes = Array.from(tree.getElementsByClassName(`hole-${i}`));\n    if (holes.length < 1) return;\n    holes.map(h => {\n      const el: HTMLElement = h as HTMLElement;\n      const xpos = 0.5 * (el.getBoundingClientRect().x + el.getBoundingClientRect().right);\n      // no layout effect if hole is invisible\n      if (xpos == 0) return;\n\n      // navigate the DOM\n      const li = getParentTagRecursive(el, 'li');\n      // not inside a list node? probably wrong tag, return\n      if(!li) return;\n\n      // process children\n      navigateDOM([li], `ul/.child-${i}/span`).map(c => {\n        const child = c as HTMLElement;\n        const xposChild = 0.5 * (child.getBoundingClientRect().x + child.getBoundingClientRect().right);\n        const xdiff = xpos - xposChild;\n        const angle = - Math.atan2(ydiff, xdiff);\n        const amount = Math.sqrt(xdiff*xdiff + ydiff*ydiff);\n        const left = (xdiff/2) - (amount/2);\n        // set css variables (usage see tree.css)\n        child.style.cssText = `\n          --connector-width: ${amount}px;\n          --connector-left: calc(50% + ${left}px);\n          --edgetext-right: calc(50% - ${xdiff/2}px);\n          --connector-transform: rotate(${angle}rad);\n        `;\n      });\n\n    });\n  }\n}\n\n// ##### generate HTML ######\n\n// ### regular node/tree\nfunction renderNode(n: node, p: grammar, i:number=-1):string {\n  return `\n    <li class=\"${i >= 0 ? `child-${i+1}` : ''}\"\n        data-collapsed=\"${i >= 0 ? 'true' : 'false'}\">\n      <span class=\"${n.holes.length > 0 ? '' : 'terminal-symbol'}\">\n\n        ${renderProduction(n, p)}\n\n        ${renderCode(n)}\n\n      </span>\n      ${n.holes.length > 0 ?\n        `<ul>${\n          n.holes.map((h, idx) =>\n            renderNode(h.content, p, idx))\n          .join('')\n        }</ul>`\n        : ''\n      }\n    </li>\n  `;\n}\n\n// ### block of code in node\nfunction renderCode(n: node):string {\n  const spans = getSpans(n);\n  return `\n  <div class=\"code\">${\n    spans.map(s =>\n      `<span class=\"char ${s.pos ? `hole hole-${s.pos}` : ''}\"\n             ${s.pos ? `onclick=\"toggleChild(event,${s.pos})\"` : ''}\n             >${n.code.slice(s.start, s.end)}</span>`)\n    .join('')}\n  </div>\n  `;\n}\n(window as any).toggleChild = (e: Event,i:number) => {\n  const hole = e.target as HTMLElement;\n  const li = getParentTagRecursive(hole, 'li');\n  const tree = getParentClassRecursive(hole, 'bsl-tools-tree');\n  if(!li || !tree) {\n    console.error('toggleChild called from .hole not in .bsl-tools-tree');\n    return;\n  };\n\n  navigateDOM([li],`ul/.child-${i}`).map(c => {\n    c.setAttribute('data-collapsed', c.getAttribute('data-collapsed') === 'true' ? 'false' : 'true');\n  });\n  adjustConnectors(tree);\n}\ninterface span {\n  pos: boolean | number;\n  start: number;\n  end: number;\n}\nfunction getSpans(n: node):span[] {\n  // slice text into holes\n  const spans = [];\n  let position = 0;\n  for(let i = 0; i < n.holes.length; i++) {\n    if (n.holes[i].start > position) {\n      spans.push({pos: false, start:position, end:n.holes[i].start});\n    }\n    spans.push({pos: i+1, ...n.holes[i]});\n    position = n.holes[i].end;\n  }\n  if (position < n.code.length) {\n    spans.push({pos: false, start:position, end:n.code.length});\n  }\n  return spans;\n}\n// ### production name - with tooltip on hover\nfunction renderProduction(n: node, p: grammar) {\n  return `\n    <div class=\"name\">${sanitize(n.production)}${\n      p[n.production] && p[n.production].length > 0 ?\n      `<div class=\"tooltip\">::= ${\n        p[n.production].map(sanitize).join('<br>&nbsp;|&nbsp;&nbsp;')\n      }</div>`\n      : ''\n    }</div>\n  `;\n}\n\n// ###### rendering a node/tree as a quiz\nfunction renderQuizNode(n: node, lang: implementedLanguage, grammar: grammar, i:number=-1):string {\n  return `\n    <li class=\"${i >= 0 ? `child-${i+1}` : ''}\"\n        data-collapsed=\"${i >= 0 ? 'true' : 'false'}\">\n      <span class=\"${n.holes.length > 0 ? '' : 'terminal-symbol'}\"\n            data-quiz-state=\"${i >= 0 ? 'production' : 'done'}\"\n            data-is-terminal=\"${n.holes.length <= 0}\"\n            data-is-trivial-hole=\"${n.holes.length === 1 && n.holes[0].start === 0 && n.holes[0].end === n.code.length}\">\n\n        ${renderProductionQuiz(n, lang, grammar)}\n\n        ${renderHoleQuiz(n, lang)}\n\n        ${renderProduction(n, grammar)}\n        ${renderCode(n)}\n      </span>\n      ${n.holes.length > 0 ?\n        `<ul>${\n          n.holes.map((h, idx) =>\n            renderQuizNode(h.content, lang, grammar, idx))\n            .join('')\n         }</ul>`\n        : ''\n      }\n    </li>\n  `;\n}\n\n// ### first part of the quiz\nfunction renderProductionQuiz(n: node, lang: implementedLanguage, grammar: grammar):string {\n  return `\n  <div class=\"production\">\n    <select onchange=\"checkProduction(event, '${n.production}')\">\n      <option selected=\"true\">${dictionary[lang]['select production']}</option>\n      ${Object.keys(grammar).map(p => `\n          <option value=\"${p}\">${sanitize(p)}</option>\n        `).join('')}\n    </select>\n  </div>\n  `;\n}\n\n(window as any).checkProduction = (e: Event, p: string) => {\n  const sel = e.target as HTMLSelectElement;\n  if (sel.value === p) {\n    // answer correct\n    const span = getParentTagRecursive(sel, 'span');\n    if (span) {\n      if (span.getAttribute('data-is-terminal') === 'true') {\n        // we're done\n        span.setAttribute('data-quiz-state', 'done');\n      } else if (span.getAttribute('data-is-trivial-hole') === 'true') {\n        // we're done\n        span.setAttribute('data-quiz-state', 'done');\n        // but we also need to expand the child\n        navigateDOM([span],'+/li',true).map(c =>\n          c.setAttribute('data-collapsed', 'false'));\n      } else {\n        // move on to selecting holes\n        span.setAttribute('data-quiz-state', 'hole-marking');\n      }\n\n      // expand next sibling (if present)\n      navigateDOM([span], '../+').map(l =>\n        l.setAttribute('data-collapsed', 'false'));\n\n      // adjust connectors\n      const quiz = getParentClassRecursive(span, 'bsl-tools-tree');\n      if (quiz) adjustConnectors(quiz);\n    }\n  } else {\n    // mark option as tried-and-wrong\n    Array.from(sel.selectedOptions).map(o =>\n      o.remove());\n    // give visual feedback\n    const span = getParentTagRecursive(sel, 'span');\n    if (span) {\n      span.classList.add('wrong');\n      window.setTimeout(() => {\n        span.classList.remove('wrong');\n      }, 100);\n    }\n  }\n}\n\n// ### second part of the quiz\nfunction renderHoleQuiz(n: node, lang: implementedLanguage):string {\n  return `\n  <div class=\"hole-marking\"\n       data-holes=\"${btoa(JSON.stringify(n.holes.map(h => [h.start,h.end, false])))}\">\n    <div class=\"textarea-container\">\n      <div class=\"marker-container\">\n        ${n.code.split('\\n')\n            .map(l => l.split('').map(c =>\n              `<span class=\"char marker\">${c}</span>`\n            ).join(''))\n            .join('<span class=\"char marker\"></span><br>')}\n      </div>\n      <textarea autocorrect=\"off\"\n                spellcheck=\"false\"\n                cols=\"${n.code.split('\\n').map(l => l.length).reduce((x,y) => x > y ? x : y)}\"\n                rows=\"${n.code.split('\\n').length}\"\n                oninput=\"stopInput(event, '${btoa(n.code)}')\">${n.code}</textarea>\n    </div><br>\n    <button onclick=\"checkSelection(event)\">\n      ${dictionary[lang]['mark selected text as hole']}\n    </button>\n  </div>\n  `;\n}\n(window as any).stopInput = (e: Event, oldVal: string) => {\n  (e.target as HTMLTextAreaElement).value = atob(oldVal);\n}\n(window as any).checkSelection = (e: Event) => {\n  // get context\n  const btn = e.target as HTMLElement;\n  const div = getParentClassRecursive(btn, 'hole-marking');\n  if (!div) {\n    console.error('checkProduction called from el. not wrapped in div.hole-marking');\n    return;\n  }\n  // get holes to find\n  const holes = JSON.parse(atob(div.getAttribute('data-holes') as string)) as [number,number,boolean][];\n\n  // get current selection\n  const textarea = div.getElementsByTagName('textarea')[0] as HTMLTextAreaElement;\n  const selStart = textarea.selectionStart;\n  const selEnd = textarea.selectionEnd;\n  const start = selStart < selEnd ? selStart : selEnd;\n  const end = selStart < selEnd ? selEnd : selStart;\n\n  // check if hole is found\n  let found = -1;\n  holes.map((h,i) => {\n    if (h[0] === start && h[1] === end) {\n      h[2] = true;\n      found = i;\n    }\n  });\n\n  if (found >= 0) {\n    // save changed state\n    div.setAttribute('data-holes', btoa(JSON.stringify(holes)));\n    // mark hole as correct\n    navigateDOM([div], '.textarea-container/.marker-container/.marker', true)\n      .slice(start, end)\n      .map(m => m.classList.add('correct'));\n  } else {\n    // give feedback about wrong selection\n    const markers = navigateDOM([div], '.textarea-container/.marker-container/.marker', true)\n      .slice(start, end);\n\n    markers.map(m => m.classList.add('wrong'));\n    window.setTimeout(() => {\n      markers.map(m => m.classList.remove('wrong'));\n    }, 100);\n  }\n  if(holes.every(h => h[2])) {\n    // move on to next phase == done\n    const span = getParentTagRecursive(div, 'span');\n    if (span) {\n      span.setAttribute('data-quiz-state', 'done');\n      // expand first child\n      navigateDOM([span], '../ul/.child-1').map(c =>\n        c.setAttribute('data-collapsed', 'false'));\n\n      // adjust connectors for width change\n      const quiz = getParentClassRecursive(span, 'bsl-tools-tree');\n      if (quiz) adjustConnectors(quiz);\n    }\n  }\n}\n", "\n// Generated by peggy v. 1.2.0 (ts-pegjs plugin v. 1.2.2 )\n//\n// https://peggyjs.org/   https://github.com/metadevpro/ts-pegjs\n\nexport interface IFilePosition {\n  offset: number;\n  line: number;\n  column: number;\n}\n\nexport interface IFileRange {\n  start: IFilePosition;\n  end: IFilePosition;\n  source: string;\n}\n\nexport interface ILiteralExpectation {\n  type: \"literal\";\n  text: string;\n  ignoreCase: boolean;\n}\n\nexport interface IClassParts extends Array<string | IClassParts> {}\n\nexport interface IClassExpectation {\n  type: \"class\";\n  parts: IClassParts;\n  inverted: boolean;\n  ignoreCase: boolean;\n}\n\nexport interface IAnyExpectation {\n  type: \"any\";\n}\n\nexport interface IEndExpectation {\n  type: \"end\";\n}\n\nexport interface IOtherExpectation {\n  type: \"other\";\n  description: string;\n}\n\nexport type Expectation = ILiteralExpectation | IClassExpectation | IAnyExpectation | IEndExpectation | IOtherExpectation;\n\nfunction peg$padEnd(str: string, targetLength: number, padString: string) {\n  padString = padString || ' ';\n  if (str.length > targetLength) {\n    return str;\n  }\n  targetLength -= str.length;\n  padString += padString.repeat(targetLength);\n  return str + padString.slice(0, targetLength);\n}\n\nexport class SyntaxError extends Error {\n  public static buildMessage(expected: Expectation[], found: string | null) {\n    function hex(ch: string): string {\n      return ch.charCodeAt(0).toString(16).toUpperCase();\n    }\n\n    function literalEscape(s: string): string {\n      return s\n        .replace(/\\\\/g, \"\\\\\\\\\")\n        .replace(/\"/g,  \"\\\\\\\"\")\n        .replace(/\\0/g, \"\\\\0\")\n        .replace(/\\t/g, \"\\\\t\")\n        .replace(/\\n/g, \"\\\\n\")\n        .replace(/\\r/g, \"\\\\r\")\n        .replace(/[\\x00-\\x0F]/g,            (ch) => \"\\\\x0\" + hex(ch) )\n        .replace(/[\\x10-\\x1F\\x7F-\\x9F]/g, (ch) => \"\\\\x\"  + hex(ch) );\n    }\n\n    function classEscape(s: string): string {\n      return s\n        .replace(/\\\\/g, \"\\\\\\\\\")\n        .replace(/\\]/g, \"\\\\]\")\n        .replace(/\\^/g, \"\\\\^\")\n        .replace(/-/g,  \"\\\\-\")\n        .replace(/\\0/g, \"\\\\0\")\n        .replace(/\\t/g, \"\\\\t\")\n        .replace(/\\n/g, \"\\\\n\")\n        .replace(/\\r/g, \"\\\\r\")\n        .replace(/[\\x00-\\x0F]/g,            (ch) => \"\\\\x0\" + hex(ch) )\n        .replace(/[\\x10-\\x1F\\x7F-\\x9F]/g, (ch) => \"\\\\x\"  + hex(ch) );\n    }\n\n    function describeExpectation(expectation: Expectation) {\n      switch (expectation.type) {\n        case \"literal\":\n          return \"\\\"\" + literalEscape(expectation.text) + \"\\\"\";\n        case \"class\":\n          const escapedParts = expectation.parts.map((part) => {\n            return Array.isArray(part)\n              ? classEscape(part[0] as string) + \"-\" + classEscape(part[1] as string)\n              : classEscape(part);\n          });\n\n          return \"[\" + (expectation.inverted ? \"^\" : \"\") + escapedParts + \"]\";\n        case \"any\":\n          return \"any character\";\n        case \"end\":\n          return \"end of input\";\n        case \"other\":\n          return expectation.description;\n      }\n    }\n\n    function describeExpected(expected1: Expectation[]) {\n      const descriptions = expected1.map(describeExpectation);\n      let i: number;\n      let j: number;\n\n      descriptions.sort();\n\n      if (descriptions.length > 0) {\n        for (i = 1, j = 1; i < descriptions.length; i++) {\n          if (descriptions[i - 1] !== descriptions[i]) {\n            descriptions[j] = descriptions[i];\n            j++;\n          }\n        }\n        descriptions.length = j;\n      }\n\n      switch (descriptions.length) {\n        case 1:\n          return descriptions[0];\n\n        case 2:\n          return descriptions[0] + \" or \" + descriptions[1];\n\n        default:\n          return descriptions.slice(0, -1).join(\", \")\n            + \", or \"\n            + descriptions[descriptions.length - 1];\n      }\n    }\n\n    function describeFound(found1: string | null) {\n      return found1 ? \"\\\"\" + literalEscape(found1) + \"\\\"\" : \"end of input\";\n    }\n\n    return \"Expected \" + describeExpected(expected) + \" but \" + describeFound(found) + \" found.\";\n  }\n\n  public message: string;\n  public expected: Expectation[];\n  public found: string | null;\n  public location: IFileRange;\n  public name: string;\n\n  constructor(message: string, expected: Expectation[], found: string | null, location: IFileRange) {\n    super();\n    this.message = message;\n    this.expected = expected;\n    this.found = found;\n    this.location = location;\n    this.name = \"SyntaxError\";\n\n    if (typeof (Object as any).setPrototypeOf === \"function\") {\n      (Object as any).setPrototypeOf(this, SyntaxError.prototype);\n    } else {\n      (this as any).__proto__ = SyntaxError.prototype;\n    }\n    if (typeof (Error as any).captureStackTrace === \"function\") {\n      (Error as any).captureStackTrace(this, SyntaxError);\n    }\n  }\n\n  format(sources: { source: string; text: string }[]): string {\n    let str = 'Error: ' + this.message;\n    if (this.location) {\n      let src: string[] | null = null;\n      let k;\n      for (k = 0; k < sources.length; k++) {\n        if (sources[k].source === this.location.source) {\n          src = sources[k].text.split(/\\r\\n|\\n|\\r/g);\n          break;\n        }\n      }\n      let s = this.location.start;\n      let loc = this.location.source + ':' + s.line + ':' + s.column;\n      if (src) {\n        let e = this.location.end;\n        let filler = peg$padEnd('', s.line.toString().length, ' ');\n        let line = src[s.line - 1];\n        let last = s.line === e.line ? e.column : line.length + 1;\n        str += '\\n --> ' + loc + '\\n' + filler + ' |\\n' + s.line + ' | ' + line + '\\n' + filler + ' | ' +\n          peg$padEnd('', s.column - 1, ' ') +\n          peg$padEnd('', last - s.column, '^');\n      } else {\n        str += '\\n at ' + loc;\n      }\n    }\n    return str;\n  }\n}\n\nfunction peg$parse(input: string, options?: IParseOptions) {\n  options = options !== undefined ? options : {};\n\n  const peg$FAILED: Readonly<any> = {};\n  const peg$source = options.grammarSource;\n\n  const peg$startRuleFunctions: {[id: string]: any} = { Program: peg$parseProgram };\n  let peg$startRuleFunction: () => any = peg$parseProgram;\n\n  const peg$c0 = function(all: any): any { return all };\n  const peg$c1 = /^[\\t \\n \\r]/;\n  const peg$c2 = peg$classExpectation([\"\\t\", \" \", \"\\n\", \" \", \"\\r\"], false, false);\n  const peg$c3 = function(def: any): any { return def };\n  const peg$c4 = \"(define-struct\";\n  const peg$c5 = peg$literalExpectation(\"(define-struct\", false);\n  const peg$c6 = \"(\";\n  const peg$c7 = peg$literalExpectation(\"(\", false);\n  const peg$c8 = \")\";\n  const peg$c9 = peg$literalExpectation(\")\", false);\n  const peg$c10 = function(binding: any, properties: any): any {\n    return {\n      \"type\": \"Struct Definition\",\n    \t\"binding\": binding,\n      \"properties\": properties\n      }\n    };\n  const peg$c11 = \"(define\";\n  const peg$c12 = peg$literalExpectation(\"(define\", false);\n  const peg$c13 = function(name: any, args: any, body: any): any {\n    return {\n      \"type\": \"Function Definition\",\n    \t\"name\": name,\n      \"args\": args,\n      \"body\": body\n      }\n    };\n  const peg$c14 = function(name: any, value: any): any {\n    return {\n      \"type\": \"Constant Definition\",\n    \t\"name\": name,\n      \"value\": value\n      }\n    };\n  const peg$c15 = function(expr: any): any { return expr };\n  const peg$c16 = \"(cond\";\n  const peg$c17 = peg$literalExpectation(\"(cond\", false);\n  const peg$c18 = function(options: any): any {\n      return {\n        \"type\": \"Cond-Expression\",\n        \"options\": options\n      }\n    };\n  const peg$c19 = \"[\";\n  const peg$c20 = peg$literalExpectation(\"[\", false);\n  const peg$c21 = \"]\";\n  const peg$c22 = peg$literalExpectation(\"]\", false);\n  const peg$c23 = function(condition: any, result: any): any {\n      return {\n        \"type\": \"Cond-Option\",\n        \"condition\": condition,\n        \"result\":result\n      }\n    };\n  const peg$c24 = function(name: any, args: any): any {\n    return {\n      \"type\": \"Function Call\",\n      \"name\": name,\n      \"args\": args\n      }\n    };\n  const peg$c25 = \"define\";\n  const peg$c26 = peg$literalExpectation(\"define\", false);\n  const peg$c27 = /^[^\",'`()[\\]{}|#\\n\\t\\r ]/;\n  const peg$c28 = peg$classExpectation([\"\\\"\", \",\", \"'\", \"`\", \"(\", \")\", \"[\", \"]\", \"{\", \"}\", \"|\", \"#\", \"\\n\", \"\\t\", \"\\r\", \" \"], true, false);\n  const peg$c29 = function(symbol: any): any {\n    return {\n      \"type\": \"Symbol\",\n    \t\"symbol\":symbol.join(\"\")\n      }\n    };\n  const peg$c30 = function(val: any): any {\n    return {\n      \"type\": \"Literal Value\",\n      \"value\": val\n      }\n    };\n  const peg$c31 = /^[0-9]/;\n  const peg$c32 = peg$classExpectation([[\"0\", \"9\"]], false, false);\n  const peg$c33 = function(): any {return parseInt(text(), 10)};\n  const peg$c34 = \"#true\";\n  const peg$c35 = peg$literalExpectation(\"#true\", false);\n  const peg$c36 = \"#false\";\n  const peg$c37 = peg$literalExpectation(\"#false\", false);\n  const peg$c38 = \"#t\";\n  const peg$c39 = peg$literalExpectation(\"#t\", false);\n  const peg$c40 = \"#f\";\n  const peg$c41 = peg$literalExpectation(\"#f\", false);\n  const peg$c42 = function(bool: any): any { return (bool === \"#true\" || bool === \"#t\") };\n  const peg$c43 = \"'()\";\n  const peg$c44 = peg$literalExpectation(\"'()\", false);\n  const peg$c45 = function(): any { return \"'()\" };\n  const peg$c46 = \"\\\"\";\n  const peg$c47 = peg$literalExpectation(\"\\\"\", false);\n  const peg$c48 = /^[^\"]/;\n  const peg$c49 = peg$classExpectation([\"\\\"\"], true, false);\n  const peg$c50 = function(str: any): any { return str.join(\"\") };\n  const peg$c51 = peg$otherExpectation(\"whitespace\");\n  const peg$c52 = function(): any {return undefined};\n\n  let peg$currPos = 0;\n  let peg$savedPos = 0;\n  const peg$posDetailsCache = [{ line: 1, column: 1 }];\n  let peg$maxFailPos = 0;\n  let peg$maxFailExpected: Expectation[] = [];\n  let peg$silentFails = 0;\n\n  let peg$result;\n\n  if (options.startRule !== undefined) {\n    if (!(options.startRule in peg$startRuleFunctions)) {\n      throw new Error(\"Can't start parsing from rule \\\"\" + options.startRule + \"\\\".\");\n    }\n\n    peg$startRuleFunction = peg$startRuleFunctions[options.startRule];\n  }\n\n  function text(): string {\n    return input.substring(peg$savedPos, peg$currPos);\n  }\n\n  function location(): IFileRange {\n    return peg$computeLocation(peg$savedPos, peg$currPos);\n  }\n\n  function expected(description: string, location1?: IFileRange) {\n    location1 = location1 !== undefined\n      ? location1\n      : peg$computeLocation(peg$savedPos, peg$currPos);\n\n    throw peg$buildStructuredError(\n      [peg$otherExpectation(description)],\n      input.substring(peg$savedPos, peg$currPos),\n      location1\n    );\n  }\n\n  function error(message: string, location1?: IFileRange) {\n    location1 = location1 !== undefined\n      ? location1\n      : peg$computeLocation(peg$savedPos, peg$currPos);\n\n    throw peg$buildSimpleError(message, location1);\n  }\n\n  function peg$literalExpectation(text1: string, ignoreCase: boolean): ILiteralExpectation {\n    return { type: \"literal\", text: text1, ignoreCase: ignoreCase };\n  }\n\n  function peg$classExpectation(parts: IClassParts, inverted: boolean, ignoreCase: boolean): IClassExpectation {\n    return { type: \"class\", parts: parts, inverted: inverted, ignoreCase: ignoreCase };\n  }\n\n  function peg$anyExpectation(): IAnyExpectation {\n    return { type: \"any\" };\n  }\n\n  function peg$endExpectation(): IEndExpectation {\n    return { type: \"end\" };\n  }\n\n  function peg$otherExpectation(description: string): IOtherExpectation {\n    return { type: \"other\", description: description };\n  }\n\n  function peg$computePosDetails(pos: number) {\n    let details = peg$posDetailsCache[pos];\n    let p;\n\n    if (details) {\n      return details;\n    } else {\n      p = pos - 1;\n      while (!peg$posDetailsCache[p]) {\n        p--;\n      }\n\n      details = peg$posDetailsCache[p];\n      details = {\n        line: details.line,\n        column: details.column\n      };\n\n      while (p < pos) {\n        if (input.charCodeAt(p) === 10) {\n          details.line++;\n          details.column = 1;\n        } else {\n          details.column++;\n        }\n\n        p++;\n      }\n\n      peg$posDetailsCache[pos] = details;\n\n      return details;\n    }\n  }\n\n  function peg$computeLocation(startPos: number, endPos: number): IFileRange {\n    const startPosDetails = peg$computePosDetails(startPos);\n    const endPosDetails = peg$computePosDetails(endPos);\n\n    return {\n      source: peg$source,\n      start: {\n        offset: startPos,\n        line: startPosDetails.line,\n        column: startPosDetails.column\n      },\n      end: {\n        offset: endPos,\n        line: endPosDetails.line,\n        column: endPosDetails.column\n      }\n    };\n  }\n\n  function peg$fail(expected1: Expectation) {\n    if (peg$currPos < peg$maxFailPos) { return; }\n\n    if (peg$currPos > peg$maxFailPos) {\n      peg$maxFailPos = peg$currPos;\n      peg$maxFailExpected = [];\n    }\n\n    peg$maxFailExpected.push(expected1);\n  }\n\n  function peg$buildSimpleError(message: string, location1: IFileRange) {\n    return new SyntaxError(message, [], \"\", location1);\n  }\n\n  function peg$buildStructuredError(expected1: Expectation[], found: string | null, location1: IFileRange) {\n    return new SyntaxError(\n      SyntaxError.buildMessage(expected1, found),\n      expected1,\n      found,\n      location1\n    );\n  }\n\n  function peg$parseProgram(): any {\n    let s0, s1, s2;\n\n    s0 = peg$currPos;\n    s1 = [];\n    s2 = peg$parseDefOrExpr();\n    if (s2 as any !== peg$FAILED) {\n      while (s2 as any !== peg$FAILED) {\n        s1.push(s2);\n        s2 = peg$parseDefOrExpr();\n      }\n    } else {\n      s1 = peg$FAILED;\n    }\n    if (s1 as any !== peg$FAILED) {\n      peg$savedPos = s0;\n      s1 = peg$c0(s1);\n    }\n    s0 = s1;\n\n    return s0;\n  }\n\n  function peg$parseDefOrExpr(): any {\n    let s0, s1, s2, s3;\n\n    s0 = peg$currPos;\n    s1 = peg$parseDefinition();\n    if (s1 as any === peg$FAILED) {\n      s1 = peg$parseExpression();\n    }\n    if (s1 as any !== peg$FAILED) {\n      s2 = [];\n      if (peg$c1.test(input.charAt(peg$currPos))) {\n        s3 = input.charAt(peg$currPos);\n        peg$currPos++;\n      } else {\n        s3 = peg$FAILED;\n        if (peg$silentFails === 0) { peg$fail(peg$c2); }\n      }\n      if (s3 as any !== peg$FAILED) {\n        while (s3 as any !== peg$FAILED) {\n          s2.push(s3);\n          if (peg$c1.test(input.charAt(peg$currPos))) {\n            s3 = input.charAt(peg$currPos);\n            peg$currPos++;\n          } else {\n            s3 = peg$FAILED;\n            if (peg$silentFails === 0) { peg$fail(peg$c2); }\n          }\n        }\n      } else {\n        s2 = peg$FAILED;\n      }\n      if (s2 as any !== peg$FAILED) {\n        peg$savedPos = s0;\n        s1 = peg$c0(s1);\n        s0 = s1;\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parseDefinition(): any {\n    let s0, s1, s2;\n\n    s0 = peg$currPos;\n    s1 = peg$parse_();\n    if (s1 as any !== peg$FAILED) {\n      s2 = peg$parseStructDef();\n      if (s2 as any === peg$FAILED) {\n        s2 = peg$parseFunDef();\n        if (s2 as any === peg$FAILED) {\n          s2 = peg$parseConstDef();\n        }\n      }\n      if (s2 as any !== peg$FAILED) {\n        peg$savedPos = s0;\n        s1 = peg$c3(s2);\n        s0 = s1;\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parseStructDef(): any {\n    let s0, s1, s2, s3, s4, s5, s6, s7, s8;\n\n    s0 = peg$currPos;\n    if (input.substr(peg$currPos, 14) === peg$c4) {\n      s1 = peg$c4;\n      peg$currPos += 14;\n    } else {\n      s1 = peg$FAILED;\n      if (peg$silentFails === 0) { peg$fail(peg$c5); }\n    }\n    if (s1 as any !== peg$FAILED) {\n      s2 = peg$parseName();\n      if (s2 as any !== peg$FAILED) {\n        s3 = peg$parse_();\n        if (s3 as any !== peg$FAILED) {\n          if (input.charCodeAt(peg$currPos) === 40) {\n            s4 = peg$c6;\n            peg$currPos++;\n          } else {\n            s4 = peg$FAILED;\n            if (peg$silentFails === 0) { peg$fail(peg$c7); }\n          }\n          if (s4 as any !== peg$FAILED) {\n            s5 = [];\n            s6 = peg$parseName();\n            if (s6 as any !== peg$FAILED) {\n              while (s6 as any !== peg$FAILED) {\n                s5.push(s6);\n                s6 = peg$parseName();\n              }\n            } else {\n              s5 = peg$FAILED;\n            }\n            if (s5 as any !== peg$FAILED) {\n              if (input.charCodeAt(peg$currPos) === 41) {\n                s6 = peg$c8;\n                peg$currPos++;\n              } else {\n                s6 = peg$FAILED;\n                if (peg$silentFails === 0) { peg$fail(peg$c9); }\n              }\n              if (s6 as any !== peg$FAILED) {\n                s7 = peg$parse_();\n                if (s7 as any !== peg$FAILED) {\n                  if (input.charCodeAt(peg$currPos) === 41) {\n                    s8 = peg$c8;\n                    peg$currPos++;\n                  } else {\n                    s8 = peg$FAILED;\n                    if (peg$silentFails === 0) { peg$fail(peg$c9); }\n                  }\n                  if (s8 as any !== peg$FAILED) {\n                    peg$savedPos = s0;\n                    s1 = peg$c10(s2, s5);\n                    s0 = s1;\n                  } else {\n                    peg$currPos = s0;\n                    s0 = peg$FAILED;\n                  }\n                } else {\n                  peg$currPos = s0;\n                  s0 = peg$FAILED;\n                }\n              } else {\n                peg$currPos = s0;\n                s0 = peg$FAILED;\n              }\n            } else {\n              peg$currPos = s0;\n              s0 = peg$FAILED;\n            }\n          } else {\n            peg$currPos = s0;\n            s0 = peg$FAILED;\n          }\n        } else {\n          peg$currPos = s0;\n          s0 = peg$FAILED;\n        }\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parseFunDef(): any {\n    let s0, s1, s2, s3, s4, s5, s6, s7, s8, s9;\n\n    s0 = peg$currPos;\n    if (input.substr(peg$currPos, 7) === peg$c11) {\n      s1 = peg$c11;\n      peg$currPos += 7;\n    } else {\n      s1 = peg$FAILED;\n      if (peg$silentFails === 0) { peg$fail(peg$c12); }\n    }\n    if (s1 as any !== peg$FAILED) {\n      s2 = peg$parse_();\n      if (s2 as any !== peg$FAILED) {\n        if (input.charCodeAt(peg$currPos) === 40) {\n          s3 = peg$c6;\n          peg$currPos++;\n        } else {\n          s3 = peg$FAILED;\n          if (peg$silentFails === 0) { peg$fail(peg$c7); }\n        }\n        if (s3 as any !== peg$FAILED) {\n          s4 = peg$parseName();\n          if (s4 as any !== peg$FAILED) {\n            s5 = peg$parse_();\n            if (s5 as any !== peg$FAILED) {\n              s6 = [];\n              s7 = peg$parseName();\n              if (s7 as any !== peg$FAILED) {\n                while (s7 as any !== peg$FAILED) {\n                  s6.push(s7);\n                  s7 = peg$parseName();\n                }\n              } else {\n                s6 = peg$FAILED;\n              }\n              if (s6 as any !== peg$FAILED) {\n                if (input.charCodeAt(peg$currPos) === 41) {\n                  s7 = peg$c8;\n                  peg$currPos++;\n                } else {\n                  s7 = peg$FAILED;\n                  if (peg$silentFails === 0) { peg$fail(peg$c9); }\n                }\n                if (s7 as any !== peg$FAILED) {\n                  s8 = peg$parseExpression();\n                  if (s8 as any !== peg$FAILED) {\n                    if (input.charCodeAt(peg$currPos) === 41) {\n                      s9 = peg$c8;\n                      peg$currPos++;\n                    } else {\n                      s9 = peg$FAILED;\n                      if (peg$silentFails === 0) { peg$fail(peg$c9); }\n                    }\n                    if (s9 as any !== peg$FAILED) {\n                      peg$savedPos = s0;\n                      s1 = peg$c13(s4, s6, s8);\n                      s0 = s1;\n                    } else {\n                      peg$currPos = s0;\n                      s0 = peg$FAILED;\n                    }\n                  } else {\n                    peg$currPos = s0;\n                    s0 = peg$FAILED;\n                  }\n                } else {\n                  peg$currPos = s0;\n                  s0 = peg$FAILED;\n                }\n              } else {\n                peg$currPos = s0;\n                s0 = peg$FAILED;\n              }\n            } else {\n              peg$currPos = s0;\n              s0 = peg$FAILED;\n            }\n          } else {\n            peg$currPos = s0;\n            s0 = peg$FAILED;\n          }\n        } else {\n          peg$currPos = s0;\n          s0 = peg$FAILED;\n        }\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parseConstDef(): any {\n    let s0, s1, s2, s3, s4;\n\n    s0 = peg$currPos;\n    if (input.substr(peg$currPos, 7) === peg$c11) {\n      s1 = peg$c11;\n      peg$currPos += 7;\n    } else {\n      s1 = peg$FAILED;\n      if (peg$silentFails === 0) { peg$fail(peg$c12); }\n    }\n    if (s1 as any !== peg$FAILED) {\n      s2 = peg$parseName();\n      if (s2 as any !== peg$FAILED) {\n        s3 = peg$parseExpression();\n        if (s3 as any !== peg$FAILED) {\n          if (input.charCodeAt(peg$currPos) === 41) {\n            s4 = peg$c8;\n            peg$currPos++;\n          } else {\n            s4 = peg$FAILED;\n            if (peg$silentFails === 0) { peg$fail(peg$c9); }\n          }\n          if (s4 as any !== peg$FAILED) {\n            peg$savedPos = s0;\n            s1 = peg$c14(s2, s3);\n            s0 = s1;\n          } else {\n            peg$currPos = s0;\n            s0 = peg$FAILED;\n          }\n        } else {\n          peg$currPos = s0;\n          s0 = peg$FAILED;\n        }\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parseExpression(): any {\n    let s0, s1, s2;\n\n    s0 = peg$currPos;\n    s1 = peg$parse_();\n    if (s1 as any !== peg$FAILED) {\n      s2 = peg$parseValue();\n      if (s2 as any === peg$FAILED) {\n        s2 = peg$parseCond();\n        if (s2 as any === peg$FAILED) {\n          s2 = peg$parseCall();\n          if (s2 as any === peg$FAILED) {\n            s2 = peg$parseName();\n          }\n        }\n      }\n      if (s2 as any !== peg$FAILED) {\n        peg$savedPos = s0;\n        s1 = peg$c15(s2);\n        s0 = s1;\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parseCond(): any {\n    let s0, s1, s2, s3, s4;\n\n    s0 = peg$currPos;\n    if (input.substr(peg$currPos, 5) === peg$c16) {\n      s1 = peg$c16;\n      peg$currPos += 5;\n    } else {\n      s1 = peg$FAILED;\n      if (peg$silentFails === 0) { peg$fail(peg$c17); }\n    }\n    if (s1 as any !== peg$FAILED) {\n      s2 = [];\n      s3 = peg$parseOption();\n      if (s3 as any !== peg$FAILED) {\n        while (s3 as any !== peg$FAILED) {\n          s2.push(s3);\n          s3 = peg$parseOption();\n        }\n      } else {\n        s2 = peg$FAILED;\n      }\n      if (s2 as any !== peg$FAILED) {\n        s3 = peg$parse_();\n        if (s3 as any !== peg$FAILED) {\n          if (input.charCodeAt(peg$currPos) === 41) {\n            s4 = peg$c8;\n            peg$currPos++;\n          } else {\n            s4 = peg$FAILED;\n            if (peg$silentFails === 0) { peg$fail(peg$c9); }\n          }\n          if (s4 as any !== peg$FAILED) {\n            peg$savedPos = s0;\n            s1 = peg$c18(s2);\n            s0 = s1;\n          } else {\n            peg$currPos = s0;\n            s0 = peg$FAILED;\n          }\n        } else {\n          peg$currPos = s0;\n          s0 = peg$FAILED;\n        }\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parseOption(): any {\n    let s0, s1, s2, s3, s4, s5, s6, s7;\n\n    s0 = peg$currPos;\n    s1 = peg$parse_();\n    if (s1 as any !== peg$FAILED) {\n      if (input.charCodeAt(peg$currPos) === 91) {\n        s2 = peg$c19;\n        peg$currPos++;\n      } else {\n        s2 = peg$FAILED;\n        if (peg$silentFails === 0) { peg$fail(peg$c20); }\n      }\n      if (s2 as any !== peg$FAILED) {\n        s3 = peg$parse_();\n        if (s3 as any !== peg$FAILED) {\n          s4 = peg$parseExpression();\n          if (s4 as any !== peg$FAILED) {\n            s5 = peg$parse_();\n            if (s5 as any !== peg$FAILED) {\n              s6 = peg$parseExpression();\n              if (s6 as any !== peg$FAILED) {\n                if (input.charCodeAt(peg$currPos) === 93) {\n                  s7 = peg$c21;\n                  peg$currPos++;\n                } else {\n                  s7 = peg$FAILED;\n                  if (peg$silentFails === 0) { peg$fail(peg$c22); }\n                }\n                if (s7 as any !== peg$FAILED) {\n                  peg$savedPos = s0;\n                  s1 = peg$c23(s4, s6);\n                  s0 = s1;\n                } else {\n                  peg$currPos = s0;\n                  s0 = peg$FAILED;\n                }\n              } else {\n                peg$currPos = s0;\n                s0 = peg$FAILED;\n              }\n            } else {\n              peg$currPos = s0;\n              s0 = peg$FAILED;\n            }\n          } else {\n            peg$currPos = s0;\n            s0 = peg$FAILED;\n          }\n        } else {\n          peg$currPos = s0;\n          s0 = peg$FAILED;\n        }\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parseCall(): any {\n    let s0, s1, s2, s3, s4;\n\n    s0 = peg$currPos;\n    if (input.charCodeAt(peg$currPos) === 40) {\n      s1 = peg$c6;\n      peg$currPos++;\n    } else {\n      s1 = peg$FAILED;\n      if (peg$silentFails === 0) { peg$fail(peg$c7); }\n    }\n    if (s1 as any !== peg$FAILED) {\n      s2 = peg$parseName();\n      if (s2 as any !== peg$FAILED) {\n        s3 = [];\n        s4 = peg$parseExpression();\n        while (s4 as any !== peg$FAILED) {\n          s3.push(s4);\n          s4 = peg$parseExpression();\n        }\n        if (s3 as any !== peg$FAILED) {\n          if (input.charCodeAt(peg$currPos) === 41) {\n            s4 = peg$c8;\n            peg$currPos++;\n          } else {\n            s4 = peg$FAILED;\n            if (peg$silentFails === 0) { peg$fail(peg$c9); }\n          }\n          if (s4 as any !== peg$FAILED) {\n            peg$savedPos = s0;\n            s1 = peg$c24(s2, s3);\n            s0 = s1;\n          } else {\n            peg$currPos = s0;\n            s0 = peg$FAILED;\n          }\n        } else {\n          peg$currPos = s0;\n          s0 = peg$FAILED;\n        }\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parseName(): any {\n    let s0, s1, s2, s3, s4;\n\n    s0 = peg$currPos;\n    s1 = peg$parse_();\n    if (s1 as any !== peg$FAILED) {\n      s2 = peg$currPos;\n      peg$silentFails++;\n      if (input.substr(peg$currPos, 6) === peg$c25) {\n        s3 = peg$c25;\n        peg$currPos += 6;\n      } else {\n        s3 = peg$FAILED;\n        if (peg$silentFails === 0) { peg$fail(peg$c26); }\n      }\n      peg$silentFails--;\n      if (s3 as any === peg$FAILED) {\n        s2 = undefined;\n      } else {\n        peg$currPos = s2;\n        s2 = peg$FAILED;\n      }\n      if (s2 as any !== peg$FAILED) {\n        s3 = [];\n        if (peg$c27.test(input.charAt(peg$currPos))) {\n          s4 = input.charAt(peg$currPos);\n          peg$currPos++;\n        } else {\n          s4 = peg$FAILED;\n          if (peg$silentFails === 0) { peg$fail(peg$c28); }\n        }\n        if (s4 as any !== peg$FAILED) {\n          while (s4 as any !== peg$FAILED) {\n            s3.push(s4);\n            if (peg$c27.test(input.charAt(peg$currPos))) {\n              s4 = input.charAt(peg$currPos);\n              peg$currPos++;\n            } else {\n              s4 = peg$FAILED;\n              if (peg$silentFails === 0) { peg$fail(peg$c28); }\n            }\n          }\n        } else {\n          s3 = peg$FAILED;\n        }\n        if (s3 as any !== peg$FAILED) {\n          peg$savedPos = s0;\n          s1 = peg$c29(s3);\n          s0 = s1;\n        } else {\n          peg$currPos = s0;\n          s0 = peg$FAILED;\n        }\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parseValue(): any {\n    let s0, s1;\n\n    s0 = peg$currPos;\n    s1 = peg$parseNumber();\n    if (s1 as any === peg$FAILED) {\n      s1 = peg$parseBoolean();\n      if (s1 as any === peg$FAILED) {\n        s1 = peg$parseEmpty();\n        if (s1 as any === peg$FAILED) {\n          s1 = peg$parseString();\n        }\n      }\n    }\n    if (s1 as any !== peg$FAILED) {\n      peg$savedPos = s0;\n      s1 = peg$c30(s1);\n    }\n    s0 = s1;\n\n    return s0;\n  }\n\n  function peg$parseNumber(): any {\n    let s0, s1, s2, s3;\n\n    s0 = peg$currPos;\n    s1 = peg$parse_();\n    if (s1 as any !== peg$FAILED) {\n      s2 = [];\n      if (peg$c31.test(input.charAt(peg$currPos))) {\n        s3 = input.charAt(peg$currPos);\n        peg$currPos++;\n      } else {\n        s3 = peg$FAILED;\n        if (peg$silentFails === 0) { peg$fail(peg$c32); }\n      }\n      if (s3 as any !== peg$FAILED) {\n        while (s3 as any !== peg$FAILED) {\n          s2.push(s3);\n          if (peg$c31.test(input.charAt(peg$currPos))) {\n            s3 = input.charAt(peg$currPos);\n            peg$currPos++;\n          } else {\n            s3 = peg$FAILED;\n            if (peg$silentFails === 0) { peg$fail(peg$c32); }\n          }\n        }\n      } else {\n        s2 = peg$FAILED;\n      }\n      if (s2 as any !== peg$FAILED) {\n        peg$savedPos = s0;\n        s1 = peg$c33();\n        s0 = s1;\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parseBoolean(): any {\n    let s0, s1, s2;\n\n    s0 = peg$currPos;\n    s1 = peg$parse_();\n    if (s1 as any !== peg$FAILED) {\n      if (input.substr(peg$currPos, 5) === peg$c34) {\n        s2 = peg$c34;\n        peg$currPos += 5;\n      } else {\n        s2 = peg$FAILED;\n        if (peg$silentFails === 0) { peg$fail(peg$c35); }\n      }\n      if (s2 as any === peg$FAILED) {\n        if (input.substr(peg$currPos, 6) === peg$c36) {\n          s2 = peg$c36;\n          peg$currPos += 6;\n        } else {\n          s2 = peg$FAILED;\n          if (peg$silentFails === 0) { peg$fail(peg$c37); }\n        }\n        if (s2 as any === peg$FAILED) {\n          if (input.substr(peg$currPos, 2) === peg$c38) {\n            s2 = peg$c38;\n            peg$currPos += 2;\n          } else {\n            s2 = peg$FAILED;\n            if (peg$silentFails === 0) { peg$fail(peg$c39); }\n          }\n          if (s2 as any === peg$FAILED) {\n            if (input.substr(peg$currPos, 2) === peg$c40) {\n              s2 = peg$c40;\n              peg$currPos += 2;\n            } else {\n              s2 = peg$FAILED;\n              if (peg$silentFails === 0) { peg$fail(peg$c41); }\n            }\n          }\n        }\n      }\n      if (s2 as any !== peg$FAILED) {\n        peg$savedPos = s0;\n        s1 = peg$c42(s2);\n        s0 = s1;\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parseEmpty(): any {\n    let s0, s1, s2;\n\n    s0 = peg$currPos;\n    s1 = peg$parse_();\n    if (s1 as any !== peg$FAILED) {\n      if (input.substr(peg$currPos, 3) === peg$c43) {\n        s2 = peg$c43;\n        peg$currPos += 3;\n      } else {\n        s2 = peg$FAILED;\n        if (peg$silentFails === 0) { peg$fail(peg$c44); }\n      }\n      if (s2 as any !== peg$FAILED) {\n        peg$savedPos = s0;\n        s1 = peg$c45();\n        s0 = s1;\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parseString(): any {\n    let s0, s1, s2, s3, s4;\n\n    s0 = peg$currPos;\n    s1 = peg$parse_();\n    if (s1 as any !== peg$FAILED) {\n      if (input.charCodeAt(peg$currPos) === 34) {\n        s2 = peg$c46;\n        peg$currPos++;\n      } else {\n        s2 = peg$FAILED;\n        if (peg$silentFails === 0) { peg$fail(peg$c47); }\n      }\n      if (s2 as any !== peg$FAILED) {\n        s3 = [];\n        if (peg$c48.test(input.charAt(peg$currPos))) {\n          s4 = input.charAt(peg$currPos);\n          peg$currPos++;\n        } else {\n          s4 = peg$FAILED;\n          if (peg$silentFails === 0) { peg$fail(peg$c49); }\n        }\n        if (s4 as any !== peg$FAILED) {\n          while (s4 as any !== peg$FAILED) {\n            s3.push(s4);\n            if (peg$c48.test(input.charAt(peg$currPos))) {\n              s4 = input.charAt(peg$currPos);\n              peg$currPos++;\n            } else {\n              s4 = peg$FAILED;\n              if (peg$silentFails === 0) { peg$fail(peg$c49); }\n            }\n          }\n        } else {\n          s3 = peg$FAILED;\n        }\n        if (s3 as any !== peg$FAILED) {\n          if (input.charCodeAt(peg$currPos) === 34) {\n            s4 = peg$c46;\n            peg$currPos++;\n          } else {\n            s4 = peg$FAILED;\n            if (peg$silentFails === 0) { peg$fail(peg$c47); }\n          }\n          if (s4 as any !== peg$FAILED) {\n            peg$savedPos = s0;\n            s1 = peg$c50(s3);\n            s0 = s1;\n          } else {\n            peg$currPos = s0;\n            s0 = peg$FAILED;\n          }\n        } else {\n          peg$currPos = s0;\n          s0 = peg$FAILED;\n        }\n      } else {\n        peg$currPos = s0;\n        s0 = peg$FAILED;\n      }\n    } else {\n      peg$currPos = s0;\n      s0 = peg$FAILED;\n    }\n\n    return s0;\n  }\n\n  function peg$parse_(): any {\n    let s0, s1, s2;\n\n    peg$silentFails++;\n    s0 = peg$currPos;\n    s1 = [];\n    if (peg$c1.test(input.charAt(peg$currPos))) {\n      s2 = input.charAt(peg$currPos);\n      peg$currPos++;\n    } else {\n      s2 = peg$FAILED;\n      if (peg$silentFails === 0) { peg$fail(peg$c2); }\n    }\n    while (s2 as any !== peg$FAILED) {\n      s1.push(s2);\n      if (peg$c1.test(input.charAt(peg$currPos))) {\n        s2 = input.charAt(peg$currPos);\n        peg$currPos++;\n      } else {\n        s2 = peg$FAILED;\n        if (peg$silentFails === 0) { peg$fail(peg$c2); }\n      }\n    }\n    if (s1 as any !== peg$FAILED) {\n      peg$savedPos = s0;\n      s1 = peg$c52();\n    }\n    s0 = s1;\n    peg$silentFails--;\n    if (s0 as any === peg$FAILED) {\n      s1 = peg$FAILED;\n      if (peg$silentFails === 0) { peg$fail(peg$c51); }\n    }\n\n    return s0;\n  }\n\n  peg$result = peg$startRuleFunction();\n\n  if (peg$result !== peg$FAILED && peg$currPos === input.length) {\n    return peg$result;\n  } else {\n    if (peg$result !== peg$FAILED && peg$currPos < input.length) {\n      peg$fail(peg$endExpectation());\n    }\n\n    throw peg$buildStructuredError(\n      peg$maxFailExpected,\n      peg$maxFailPos < input.length ? input.charAt(peg$maxFailPos) : null,\n      peg$maxFailPos < input.length\n        ? peg$computeLocation(peg$maxFailPos, peg$maxFailPos + 1)\n        : peg$computeLocation(peg$maxFailPos, peg$maxFailPos)\n    );\n  }\n}\n\nexport interface IParseOptions {\n  filename?: string;\n  startRule?: string;\n  tracer?: any;\n  [key: string]: any;\n}\nexport type ParseFunction = (input: string, options?: IParseOptions) => any;\nexport const parse: ParseFunction = peg$parse;\n", "// ######### LAYOUT AST AS TREE DIAGRAM ########\nimport * as BSL_AST from \"./BSL_AST\";\nimport * as BSL_Print from \"./BSL_Print\";\nimport {node, productionTree} from \"./Production_Tree\";\nimport {parse} from \"./BSL_Parser\";\nimport {default as error_css} from './ressources/error.css';\n\n// ### main api\nexport function processBslTrees() {\n  Array.from(document.getElementsByTagName('bsltree')).map(el => {\n    try {\n      const program : BSL_AST.program = parse(BSL_Print.dirtify(el.innerHTML));\n      const root = programToNode(program);\n      const quiz = el.getAttribute('quiz') === 'true' ? true : false;\n      const lang = (el.getAttribute('lang') ? el.getAttribute('lang') : undefined) as string | undefined;\n      productionTree(root, el as HTMLElement, productions, quiz, lang);\n    } catch(e:any) {\n      renderError(el as HTMLElement, `${e.location.start.line}:${e.location.start.column} ${e}`);\n    }\n  });\n}\n// ### error Render Function\nfunction renderError(el: HTMLElement, error:string){\n  // add css if necessary\n  if(!document.getElementById('bsl-tools-error-style')) {\n    const styleNode = document.createElement('style');\n    styleNode.innerHTML = error_css;\n    styleNode.id = 'bsl-tools-error-style';\n    document.getElementsByTagName('head')[0].appendChild(styleNode);\n  }\n\n  const origin = el.innerHTML;\n  el.innerHTML =\"\";\n  //create error-wrapper\n  const errorWrapper = document.createElement('div');\n  errorWrapper.classList.add('error-wrapper');\n  el.appendChild(errorWrapper);\n  //create originDiv\n  const message =`<p> BSL-Tree could not be parsed! </p>\n                  <p> Input: <b style=\"font-size:0.9em;\">${origin}</b> </p>`;\n  const originDiv = document.createElement('div');\n  originDiv.classList.add('origin');\n  originDiv.innerHTML = message;\n  errorWrapper.appendChild(originDiv);\n  //Create errPre\n  const errPre = document.createElement('pre');\n  errPre.classList.add('error');\n  const errCode = document.createElement('code');\n  errCode.textContent = error;\n  errorWrapper.appendChild(errPre);\n  errPre.appendChild(errCode);\n}\n\n// ### known list of productions\nconst productions = {\n  '<program>':      ['<def-or-expr>*'],\n  '<def-or-expr>*': [], // ['<def-or-expr> <def-or-expr>*',\n                        // ''],\n  '<def-or-expr>':  ['<definition>',\n                     '<e>'],\n  '<definition>':   ['(define (<name> <name>+) <e>)',\n                     '(define <name> <e>)',\n                     '(define-struct <name> (<name>*))'],\n  '<e>':            ['(name <e>*)',\n                     '(cond {[<e>,<e>]}+)',\n                     '<name>',\n                     '<v>'],\n  '<e>*':           [], //['<e> <e>*',\n                        // ''],\n  '{[ <e> <e> ]}+': [], //['[<e> <e>]',\n                        // '[<e> <e>] {[<e>,<e>]}+'],\n  '[ <e> <e> ]':    [], //['[<e> <e>]'],\n  '<name>*':        [], //['',\n                        // '<name> <name>*'],\n  '<name>+':        [], //['<name>',\n                        // '<name> <name>+'],\n  '<name>':         [],\n  '<v>':            []\n};\n\n// ### transform AST into node helper structure\nfunction programToNode(p: BSL_AST.program): node {\n  const expressions = p.map(BSL_Print.printDefOrExpr);\n  const indices = [];\n  let program = '';\n  for(let i = 0; i < expressions.length; i++) {\n    if (i > 0) program = `${program}\\n`;\n    const start = program.length;\n    program = `${program}${expressions[i]}`;\n    const end = program.length;\n    indices.push({start:start,end:end});\n  }\n  return {\n    production: '<program>',\n    code: program,\n    holes: [\n      {\n        start: 0,\n        end: program.length,\n        content: {\n          production: '<def-or-expr>*',\n          code: program,\n          holes: indices.map((h,idx) => { return {\n            start: h.start,\n            end: h.end,\n            content: defOrExprToNode(p[idx])\n          }})\n        }\n      }\n    ]\n  };\n}\n\nfunction defOrExprToNode(de: BSL_AST.defOrExpr):node {\n  const code = BSL_Print.printDefOrExpr(de) as string;\n  return {\n    production: '<def-or-expr>',\n    code: code,\n    holes: [{\n      start: 0,\n      end: code.length,\n      content: BSL_AST.isDefinition(de) ? defToNode(de) : expToNode(de)\n    }]\n  }\n}\n\nfunction defToNode(d: BSL_AST.definition):node {\n  let code = '';\n  const holes = [];\n  if (BSL_AST.isFunDef(d)) {\n    code = '(define (';\n    let start = code.length;\n    code = `${code}${BSL_Print.printName(d.name)}`;\n    holes.push({start:start, end:code.length, content:nameToNode(d.name)});\n\n    code = `${code} `;\n    start = code.length;\n    code = `${code}${d.args.map(BSL_Print.printName).join(' ')}`;\n    holes.push({start:start, end:code.length, content:namePlusToNode(d.args)});\n\n    code = `${code}) `;\n    start = code.length;\n    code = `${code}${BSL_Print.printE(d.body)}`;\n    holes.push({start:start, end:code.length, content:expToNode(d.body)});\n\n    code = `${code})`;\n  } else if (BSL_AST.isConstDef(d)) {\n    code = '(define ';\n    let start = code.length;\n    code = `${code}${BSL_Print.printName(d.name)}`;\n    holes.push({start:start, end:code.length, content:nameToNode(d.name)});\n\n    code = `${code} `;\n    start = code.length;\n    code = `${code}${BSL_Print.printE(d.value)}`;\n    holes.push({start:start, end:code.length, content:expToNode(d.value)});\n\n    code = `${code})`;\n  } else {\n    code = '(define-struct ';\n    let start = code.length;\n    code = `${code}${BSL_Print.printName(d.binding)}`;\n    holes.push({start:start, end:code.length, content:nameToNode(d.binding)});\n\n    code = `${code} (`;\n    start = code.length;\n    code = `${code}${d.properties.map(BSL_Print.printName).join(' ')}`;\n    holes.push({start:start, end:code.length, content:nameStarToNode(d.properties)});\n\n    code = `${code}))`;\n  }\n  return {\n    production: `<definition>`,\n    code: code,\n    holes: holes\n  };\n}\n\nfunction expToNode(e: BSL_AST.expr):node {\n  let code = '';\n  const holes = [];\n  if(BSL_AST.isCall(e)) {\n    code = '(';\n    let start = code.length;\n    code = `${code}${BSL_Print.printName(e.name)}`;\n    holes.push({start:start, end:code.length, content:nameToNode(e.name)});\n\n    code = `${code} `;\n    start = code.length;\n    code = `${code}${e.args.map(BSL_Print.printE).join(' ')}`;\n    holes.push({start:start, end:code.length, content:eStarToNode(e.args)});\n\n    code = `${code})`;\n  } else if (BSL_AST.isCond(e)) {\n    code = '(cond ';\n    let start = code.length;\n    code = `${code}${e.options.map(BSL_Print.printOption).join(' ')}`;\n    holes.push({start:start, end:code.length, content:optionsToNode(e.options)});\n    code = `${code})`;\n  } else if (BSL_AST.isName(e)) {\n    code = BSL_Print.printName(e);\n    holes.push({start:0, end:code.length, content:nameToNode(e)});\n  } else {\n    code = BSL_Print.printE(e);\n    holes.push({start:0, end:code.length, content:literalToNode(e)});\n  }\n  return {\n    production: '<e>',\n    code: code,\n    holes: holes\n  };\n}\n\nfunction nameToNode(n: BSL_AST.Name):node {\n  return {\n    production: '<name>',\n    code: BSL_Print.printName(n),\n    holes: []\n  };\n}\n\nfunction namePlusToNode(ns: BSL_AST.Name[]):node {\n  if (ns.length < 1) console.error('<name>+ but used but names are empty');\n  let code = '';\n  const holes = [];\n  for(let i = 0; i < ns.length; i++) {\n    const start = code.length;\n    code = `${code}${BSL_Print.printName(ns[i])}`;\n    holes.push({start:start, end:code.length, content:nameToNode(ns[i])});\n\n    if(i < ns.length - 1) code = `${code} `;\n  }\n  return {\n    production: '<name>+',\n    code: code,\n    holes: holes\n  }\n}\n\nfunction nameStarToNode(ns: BSL_AST.Name[]):node {\n  let code = '';\n  const holes = [];\n  for(let i = 0; i < ns.length; i++) {\n    const start = code.length;\n    code = `${code}${BSL_Print.printName(ns[i])}`;\n    holes.push({start:start, end:code.length, content:nameToNode(ns[i])});\n\n    if(i < ns.length - 1) code = `${code} `;\n  }\n  return {\n    production: '<name>*',\n    code: code,\n    holes: holes\n  }\n}\n\nfunction eStarToNode(es: BSL_AST.expr[]):node {\n  let code = '';\n  const holes = [];\n  for(let i = 0; i < es.length; i++) {\n    const start = code.length;\n    code = `${code}${BSL_Print.printE(es[i])}`;\n    holes.push({start:start, end:code.length, content:expToNode(es[i])});\n\n    if(i < es.length - 1) code = `${code} `;\n  }\n  return {\n    production: '<e>*',\n    code: code,\n    holes: holes\n  }\n}\n\nfunction optionsToNode(os: BSL_AST.Clause[]):node {\n  let code = '';\n  const holes = [];\n  for(let i = 0; i < os.length; i++) {\n    const start = code.length;\n    code = `${code}${BSL_Print.printOption(os[i])}`;\n    holes.push({start:start, end:code.length, content:optionToNode(os[i])});\n\n    if(i < os.length - 1) code = `${code} `;\n  }\n  return {\n    production: '{[ <e> <e> ]}+',\n    code: code,\n    holes: holes\n  }\n}\n\nfunction optionToNode(o: BSL_AST.Clause):node {\n  let code = '';\n  const holes = [];\n  code = `${code}[`;\n  let start = code.length;\n  code = `${code}${BSL_Print.printE(o.condition)}`;\n  holes.push({start:start, end:code.length, content:expToNode(o.condition)});\n\n  code = `${code} `;\n  start = code.length;\n  code = `${code}${BSL_Print.printE(o.result)}`;\n  holes.push({start:start, end:code.length, content:expToNode(o.result)});\n\n  code = `${code}]`;\n\n  return {\n    production: '[ <e> <e> ]',\n    code: code,\n    holes: holes\n  };\n\n}\n\nfunction literalToNode(v: BSL_AST.Literal):node {\n  return {\n    production: '<v>',\n    code: BSL_Print.printE(v),\n    holes: []\n  }\n}\n", "import {node, productionTree, grammar} from \"./Production_Tree\";\nimport {dirtify} from './BSL_Print';\n\nexport function processJsonTrees() {\n  Array.from(document.getElementsByTagName('jsontree')).map(el => {\n    try {\n      const ret = parseJsonTree(dirtify(el.innerHTML));\n      const root = ret.root;\n      const grammar = ret.grammar;\n      const quiz = el.getAttribute('quiz') === 'true' ? true : false;\n      const lang = (el.getAttribute('lang') ? el.getAttribute('lang') : undefined) as string | undefined;\n      productionTree(root, el as HTMLElement, grammar, quiz, lang);\n    } catch(e:any) {\n      console.error(e);\n      el.innerHTML = `${e}`;\n      (el as HTMLElement).style.cssText = `\n        padding: 2em;\n        color: darkred;\n        display: block;\n      `;\n    }\n  });\n}\n\nfunction parseJsonTree(js: string): {root: node, grammar: grammar | undefined} {\n  const json = JSON.parse(js.trim());\n  const grammar = json['grammar'];\n  const root = processHolesRecursive(json);\n  return {\n    root: root,\n    grammar: grammar\n  };\n}\n\n// ### runtime type checking, extracting hole positions and removing\n//     dividers (|) from code\nfunction processHolesRecursive(n: node): node {\n  // runtime type checking\n  const p = n.production;\n  if(!p || typeof(p) !== 'string') {\n    throw `${renderErronousJSON(n)}<br> has wrong structure, production needs to be a string`;\n  }\n  const c = n.code;\n  if(!c || typeof(c) !== 'string') {\n    throw `${renderErronousJSON(n)}<br>  has wrong structure, code needs to be a string`;\n  }\n  if (!n.holes) n.holes = [];\n\n  // extracting hole positions and removing dividers || from code\n  const codeParts = c.split('|');\n  let code = '';\n  let holes = [];\n  for(let i = 0; i < codeParts.length; i++) {\n    // start: not enclosed in ||\n    code = `${code}${codeParts[i]}`;\n\n    // next part: enter ||\n    i++;\n    if(i < codeParts.length && codeParts[i]) {\n      const start = code.length;\n      code = `${code}${codeParts[i]}`;\n      const content = n.holes[holes.length] as any;\n      if(!content) {\n        throw `${renderErronousJSON(n)}<br> has wrong structure: less holes than marked with || in the code`;\n      }\n      holes.push({start: start, end: code.length, content: processHolesRecursive(content)});\n    }\n  }\n  // return processed node\n  return {\n    production: p,\n    code: code,\n    holes: holes\n  };\n\n}\n\nfunction renderErronousJSON(n: node): string {\n  const code = JSON.stringify(n, undefined, 2);\n  return `\n    <textarea rows=\"${code.split('\\n').length}\"\n              cols=\"${code.split('\\n').map(l => l.length).reduce((x,y) => x > y ? x : y)}\"\n              readOnly=\"true\"\n              resizable=\"false\">${code}</textarea>\n  `;\n}\n", "import * as BSL_AST from \"./BSL_AST\";\n\nexport enum Production {\n  Stepper = \"Stepper\",\n  ExprStep = \"ExprStep\",\n  DefinitionStep = \"DefinitionStep\",\n  EvalStep = \"EvalStep\",\n  Split = \"Split\",\n  CallRedex = \"CallRedex\",\n  CondRedex = \"CondRedex\",\n  NameRedex = \"NameRedex\",\n  CondOption = \"CondOption\",\n  AppContext = \"AppContext\",\n  CondContext = \"CondContext\",\n  Hole = \"Hole\",\n  PrimDef = \"PrimDef\",\n  FunDef = \"FunEnv\",\n  StructDef = \"StructDef\",\n  MakeFun = \"MakeFun\",\n  PredFun = \"PredFun\",\n  SelectFun = \"SelectFun\",\n  Id = \"Identifier\",\n}\n\nexport enum Decomposition {\n  Stepper = \"Stepper\",\n  ExprStep = \"ExprStep\",\n  DefinitionStep = \"DefinitionStep\",\n  EvalStep = \"EvalStep\",\n  Split = \"Split\",\n  CallRedex = \"CallRedex\",\n  CondRedex = \"CondRedex\",\n  NameRedex = \"NameRedex\",\n  CondOption = \"CondOption\",\n  AppContext = \"AppContext\",\n  CondContext = \"CondContext\",\n  Hole = \"Hole\",\n  Id = \"Identifier\",\n}\nexport enum EnvironmentValue {\n  FunDef = \"FunEnv\",\n  StructDef = \"StructDef\",\n  MakeFun = \"MakeFun\",\n  PredFun = \"PredFun\",\n  SelectFun = \"SelectFun\",\n}\nexport enum Rule {\n  Kong = \"Kong\",\n  Prim = \"Prim\",\n  PrimError = \"PrimError\",\n  CondTrue = \"CondTrue\",\n  CondFalse = \"CondFalse\",\n  CondError = \"CondError\",\n  Prog = \"Prog\",\n  ProgError = \"ProgError\",\n  Const = \"Const\",\n  ConstError = \"ConstError\",\n  Fun = \"Fun\",\n  FunError = \"FunError\",\n  StructMake = \"StructMake\",\n  StructMakeError = \"StructMakeError\",\n  StructPredTrue = \"StructPredTrue\",\n  StructPredFalse = \"StructPredFalse\",\n  StructPredError = \"StructPredError\",\n  StructSelect = \"StructSelect\",\n  StructSelectError = \"StructSelectError\",\n}\nexport enum PrimFuns {\n  Add = \"+\",\n  Sub = \"-\",\n  Mul = \"*\",\n  Div = \"/\",\n  And = \"and\",\n  Or = \"or\",\n  Not = \"not\",\n  Leq = \"<=\",\n  Geq = \">=\",\n  Lt = \"<\",\n  Gt = \">\",\n}\nexport interface Stepper {\n  type: Production.Stepper;\n  originProgram: BSL_AST.program;\n  progSteps: ProgStep[];\n}\nexport type ProgStep = ExprStep | DefinitionStep;\n// DefinitionStep has ProgRule\nexport interface DefinitionStep {\n  type: Production.DefinitionStep;\n  env: Environment;\n  evalSteps: EvalStep[];\n  rule: Prog | ProgError;\n  originalDefOrExpr: BSL_AST.definition;\n  result: BSL_AST.definition | Error; //evaluated definition, which is given to env\n}\nexport interface ExprStep {\n  type: Production.ExprStep;\n  env: Environment;\n  evalSteps: EvalStep[];\n  originalDefOrExpr: BSL_AST.expr;\n  result: Value | Error;\n}\nexport interface EvalStep {\n  type: Production.EvalStep;\n  env: Environment;\n  rule: Kong | OneRule;\n  result: BSL_AST.expr | Value | Error;\n}\nexport type SplitResult = Split | Value;\nexport interface Split {\n  type: Production.Split;\n  redex: Redex;\n  context: Context;\n}\n\n// Redex ist Summentyp: CallRedex | CondRedex, etc.\n// ####### REDEX #######\nexport type Redex = CallRedex | CondRedex | NameRedex;\n\nexport interface CallRedex {\n  type: Production.CallRedex;\n  name: BSL_AST.Name;\n  args: (Value | Id)[];\n}\n\nexport interface CondRedex {\n  type: Production.CondRedex;\n  options: BSL_AST.Clause[];\n}\n\nexport interface NameRedex {\n  type: Production.NameRedex;\n  symbol: string;\n}\n// ####### Context #######\nexport type Context = AppContext | CondContext | Hole;\n\nexport interface AppContext {\n  type: Production.AppContext;\n  op: BSL_AST.Name;\n  values: (Value | Id)[];\n  ctx: Context;\n  args: BSL_AST.expr[];\n}\nexport interface CondContext {\n  type: Production.CondContext;\n  options: BSL_AST.Clause[];\n  ctx: Context;\n}\nexport interface Hole {\n  type: Production.Hole;\n}\nexport type Value =\n  | number\n  | string\n  | boolean\n  | `'()`\n  | BSL_AST.StructValue /*| FunValue/*| Closure */;\n\nexport type EnvValue = Value | PrimDef | FunDef | StructDef | StructFun;\nexport interface Id {\n  type: Production.Id;\n  symbol: string;\n}\nexport interface PrimDef {\n  type: Production.PrimDef;\n}\nexport interface FunDef {\n  type: Production.FunDef;\n  params: BSL_AST.Name[];\n  body: BSL_AST.expr;\n}\nexport interface StructDef {\n  type: Production.StructDef;\n  properties: BSL_AST.Name[];\n}\nexport type StructFun = MakeFun | PredFun | SelectFun;\n\nexport interface MakeFun {\n  type: Production.MakeFun;\n  structDef: StructDef;\n}\nexport interface PredFun {\n  type: Production.PredFun;\n  structDef: StructDef;\n}\nexport interface SelectFun {\n  type: Production.SelectFun;\n  structDef: StructDef;\n}\n\n//######## OneRule(s) ########\nexport type PrimRule = Prim | PrimError;\nexport interface Prim {\n  type: Rule.Prim;\n  redex: CallRedex;\n  result: Value;\n}\nexport interface PrimError {\n  type: Rule.PrimError;\n  redex: CallRedex;\n  result: Error;\n}\nexport type CondRule = CondTrue | CondFalse | CondError;\nexport interface CondTrue {\n  type: Rule.CondTrue;\n  redex: CondRedex;\n  result: BSL_AST.expr | Value;\n}\nexport interface CondFalse {\n  type: Rule.CondFalse;\n  redex: CondRedex;\n  result: BSL_AST.Cond;\n}\nexport interface CondError {\n  type: Rule.CondError;\n  redex: CondRedex;\n  result: Error;\n}\nexport type ProgRule = Prog | ProgError;\nexport interface Prog {\n  type: Rule.Prog;\n  result: BSL_AST.definition;\n}\nexport interface ProgError {\n  type: Rule.ProgError;\n  result: Error;\n}\nexport type ConstRule = Const | ConstError;\nexport interface Const {\n  type: Rule.Const;\n  redex: Redex;\n  result: BSL_AST.expr | Value;\n}\nexport interface ConstError {\n  type: Rule.ConstError;\n  redex: Redex;\n  result: Error;\n}\nexport type FunRule = Fun | FunError;\nexport interface Fun {\n  type: Rule.Fun;\n  redex: CallRedex;\n  result: BSL_AST.expr;\n}\nexport interface FunError {\n  type: Rule.FunError;\n  redex: CallRedex;\n  result: Error;\n}\ntype StructRule =\n  | StructMake\n  | StructMakeError\n  | StructPredTrue\n  | StructPredFalse\n  | StructPredError\n  | StructSelect\n  | StructSelectError;\nexport interface StructMake {\n  type: Rule.StructMake;\n  redex: CallRedex;\n  result: Value;\n}\nexport interface StructMakeError {\n  type: Rule.StructMakeError;\n  redex: CallRedex;\n  result: Error;\n}\nexport interface StructPredTrue {\n  type: Rule.StructPredTrue;\n  redex: CallRedex;\n  result: true;\n}\nexport interface StructPredFalse {\n  type: Rule.StructPredFalse;\n  redex: CallRedex;\n  result: false;\n}\nexport interface StructPredError {\n  type: Rule.StructPredError;\n  redex: CallRedex;\n  result: Error;\n}\nexport interface StructSelect {\n  type: Rule.StructSelect;\n  redex: CallRedex;\n  result: BSL_AST.expr | Value;\n}\nexport interface StructSelectError {\n  type: Rule.StructSelectError;\n  redex: CallRedex;\n  result: Error;\n}\n\nexport type OneRule = PrimRule | CondRule | ConstRule | FunRule | StructRule;\n\n// ####### ProgStepRule(s) ########\nexport interface Kong {\n  type: Rule.Kong;\n  context: Context;\n  redexRule: OneRule;\n}\n// ######### DEFINITIONS ########\n\n// definition is either structDef, funDef or constDef\n// DefRules PROG, STRUCT, FUN, CONST\n\n// ENVIRONMENT\n\nexport type Environment = { [key: string]: EnvValue };\n// BSL_AST.expr is evaluated first (call by value)\n// ##########################\n\n// runtime type checking\n// Stepper and Steps\nexport function isStepper(obj: any): obj is Stepper {\n  return obj.type === Production.Stepper;\n}\nexport function isExprStep(obj: any): obj is ExprStep {\n  return obj.type === Production.ExprStep;\n}\nexport function isDefinitionStep(obj: any): obj is DefinitionStep {\n  return obj.type === Production.DefinitionStep;\n}\nexport function isEvalStep(obj: any): obj is EvalStep {\n  return obj.type === Production.EvalStep;\n}\n//Redex\nexport function isCallRedex(obj: any): obj is CallRedex {\n  return obj.type === Production.CallRedex;\n}\nexport function isCondRedex(obj: any): obj is CondRedex {\n  return obj.type === Production.CondRedex;\n}\nexport function isNameRedex(obj: any): obj is NameRedex {\n  return obj.type === Production.NameRedex;\n}\n\nexport function isHole(obj: any): obj is Hole {\n  return obj.type === Production.Hole;\n}\nexport function isContext(obj: any): obj is Context {\n  return (\n    obj.type === Production.AppContext || obj.type === Production.CondContext\n  );\n}\nexport function isAppContext(obj: any): obj is AppContext {\n  return obj.type === Production.AppContext;\n}\nexport function isCondContext(obj: any): obj is CondContext {\n  return obj.type === Production.CondContext;\n}\nexport function isSplit(obj: any): obj is Split {\n  return obj.type === Production.Split;\n}\nexport function isOneRule(obj: any): obj is OneRule {\n  return (\n    obj.type === Rule.Prim ||\n    obj.type === Rule.PrimError ||\n    obj.type === Rule.CondTrue ||\n    obj.type === Rule.CondFalse ||\n    obj.type === Rule.CondError ||\n    obj.type === Rule.Const ||\n    obj.type === Rule.ConstError ||\n    obj.type === Rule.Fun ||\n    obj.type === Rule.FunError ||\n    obj.type === Rule.StructMake ||\n    obj.type === Rule.StructMakeError ||\n    obj.type === Rule.StructPredTrue ||\n    obj.type === Rule.StructPredFalse ||\n    obj.type === Rule.StructPredError ||\n    obj.type === Rule.StructSelect ||\n    obj.type === Rule.StructSelectError\n  );\n}\nexport function isProgRule(obj: any): obj is ProgRule {\n  return obj.type === Rule.Prog || obj.type === Rule.ProgError;\n}\nexport function isProg(obj: any): obj is Prog {\n  return obj.type === Rule.Prog;\n}\nexport function isProgError(obj: any): obj is ProgError {\n  return obj.type === Rule.ProgError;\n}\nexport function isKong(obj: any): obj is Kong {\n  return obj.type === Rule.Kong;\n}\nexport function isValue(obj: any): obj is Value {\n  return (\n    typeof obj === \"number\" ||\n    typeof obj === \"string\" ||\n    typeof obj === \"boolean\" ||\n    obj === `'()` ||\n    BSL_AST.isStructValue(obj)\n  ); //|| isClosure(obj);\n}\nexport function isPrimDef(obj: any): obj is PrimDef {\n  return obj.type === Production.PrimDef;\n}\nexport function isFunDef(obj: any): obj is FunDef {\n  return obj.type === Production.FunDef;\n}\nexport function isStructDef(obj: any): obj is StructDef {\n  return obj.type === Production.StructDef;\n}\nexport function isId(obj: any): obj is Id {\n  return obj.type === Production.Id;\n}\nexport function isStructFun(obj: any): obj is StructFun {\n  return (\n    obj.type === Production.MakeFun ||\n    obj.type === Production.PredFun ||\n    obj.type === Production.SelectFun\n  );\n}\nexport function isMakeFun(obj: any): obj is MakeFun {\n  return obj.type === Production.MakeFun;\n}\nexport function isPredFun(obj: any): obj is PredFun {\n  return obj.type === Production.PredFun;\n}\nexport function isSelectFun(obj: any): obj is SelectFun {\n  return obj.type === Production.SelectFun;\n}\n", "import * as BSL_AST from \"./BSL_AST\";\nimport * as SI_STRUCT from \"./SI_STRUCT\";\n\n// calculateAllSteps (for the whole program)\nexport function calculateProgram(\n  program: BSL_AST.program\n): SI_STRUCT.Stepper | Error {\n  // Initialize the environment\n  const maybeEnv = initEnv();\n  if (maybeEnv instanceof Error) return maybeEnv;\n  let env: SI_STRUCT.Environment = maybeEnv;\n  \n\n  // rewrite this \n  const progSteps = program.map((defOrExpr) => {\n    const newStep = calculateProgStep(defOrExpr, env);\n    if (newStep instanceof Error) return newStep;\n    env = newStep.env;\n    return newStep;\n  });\n  // if a ProgStep itself is an Error, return the Error\n  const isProgError = progSteps.some((s) => s instanceof Error);\n  if (isProgError) return progSteps.find((s) => s instanceof Error) as Error;\n  // else check if there is an error in the result\n  const isStepResError = progSteps.some(s=> (s as SI_STRUCT.ProgStep).result instanceof Error);\n  // if there is an error in the result, find the index of the error and slice the array at the last index after the error\n  const progStepErrorId = isStepResError ? progSteps.findIndex((s) => (s as SI_STRUCT.ProgStep).result instanceof Error) : -1;\n  const newProgSteps = isStepResError ? progSteps.slice(0, progStepErrorId + 1) as SI_STRUCT.ProgStep[] : progSteps as SI_STRUCT.ProgStep[];\n\n  return {\n    type: SI_STRUCT.Production.Stepper,\n    originProgram: program,\n    progSteps: newProgSteps,\n  };\n}\n// calculate ProgStep\n// One ProgStep represents a line of program code -> ProgStep | Error\nexport function calculateProgStep(\n  defOrExpr: BSL_AST.expr | BSL_AST.definition,\n  env: SI_STRUCT.Environment\n): SI_STRUCT.ProgStep | Error {\n  // If it is an expression, calculate the steps for the expression\n  if (BSL_AST.isExpr(defOrExpr)) {\n    const evalStep = calculateEvalSteps(defOrExpr, env);\n    if (evalStep instanceof Error) return evalStep;\n    if (evalStep.length === 0) {\n      return {\n        type: SI_STRUCT.Production.ExprStep,\n        env: env,\n        evalSteps: [],\n        originalDefOrExpr: defOrExpr,\n        result: evaluateExpression(defOrExpr, env) as SI_STRUCT.Value,\n      };\n    } else {\n      const result = evalStep[evalStep.length - 1].result;\n      if (BSL_AST.isExpr(result)) return new Error(\"Result is not a value\");\n      else\n        return {\n          type: SI_STRUCT.Production.ExprStep,\n          env: evalStep[evalStep.length - 1].env,\n          evalSteps: evalStep,\n          originalDefOrExpr: defOrExpr,\n          result: result,\n        };\n    }\n  } else {\n    // If it is a definition, calculate the step for the definition\n    const defStep = calculateDefSteps(defOrExpr, env);\n    // If the an error occurs, return the error\n    // if (defStep instanceof Error) return defStep;\n    return defStep;\n  }\n}\n//calculateDefSteps\n//definition, Environment => SI_STRUCT.DefStep\nexport function calculateDefSteps(\n  def: BSL_AST.definition,\n  env: SI_STRUCT.Environment\n): SI_STRUCT.DefinitionStep | Error {\n  // If Constant Definition => Add Constant Definition to Environment\n  if (BSL_AST.isConstDef(def)) {\n    const name = def.name;\n    const expr = def.value;\n    // If the expression is a literal, add the literal to the environment\n    if (BSL_AST.isLiteral(expr)) {\n      const value = expr.value;\n      const newEnv = addToEnv(env, name.symbol, value);\n      const err = newEnv instanceof Error;\n      const progRule: SI_STRUCT.ProgRule | SI_STRUCT.ProgError = err\n        ? {\n            type: SI_STRUCT.Rule.ProgError,\n            result: newEnv,\n          }\n        : { type: SI_STRUCT.Rule.Prog, result: def };\n      return {\n        type: SI_STRUCT.Production.DefinitionStep,\n        env: err ? env : newEnv,\n        rule: progRule,\n        evalSteps: [],\n        originalDefOrExpr: def,\n        result: err ? newEnv : def,\n      };\n    } else {\n      let stepList = calculateEvalSteps(expr, env);\n      if (stepList instanceof Error) return stepList;\n      const value = stepList[stepList.length - 1].result;\n      if (SI_STRUCT.isValue(value)) {\n        const newEnv = addToEnv(env, name.symbol, value);\n        const err = newEnv instanceof Error;\n        const newDef: BSL_AST.ConstDef = {\n          type: BSL_AST.Production.ConstantDefinition,\n          name: name,\n          value: { type: BSL_AST.Production.Literal, value: value },\n        };\n        const progRule: SI_STRUCT.ProgRule | SI_STRUCT.ProgError = err\n          ? {\n              type: SI_STRUCT.Rule.ProgError,\n              result: newEnv,\n            }\n          : { type: SI_STRUCT.Rule.Prog, result: newDef };\n        return {\n          type: SI_STRUCT.Production.DefinitionStep,\n          env: err ? env : newEnv,\n          rule: progRule,\n          evalSteps: stepList,\n          originalDefOrExpr: def,\n          result: newDef,\n        };\n      } else if (value instanceof Error) {\n        return {\n          type: SI_STRUCT.Production.DefinitionStep,\n          env: env,\n          rule: {\n            type: SI_STRUCT.Rule.ProgError,\n            result: value,\n          },\n          evalSteps: stepList,\n          originalDefOrExpr: def,\n          result: value,\n        }\n      }else {\n        return new Error(\"Neither a value nor an error; Could not evaluate expression with call-by-value\");\n      }\n    }\n  } else if (BSL_AST.isFunDef(def)) {\n    const name = def.name;\n    const funDef: SI_STRUCT.FunDef = {\n      type: SI_STRUCT.Production.FunDef,\n      params: def.args,\n      body: def.body,\n    };\n    const newEnv = addToEnv(env, name.symbol, funDef);\n    const err = newEnv instanceof Error;\n    const progRule: SI_STRUCT.ProgRule | SI_STRUCT.ProgError = err\n      ? {\n          type: SI_STRUCT.Rule.ProgError,\n          result: newEnv,\n        }\n      : { type: SI_STRUCT.Rule.Prog, result: def };\n    const defStep: SI_STRUCT.DefinitionStep = {\n      type: SI_STRUCT.Production.DefinitionStep,\n      env: err ? env : newEnv,\n      rule: progRule,\n      evalSteps: [],\n      originalDefOrExpr: def,\n      result: err ? newEnv : def,\n    };\n    return defStep;\n  } else {\n    const binding = def.binding;\n    const properties = def.properties;\n    // add StructDef to environment\n    const structDef: SI_STRUCT.StructDef = {\n      type: SI_STRUCT.Production.StructDef,\n      properties: properties,\n    };\n    let newEnv = addToEnv(env, binding.symbol, structDef);\n    //check if newEnv is an Error before defining structFuns\n    //return a ProgError in DefinitionStep\n    if (newEnv instanceof Error)\n      return {\n        type: SI_STRUCT.Production.DefinitionStep,\n        env: env,\n        rule: {\n          type: SI_STRUCT.Rule.ProgError,\n          result: newEnv,\n        },\n        evalSteps: [],\n        originalDefOrExpr: def,\n        result: newEnv,\n      };\n    // construct structFuns\n    const structFuns = constructFunStructs(binding, structDef);\n    // add all structFuns to environment\n    // if an error occurs, return the error\n    const finalEnv = addStructFunToEnv(newEnv, structFuns);\n    const err = finalEnv instanceof Error;\n    const progRule: SI_STRUCT.ProgRule | SI_STRUCT.ProgError = err\n      ? {\n          type: SI_STRUCT.Rule.ProgError,\n          result: finalEnv,\n        }\n      : {\n          type: SI_STRUCT.Rule.Prog,\n          result: def,\n        };\n\n    const defStep: SI_STRUCT.DefinitionStep = {\n      type: SI_STRUCT.Production.DefinitionStep,\n      env: err ? env : finalEnv,\n      evalSteps: [],\n      rule: progRule,\n      originalDefOrExpr: def,\n      result: err ? finalEnv : def,\n    };\n    return defStep;\n  }\n  // helper function for calculateDefSteps\n  function constructFunStructs(\n    binding: BSL_AST.Name,\n    structDef: SI_STRUCT.StructDef\n  ): [string, SI_STRUCT.StructFun][] {\n    const properties = structDef.properties;\n    const makeFunName = `make-${binding.symbol}`;\n    const makeFunDef: SI_STRUCT.MakeFun = {\n      type: SI_STRUCT.Production.MakeFun,\n      structDef: structDef,\n    };\n    const predFunName = `${binding.symbol}?`;\n    const predFunDef: SI_STRUCT.PredFun = {\n      type: SI_STRUCT.Production.PredFun,\n      structDef: structDef,\n    };\n    // reserve all possible struct-property names\n    const selectFunNames: string[] = [];\n    properties.map((property) => {\n      selectFunNames.push(`${binding.symbol}-${property.symbol}`);\n    });\n    const selectFunDef: SI_STRUCT.SelectFun = {\n      type: SI_STRUCT.Production.SelectFun,\n      structDef: structDef,\n    };\n    const structFuns: [string, SI_STRUCT.StructFun][] = [\n      [makeFunName, makeFunDef],\n      [predFunName, predFunDef],\n    ];\n    selectFunNames.forEach((name) => {\n      structFuns.push([name, selectFunDef]);\n    });\n    return structFuns;\n  }\n  // helper function adding all structFuns to environment\n  function addStructFunToEnv(\n    env: SI_STRUCT.Environment,\n    funDefs: [string, SI_STRUCT.StructFun][]\n  ): SI_STRUCT.Environment | Error {\n    console.log(\"funDefs: \", funDefs);\n    let newEnv: SI_STRUCT.Environment | Error = env;\n    // iterate through all funDefs and change environment\n    // if there is an error return it\n    for (let i = 0; i < funDefs.length; i++) {\n      const funDef = funDefs[i];\n      newEnv = addToEnv(newEnv, funDef[0], funDef[1]);\n      if (newEnv instanceof Error) return newEnv;\n    }\n    return newEnv;\n  }\n}\n\n// expr, steppResult[] => exprStep[] | Error\nexport function calculateEvalSteps(\n  expr: BSL_AST.expr,\n  env: SI_STRUCT.Environment\n): SI_STRUCT.EvalStep[] | Error {\n  let stepList: SI_STRUCT.EvalStep[] = [];\n  let currentExpr: BSL_AST.expr | SI_STRUCT.Value = expr;\n  while (!SI_STRUCT.isValue(currentExpr)) {\n    const step = evaluateExpression(currentExpr, env);\n    if (SI_STRUCT.isValue(step)) {\n      currentExpr = step;\n    } else if (SI_STRUCT.isEvalStep(step)) {\n      if (step.result instanceof Error) {\n        stepList.push(step);\n        break;\n      } else {\n        currentExpr = step.result;\n        stepList.push(step);\n      }\n    } else {\n      return step;\n    }\n  }\n  return stepList;\n}\n\n//evaluateExpression\nexport function evaluateExpression(\n  expr: BSL_AST.expr,\n  env: SI_STRUCT.Environment\n): SI_STRUCT.EvalStep | SI_STRUCT.Value | Error {\n  if (BSL_AST.isLiteral(expr)) {\n    return expr.value;\n  } else {\n    const splitExpr = split(expr);\n    if (SI_STRUCT.isSplit(splitExpr)) {\n      const stepExpr = step(splitExpr.redex, env);\n      if (SI_STRUCT.isOneRule(stepExpr)) {\n        const exprStep = plug(stepExpr, splitExpr.context, env);\n        if (SI_STRUCT.isEvalStep(exprStep)) {\n          return exprStep;\n        } else {\n          return exprStep;\n        }\n      } else {\n        return stepExpr;\n      }\n    } else {\n      return splitExpr;\n    }\n  }\n}\n\n//split\n// Expression = > SplitResult | Error\nexport function split(expr: BSL_AST.expr): SI_STRUCT.SplitResult | Error {\n  const hole: SI_STRUCT.Hole = { type: SI_STRUCT.Production.Hole };\n  if (BSL_AST.isCall(expr)) {\n    const name = expr.name;\n    const args = expr.args;\n\n    if (args.every((x) => BSL_AST.isLiteral(x))) {\n      // all arguments are values, no need to recurse: found redex\n      const redex: SI_STRUCT.CallRedex = {\n        type: SI_STRUCT.Production.CallRedex,\n        name: name,\n        args: args.map((a) => (a as BSL_AST.Literal).value),\n      };\n      return {\n        type: SI_STRUCT.Production.Split,\n        redex: redex,\n        context: hole,\n      };\n    }\n    // some arguments still need evaluation, recurse further\n    const firstRedexIndex = args.findIndex((x) => !BSL_AST.isLiteral(x));\n    const valueLst = args.slice(0, firstRedexIndex) as BSL_AST.Literal[];\n    const recExpr = args[firstRedexIndex];\n    const exprLst = args.slice(firstRedexIndex + 1);\n\n    const splitResult = split(recExpr);\n    if (SI_STRUCT.isSplit(splitResult)) {\n      return {\n        type: SI_STRUCT.Production.Split,\n        redex: splitResult.redex,\n        context: {\n          type: SI_STRUCT.Production.AppContext,\n          op: name,\n          values: valueLst.map((x) => x.value),\n          ctx: splitResult.context,\n          args: exprLst,\n        },\n      };\n    } else {\n      return splitResult;\n    }\n  } else if (BSL_AST.isCond(expr)) {\n    const clause = expr.options[0];\n    // if condition is already reduced, build CondRedex\n    if (BSL_AST.isLiteral(clause.condition)) {\n      return {\n        type: SI_STRUCT.Production.Split,\n        redex: {\n          type: SI_STRUCT.Production.CondRedex,\n          options: expr.options,\n        },\n        context: hole,\n      };\n    }\n    // else split condition\n    else {\n      const splitResult = split(clause.condition);\n      if (SI_STRUCT.isSplit(splitResult)) {\n        return {\n          type: SI_STRUCT.Production.Split,\n          redex: splitResult.redex,\n          context: {\n            type: SI_STRUCT.Production.CondContext,\n            options: expr.options,\n            ctx: splitResult.context,\n          },\n        };\n      } else {\n        return splitResult;\n      }\n    }\n  } else if (BSL_AST.isName(expr)) {\n    return {\n      type: SI_STRUCT.Production.Split,\n      context: hole,\n      redex: {\n        type: SI_STRUCT.Production.NameRedex,\n        symbol: expr.symbol,\n      },\n    };\n  } else {\n    return Error(\"split: neither a call nor a cond nor name\");\n  }\n}\n\n// step\n// Redex => OneRule | Error\nexport function step(\n  r: SI_STRUCT.Redex,\n  env: SI_STRUCT.Environment\n): SI_STRUCT.OneRule | Error {\n  // before stepping check if the redex has no names in it\n  // if it has, lookup in environment and construct Rule (Const, Fun, or Struct)\n  if (SI_STRUCT.isCallRedex(r)) {\n    //check if all args do not contain names\n    const allArgsAreValues = r.args.every(SI_STRUCT.isValue);\n    if (allArgsAreValues) {\n      const args: SI_STRUCT.Value[] = r.args as SI_STRUCT.Value[];\n      //check if r.name is primitive or in env\n      /* if (isPrimitive(r.name)) {\n       */\n      const funDef = lookupEnv(env, r.name.symbol);\n      //check if name is in primitive functions list\n      if (SI_STRUCT.isPrimDef(funDef)) {\n        const primResult = prim(r.name, args);\n        if (primResult instanceof Error)\n          return {\n            type: SI_STRUCT.Rule.PrimError,\n            redex: r,\n            result: primResult,\n          };\n        else\n          return {\n            type: SI_STRUCT.Rule.Prim,\n            redex: r,\n            result: primResult,\n          };\n        //if name => function\n      } else if (SI_STRUCT.isFunDef(funDef)) {\n        //check if funDef is a defined function or a struct-predefined function\n        //substitute names in body with args\n        const newExpr = substFun(r, env);\n        if (newExpr instanceof Error)\n          return {\n            type: SI_STRUCT.Rule.FunError,\n            redex: r,\n            result: newExpr,\n          };\n        else\n          return {\n            type: SI_STRUCT.Rule.Fun,\n            redex: r,\n            result: newExpr,\n          };\n        //if name => structFunction\n      } else if (SI_STRUCT.isStructFun(funDef)) {\n        //decide which struct Rule to use\n        if (SI_STRUCT.isMakeFun(funDef)) {\n          const structVal = makeStruct(r.name, funDef, args, env);\n          if (structVal instanceof Error)\n            return {\n              type: SI_STRUCT.Rule.StructMakeError,\n              redex: r,\n              result: structVal,\n            };\n          const makeRule: SI_STRUCT.StructMake = {\n            type: SI_STRUCT.Rule.StructMake,\n            redex: r,\n            result: structVal,\n          };\n          return makeRule;\n        } else if (SI_STRUCT.isPredFun(funDef)) {\n          const predVal = predStruct(r.name, funDef, args);\n          if (predVal instanceof Error)\n            return {\n              type: SI_STRUCT.Rule.StructPredError,\n              redex: r,\n              result: predVal,\n            };\n          // if check which StructPredRule to use\n          if (predVal) {\n            const predRule: SI_STRUCT.StructPredTrue = {\n              type: SI_STRUCT.Rule.StructPredTrue,\n              redex: r,\n              result: predVal,\n            };\n            return predRule;\n          } else {\n            const predRule: SI_STRUCT.StructPredFalse = {\n              type: SI_STRUCT.Rule.StructPredFalse,\n              redex: r,\n              result: predVal,\n            };\n            return predRule;\n          }\n        } else {\n          const selectVal = selectStruct(r.name, funDef, args);\n          if (selectVal instanceof Error)\n            return {\n              type: SI_STRUCT.Rule.StructSelectError,\n              redex: r,\n              result: selectVal,\n            };\n          const selectRule: SI_STRUCT.StructSelect = {\n            type: SI_STRUCT.Rule.StructSelect,\n            redex: r,\n            result: selectVal,\n          };\n          return selectRule;\n        }\n      } else\n        return {\n          type: SI_STRUCT.Rule.FunError,\n          redex: r,\n          result: Error(`function '${r.name.symbol}' is not in env`),\n        };\n    } else {\n      const substRed: BSL_AST.expr | SI_STRUCT.Value | Error = substConst(\n        r,\n        env\n      );\n      if (substRed instanceof Error)\n        return {\n          type: SI_STRUCT.Rule.ConstError,\n          redex: r,\n          result: substRed,\n        };\n      return {\n        type: SI_STRUCT.Rule.Const,\n        redex: r,\n        result: substRed,\n      };\n    }\n  } else if (SI_STRUCT.isCondRedex(r)) {\n    //check if condition is a name\n    if (BSL_AST.isLiteral(r.options[0].condition)) {\n      const condResult = cond(r);\n      if (condResult === undefined) {\n        const newOptions = r.options.slice(1);\n        if (newOptions.length < 1) {\n          return {\n            type: SI_STRUCT.Rule.CondError,\n            redex: r,\n            result: Error(\"'cond': all question results were false\"),\n          };\n        }\n        const newExpr: BSL_AST.Cond = {\n          type: BSL_AST.Production.CondExpression,\n          options: newOptions,\n        };\n        return {\n          type: SI_STRUCT.Rule.CondFalse,\n          redex: r,\n          result: newExpr,\n        };\n      } else if (BSL_AST.isExpr(condResult) || SI_STRUCT.isValue(condResult)) {\n        return {\n          type: SI_STRUCT.Rule.CondTrue,\n          redex: r,\n          result: condResult,\n        };\n      } else {\n        return {\n          type: SI_STRUCT.Rule.CondError,\n          redex: r,\n          result: condResult,\n        };\n      }\n    } else {\n      const substRed: BSL_AST.expr | SI_STRUCT.Value | Error = substConst(\n        r,\n        env\n      );\n      if (substRed instanceof Error)\n        return {\n          type: SI_STRUCT.Rule.ConstError,\n          redex: r,\n          result: substRed,\n        };\n      return {\n        type: SI_STRUCT.Rule.Const,\n        redex: r,\n        result: substRed,\n      };\n    }\n  } else if (SI_STRUCT.isNameRedex(r)) {\n    const substRed: BSL_AST.expr | SI_STRUCT.Value | Error = substConst(r, env);\n    if (substRed instanceof Error)\n      return {\n        type: SI_STRUCT.Rule.ConstError,\n        redex: r,\n        result: substRed,\n      };\n    return {\n      type: SI_STRUCT.Rule.Const,\n      redex: r,\n      result: substRed,\n    };\n  } else {\n    return Error(\"step: redex is neither a call nor cond nor name\");\n  }\n}\n\n// plug(oneRule, c: Context): ExprStep | Error\nexport function plug(\n  oneRule: SI_STRUCT.OneRule,\n  c: SI_STRUCT.Context,\n  env: SI_STRUCT.Environment\n): SI_STRUCT.EvalStep | Error {\n  //check if context is a Hole\n  if (SI_STRUCT.isHole(c)) {\n    return {\n      type: SI_STRUCT.Production.EvalStep,\n      env: env,\n      rule: oneRule,\n      result: oneRule.result,\n    };\n  } else {\n    //Apply OneRule with KONG RULE\n    const exprStep = plug(oneRule, c.ctx, env);\n    if (SI_STRUCT.isEvalStep(exprStep)) {\n      // Result is RuleError\n      if (exprStep.result instanceof Error) return exprStep;\n      //AppContext\n      if (SI_STRUCT.isAppContext(c)) {\n        const args = [c.values, exprStep.result, c.args].flat();\n        const newArgs = args.map((arg) => {\n          if (SI_STRUCT.isValue(arg)) {\n            const newArg: BSL_AST.Literal = {\n              type: BSL_AST.Production.Literal,\n              value: arg,\n            };\n            return newArg;\n          } else if (SI_STRUCT.isId(arg)) {\n            const newArg: BSL_AST.Name = {\n              type: BSL_AST.Production.Symbol,\n              symbol: arg.symbol,\n            };\n            return newArg;\n          } else return arg;\n        });\n        const finalExpr: BSL_AST.Call = {\n          type: BSL_AST.Production.FunctionCall,\n          name: c.op,\n          args: newArgs,\n        };\n        return {\n          type: SI_STRUCT.Production.EvalStep,\n          env: env,\n          rule: {\n            type: SI_STRUCT.Rule.Kong,\n            context: c,\n            redexRule: oneRule,\n          },\n          result: finalExpr,\n        };\n        //CondContext\n      } else if (SI_STRUCT.isCondContext(c)) {\n        const options = c.options;\n        const expr: BSL_AST.expr = SI_STRUCT.isValue(exprStep.result)\n          ? { type: BSL_AST.Production.Literal, value: exprStep.result }\n          : exprStep.result;\n        const firstClause: BSL_AST.Clause = {\n          type: BSL_AST.Production.CondOption,\n          condition: expr,\n          result: options[0].result,\n        };\n        const newOptions = [firstClause, ...options.slice(1)];\n        const finalExpr: BSL_AST.Cond = {\n          type: BSL_AST.Production.CondExpression,\n          options: newOptions,\n        };\n        return {\n          type: SI_STRUCT.Production.EvalStep,\n          env: env,\n          rule: {\n            type: SI_STRUCT.Rule.Kong,\n            context: c,\n            redexRule: oneRule,\n          },\n          result: finalExpr,\n        };\n      } else {\n        return Error(\"plug: context is not an AppContext or CondContext\");\n      }\n    } else {\n      return exprStep;\n    }\n  }\n}\n\n// ####### ONE RULE FUNCTIONS #######\nexport function prim(\n  name: BSL_AST.Name,\n  args: SI_STRUCT.Value[]\n): SI_STRUCT.Value | Error {\n  // + - * /\n  if (\n    [\"+\", \"*\", \"-\", \"/\"].includes(name.symbol) &&\n    !args.every((a) => typeof a === \"number\")\n  ) {\n    const firstOffender = args.find((a) => typeof a != \"number\");\n    return Error(\n      `argument '${firstOffender}' is not a number in function '${name.symbol}'`\n    );\n  }\n  switch (name.symbol) {\n    case \"+\":\n      return args.reduce((x, y) => (x as number) + (y as number));\n    case \"*\":\n      return args.reduce((x, y) => (x as number) * (y as number));\n    case \"-\":\n      return args.reduce((x, y) => (x as number) - (y as number));\n    case \"/\":\n      if (!args.slice(1).every((a) => a != 0))\n        return Error(`division by zero in function '${name.symbol}'`);\n      return args.reduce((x, y) => (x as number) / (y as number));\n    default:\n  }\n  // and, or, not\n  if (\n    [\"and\", \"or\", \"not\"].includes(name.symbol) &&\n    !args.every((a) => typeof a === \"boolean\")\n  ) {\n    const firstOffender = args.find((a) => typeof a != \"boolean\");\n    return Error(\n      `argument '${firstOffender}' is not a boolean in function '${name.symbol}'`\n    );\n  }\n  switch (name.symbol) {\n    case \"and\":\n      if (args.length < 2)\n        return Error(`function '${name.symbol}' needs at least two arguments`);\n      return args.every((x) => x);\n    case \"or\":\n      if (args.length < 2)\n        return Error(`function '${name.symbol}' needs at least two arguments`);\n      return args.some((x) => x);\n    case \"not\":\n      if (args.length !== 1)\n        return Error(`function '${name.symbol}' needs exactly one argument`);\n      return !args[0];\n    default:\n  }\n  // less than and greater than, to test HTML escaping\n  if ([\"<\", \">\", \"<=\", \">=\"].includes(name.symbol)) {\n    if (args.length !== 2) {\n      return Error(`function '${name.symbol}' needs exactly two arguments`);\n    }\n    const left = args[0];\n    const right = args[1];\n    if (typeof left !== \"number\" || typeof right !== \"number\") {\n      return Error(\n        `function '${name.symbol}' needs two numbers, but received '${left}' and '${right}'`\n      );\n    }\n    switch (name.symbol) {\n      case \"<\":\n        return left < right;\n      case \"<=\":\n        return left <= right;\n      case \">=\":\n        return left >= right;\n      case \">\":\n        return left > right;\n      default:\n        return true; // never reached but needed for compiler\n    }\n  } else {\n    // will never be reached but needed for compiler\n    return Error(\n      `function '${name.symbol}' is no implemented primitive function`\n    );\n  }\n}\n\n// cond\n// cond Redex =>  BSL_AST.expr | false\nfunction cond(\n  r: SI_STRUCT.CondRedex\n): BSL_AST.expr | SI_STRUCT.Value | undefined | Error {\n  const clause = r.options[0];\n  if (BSL_AST.isLiteral(clause.condition) && clause.condition.value == true) {\n    const result = BSL_AST.isLiteral(clause.result)\n      ? clause.result.value\n      : clause.result;\n    return result;\n  } else if (\n    BSL_AST.isLiteral(clause.condition) &&\n    clause.condition.value == false\n  ) {\n    return undefined;\n  } else {\n    return Error(\"'cond': condition is not a boolean\");\n  }\n}\n\nfunction substConst(\n  r: SI_STRUCT.Redex,\n  env: SI_STRUCT.Environment\n): BSL_AST.expr | SI_STRUCT.Value | Error {\n  if (SI_STRUCT.isCallRedex(r)) {\n    // get the identifier argument\n    const id = r.args.find(SI_STRUCT.isId);\n    if (!id) return Error(\"id: could not find an identifier in argument list\");\n    const value = lookupConst(env, id.symbol);\n    if (value instanceof Error) return value;\n    const newArgs: BSL_AST.expr[] = r.args.map((el) => {\n      if (SI_STRUCT.isId(el) && el.symbol === id.symbol) {\n        let newLit: BSL_AST.Literal = {\n          type: BSL_AST.Production.Literal,\n          value: value,\n        };\n        return newLit;\n      } else if (SI_STRUCT.isId(el)) {\n        let newName: BSL_AST.Name = {\n          type: BSL_AST.Production.Symbol,\n          symbol: el.symbol,\n        };\n        return newName;\n      } else {\n        let newLit: BSL_AST.Literal = {\n          type: BSL_AST.Production.Literal,\n          value: el,\n        };\n        return newLit;\n      }\n    });\n    return {\n      type: BSL_AST.Production.FunctionCall,\n      name: r.name,\n      args: newArgs,\n    };\n  } else if (SI_STRUCT.isCondRedex(r)) {\n    const name = r.options[0].condition;\n    if (!BSL_AST.isName(name))\n      return Error(\"substConst: condition is not a name\");\n\n    const value = lookupConst(env, name.symbol);\n    if (value instanceof Error) return value;\n\n    const newLit: BSL_AST.Literal = {\n      type: BSL_AST.Production.Literal,\n      value: value,\n    };\n    const newOpt: BSL_AST.Clause = {\n      type: BSL_AST.Production.CondOption,\n      condition: newLit,\n      result: r.options[0].result,\n    };\n    const newCond: BSL_AST.Cond = {\n      type: BSL_AST.Production.CondExpression,\n      options: [newOpt],\n    };\n    return newCond;\n  } else if (SI_STRUCT.isNameRedex(r)) {\n    return lookupConst(env, r.symbol);\n  } else {\n    return Error(\"substConst: redex is not a call or cond or name\");\n  }\n}\n\n//fun\nfunction substFun(\n  r: SI_STRUCT.CallRedex,\n  env: SI_STRUCT.Environment\n): BSL_AST.expr | Error {\n  const funDef = lookupFun(env, r.name.symbol);\n  if (funDef instanceof Error) return funDef;\n  const params = funDef.params;\n  if (r.args.length != params.length)\n    return Error(\n      `Arity mismatch in '${r.name.symbol}': number of arguments are not equal to number of parameters`\n    );\n  let newEnv: SI_STRUCT.Environment = {};\n  params.forEach((param, i) => {\n    let tempEnv = addToEnv(newEnv, param.symbol, r.args[i] as SI_STRUCT.Value);\n    if (tempEnv instanceof Error) return tempEnv;\n    newEnv = tempEnv;\n  });\n  const body = funDef.body;\n  const newExpr = substExpr(body, newEnv);\n  return newExpr;\n}\n\n//structRules\nfunction makeStruct(\n  name: BSL_AST.Name,\n  funDef: SI_STRUCT.MakeFun,\n  args: SI_STRUCT.Value[],\n  env: SI_STRUCT.Environment\n): BSL_AST.StructValue | Error {\n  const params = funDef.structDef.properties;\n  // slice name to get struct name\n  const structName = name.symbol.slice(5);\n  const inEnv = lookupStruct(env, structName);\n  if (inEnv instanceof Error)\n    return Error(`'${structName}' not found in environment`);\n  // check arity\n  if (params.length == args.length) {\n    const structVal: BSL_AST.StructValue = {\n      type: BSL_AST.Production.StructValue,\n      structDef: name,\n      properties: args.map((arg) => {\n        const lit: BSL_AST.Literal = {\n          type: BSL_AST.Production.Literal,\n          value: arg,\n        };\n        return lit;\n      }),\n    };\n    return structVal;\n  } else {\n    return Error(\n      `Arity mismatch in '${name.symbol}: number of arguments does not match number of properties`\n    );\n  }\n}\n\nfunction predStruct(\n  name: BSL_AST.Name,\n  funDef: SI_STRUCT.PredFun,\n  args: SI_STRUCT.Value[]\n): boolean | Error {\n  const params = funDef.structDef.properties;\n  if (args.length != 1) {\n    return Error(`'${name.symbol}' takes exactly one argument`);\n  } else {\n    if (!BSL_AST.isStructValue(args[0])) {\n      return false;\n    } else {\n      const structVal = args[0];\n      //extract struct in make-struct\n      const structName = structVal.structDef.symbol.split(\"-\")[1];\n      //extract struct in struct?\n      const predName = name.symbol.split(\"?\")[0];\n      if (structName === predName) {\n        if (params.length == structVal.properties.length) {\n          return true;\n        } else {\n          return false;\n        }\n      } else {\n        return false;\n      }\n    }\n  }\n}\n\nfunction selectStruct(\n  name: BSL_AST.Name,\n  funDef: SI_STRUCT.SelectFun,\n  args: SI_STRUCT.Value[]\n): BSL_AST.expr | SI_STRUCT.Value | Error {\n  //check if the number of arguments is 1\n  if (args.length != 1) {\n    return Error(\"selectStruct: number of arguments doesn't match\");\n  } else {\n    //check if the argument is a struct value\n    if (!BSL_AST.isStructValue(args[0])) {\n      return Error(\"selectStruct: argument is not a struct value\");\n    } else {\n      const structVal: BSL_AST.StructValue = args[0];\n      //extract struct in make-struct\n      const structName = structVal.structDef.symbol.split(\"-\")[1];\n      //extract struct in struct-property\n      const selectName = name.symbol.split(\"-\")[0];\n      const property: string = name.symbol.split(\"-\")[1];\n      //check if the struct name is the same\n      if (structName !== selectName) {\n        return Error(\"selectStruct: struct name doesn't match\");\n      } else {\n        const params: string[] = funDef.structDef.properties.map(\n          (param) => param.symbol\n        );\n        //check if the property is in the struct\n        if (params.includes(property)) {\n          const index = params.indexOf(property);\n          const res: BSL_AST.expr = structVal.properties[index];\n          //check if the property is a literal\n          //reduce to value\n          if (BSL_AST.isLiteral(res)) {\n            return res.value;\n          } else {\n            return structVal.properties[index];\n          }\n        } else {\n          return Error(\"selectStruct: property doesn't exist\");\n        }\n      }\n    }\n  }\n}\n//substExpr\n//substitute all names in an expression with the values of a given environment\nfunction substExpr(\n  expr: BSL_AST.expr,\n  env: SI_STRUCT.Environment\n): BSL_AST.expr | Error {\n  if (BSL_AST.isLiteral(expr)) {\n    return expr;\n  } else if (BSL_AST.isName(expr)) {\n    const value = lookupConst(env, expr.symbol);\n    if (value instanceof Error) return value;\n    let newLit: BSL_AST.Literal = {\n      type: BSL_AST.Production.Literal,\n      value: value,\n    };\n    return newLit;\n  } else if (BSL_AST.isCall(expr)) {\n    let args = expr.args.map((arg) => {\n      let newExpr = substExpr(arg, env);\n      if (newExpr instanceof Error) return arg;\n      else return newExpr;\n    });\n    //need case for names, which are in the other dictionary as well\n    if (args.some((arg) => arg instanceof Error)) {\n      return Error(\"substExpr: error in args\");\n    } else {\n      let newCall: BSL_AST.Call = {\n        type: BSL_AST.Production.FunctionCall,\n        name: expr.name,\n        args: args,\n      };\n      return newCall;\n    }\n  } else {\n    let options = expr.options.map((clause) => {\n      let newCondition = substExpr(clause.condition, env);\n      let newResult = substExpr(clause.result, env);\n      if (newCondition instanceof Error || newResult instanceof Error)\n        return Error(\"substExpr: error in cond\");\n      let newClause: BSL_AST.Clause = {\n        type: BSL_AST.Production.CondOption,\n        condition: newCondition,\n        result: newResult,\n      };\n      return newClause;\n    });\n    if (options.some((clause) => clause instanceof Error))\n      return Error(\"substExpr: error in cond\");\n    let newCond: BSL_AST.Cond = {\n      type: BSL_AST.Production.CondExpression,\n      options: options as BSL_AST.Clause[],\n    };\n    return newCond;\n  }\n}\n\n// ####### Environment Functions #######\n\n// initialize environment with built-in functions\nfunction initEnv(): SI_STRUCT.Environment | Error {\n  let env: SI_STRUCT.Environment | Error = {};\n  //add built-in functions\n  Object.entries(SI_STRUCT.PrimFuns).forEach((name) => {\n    if (env instanceof Error) return env;\n    else env = addToEnv(env, name[1], { type: SI_STRUCT.Production.PrimDef });\n  });\n  if (env === undefined) return Error(\"initEnv: environment is undefined\");\n  else if (env instanceof Error) return env;\n  return env;\n}\n\n//adds a Value to an Environment\nfunction addToEnv(\n  env: SI_STRUCT.Environment,\n  name: string,\n  value: SI_STRUCT.EnvValue\n): SI_STRUCT.Environment | Error {\n  if (env[name] === undefined) {\n    const newEnv = { ...env };\n    newEnv[name] = value;\n    return newEnv;\n  } else return Error(`'${name}' already exists in environment`);\n}\n\nfunction lookupEnv(\n  env: SI_STRUCT.Environment,\n  name: string\n): SI_STRUCT.EnvValue | Error {\n  if (name in env) {\n    return env[name];\n  } else {\n    return Error(`'${name}' is not bound in environment`);\n  }\n}\n\n//LookUp helper functions\n\nfunction lookupConst(\n  env: SI_STRUCT.Environment,\n  name: string\n): SI_STRUCT.Value | Error {\n  const value = lookupEnv(env, name);\n  if (value instanceof Error) return value;\n  else if (SI_STRUCT.isValue(value)) return value;\n  else return Error(\"lookupConst: name is not bound to a Value\");\n}\n\nfunction lookupFun(\n  env: SI_STRUCT.Environment,\n  name: string\n): SI_STRUCT.FunDef | Error {\n  const value = lookupEnv(env, name);\n  if (value instanceof Error) return value;\n  else if (SI_STRUCT.isFunDef(value)) return value;\n  else return Error(\"lookupFun: name is not bound to a Fun\");\n}\n\nfunction lookupStruct(\n  env: SI_STRUCT.Environment,\n  name: string\n): SI_STRUCT.StructDef | Error {\n  const value = lookupEnv(env, name);\n  if (value instanceof Error) return value;\n  else if (SI_STRUCT.isStructDef(value)) return value;\n  else return Error(\"lookupStruct: name is not bound to a Struct\");\n}\n", "// parsing and processing code input\nimport { parse } from \"./BSL_Parser\";\nimport * as BSL_AST from \"./BSL_AST\";\nimport * as BSL_Print from \"./BSL_Print\";\n// small-step interpreter back-end\nimport * as SI_STRUCT from \"./SI_STRUCT\";\nimport { calculateProgram } from \"./SI\";\n// styles & icon ressources\nimport { default as stepper_css } from \"./ressources/stepper.css\";\nimport { default as angle_up } from \"./ressources/icons/angle-up-solid.svg\";\nimport { default as angle_down } from \"./ressources/icons/angle-down-solid.svg\";\nimport { default as plus_icon } from \"./ressources/icons/plus-solid.svg\";\nimport { default as minus_icon } from \"./ressources/icons/minus-solid.svg\";\nimport { default as circle_info } from \"./ressources/icons/circle-info-solid.svg\";\nimport { default as circle_xmark } from \"./ressources/icons/circle-xmark-solid.svg\";\n// html helpers\nimport { getParentClassRecursive, navigateDOM } from \"./DOM_Helpers\";\n\n// ######### main function processing steppers ###########\nexport function processSteppers() {\n  Array.from(document.getElementsByTagName(\"stepper\")).map((el) => {\n    try {\n      const program: BSL_AST.program = parse(BSL_Print.dirtify(el.innerHTML));\n      console.log(program);\n      setUpStepperGui(program, el as HTMLElement);\n    } catch (e: any) {\n      renderError(e, el as HTMLElement);\n    }\n  });\n}\n\nfunction renderError(err: any, el: HTMLElement) {\n  console.error(err);\n  const error = err ? `${err}` : 'Unknown Error';\n  el.innerHTML = `\n    <h3>Error turning Program into Stepper</h3>\n    <div>${el.innerHTML}</div>\n    <div>${error}</div>\n  `;\n  (el as HTMLElement).style.cssText = `\n    padding: 2em;\n    color: darkred;\n    display: block;\n  `;\n}\n\n// ### set up a single stepper ###\nexport function setUpStepperGui(\n  program: BSL_AST.program,\n  el: HTMLElement\n): void {\n  addStylesheet();\n  const stepper = calculateProgram(program);\n  console.log(BSL_Print.indent(BSL_Print.pprint(program), 30));\n  console.log(stepper);\n  if (stepper instanceof Error) throw stepper;\n  const lang = getLanguage(el);\n  const measures = getPixelMeasurements(el); // for static maxwidth indentation & clipping\n  el.innerHTML = renderStepper(stepper, lang, measures);\n}\n\nfunction addStylesheet() {\n  if (!document.getElementById(\"bsl-tools-stepper-style\")) {\n    const styleNode = document.createElement(\"style\");\n    styleNode.innerHTML = stepper_css;\n    styleNode.id = \"bsl-tools-stepper-style\";\n    document.getElementsByTagName(\"head\")[0].appendChild(styleNode);\n  }\n}\n\nfunction getLanguage(el: HTMLElement): implementedLanguage {\n  const lang = el.getAttribute(\"lang\");\n  if (!lang) {\n    return \"en\";\n  } else if (!implementedLanguages.includes(lang)) {\n    console.error(`\n        Language ${lang} is not implemented for this module,\n        you can choose from ${implementedLanguages.join(\",\")}.\n        Defaulting to 'en'.\n      `);\n    return \"en\";\n  }\n  return lang as implementedLanguage;\n}\n\n// helper for getting width of em in px\ninterface PixelMeasurements {\n  charWidth: number,\n  maxChars: number\n}\nfunction getPixelMeasurements(el: HTMLElement): PixelMeasurements {\n  const measureText = 'Loading...';\n  el.innerHTML = `\n    <div class=\"bsl-tools-stepper\" style=\"width: 100%;\">\n      <div class=\"box\">\n        <div class=\"step code\"\n             data-currentStep=\"true\">\n          <p style=\"display: inline-block;\">${measureText}</p>\n        </div>\n      </div>\n    </div>\n  `;\n  const p = el.getElementsByTagName(\"p\")[0];\n  const stepper = el.getElementsByClassName(\"bsl-tools-stepper\")[0];\n  if (!p || !stepper) {\n    console.error(\"failed to inject measuring HTML into\", el);\n    return {charWidth: 12, maxChars: 80}; // arbitrary value\n  }\n  const charPxWidth = p.clientWidth / measureText.length;\n  const factor = 0.9;\n  const maxWidthInChars = Math.round((factor * stepper.clientWidth) / charPxWidth);\n  return {charWidth: charPxWidth, maxChars: maxWidthInChars};\n}\n\n// ###### internationalization for this module #####\ntype implementedLanguage = \"en\" | \"de\";\nconst implementedLanguages = [\"en\", \"de\"];\n\nconst dictionary = {\n  en: {\n    \"current evaluation\": \"Current Evaluation\",\n    \"next step\": \"Next Step\",\n    \"previous step\": \"Previous Step\",\n    \"environment\": \"Environment\",\n    \"remaining program\": \"Remaining Program\",\n    \"start evaluation\": \"Start Evaluation\",\n    \"evaluation finished\": \"Evaluation Finished\",\n    \"go back\": \"Go Back\",\n  },\n  de: {\n    \"current evaluation\": \"Aktuelle Auswertung\",\n    \"next step\": \"N\u00E4chster Schritt\",\n    \"previous step\": \"Vorheriger Schritt\",\n    \"environment\": \"Umgebung\",\n    \"remaining program\": \"Verbleibendes Programm\",\n    \"start evaluation\": \"Auswertung Starten\",\n    \"evaluation finished\": \"Auswertung Beendet\",\n    \"go back\": \"Schritt zur\u00FCck\",\n  },\n};\n\n// ####### RENDER FUNCTIONS #######\n\n// main function\nfunction renderStepper(\n  stepper: SI_STRUCT.Stepper,\n  lang: implementedLanguage,\n  measures: PixelMeasurements\n): string {\n  const progSteps = stepper.progSteps;\n\n  return `\n    <div class=\"bsl-tools-stepper\">\n\n       <div class=\"box environment\">\n         <div class=\"boxlabel\">${dictionary[lang][\"environment\"]}</div>\n         ${progSteps.map((s,i) => renderDefinition(s, i, measures)).join(\"\")}\n       </div>\n\n       <div class=\"box eval-steps\"\n            data-progstep=\"-1\"\n            data-visible=\"true\">\n         <div class=\"boxlabel\">${dictionary[lang][\"current evaluation\"]}</div>\n         <div class=\"step\"\n              data-currentStep=\"true\">\n           <div class=\"next-button\"\n                onclick=\"takeProgSteps(event, 1)\">\n             <cap>Prog</cap>: ${\n               dictionary[lang][\"start evaluation\"]\n             } <img class=\"icon\" src=\"${angle_down}\">\n           </div>\n           <div class=\"plug-result code\"\n                data-info-collapsed=\"true\">\n             <img class=\"icon info-toggle info-expand\"\n                     src=\"${circle_info}\"\n                     onclick=\"expandInfo(event)\">\n             <img class=\"icon info-toggle info-collapse\"\n                     src=\"${circle_xmark}\"\n                     onclick=\"collapseInfo(event)\">\n             ${renderRuleInformation('Prog', false)}\n           </div>\n         </div>\n       </div>\n\n       ${progSteps.map((el, i) => renderEvalSteps(el, i, lang, measures)).join(\"\")}\n\n       <div class=\"box eval-steps\"\n            data-progstep=\"${progSteps.length}\"\n            data-visible=\"false\">\n         <div class=\"boxlabel\">${dictionary[lang][\"current evaluation\"]}</div>\n         <div class=\"step\"\n              data-currentStep=\"true\">\n            <div class=\"code\">${dictionary[lang][\"evaluation finished\"]}</div>\n            <div class=\"prev-button\"\n                 onclick=\"takeProgSteps(event, -1)\">\n              ${\n                dictionary[lang][\"go back\"]\n              } <img class=\"icon\" src=\"${angle_up}\">\n            </div>\n         </div>\n       </div>\n\n       <div class=\"box program\">\n         <div class=\"boxlabel\">${dictionary[lang][\"remaining program\"]}</div>\n         ${stepper.originProgram.map((s,i) => renderOriginalExpression(s,i,measures)).join(\"\")}\n       </div>\n\n    </div>`;\n}\n(window as any).takeProgSteps = (e: Event, a: number) => {\n  takeProgSteps(e, a);\n};\n// render what remains of an expression after evaluation\nfunction renderDefinition(progStep: SI_STRUCT.ProgStep, idx: number, measures: PixelMeasurements): string {\n  // filtering at this position in order to keep correct implicit progStep index\n  if (!SI_STRUCT.isDefinitionStep(progStep) || progStep.result instanceof Error) return \"\";\n  return `\n      <div class=\"step code\"\n           data-progstep=\"${idx}\"\n           data-visible=\"false\">\n        ${BSL_Print.indent(\n          BSL_Print.sanitize(BSL_Print.printDefinition(progStep.result)),\n          measures.maxChars,\n          \"html\"\n        )}\n      </div>\n    `;\n}\n\n// render the part of the original Program that is being represented by a progstep\nfunction renderOriginalExpression(\n  expression: BSL_AST.defOrExpr,\n  idx: number,\n  measures: PixelMeasurements\n): string {\n  return `\n    <div class=\"step code\"\n         data-progstep=\"${idx}\"\n         data-visible=\"true\">\n      ${BSL_Print.indent(\n        BSL_Print.sanitize(\n          BSL_Print.printDefOrExpr(expression)\n        ),\n        measures.maxChars,\n        \"html\"\n      )}\n    </div>\n  `;\n}\n// one stepper for one expression\nfunction renderEvalSteps(\n  progStep: SI_STRUCT.ProgStep,\n  idx: number,\n  lang: implementedLanguage,\n  measures: PixelMeasurements\n): string {\n  const ctx =\n    SI_STRUCT.isDefinitionStep(progStep) && BSL_AST.isConstDef(progStep.originalDefOrExpr)\n    ? { left: `(define ${progStep.originalDefOrExpr.name.symbol} `, right: \")\" }\n    : { left: \"\", right: \"\" };\n  return `\n    <div class=\"box eval-steps\"\n         data-progstep=\"${idx}\"\n         data-visible=\"false\">\n      <div class=\"boxlabel\">${dictionary[lang][\"current evaluation\"]}</div>\n      ${\n        progStep.evalSteps\n          .map((el, i) => renderStep(i, el, lang, { ...ctx }, measures))\n          .join(\"\")\n      }\n      ${renderLastStep(progStep, lang, measures)}\n\n    </div>\n  `;\n}\n\nfunction renderLastStep(\n  progStep: SI_STRUCT.ProgStep,\n  lang: implementedLanguage,\n  measures: PixelMeasurements\n): string {\n  return `\n  <div class=\"step\"\n       data-step=\"${progStep.evalSteps.length}\"\n       data-currentStep=\"${\n         progStep.evalSteps.length === 0 ? \"true\" : \"false\"\n       }\"\n       data-collapsed=\"false\">\n    <div class=\"prev-button\"\n         onclick=\"prevStep(event)\">\n      ${\n        dictionary[lang][\"previous step\"]\n      } <img class=\"icon\" src=\"${angle_up}\">\n    </div>\n    <div class=\"next-button\"\n         onclick=\"nextStep(event)\">\n      <cap>Prog</cap>: ${\n        dictionary[lang][\"next step\"]\n      } <img class=\"icon\" src=\"${angle_down}\">\n    </div>\n\n    <div class=\"plug-result code\"\n         data-info-collapsed=\"true\">\n      ${\n        BSL_Print.indent(BSL_Print.sanitize(\n          SI_STRUCT.isDefinitionStep(progStep) && !(progStep.result instanceof Error)\n          ? BSL_Print.printDefinition(progStep.result)\n          : `${\n              progStep.result instanceof Error\n                ? progStep.result\n                : BSL_Print.printValue(progStep.result as SI_STRUCT.Value)\n            }`), measures.maxChars)\n      }\n      <img class=\"icon info-toggle info-expand\"\n              src=\"${circle_info}\"\n              onclick=\"expandInfo(event)\">\n      <img class=\"icon info-toggle info-collapse\"\n              src=\"${circle_xmark}\"\n              onclick=\"collapseInfo(event)\">\n      ${renderRuleInformation('Prog', false)}\n    </div>\n  </div>\n  `;\n}\n\n/*\n  update visibility of expressions in environment/remaining program and steppers\n  amount: number of ProgSteps to move forward/backwards\n*/\nfunction takeProgSteps(e: Event, amount: number): void {\n  const button = e.target as HTMLElement;\n  // el will be a button\n  const oldButtonPosition = button.getBoundingClientRect().y;\n  const currentStep = getParentClassRecursive(button, \"eval-steps\");\n  if (!currentStep) {\n    console.error(\"found no parent with class .eval-steps\", button);\n    return;\n  }\n  const idxString = currentStep.getAttribute(\"data-progstep\");\n  if (!idxString) {\n    console.error(\n      \"div with class .eval-steps has no data-progstep attribute\",\n      currentStep\n    );\n    return;\n  }\n  const idx = parseInt(idxString);\n  const targetIdx = idx + amount;\n  if (targetIdx < -1) {\n    console.error(`cannot navigate to progStep ${targetIdx}: does not exist`);\n    return;\n  }\n  const root = currentStep.parentElement;\n  if(!root) return;\n  showEnvironment(root, targetIdx);\n  showRemainingProgram(root, targetIdx);\n  const newCurrentStep = showProgStep(root, targetIdx);\n  moveProgStepButton(newCurrentStep, oldButtonPosition, amount > 0);\n}\n\nfunction showEnvironment(root: HTMLElement, step: number) {\n  navigateDOM([root], \".environment/div\").forEach((def) => {\n    const idxString = def.getAttribute(\"data-progstep\");\n    if (idxString) {\n      def.setAttribute('data-visible', parseInt(idxString) < step ? 'true': 'false');\n    }\n  });\n}\n\nfunction showRemainingProgram(root: HTMLElement, step: number) {\n  navigateDOM([root], \".program/div\").forEach((prog) => {\n    const idxString = prog.getAttribute(\"data-progstep\");\n    if (idxString) {\n      prog.setAttribute('data-visible', parseInt(idxString) > step ? 'true': 'false');\n    }\n  });\n}\n\nfunction showProgStep(root: HTMLElement, index: number): HTMLElement {\n  return navigateDOM([root], \".eval-steps\").filter((progStep) => {\n    const idxString = progStep.getAttribute(\"data-progstep\");\n    const current = idxString && parseInt(idxString) === index;\n    progStep.setAttribute('data-visible', current ? 'true' : 'false');\n    return current;\n  })[0];\n}\n\nfunction moveProgStepButton(progStep: HTMLElement, oldButtonPosition: number, forward: boolean) {\n  // move prev/next-button to stay under mouse\n  const currentStep = Array.from(progStep.children)\n    .filter((c) => c.getAttribute(\"data-currentstep\") === \"true\")[0];\n  if(!currentStep) return;\n  const newButton = currentStep.querySelector(\n    forward ? \".next-button\" : \".prev-button\"\n  );\n  if (!newButton) return;\n  const newButtonPosition = newButton.getBoundingClientRect().y;\n  window.scrollBy(0, newButtonPosition - oldButtonPosition);\n}\n\n// one individual step\nfunction renderStep(\n  currentStep: number,\n  step: SI_STRUCT.EvalStep,\n  lang: implementedLanguage,\n  ctx: Context = { left: \"\", right: \"\" },\n  measures: PixelMeasurements\n): string {\n  // acquire necessary information:\n  // context and redex\n  const context: Context = SI_STRUCT.isKong(step.rule)\n    ? printContext(step.rule.context, ctx)\n    : ctx;\n  const redexRule = SI_STRUCT.isKong(step.rule)\n    ? step.rule.redexRule\n    : step.rule;\n  // result and rule name\n  const redex: string = BSL_Print.sanitize(printRedex(redexRule.redex));\n  function renderResult(res: BSL_AST.expr | SI_STRUCT.Value | Error): {html: string, redex: string} {\n    if (SI_STRUCT.isValue(res)) {\n      const redexResult = BSL_Print.printValue(res);\n      const resultHtml = `${\n        context.left\n      }<span class=\"hole hole-result\">${BSL_Print.sanitize(\n        redexResult\n      )}</span>${\n        context.right\n      }`;\n      return {html: resultHtml, redex: redexResult};\n    } else if (res instanceof Error) {\n      const redexResult = `${res}`;\n      const resultHtml = `<span class=\"hole hole-result hole-error\">\"${res}\"</span>`; // to prevent indentation issues\n      return {redex: redexResult, html: resultHtml};\n    } else {\n      const redexResult = BSL_Print.printE(res);\n      const resultHtml = `${\n        context.left\n      }<span class=\"hole hole-result\">${BSL_Print.sanitize(\n        redexResult\n      )}</span>${context.right}`;\n      return {redex: redexResult, html: resultHtml};\n    }\n  }\n  const result = renderResult(redexRule.result);\n  const ruleName = redexRule.type;\n  // prepare indented code expressions\n  const code_before = BSL_Print.indent(\n    `${context.left}<span class=\"hole\">${redex}</span>${context.right}`,\n    measures.maxChars,\n    \"html\"\n  );\n  const code_after = BSL_Print.indent(result.html, measures.maxChars, \"html\");\n\n  // find out where to position the rule arrow so that it points at the hole\n  const code_before_hole = code_after\n    .slice(0, code_after.indexOf('<span class=\"hole hole-result'))\n    .split(\"<br>\")\n    .reverse()[0];\n  const hole_position = code_before_hole\n    ? BSL_Print.dirtify(code_before_hole).length\n    : 0;\n  const KONG_WIDTH = 4;\n  const left_offset_arrow =\n    context.left.length > 0 && hole_position < KONG_WIDTH\n      ? KONG_WIDTH\n      : hole_position;\n  // find out if we have place to repeat the holes\n  const ruleNameOnlyText = rules[ruleName][\"name\"].replaceAll('<cap>', '').replaceAll('</cap>','');\n  const space_left = // 3 for the arrow, 2 for the icon ---v\n    measures.maxChars - left_offset_arrow - ruleNameOnlyText.length - 5;\n  const renderHolesInRule = redex.length + result.redex.length <= space_left;\n\n  return `\n    <div class=\"step\"\n         data-step=\"${currentStep}\"\n         data-currentStep=\"${currentStep === 0 ? \"true\" : \"false\"}\"\n         data-collapsed=\"false\">\n      <div class=\"prev-button\"\n           onclick=\"prevStep(event)\">\n        ${dictionary[lang][\"previous step\"]} <img class=\"icon\" src=\"${angle_up}\">\n      </div>\n      <div class=\"next-button\"\n           onclick=\"nextStep(event)\">\n        ${dictionary[lang][\"next step\"]} <img class=\"icon\" src=\"${angle_down}\">\n      </div>\n\n      <div class=\"split-result code\">${code_before}<img class=\"icon expander\"\n              src=\"${plus_icon}\"\n              onclick=\"expand(event)\"\n        ><img class=\"icon collapser\"\n              src=\"${minus_icon}\"\n              onclick=\"collapse(event)\"\n      ></div>\n\n      <div class=\"plug-result code\"\n           data-info-collapsed=\"true\">\n        <div>\n          ${\n            // if context is not empty, we are applying KONG\n            context.left !== \"\"\n              ? `<span class=\"rule rule-name left-arrowed kong\">\n                 ${rules[\"Kong\"][\"name\"]}\n              </span>`\n              : \"\"\n          }\n\n          <span class=\"rule left-arrowed one-rule\"\n                style=\"--one-rule-margin-left: ${left_offset_arrow * measures.charWidth}px\">\n             <span class=\"rule-name\">${rules[ruleName][\"name\"]}</span>${\n                renderHolesInRule\n                  ? `:\n                   <span class=\"rule-description\">\n                     <span class=\"hole rule-hole\">${redex}</span> \u2192\n                     <span class=\"hole hole-result rule-hole\">${\n                       BSL_Print.sanitize(result.redex)\n                     }</span>\n                   </span>`\n                  : \"\"\n              }\n           </span>\n\n           <img src=\"${circle_info}\"\n                class=\"icon info-toggle info-expand\"\n                onclick=\"expandInfo(event)\">\n           <img src=\"${circle_xmark}\"\n                class=\"icon info-toggle info-collapse\"\n                onclick=\"collapseInfo(event)\">\n\n        </div>\n        ${renderRuleInformation(ruleName, context.left !== \"\")}\n        <div>${code_after}</div>\n      </div>\n\n    </div>\n  `;\n}\n// event handlers\n(window as any).nextStep = (e: Event) => {\n  const button = e.target as HTMLElement;\n  const oldButtonPosition = button.getBoundingClientRect().y;\n  const currentStep = getParentClassRecursive(button, \"step\");\n  if(!currentStep) return;\n  const newCurrentStep = currentStep.nextElementSibling;\n  if(!newCurrentStep) {\n    // continue with next expression\n    takeProgSteps(e, 1);\n    return;\n  }\n  currentStep.setAttribute(\"data-currentStep\", \"false\");\n  currentStep.setAttribute(\"data-collapsed\", \"true\");\n  newCurrentStep.setAttribute(\"data-currentStep\", \"true\");\n  newCurrentStep.setAttribute(\"data-collapsed\", \"false\");\n  // move \"next\" button under mouse\n  const newButton = newCurrentStep.querySelector(\".next-button\");\n  if (!newButton) return;\n  const newButtonPosition = newButton.getBoundingClientRect().y;\n  window.scrollBy(0, newButtonPosition - oldButtonPosition);\n};\n(window as any).prevStep = (e: Event) => {\n  const button = e.target as HTMLElement;\n  const oldButtonPosition = button.getBoundingClientRect().y;\n  const currentStep = getParentClassRecursive(button, \"step\");\n  if (!currentStep) {\n    console.error(\"prevStep not called from within an element of the .step class\");\n    return;\n  }\n  const position = currentStep.getAttribute(\"data-step\");\n  if (position === \"0\") {\n    takeProgSteps(e, -1);\n    return;\n  }\n  const newCurrentStep = currentStep.previousElementSibling;\n  if(!newCurrentStep) {\n    console.error(\"prevStep called on a step with no previous html element\");\n    return;\n  }\n  currentStep.setAttribute(\"data-currentStep\", \"false\");\n  currentStep.setAttribute(\"data-collapsed\", \"true\");\n  newCurrentStep.setAttribute(\"data-currentStep\",\"true\");\n  newCurrentStep.setAttribute(\"data-collapsed\",\"false\");\n  // move \"prev\" button to be under mouse\n  const newButton = newCurrentStep.querySelector(\".prev-button\");\n  if (!newButton) return;\n  const newButtonPosition = newButton.getBoundingClientRect().y;\n  window.scrollBy(0, newButtonPosition - oldButtonPosition);\n};\n(window as any).collapse = (e: Event) => {\n  const button = e.target as HTMLElement;\n  const step = getParentClassRecursive(button, \"step\");\n  if (step) {\n    step.setAttribute(\"data-collapsed\", \"true\");\n  }\n};\n(window as any).expand = (e: Event) => {\n  const button = e.target as HTMLElement;\n  const step = getParentClassRecursive(button, \"step\");\n  if (step) {\n    step.setAttribute(\"data-collapsed\", \"false\");\n  }\n};\n\n// recursive definition of printing the context\ninterface Context {\n  left: string;\n  right: string;\n}\nfunction printContext(\n  ctx: SI_STRUCT.Context,\n  acc: Context = { left: \"\", right: \"\" }\n): Context {\n  if (SI_STRUCT.isHole(ctx)) {\n    return {\n      left: BSL_Print.sanitize(acc.left),\n      right: BSL_Print.sanitize(acc.right),\n    };\n  }\n  if (SI_STRUCT.isAppContext(ctx)) {\n    const leftEls = [\n      BSL_Print.printName(ctx.op),\n      ...ctx.values.map((v) => BSL_AST.isStructValue(v) ? BSL_Print.printValue(v) : `${v}`),\n    ];\n    acc.left = `${acc.left}(${leftEls.join(\" \")} `;\n    acc.right =\n      ctx.args.length > 0\n        ? ` ${ctx.args.map(BSL_Print.printE).join(\" \")})${acc.right}`\n        : `)${acc.right}`;\n  } else if (SI_STRUCT.isCondContext(ctx)) {\n    acc.left = `${acc.left}(cond [`;\n    const rest = [\n      `${BSL_Print.printE(ctx.options[0].result)}]`,\n      ...ctx.options.slice(1).map(BSL_Print.printOption),\n    ];\n    acc.right = ` ${rest.join(\" \")})${acc.right}`;\n  } else {\n    console.error(\"Printing this context is not implemented yet\", ctx);\n    throw `Printing ${ctx[\"type\"]} context is not implemented yet!`;\n  }\n  return printContext(ctx.ctx, acc);\n}\nfunction printValueOrId(vOrId: (SI_STRUCT.Value | SI_STRUCT.Id)): string {\n  if(SI_STRUCT.isValue(vOrId)) {\n    return BSL_Print.printValue(vOrId);\n  } else {\n    return printIdentifier(vOrId);\n  }\n}\n// recursive definition of printing the redex\nfunction printRedex(redex: SI_STRUCT.Redex): string {\n  if (SI_STRUCT.isCallRedex(redex)) {\n    return `(${BSL_Print.printName(redex.name)} ${redex.args\n      .map(printValueOrId)\n      .join(\" \")})`;\n  } else if (SI_STRUCT.isCondRedex(redex)) {\n    return `(cond ${redex.options.map(BSL_Print.printOption).join(\" \")})`;\n  } else if (SI_STRUCT.isNameRedex(redex)) {\n    return redex.symbol;\n  } else {\n    throw \"Invalid Input to printRedex\";\n  }\n}\n// Print Identifier\nfunction printIdentifier(id: SI_STRUCT.Id): string {\n  return id.symbol;\n}\n\n// rendering the rule tip\nfunction renderRuleInformation(rule: availableRules, kong: boolean): string {\n  const ruleInfo = rules[rule];\n  return `<div class=\"rule-info\">${\n    kong\n      ? `\n            <div class=\"rule-info-text-container\">\n              <div class=\"rule-info-rule-name\">${rules[\"Kong\"][\"name\"]}</div>\n              <div class=\"rule-info-rule-text\">${rules[\"Kong\"][\"text\"]}</div>\n            </div>\n           `\n      : \"\"\n  }\n         <div class=\"rule-info-text-container\">\n           <div class=\"rule-info-rule-name\">${ruleInfo[\"name\"]}</div>\n           <div class=\"rule-info-rule-text\">${ruleInfo[\"text\"]}</div>\n         </div>\n         </div>`;\n}\n(window as any).expandInfo = (e: Event) => {\n  const t = e.target as HTMLElement;\n  const p = getParentClassRecursive(t, \"plug-result\");\n  if (!p) return;\n  p.setAttribute(\"data-info-collapsed\", \"false\");\n};\n(window as any).collapseInfo = (e: Event) => {\n  const t = e.target as HTMLElement;\n  const p = getParentClassRecursive(t, \"plug-result\");\n  if (p) p.setAttribute(\"data-info-collapsed\", \"true\");\n};\n// ### rules ###\n// as taken from overview-reduction-and-equivalence.pdf, i.e. the script\n// to be displayed as reference\ntype availableRules =\n  | \"Kong\"\n  | \"Fun\"\n  | \"FunError\"\n  | \"Prim\"\n  | \"PrimError\"\n  | \"Const\"\n  | \"ConstError\"\n  | \"CondTrue\"\n  | \"CondFalse\"\n  | \"CondError\"\n  | \"StructMake\"\n  | \"StructMakeError\"\n  | \"StructSelect\"\n  | \"StructSelectError\"\n  | \"StructPredTrue\"\n  | \"StructPredFalse\"\n  | \"StructPredError\"\n  | \"Prog\"\n  | \"ProgError\";\nconst rules = {\n  Kong: {\n    name: `<cap>Kong</cap>`,\n    text: `\n      <em>E[e<small>1</small>] \u2192 E[e<small>2</small>] falls e<small>1</small> \u2192 e<small>2</small></em><br>\n      <em>\u2039E\u203A ::= []<br>\n      &nbsp;&nbsp;&nbsp;| (\u2039name\u203A \u2039v\u203A* \u2039E\u203A \u2039e\u203A*)<br>\n      &nbsp;&nbsp;&nbsp;| (<strong>cond</strong> [\u2039E\u203A \u2039e\u203A ]{[ \u2039e\u203A \u2039e\u203A]}*)</em>\n    `,\n  },\n  Fun: {\n    name: `<cap>Fun</cap>`,\n    text: `\n      <em>(name v<small>1</small> \u2026 v<small>n</small>) \u2192\n      e[name<small>1</small> := v<small>1</small> \u2026 name<small>n</small> := v<small>n</small> ]</em>\n      falls\n      <em>(</em> <strong>define</strong> <em>(name name<small>1</small> \u2026 name<small>n</small>) e)</em> in Umgebung\n    `,\n  },\n  FunError: {\n    name: `<cap>FunError</cap>`,\n    text: `\n      <em>(name v<small>1</small> \u2026 v<small>n</small>) \u2192 Error</em>\n      falls\n      <em>(</em> <strong>define</strong> <em>(name name<small>1</small> \u2026 name<small>n</small>) e)</em> nicht in Umgebung.\n    `,\n  },\n  Prim: {\n    name: `<cap>Prim</cap>`,\n    text: `\n      <em>(name v<small>1</small> \u2026 v<small>n</small>) \u2192 v</em> falls\n      <em>name</em> eine primitive Funktion <em>f</em> ist und\n      <em>f(v<small>1</small> \u2026 v<small>n</small>) = v</em>\n    `,\n  },\n  PrimError: {\n    name: `<cap>Prim</cap>-Error`,\n    text: `\n      <em>(name v<small>1</small> \u2026 v<small>n</small>) \u2192 Error</em> falls\n      <em>name</em> eine primitive Funktion <em>f</em> ist und\n      <em>f(v<small>1</small> \u2026 v<small>n</small>) = Error</em>\n    `,\n  },\n  Const: {\n    name: `<cap>Const</cap>`,\n    text: `\n      <em>name \u2192 v</em> falls <em>(<strong>define</strong> name v)</em> in Umgebung.\n    `,\n  },\n  ConstError: {\n    name: `<cap>Const</cap>-Error`,\n    text: `\n      <em>name \u2192 Error</em> falls <em>(<strong>define</strong> name v)</em>\n      nicht in Umgebung.\n    `,\n  },\n  CondTrue: {\n    name: `<cap>Cond</cap>-True`,\n    text: `\n      <em>(<strong>cond</strong> [<strong>#true</strong> e] \u2026) \u2192 e</em>\n    `,\n  },\n  CondFalse: {\n    name: `<cap>Cond</cap>-False`,\n    text: `\n      <em>(<strong>cond</strong> [<strong>#false</strong> e<small>1</small>]\n         [e<small>2</small> e<small>3</small>] \u2026) \u2192\n         (<strong>cond</strong> [e<small>2</small> e<small>3</small>] \u2026)</em>\n    `,\n  },\n  CondError: {\n    name: `<cap>Cond</cap>-Error`,\n    text: `\n      <em>(<strong>cond</strong> [e<small>1</small> e<small>2</small>] \u2026) \u2192\n          (<strong>error</strong> \"cond: all conditions false\")</em>\n    `,\n  },\n  StructMake: {\n    name: `<cap>Struct</cap>-make`,\n    text: `\n      <em>(<strong>make</strong>-name v<small>1</small> \u2026 v<small>n</small>) \u2192\n      &lt;<strong>make</strong>-name v<small>1</small> \u2026 v<small>n</small>&gt;</em>\n      falls <em>(<strong>define-struct</strong> name (name<small>1</small> \u2026 name<small>n</small>))</em> in Umgebung\n    `,\n  },\n  StructMakeError: {\n    name: `<cap>Struct</cap>-make-Error`,\n    text: ``,\n  },\n  StructSelect: {\n    name: `<cap>Struct</cap>-select`,\n    text: `\n      <em>(name-name<small>i</small> &lt;<strong>make</strong>-name\n        v<small>1</small> \u2026 v<small>n</small>&gt;) \u2192 v<small>i</small></em>\n        falls <em>(<strong>define-struct</strong> name\n          (name<small>1</small> \u2026 name<small>n</small>))</em> in Umgebung\n    `,\n  },\n  StructSelectError: {\n    name: `<cap>Struct</cap>-select-Error`,\n    text: ``,\n  },\n  StructPredTrue: {\n    name: `<cap>Struct</cap>-predtrue`,\n    text: `\n      <em>(name? &lt;<strong>make</strong>-name \u2026&gt;) \u2192 <strong>#true</strong></em>\n    `,\n  },\n  StructPredFalse: {\n    name: `<cap>Struct</cap>-predfalse`,\n    text: `\n      <em>(name? v) \u2192 <strong>#false</strong></em> falls <em>v</em> nicht\n      <em>&lt;<strong>make</strong>-name \u2026&gt;</em> ist\n    `,\n  },\n  StructPredError: {\n    name: `<cap>Struct</cap>-prederror`,\n    text: ``,\n  },\n  Prog: {\n    name: `<cap>Prog</cap>`,\n    text: `\n      Ein Programm wird von links nach rechts ausgef\u00FChrt und startet mit der\n      leeren Umgebung. Ist das n\u00E4chste Programmelement eine Funktions- oder\n      Strukturdefinition, so wird diese Definition in die Umgebung aufgenommen\n      und die Ausf\u00FChrung mit dem n\u00E4chsten Programmelement in der erweiterten\n      Umgebung fortgesetzt. Ist das n\u00E4chste Programmelement ein Ausdruck, so\n      wird dieser gem\u00E4\u00DF der unten stehenden Regeln in der aktuellen Umgebung zu\n      einem Wert ausgewert. Ist das n\u00E4chste Programmelement eine\n      Konstantendefinition <em>(<strong>define</strong> x e)</em>, so wird in\n      der aktuellen Umgebung zun\u00E4chst <em>e</em> zu einem Wert <em>v</em>\n      ausgewertet und dann <em>(<strong>define</strong> x v)</em> zur aktuellen\n      Umgebung hinzugef\u00FCgt.\n    `,\n  },\n  ProgError: {\n    name: `<cap>Prog</cap>-Error`,\n    text: `\n    Ein Programm wird von links nach rechts ausgef\u00FChrt und startet mit der\n    leeren Umgebung. Ist das n\u00E4chste Programmelement eine Funktions- oder\n    Strukturdefinition, so wird diese Definition in die Umgebung aufgenommen\n    und die Ausf\u00FChrung mit dem n\u00E4chsten Programmelement in der erweiterten\n    Umgebung fortgesetzt. Sofern die Definition allerdings schon in der Umgebung\n    vorhanden ist, wird ein Fehler ausgegeben.\n    `,\n  },\n};\n// execute the const rule = ...-definition in a js console (e.g. Dev Tools)\n// and then run the following snippet to\n// verify it contains no invalid HTML with open tags\n// Object.keys(rules).forEach(name => {\n//   const rule = rules[name];\n//   const text = `${rule.name}${rule.text}`;\n//   const tags = text\n//     .split('<')\n//     .slice(1)\n//     .map(s => s.split('>')[0])\n//     .filter(s => s != 'br');\n//   let tagStack = [];\n//   tags.forEach(t => {\n//     if(!t.startsWith('/')) return tagStack.push(t);\n//     const tag = t.slice(1);\n//     if(tagStack.pop() != tag) throw Error(\n//       `Rule ${name} contains invalid HTML: ${t} has no corresponding open tag`);\n//   });\n//   if (tagStack.length > 0)\n//     throw Error(`Rule ${name} contains invalid HTML: ${tagStack.join(',')} are opened but not closed`);\n// });\n", "import {processBslTrees} from './BSL_Tree';\nimport {processJsonTrees} from './JSON_Tree';\nimport {processSteppers} from './SI_Renderer';\n\n// setup callbacks\n// - do not set window.onload - other scripts might use it, too\n// - 'load' and not 'DOMContentLoaded' since we want CSS to be ready when we \"measure\" layout-related stuff\nwindow.addEventListener('load', () => {\n  processBslTrees();\n  processJsonTrees();\n  processSteppers();\n});\n"],
  "mappings": "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",
  "names": []
}
