26 lines
4.5 KiB
JavaScript
26 lines
4.5 KiB
JavaScript
import{_ as f,F as m,K as B,e as C,l as u,b as v,a as P,q as z,t as F,g as S,s as W,G as E,H as T,z as D}from"./mermaid.core-DrJfu-9d.chunk.mjs";import{p as A}from"./chunk-4BX2VUAB-CXxCl32T.chunk.mjs";import{p as H}from"./treemap-KMMF4GRG-BHT9xVli.chunk.mjs";import"./index-CRQM6PVi.chunk.mjs";import"./emoji-picker-MDCGxHB0.chunk.mjs";import"./NcLoadingIcon-ZJnsd-es.chunk.mjs";import"./vue.runtime.esm-CLeelJur.chunk.mjs";import"./index-DxwFe63_.chunk.mjs";import"./_baseUniq-pf37y4On.chunk.mjs";import"./_basePickBy-Dy1ViJhr.chunk.mjs";import"./clone-DchRqQR-.chunk.mjs";var R=T.packet,w=class{constructor(){this.packet=[],this.setAccTitle=v,this.getAccTitle=P,this.setDiagramTitle=z,this.getDiagramTitle=F,this.getAccDescription=S,this.setAccDescription=W}static{f(this,"PacketDB")}getConfig(){const t=m({...R,...E().packet});return t.showBits&&(t.paddingY+=10),t}getPacket(){return this.packet}pushWord(t){t.length>0&&this.packet.push(t)}clear(){D(),this.packet=[]}},Y=1e4,L=f((t,e)=>{A(t,e);let r=-1,s=[],l=1;const{bitsPerRow:n}=e.getConfig();for(let{start:a,end:i,bits:d,label:c}of t.blocks){if(a!==void 0&&i!==void 0&&i<a)throw new Error(`Packet block ${a} - ${i} is invalid. End must be greater than start.`);if(a??=r+1,a!==r+1)throw new Error(`Packet block ${a} - ${i??a} is not contiguous. It should start from ${r+1}.`);if(d===0)throw new Error(`Packet block ${a} is invalid. Cannot have a zero bit field.`);for(i??=a+(d??1)-1,d??=i-a+1,r=i,u.debug(`Packet block ${a} - ${r} with label ${c}`);s.length<=n+1&&e.getPacket().length<Y;){const[p,o]=M({start:a,end:i,bits:d,label:c},l,n);if(s.push(p),p.end+1===l*n&&(e.pushWord(s),s=[],l++),!o)break;({start:a,end:i,bits:d,label:c}=o)}}e.pushWord(s)},"populate"),M=f((t,e,r)=>{if(t.start===void 0)throw new Error("start should have been set during first phase");if(t.end===void 0)throw new Error("end should have been set during first phase");if(t.start>t.end)throw new Error(`Block start ${t.start} is greater than block end ${t.end}.`);if(t.end+1<=e*r)return[t,void 0];const s=e*r-1,l=e*r;return[{start:t.start,end:s,label:t.label,bits:s-t.start},{start:l,end:t.end,label:t.label,bits:t.end-l}]},"getNextFittingBlock"),x={parser:{yy:void 0},parse:f(async t=>{const e=await H("packet",t),r=x.parser?.yy;if(!(r instanceof w))throw new Error("parser.parser?.yy was not a PacketDB. This is due to a bug within Mermaid, please report this issue at https://github.com/mermaid-js/mermaid/issues.");u.debug(e),L(e,r)},"parse")},j=f((t,e,r,s)=>{const l=s.db,n=l.getConfig(),{rowHeight:a,paddingY:i,bitWidth:d,bitsPerRow:c}=n,p=l.getPacket(),o=l.getDiagramTitle(),h=a+i,b=h*(p.length+1)-(o?0:a),k=d*c+2,g=B(e);g.attr("viewbox",`0 0 ${k} ${b}`),C(g,b,k,n.useMaxWidth);for(const[y,$]of p.entries())q(g,$,y,n);g.append("text").text(o).attr("x",k/2).attr("y",b-h/2).attr("dominant-baseline","middle").attr("text-anchor","middle").attr("class","packetTitle")},"draw"),q=f((t,e,r,{rowHeight:s,paddingX:l,paddingY:n,bitWidth:a,bitsPerRow:i,showBits:d})=>{const c=t.append("g"),p=r*(s+n)+n;for(const o of e){const h=o.start%i*a+1,b=(o.end-o.start+1)*a-l;if(c.append("rect").attr("x",h).attr("y",p).attr("width",b).attr("height",s).attr("class","packetBlock"),c.append("text").attr("x",h+b/2).attr("y",p+s/2).attr("class","packetLabel").attr("dominant-baseline","middle").attr("text-anchor","middle").text(o.label),!d)continue;const k=o.end===o.start,g=p-2;c.append("text").attr("x",h+(k?b/2:0)).attr("y",g).attr("class","packetByte start").attr("dominant-baseline","auto").attr("text-anchor",k?"middle":"start").text(o.start),k||c.append("text").attr("x",h+b).attr("y",g).attr("class","packetByte end").attr("dominant-baseline","auto").attr("text-anchor","end").text(o.end)}},"drawWord"),G={draw:j},I={byteFontSize:"10px",startByteColor:"black",endByteColor:"black",labelColor:"black",labelFontSize:"12px",titleColor:"black",titleFontSize:"14px",blockStrokeColor:"black",blockStrokeWidth:"1",blockFillColor:"#efefef"},K=f(({packet:t}={})=>{const e=m(I,t);return`
|
|
.packetByte {
|
|
font-size: ${e.byteFontSize};
|
|
}
|
|
.packetByte.start {
|
|
fill: ${e.startByteColor};
|
|
}
|
|
.packetByte.end {
|
|
fill: ${e.endByteColor};
|
|
}
|
|
.packetLabel {
|
|
fill: ${e.labelColor};
|
|
font-size: ${e.labelFontSize};
|
|
}
|
|
.packetTitle {
|
|
fill: ${e.titleColor};
|
|
font-size: ${e.titleFontSize};
|
|
}
|
|
.packetBlock {
|
|
stroke: ${e.blockStrokeColor};
|
|
stroke-width: ${e.blockStrokeWidth};
|
|
fill: ${e.blockFillColor};
|
|
}
|
|
`},"styles"),at={parser:x,get db(){return new w},renderer:G,styles:K};export{at as diagram};
|
|
//# sourceMappingURL=diagram-S2PKOQOG-Cq6r2uXt.chunk.mjs.map
|