@prisma/studio-core 0.2.0 → 0.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/dist/chunk-BUOKRYKO.js +10 -0
  2. package/dist/chunk-FRW62KTF.js +10 -0
  3. package/dist/chunk-O6LRAFT5.js +10 -0
  4. package/dist/chunk-P5LRZ6C2.js +10 -0
  5. package/dist/data/accelerate/index.cjs +2 -1
  6. package/dist/data/accelerate/index.d.cts +10 -2
  7. package/dist/data/accelerate/index.d.ts +10 -2
  8. package/dist/data/accelerate/index.js +10 -1
  9. package/dist/data/bff/index.cjs +2 -1
  10. package/dist/data/bff/index.d.cts +10 -3
  11. package/dist/data/bff/index.d.ts +10 -3
  12. package/dist/data/bff/index.js +10 -1
  13. package/dist/data/index.cjs +2 -1
  14. package/dist/data/index.d.cts +11 -2
  15. package/dist/data/index.d.ts +11 -2
  16. package/dist/data/index.js +10 -1
  17. package/dist/data/pglite/index.cjs +2 -1
  18. package/dist/data/pglite/index.d.cts +2 -2
  19. package/dist/data/pglite/index.d.ts +2 -2
  20. package/dist/data/pglite/index.js +10 -1
  21. package/dist/data/postgres-core/index.cjs +2 -1
  22. package/dist/data/postgres-core/index.d.cts +80 -20
  23. package/dist/data/postgres-core/index.d.ts +80 -20
  24. package/dist/data/postgres-core/index.js +10 -1
  25. package/dist/metafile-cjs.json +1 -0
  26. package/dist/metafile-esm.json +1 -0
  27. package/dist/{adapter-CKFCHq71.d.cts → query-Q-ZKX_Vr.d.cts} +94 -7
  28. package/dist/{adapter-CKFCHq71.d.ts → query-Q-ZKX_Vr.d.ts} +94 -7
  29. package/dist/ui/index.cjs +258 -1370
  30. package/dist/ui/index.css +1234 -700
  31. package/dist/ui/index.d.cts +69 -3
  32. package/dist/ui/index.d.ts +69 -3
  33. package/dist/ui/index.js +267 -42
  34. package/package.json +36 -32
  35. package/dist/CPIOZS5X-V4BHP4CI.js +0 -1
  36. package/dist/OKF6E45R-XYOIK2NY.js +0 -1
  37. package/dist/chunk-2ZJZX5I7.js +0 -0
  38. package/dist/chunk-5MNS4IJC.js +0 -1332
  39. package/dist/chunk-BMVJYUJW.js +0 -1
  40. package/dist/chunk-N2MLAUEV.js +0 -1
  41. package/dist/chunk-P72NBTYE.js +0 -1
  42. package/dist/chunk-XS52QRY2.js +0 -1
  43. package/dist/index-BDPv5Gnt.d.ts +0 -48
  44. package/dist/index-BNAA6jKD.d.cts +0 -48
@@ -1 +1,2 @@
1
- "use strict";var ri=Object.defineProperty;var pn=Object.getOwnPropertyDescriptor;var cn=Object.getOwnPropertyNames;var hn=Object.prototype.hasOwnProperty;var mn=(t,e)=>{for(var r in e)ri(t,r,{get:e[r],enumerable:!0})},ln=(t,e,r,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of cn(e))!hn.call(t,n)&&n!==r&&ri(t,n,{get:()=>e[n],enumerable:!(o=pn(e,n))||o.enumerable});return t};var fn=t=>ln(ri({},"__esModule",{value:!0}),t);var ss={};mn(ss,{createPGLiteAdapter:()=>ns,createPGLiteExecutor:()=>dn});module.exports=fn(ss);var ro={bool:{group:"boolean"},boolean:{group:"boolean"},bytea:{group:"string"},char:{group:"string"},citext:{group:"string"},date:{group:"datetime"},interval:{group:"string"},name:{group:"string"},varchar:{group:"string"},text:{group:"string"},time:{group:"time"},timestamp:{group:"datetime"},timestamptz:{group:"datetime"},"timestamp without time zone":{group:"datetime"},"timestamp with time zone":{group:"datetime"},timetz:{group:"time"},"time without time zone":{group:"time"},"time with time zone":{group:"datetime"},uuid:{group:"string"},int2:{group:"numeric"},int4:{group:"numeric"},int8:{group:"numeric"},smallint:{group:"numeric"},integer:{group:"numeric"},bigint:{group:"numeric"},decimal:{group:"numeric"},numeric:{group:"numeric"},real:{group:"numeric"},float4:{group:"numeric"},float8:{group:"numeric"},"double precision":{group:"numeric"},json:{group:"json"},jsonb:{group:"json"}};function j(t){return typeof t>"u"||t===void 0}function C(t){return typeof t=="string"}function Se(t){return typeof t=="number"}function Ve(t){return typeof t=="boolean"}function Xe(t){return t===null}function io(t){return t instanceof Date}function Ze(t){return typeof t=="bigint"}function T(t){return typeof t=="function"}function L(t){return typeof t=="object"&&t!==null}function i(t){return Object.freeze(t)}function Rt(t){return F(t)?t:[t]}function F(t){return Array.isArray(t)}function U(t){return t}var l=i({is(t){return t.kind==="AlterTableNode"},create(t){return i({kind:"AlterTableNode",table:t})},cloneWithTableProps(t,e){return i({...t,...e})},cloneWithColumnAlteration(t,e){return i({...t,columnAlterations:t.columnAlterations?[...t.columnAlterations,e]:[e]})}});var p=i({is(t){return t.kind==="IdentifierNode"},create(t){return i({kind:"IdentifierNode",name:t})}});var re=i({is(t){return t.kind==="CreateIndexNode"},create(t){return i({kind:"CreateIndexNode",name:p.create(t)})},cloneWith(t,e){return i({...t,...e})},cloneWithColumns(t,e){return i({...t,columns:[...t.columns||[],...e]})}});var $t=i({is(t){return t.kind==="CreateSchemaNode"},create(t,e){return i({kind:"CreateSchemaNode",schema:p.create(t),...e})},cloneWith(t,e){return i({...t,...e})}});var oo=["preserve rows","delete rows","drop"],z=i({is(t){return t.kind==="CreateTableNode"},create(t){return i({kind:"CreateTableNode",table:t,columns:i([])})},cloneWithColumn(t,e){return i({...t,columns:i([...t.columns,e])})},cloneWithConstraint(t,e){return i({...t,constraints:t.constraints?i([...t.constraints,e]):i([e])})},cloneWithFrontModifier(t,e){return i({...t,frontModifiers:t.frontModifiers?i([...t.frontModifiers,e]):i([e])})},cloneWithEndModifier(t,e){return i({...t,endModifiers:t.endModifiers?i([...t.endModifiers,e]):i([e])})},cloneWith(t,e){return i({...t,...e})}});var V=i({is(t){return t.kind==="SchemableIdentifierNode"},create(t){return i({kind:"SchemableIdentifierNode",identifier:p.create(t)})},createWithSchema(t,e){return i({kind:"SchemableIdentifierNode",schema:p.create(t),identifier:p.create(e)})}});var ke=i({is(t){return t.kind==="DropIndexNode"},create(t,e){return i({kind:"DropIndexNode",name:V.create(t),...e})},cloneWith(t,e){return i({...t,...e})}});var It=i({is(t){return t.kind==="DropSchemaNode"},create(t,e){return i({kind:"DropSchemaNode",schema:p.create(t),...e})},cloneWith(t,e){return i({...t,...e})}});var Dt=i({is(t){return t.kind==="DropTableNode"},create(t,e){return i({kind:"DropTableNode",table:t,...e})},cloneWith(t,e){return i({...t,...e})}});var I=i({is(t){return t.kind==="AliasNode"},create(t,e){return i({kind:"AliasNode",node:t,alias:e})}});var H=i({is(t){return t.kind==="TableNode"},create(t){return i({kind:"TableNode",table:V.create(t)})},createWithSchema(t,e){return i({kind:"TableNode",table:V.createWithSchema(t,e)})}});function b(t){return L(t)&&T(t.toOperationNode)}function Kt(t){return L(t)&&"expressionType"in t&&b(t)}function no(t){return L(t)&&"expression"in t&&C(t.alias)&&b(t)}var ce=i({is(t){return t.kind==="SelectModifierNode"},create(t,e){return i({kind:"SelectModifierNode",modifier:t,of:e})},createWithExpression(t){return i({kind:"SelectModifierNode",rawModifier:t})}});var K=i({is(t){return t.kind==="AndNode"},create(t,e){return i({kind:"AndNode",left:t,right:e})}});var ie=i({is(t){return t.kind==="OrNode"},create(t,e){return i({kind:"OrNode",left:t,right:e})}});var Gt=i({is(t){return t.kind==="OnNode"},create(t){return i({kind:"OnNode",on:t})},cloneWithOperation(t,e,r){return i({...t,on:e==="And"?K.create(t.on,r):ie.create(t.on,r)})}});var we=i({is(t){return t.kind==="JoinNode"},create(t,e){return i({kind:"JoinNode",joinType:t,table:e,on:void 0})},createWithOn(t,e,r){return i({kind:"JoinNode",joinType:t,table:e,on:Gt.create(r)})},cloneWithOn(t,e){return i({...t,on:t.on?Gt.cloneWithOperation(t.on,"And",e):Gt.create(e)})}});var Ee=i({is(t){return t.kind==="BinaryOperationNode"},create(t,e,r){return i({kind:"BinaryOperationNode",leftOperand:t,operator:e,rightOperand:r})}});var Nn=["=","==","!=","<>",">",">=","<","<=","in","not in","is","is not","like","not like","match","ilike","not ilike","@>","<@","^@","&&","?","?&","?|","!<","!>","<=>","!~","~","~*","!~*","@@","@@@","!!","<->","regexp","is distinct from","is not distinct from"],yn=["+","-","*","/","%","^","&","|","#","<<",">>"],so=["->","->>"],wn=[...Nn,...yn,"&&","||"],xn=["exists","not exists"],gn=["not","-",...xn],ao=[...wn,...so,...gn,"between","between symmetric"],Y=i({is(t){return t.kind==="OperatorNode"},create(t){return i({kind:"OperatorNode",operator:t})}});function ii(t){return C(t)&&so.includes(t)}var h=i({is(t){return t.kind==="ColumnNode"},create(t){return i({kind:"ColumnNode",column:p.create(t)})}});var _e=i({is(t){return t.kind==="SelectAllNode"},create(){return i({kind:"SelectAllNode"})}});var et=i({is(t){return t.kind==="ReferenceNode"},create(t,e){return i({kind:"ReferenceNode",table:e,column:t})},createSelectAll(t){return i({kind:"ReferenceNode",table:t,column:_e.create()})}});var jt=class{#e;get dynamicReference(){return this.#e}get refType(){}constructor(e){this.#e=e}toOperationNode(){return oi(this.#e)}};function Ht(t){return L(t)&&b(t)&&C(t.dynamicReference)}var oe=i({is(t){return t.kind==="OrderByItemNode"},create(t,e){return i({kind:"OrderByItemNode",orderBy:t,direction:e})},cloneWith(t,e){return i({...t,...e})}});var W=i({is(t){return t.kind==="RawNode"},create(t,e){return i({kind:"RawNode",sqlFragments:i(t),parameters:i(e)})},createWithSql(t){return W.create([t],[])},createWithChild(t){return W.create(["",""],[t])},createWithChildren(t){return W.create(new Array(t.length+1).fill(""),t)}});var uo={is(t){return t.kind==="CollateNode"},create(t){return i({kind:"CollateNode",collation:p.create(t)})}};var Yt=class t{#e;constructor(e){this.#e=i(e)}desc(){return new t({node:oe.cloneWith(this.#e.node,{direction:W.createWithSql("desc")})})}asc(){return new t({node:oe.cloneWith(this.#e.node,{direction:W.createWithSql("asc")})})}nullsLast(){return new t({node:oe.cloneWith(this.#e.node,{nulls:"last"})})}nullsFirst(){return new t({node:oe.cloneWith(this.#e.node,{nulls:"first"})})}collate(e){return new t({node:oe.cloneWith(this.#e.node,{collation:uo.create(e)})})}toOperationNode(){return this.#e.node}};var po=new Set;function Ae(t){po.has(t)||(po.add(t),console.log(t))}function si(t){return t==="asc"||t==="desc"}function Z(t){if(t.length===2)return[ni(t[0],t[1])];if(t.length===1){let[e]=t;return Array.isArray(e)?(Ae("orderBy(array) is deprecated, use multiple orderBy calls instead."),e.map(r=>ni(r))):[ni(e)]}throw new Error(`Invalid number of arguments at order by! expected 1-2, received ${t.length}`)}function ni(t,e){let r=On(t);if(oe.is(r)){if(e)throw new Error("Cannot specify direction twice!");return r}return co(r,e)}function On(t){if(xe(t))return G(t);if(Ht(t))return t.toOperationNode();let[e,r]=t.split(" ");return r?(Ae("`orderBy('column asc')` is deprecated. Use `orderBy('column', 'asc')` instead."),co(X(e),r)):X(t)}function co(t,e){if(typeof e=="string"){if(!si(e))throw new Error(`Invalid order by direction: ${e}`);return oe.create(t,W.createWithSql(e))}if(Kt(e))return Ae("`orderBy(..., expr)` is deprecated. Use `orderBy(..., 'asc')` or `orderBy(..., (ob) => ...)` instead."),oe.create(t,e.toOperationNode());let r=oe.create(t);return e?e(new Yt({node:r})).toOperationNode():r}var tt=i({is(t){return t.kind==="JSONReferenceNode"},create(t,e){return i({kind:"JSONReferenceNode",reference:t,traversal:e})},cloneWithTraversal(t,e){return i({...t,traversal:e})}});var Xt=i({is(t){return t.kind==="JSONOperatorChainNode"},create(t){return i({kind:"JSONOperatorChainNode",operator:t,values:i([])})},cloneWithValue(t,e){return i({...t,values:i([...t.values,e])})}});var Re=i({is(t){return t.kind==="JSONPathNode"},create(t){return i({kind:"JSONPathNode",inOperator:t,pathLegs:i([])})},cloneWithLeg(t,e){return i({...t,pathLegs:i([...t.pathLegs,e])})}});function oi(t){return C(t)?X(t):t.toOperationNode()}function ge(t){return F(t)?t.map(e=>Q(e)):[Q(t)]}function Q(t){return xe(t)?G(t):oi(t)}function ho(t,e){let r=X(t);if(ii(e))return tt.create(r,Xt.create(Y.create(e)));let o=e.slice(0,-1);if(ii(o))return tt.create(r,Re.create(Y.create(o)));throw new Error(`Invalid JSON operator: ${e}`)}function X(t){let e=".";if(!t.includes(e))return et.create(h.create(t));let r=t.split(e).map(ui);if(r.length===3)return bn(r);if(r.length===2)return vn(r);throw new Error(`invalid column reference ${t}`)}function mo(t){let e=" as ";if(t.includes(e)){let[r,o]=t.split(e).map(ui);return I.create(X(r),p.create(o))}else return X(t)}function ai(t){return h.create(t)}function rt(t){let e=" ";if(t.includes(e)){let[r,o]=t.split(e).map(ui);if(!si(o))throw new Error(`invalid order direction "${o}" next to "${r}"`);return Z([r,o])[0]}else return ai(t)}function bn(t){let[e,r,o]=t;return et.create(h.create(o),H.createWithSchema(e,r))}function vn(t){let[e,r]=t;return et.create(h.create(r),H.create(e))}function ui(t){return t.trim()}var Zt=i({is(t){return t.kind==="PrimitiveValueListNode"},create(t){return i({kind:"PrimitiveValueListNode",values:i([...t])})}});var he=i({is(t){return t.kind==="ValueListNode"},create(t){return i({kind:"ValueListNode",values:i(t)})}});var k=i({is(t){return t.kind==="ValueNode"},create(t){return i({kind:"ValueNode",value:t})},createImmediate(t){return i({kind:"ValueNode",value:t,immediate:!0})}});function lo(t){return F(t)?Cn(t):g(t)}function g(t){return xe(t)?G(t):k.create(t)}function _t(t){return Se(t)||Ve(t)||Xe(t)}function qt(t){if(!_t(t))throw new Error(`unsafe immediate value ${JSON.stringify(t)}`);return k.createImmediate(t)}function Cn(t){return t.some(xe)?he.create(t.map(e=>g(e))):Zt.create(t)}var me=i({is(t){return t.kind==="ParensNode"},create(t){return i({kind:"ParensNode",node:t})}});function O(t){if(t.length===3)return er(t[0],t[1],t[2]);if(t.length===1)return g(t[0]);throw new Error(`invalid arguments: ${JSON.stringify(t)}`)}function er(t,e,r){return Wn(e)&&No(r)?Ee.create(Q(t),di(e),k.createImmediate(r)):Ee.create(Q(t),di(e),lo(r))}function D(t,e,r){return Ee.create(Q(t),di(e),Q(r))}function pi(t,e){return it(Object.entries(t).filter(([,r])=>!j(r)).map(([r,o])=>er(r,No(o)?"is":"=",o)),e)}function it(t,e,r=!0){let o=e==="and"?K.create:ie.create;if(t.length===0)return Ee.create(k.createImmediate(1),Y.create("="),k.createImmediate(e==="and"?1:0));let n=fo(t[0]);for(let a=1;a<t.length;++a)n=o(n,fo(t[a]));return t.length>1&&r?me.create(n):n}function Wn(t){return t==="is"||t==="is not"}function No(t){return Xe(t)||Ve(t)}function di(t){if(C(t)&&ao.includes(t))return Y.create(t);if(b(t))return t.toOperationNode();throw new Error(`invalid operator ${JSON.stringify(t)}`)}function fo(t){return b(t)?t.toOperationNode():t}var Oe=i({is(t){return t.kind==="OrderByNode"},create(t){return i({kind:"OrderByNode",items:i([...t])})},cloneWithItems(t,e){return i({...t,items:i([...t.items,...e])})}});var ci=i({is(t){return t.kind==="PartitionByNode"},create(t){return i({kind:"PartitionByNode",items:i(t)})},cloneWithItems(t,e){return i({...t,items:i([...t.items,...e])})}});var Bt=i({is(t){return t.kind==="OverNode"},create(){return i({kind:"OverNode"})},cloneWithOrderByItems(t,e){return i({...t,orderBy:t.orderBy?Oe.cloneWithItems(t.orderBy,e):Oe.create(e)})},cloneWithPartitionByItems(t,e){return i({...t,partitionBy:t.partitionBy?ci.cloneWithItems(t.partitionBy,e):ci.create(e)})}});var Ue=i({is(t){return t.kind==="FromNode"},create(t){return i({kind:"FromNode",froms:i(t)})},cloneWithFroms(t,e){return i({...t,froms:i([...t.froms,...e])})}});var hi=i({is(t){return t.kind==="GroupByNode"},create(t){return i({kind:"GroupByNode",items:i(t)})},cloneWithItems(t,e){return i({...t,items:i([...t.items,...e])})}});var mi=i({is(t){return t.kind==="HavingNode"},create(t){return i({kind:"HavingNode",having:t})},cloneWithOperation(t,e,r){return i({...t,having:e==="And"?K.create(t.having,r):ie.create(t.having,r)})}});var S=i({is(t){return t.kind==="InsertQueryNode"},create(t,e,r){return i({kind:"InsertQueryNode",into:t,...e&&{with:e},replace:r})},createWithoutInto(){return i({kind:"InsertQueryNode"})},cloneWith(t,e){return i({...t,...e})}});var tr=i({is(t){return t.kind==="ListNode"},create(t){return i({kind:"ListNode",items:i(t)})}});var le=i({is(t){return t.kind==="UpdateQueryNode"},create(t,e){return i({kind:"UpdateQueryNode",table:t.length===1?t[0]:tr.create(t),...e&&{with:e}})},createWithoutTable(){return i({kind:"UpdateQueryNode"})},cloneWithFromItems(t,e){return i({...t,from:t.from?Ue.cloneWithFroms(t.from,e):Ue.create(e)})},cloneWithUpdates(t,e){return i({...t,updates:t.updates?i([...t.updates,...e]):e})},cloneWithLimit(t,e){return i({...t,limit:e})}});var li=i({is(t){return t.kind==="UsingNode"},create(t){return i({kind:"UsingNode",tables:i(t)})},cloneWithTables(t,e){return i({...t,tables:i([...t.tables,...e])})}});var Ie=i({is(t){return t.kind==="DeleteQueryNode"},create(t,e){return i({kind:"DeleteQueryNode",from:Ue.create(t),...e&&{with:e}})},cloneWithOrderByItems:(t,e)=>u.cloneWithOrderByItems(t,e),cloneWithoutOrderBy:t=>u.cloneWithoutOrderBy(t),cloneWithLimit(t,e){return i({...t,limit:e})},cloneWithoutLimit(t){return i({...t,limit:void 0})},cloneWithUsing(t,e){return i({...t,using:t.using!==void 0?li.cloneWithTables(t.using,e):li.create(e)})}});var P=i({is(t){return t.kind==="WhereNode"},create(t){return i({kind:"WhereNode",where:t})},cloneWithOperation(t,e,r){return i({...t,where:e==="And"?K.create(t.where,r):ie.create(t.where,r)})}});var fi=i({is(t){return t.kind==="ReturningNode"},create(t){return i({kind:"ReturningNode",selections:i(t)})},cloneWithSelections(t,e){return i({...t,selections:t.selections?i([...t.selections,...e]):i(e)})}});var yo=i({is(t){return t.kind==="ExplainNode"},create(t,e){return i({kind:"ExplainNode",format:t,options:e})}});var be=i({is(t){return t.kind==="WhenNode"},create(t){return i({kind:"WhenNode",condition:t})},cloneWithResult(t,e){return i({...t,result:e})}});var q=i({is(t){return t.kind==="MergeQueryNode"},create(t,e){return i({kind:"MergeQueryNode",into:t,...e&&{with:e}})},cloneWithUsing(t,e){return i({...t,using:e})},cloneWithWhen(t,e){return i({...t,whens:t.whens?i([...t.whens,e]):i([e])})},cloneWithThen(t,e){return i({...t,whens:t.whens?i([...t.whens.slice(0,-1),be.cloneWithResult(t.whens[t.whens.length-1],e)]):void 0})}});var Ni=i({is(t){return t.kind==="OutputNode"},create(t){return i({kind:"OutputNode",selections:i(t)})},cloneWithSelections(t,e){return i({...t,selections:t.selections?i([...t.selections,...e]):i(e)})}});var u=i({is(t){return x.is(t)||S.is(t)||le.is(t)||Ie.is(t)||q.is(t)},cloneWithEndModifier(t,e){return i({...t,endModifiers:t.endModifiers?i([...t.endModifiers,e]):i([e])})},cloneWithWhere(t,e){return i({...t,where:t.where?P.cloneWithOperation(t.where,"And",e):P.create(e)})},cloneWithJoin(t,e){return i({...t,joins:t.joins?i([...t.joins,e]):i([e])})},cloneWithReturning(t,e){return i({...t,returning:t.returning?fi.cloneWithSelections(t.returning,e):fi.create(e)})},cloneWithoutReturning(t){return i({...t,returning:void 0})},cloneWithoutWhere(t){return i({...t,where:void 0})},cloneWithExplain(t,e,r){return i({...t,explain:yo.create(e,r?.toOperationNode())})},cloneWithTop(t,e){return i({...t,top:e})},cloneWithOutput(t,e){return i({...t,output:t.output?Ni.cloneWithSelections(t.output,e):Ni.create(e)})},cloneWithOrderByItems(t,e){return i({...t,orderBy:t.orderBy?Oe.cloneWithItems(t.orderBy,e):Oe.create(e)})},cloneWithoutOrderBy(t){return i({...t,orderBy:void 0})}});var x=i({is(t){return t.kind==="SelectQueryNode"},create(t){return i({kind:"SelectQueryNode",...t&&{with:t}})},createFrom(t,e){return i({kind:"SelectQueryNode",from:Ue.create(t),...e&&{with:e}})},cloneWithSelections(t,e){return i({...t,selections:t.selections?i([...t.selections,...e]):i(e)})},cloneWithDistinctOn(t,e){return i({...t,distinctOn:t.distinctOn?i([...t.distinctOn,...e]):i(e)})},cloneWithFrontModifier(t,e){return i({...t,frontModifiers:t.frontModifiers?i([...t.frontModifiers,e]):i([e])})},cloneWithOrderByItems:(t,e)=>u.cloneWithOrderByItems(t,e),cloneWithGroupByItems(t,e){return i({...t,groupBy:t.groupBy?hi.cloneWithItems(t.groupBy,e):hi.create(e)})},cloneWithLimit(t,e){return i({...t,limit:e})},cloneWithOffset(t,e){return i({...t,offset:e})},cloneWithFetch(t,e){return i({...t,fetch:e})},cloneWithHaving(t,e){return i({...t,having:t.having?mi.cloneWithOperation(t.having,"And",e):mi.create(e)})},cloneWithSetOperations(t,e){return i({...t,setOperations:t.setOperations?i([...t.setOperations,...e]):i([...e])})},cloneWithoutSelections(t){return i({...t,selections:[]})},cloneWithoutLimit(t){return i({...t,limit:void 0})},cloneWithoutOffset(t){return i({...t,offset:void 0})},cloneWithoutOrderBy:t=>u.cloneWithoutOrderBy(t),cloneWithoutGroupBy(t){return i({...t,groupBy:void 0})}});var rr=class t{#e;constructor(e){this.#e=i(e)}on(...e){return new t({...this.#e,joinNode:we.cloneWithOn(this.#e.joinNode,O(e))})}onRef(e,r,o){return new t({...this.#e,joinNode:we.cloneWithOn(this.#e.joinNode,D(e,r,o))})}onTrue(){return new t({...this.#e,joinNode:we.cloneWithOn(this.#e.joinNode,W.createWithSql("true"))})}$call(e){return e(this)}toOperationNode(){return this.#e.joinNode}};var wo=i({is(t){return t.kind==="PartitionByItemNode"},create(t){return i({kind:"PartitionByItemNode",partitionBy:t})}});function xo(t){return ge(t).map(wo.create)}var ir=class t{#e;constructor(e){this.#e=i(e)}orderBy(...e){return new t({overNode:Bt.cloneWithOrderByItems(this.#e.overNode,Z(e))})}clearOrderBy(){return new t({overNode:u.cloneWithoutOrderBy(this.#e.overNode)})}partitionBy(e){return new t({overNode:Bt.cloneWithPartitionByItems(this.#e.overNode,xo(e))})}$call(e){return e(this)}toOperationNode(){return this.#e.overNode}};var ot=i({is(t){return t.kind==="SelectionNode"},create(t){return i({kind:"SelectionNode",selection:t})},createSelectAll(){return i({kind:"SelectionNode",selection:_e.create()})},createSelectAllFromTable(t){return i({kind:"SelectionNode",selection:et.createSelectAll(t)})}});function A(t){return T(t)?A(t(ne())):F(t)?t.map(e=>go(e)):[go(t)]}function go(t){return C(t)?ot.create(mo(t)):Ht(t)?ot.create(t.toOperationNode()):ot.create(or(t))}function B(t){return t?Array.isArray(t)?t.map(Oo):[Oo(t)]:[ot.createSelectAll()]}function Oo(t){if(C(t))return ot.createSelectAllFromTable(f(t));throw new Error(`invalid value selectAll expression: ${JSON.stringify(t)}`)}var bo=i({is(t){return t.kind==="ValuesNode"},create(t){return i({kind:"ValuesNode",values:i(t)})}});var vo=i({is(t){return t.kind==="DefaultInsertValueNode"},create(){return i({kind:"DefaultInsertValueNode"})}});function nr(t){let e=T(t)?t(ne()):t,r=F(e)?e:i([e]);return Tn(r)}function Tn(t){let e=Sn(t);return[i([...e.keys()].map(h.create)),bo.create(t.map(r=>kn(r,e)))]}function Sn(t){let e=new Map;for(let r of t){let o=Object.keys(r);for(let n of o)!e.has(n)&&r[n]!==void 0&&e.set(n,e.size)}return e}function kn(t,e){let r=Object.keys(t),o=Array.from({length:e.size}),n=!1,a=r.length;for(let c of r){let N=e.get(c);if(j(N)){a--;continue}let y=t[c];(j(y)||xe(y))&&(n=!0),o[N]=y}if(a<e.size||n){let c=vo.create();return he.create(o.map(N=>j(N)?c:g(N)))}return Zt.create(o)}var yi=i({is(t){return t.kind==="ColumnUpdateNode"},create(t,e){return i({kind:"ColumnUpdateNode",column:t,value:e})}});function Co(...t){return t.length===2?[yi.create(Q(t[0]),g(t[1]))]:Lt(t[0])}function Lt(t){let e=T(t)?t(ne()):t;return Object.entries(e).filter(([r,o])=>o!==void 0).map(([r,o])=>yi.create(h.create(r),g(o)))}var Wo=i({is(t){return t.kind==="OnDuplicateKeyNode"},create(t){return i({kind:"OnDuplicateKeyNode",updates:t})}});var sr=class{insertId;numInsertedOrUpdatedRows;constructor(e,r){this.insertId=e,this.numInsertedOrUpdatedRows=r}};var ee=class extends Error{node;constructor(e){super("no result"),this.node=e}};function fe(t){return Object.prototype.hasOwnProperty.call(t,"prototype")}var J=i({is(t){return t.kind==="OnConflictNode"},create(){return i({kind:"OnConflictNode"})},cloneWith(t,e){return i({...t,...e})},cloneWithIndexWhere(t,e){return i({...t,indexWhere:t.indexWhere?P.cloneWithOperation(t.indexWhere,"And",e):P.create(e)})},cloneWithIndexOrWhere(t,e){return i({...t,indexWhere:t.indexWhere?P.cloneWithOperation(t.indexWhere,"Or",e):P.create(e)})},cloneWithUpdateWhere(t,e){return i({...t,updateWhere:t.updateWhere?P.cloneWithOperation(t.updateWhere,"And",e):P.create(e)})},cloneWithUpdateOrWhere(t,e){return i({...t,updateWhere:t.updateWhere?P.cloneWithOperation(t.updateWhere,"Or",e):P.create(e)})},cloneWithoutIndexWhere(t){return i({...t,indexWhere:void 0})},cloneWithoutUpdateWhere(t){return i({...t,updateWhere:void 0})}});var ar=class t{#e;constructor(e){this.#e=i(e)}column(e){let r=h.create(e);return new t({...this.#e,onConflictNode:J.cloneWith(this.#e.onConflictNode,{columns:this.#e.onConflictNode.columns?i([...this.#e.onConflictNode.columns,r]):i([r])})})}columns(e){let r=e.map(h.create);return new t({...this.#e,onConflictNode:J.cloneWith(this.#e.onConflictNode,{columns:this.#e.onConflictNode.columns?i([...this.#e.onConflictNode.columns,...r]):i(r)})})}constraint(e){return new t({...this.#e,onConflictNode:J.cloneWith(this.#e.onConflictNode,{constraint:p.create(e)})})}expression(e){return new t({...this.#e,onConflictNode:J.cloneWith(this.#e.onConflictNode,{indexExpression:e.toOperationNode()})})}where(...e){return new t({...this.#e,onConflictNode:J.cloneWithIndexWhere(this.#e.onConflictNode,O(e))})}whereRef(e,r,o){return new t({...this.#e,onConflictNode:J.cloneWithIndexWhere(this.#e.onConflictNode,D(e,r,o))})}clearWhere(){return new t({...this.#e,onConflictNode:J.cloneWithoutIndexWhere(this.#e.onConflictNode)})}doNothing(){return new wi({...this.#e,onConflictNode:J.cloneWith(this.#e.onConflictNode,{doNothing:!0})})}doUpdateSet(e){return new xi({...this.#e,onConflictNode:J.cloneWith(this.#e.onConflictNode,{updates:Lt(e)})})}$call(e){return e(this)}},wi=class{#e;constructor(e){this.#e=i(e)}toOperationNode(){return this.#e.onConflictNode}},xi=class t{#e;constructor(e){this.#e=i(e)}where(...e){return new t({...this.#e,onConflictNode:J.cloneWithUpdateWhere(this.#e.onConflictNode,O(e))})}whereRef(e,r,o){return new t({...this.#e,onConflictNode:J.cloneWithUpdateWhere(this.#e.onConflictNode,D(e,r,o))})}clearWhere(){return new t({...this.#e,onConflictNode:J.cloneWithoutUpdateWhere(this.#e.onConflictNode)})}$call(e){return e(this)}toOperationNode(){return this.#e.onConflictNode}};var To=i({is(t){return t.kind==="TopNode"},create(t,e){return i({kind:"TopNode",expression:t,modifiers:e})}});function se(t,e){if(!Se(t)&&!Ze(t))throw new Error(`Invalid top expression: ${t}`);if(!j(e)&&!En(e))throw new Error(`Invalid top modifiers: ${e}`);return To.create(t,e)}function En(t){return t==="percent"||t==="with ties"||t==="percent with ties"}var Je=i({is(t){return t.kind==="OrActionNode"},create(t){return i({kind:"OrActionNode",action:t})}});var Qt=class t{#e;constructor(e){this.#e=i(e)}values(e){let[r,o]=nr(e);return new t({...this.#e,queryNode:S.cloneWith(this.#e.queryNode,{columns:r,values:o})})}columns(e){return new t({...this.#e,queryNode:S.cloneWith(this.#e.queryNode,{columns:i(e.map(h.create))})})}expression(e){return new t({...this.#e,queryNode:S.cloneWith(this.#e.queryNode,{values:G(e)})})}defaultValues(){return new t({...this.#e,queryNode:S.cloneWith(this.#e.queryNode,{defaultValues:!0})})}modifyEnd(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,e.toOperationNode())})}ignore(){return new t({...this.#e,queryNode:S.cloneWith(this.#e.queryNode,{orAction:Je.create("ignore")})})}orIgnore(){return new t({...this.#e,queryNode:S.cloneWith(this.#e.queryNode,{orAction:Je.create("ignore")})})}orAbort(){return new t({...this.#e,queryNode:S.cloneWith(this.#e.queryNode,{orAction:Je.create("abort")})})}orFail(){return new t({...this.#e,queryNode:S.cloneWith(this.#e.queryNode,{orAction:Je.create("fail")})})}orReplace(){return new t({...this.#e,queryNode:S.cloneWith(this.#e.queryNode,{orAction:Je.create("replace")})})}orRollback(){return new t({...this.#e,queryNode:S.cloneWith(this.#e.queryNode,{orAction:Je.create("rollback")})})}top(e,r){return new t({...this.#e,queryNode:u.cloneWithTop(this.#e.queryNode,se(e,r))})}onConflict(e){return new t({...this.#e,queryNode:S.cloneWith(this.#e.queryNode,{onConflict:e(new ar({onConflictNode:J.create()})).toOperationNode()})})}onDuplicateKeyUpdate(e){return new t({...this.#e,queryNode:S.cloneWith(this.#e.queryNode,{onDuplicateKey:Wo.create(Lt(e))})})}returning(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,A(e))})}returningAll(){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,B())})}output(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,A(e))})}outputAll(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,B(e))})}clearReturning(){return new t({...this.#e,queryNode:u.cloneWithoutReturning(this.#e.queryNode)})}$call(e){return e(this)}$if(e,r){return e?r(this):new t({...this.#e})}$castTo(){return new t(this.#e)}$narrowType(){return new t(this.#e)}$assertType(){return new t(this.#e)}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}toOperationNode(){return this.#e.executor.transformQuery(this.#e.queryNode,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){let e=this.compile(),r=await this.#e.executor.executeQuery(e,this.#e.queryId),{adapter:o}=this.#e.executor,n=e.query;return n.returning&&o.supportsReturning||n.output&&o.supportsOutput?r.rows:[new sr(r.insertId,r.numAffectedRows??BigInt(0))]}async executeTakeFirst(){let[e]=await this.execute();return e}async executeTakeFirstOrThrow(e=ee){let r=await this.executeTakeFirst();if(r===void 0)throw fe(e)?new e(this.toOperationNode()):e(this.toOperationNode());return r}async*stream(e=100){let r=this.compile(),o=this.#e.executor.stream(r,e,this.#e.queryId);for await(let n of o)yield*n.rows}async explain(e,r){return await new t({...this.#e,queryNode:u.cloneWithExplain(this.#e.queryNode,e,r)}).execute()}};var ur=class{numDeletedRows;constructor(e){this.numDeletedRows=e}};var nt=i({is(t){return t.kind==="LimitNode"},create(t){return i({kind:"LimitNode",limit:t})}});var dr=class t{#e;constructor(e){this.#e=i(e)}where(...e){return new t({...this.#e,queryNode:u.cloneWithWhere(this.#e.queryNode,O(e))})}whereRef(e,r,o){return new t({...this.#e,queryNode:u.cloneWithWhere(this.#e.queryNode,D(e,r,o))})}clearWhere(){return new t({...this.#e,queryNode:u.cloneWithoutWhere(this.#e.queryNode)})}top(e,r){return new t({...this.#e,queryNode:u.cloneWithTop(this.#e.queryNode,se(e,r))})}using(e){return new t({...this.#e,queryNode:Ie.cloneWithUsing(this.#e.queryNode,ae(e))})}innerJoin(...e){return this.#t("InnerJoin",e)}leftJoin(...e){return this.#t("LeftJoin",e)}rightJoin(...e){return this.#t("RightJoin",e)}fullJoin(...e){return this.#t("FullJoin",e)}#t(e,r){return new t({...this.#e,queryNode:u.cloneWithJoin(this.#e.queryNode,De(e,r))})}returning(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,A(e))})}returningAll(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,B(e))})}output(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,A(e))})}outputAll(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,B(e))})}clearReturning(){return new t({...this.#e,queryNode:u.cloneWithoutReturning(this.#e.queryNode)})}clearLimit(){return new t({...this.#e,queryNode:Ie.cloneWithoutLimit(this.#e.queryNode)})}orderBy(...e){return new t({...this.#e,queryNode:u.cloneWithOrderByItems(this.#e.queryNode,Z(e))})}clearOrderBy(){return new t({...this.#e,queryNode:u.cloneWithoutOrderBy(this.#e.queryNode)})}limit(e){return new t({...this.#e,queryNode:Ie.cloneWithLimit(this.#e.queryNode,nt.create(g(e)))})}modifyEnd(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,e.toOperationNode())})}$call(e){return e(this)}$if(e,r){return e?r(this):new t({...this.#e})}$castTo(){return new t(this.#e)}$narrowType(){return new t(this.#e)}$assertType(){return new t(this.#e)}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}toOperationNode(){return this.#e.executor.transformQuery(this.#e.queryNode,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){let e=this.compile(),r=await this.#e.executor.executeQuery(e,this.#e.queryId),{adapter:o}=this.#e.executor,n=e.query;return n.returning&&o.supportsReturning||n.output&&o.supportsOutput?r.rows:[new ur(r.numAffectedRows??BigInt(0))]}async executeTakeFirst(){let[e]=await this.execute();return e}async executeTakeFirstOrThrow(e=ee){let r=await this.executeTakeFirst();if(r===void 0)throw fe(e)?new e(this.toOperationNode()):e(this.toOperationNode());return r}async*stream(e=100){let r=this.compile(),o=this.#e.executor.stream(r,e,this.#e.queryId);for await(let n of o)yield*n.rows}async explain(e,r){return await new t({...this.#e,queryNode:u.cloneWithExplain(this.#e.queryNode,e,r)}).execute()}};var pr=class{numUpdatedRows;numChangedRows;constructor(e,r){this.numUpdatedRows=e,this.numChangedRows=r}};var st=class t{#e;constructor(e){this.#e=i(e)}where(...e){return new t({...this.#e,queryNode:u.cloneWithWhere(this.#e.queryNode,O(e))})}whereRef(e,r,o){return new t({...this.#e,queryNode:u.cloneWithWhere(this.#e.queryNode,D(e,r,o))})}clearWhere(){return new t({...this.#e,queryNode:u.cloneWithoutWhere(this.#e.queryNode)})}top(e,r){return new t({...this.#e,queryNode:u.cloneWithTop(this.#e.queryNode,se(e,r))})}from(e){return new t({...this.#e,queryNode:le.cloneWithFromItems(this.#e.queryNode,ae(e))})}innerJoin(...e){return this.#t("InnerJoin",e)}leftJoin(...e){return this.#t("LeftJoin",e)}rightJoin(...e){return this.#t("RightJoin",e)}fullJoin(...e){return this.#t("FullJoin",e)}#t(e,r){return new t({...this.#e,queryNode:u.cloneWithJoin(this.#e.queryNode,De(e,r))})}orderBy(...e){return new t({...this.#e,queryNode:u.cloneWithOrderByItems(this.#e.queryNode,Z(e))})}clearOrderBy(){return new t({...this.#e,queryNode:u.cloneWithoutOrderBy(this.#e.queryNode)})}limit(e){return new t({...this.#e,queryNode:le.cloneWithLimit(this.#e.queryNode,nt.create(g(e)))})}set(...e){return new t({...this.#e,queryNode:le.cloneWithUpdates(this.#e.queryNode,Co(...e))})}returning(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,A(e))})}returningAll(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,B(e))})}output(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,A(e))})}outputAll(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,B(e))})}modifyEnd(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,e.toOperationNode())})}clearReturning(){return new t({...this.#e,queryNode:u.cloneWithoutReturning(this.#e.queryNode)})}$call(e){return e(this)}$if(e,r){return e?r(this):new t({...this.#e})}$castTo(){return new t(this.#e)}$narrowType(){return new t(this.#e)}$assertType(){return new t(this.#e)}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}toOperationNode(){return this.#e.executor.transformQuery(this.#e.queryNode,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){let e=this.compile(),r=await this.#e.executor.executeQuery(e,this.#e.queryId),{adapter:o}=this.#e.executor,n=e.query;return n.returning&&o.supportsReturning||n.output&&o.supportsOutput?r.rows:[new pr(r.numAffectedRows??BigInt(0),r.numChangedRows)]}async executeTakeFirst(){let[e]=await this.execute();return e}async executeTakeFirstOrThrow(e=ee){let r=await this.executeTakeFirst();if(r===void 0)throw fe(e)?new e(this.toOperationNode()):e(this.toOperationNode());return r}async*stream(e=100){let r=this.compile(),o=this.#e.executor.stream(r,e,this.#e.queryId);for await(let n of o)yield*n.rows}async explain(e,r){return await new t({...this.#e,queryNode:u.cloneWithExplain(this.#e.queryNode,e,r)}).execute()}};var gi=i({is(t){return t.kind==="CommonTableExpressionNameNode"},create(t,e){return i({kind:"CommonTableExpressionNameNode",table:H.create(t),columns:e?i(e.map(h.create)):void 0})}});var at=i({is(t){return t.kind==="CommonTableExpressionNode"},create(t,e){return i({kind:"CommonTableExpressionNode",name:t,expression:e})},cloneWith(t,e){return i({...t,...e})}});var cr=class t{#e;constructor(e){this.#e=i(e)}materialized(){return new t({...this.#e,node:at.cloneWith(this.#e.node,{materialized:!0})})}notMaterialized(){return new t({...this.#e,node:at.cloneWith(this.#e.node,{materialized:!1})})}toOperationNode(){return this.#e.node}};function Oi(t,e){let r=e(ko()).toOperationNode();return T(t)?t(An(r)).toOperationNode():at.create(So(t),r)}function An(t){return e=>new cr({node:at.create(So(e),t)})}function So(t){if(t.includes("(")){let e=t.split(/[\(\)]/),r=e[0],o=e[1].split(",").map(n=>n.trim());return gi.create(r,o)}else return gi.create(t)}var Pt=i({is(t){return t.kind==="WithNode"},create(t,e){return i({kind:"WithNode",expressions:i([t]),...e})},cloneWithExpression(t,e){return i({...t,expressions:i([...t.expressions,e])})}});var Eo=["A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z","a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z","0","1","2","3","4","5","6","7","8","9"];function Ao(t){let e="";for(let r=0;r<t;++r)e+=Rn();return e}function Rn(){return Eo[~~(Math.random()*Eo.length)]}function m(){return new bi}var bi=class{#e;get queryId(){return this.#e===void 0&&(this.#e=Ao(8)),this.#e}};var qe=class{nodeStack=[];#e=i({AliasNode:this.transformAlias.bind(this),ColumnNode:this.transformColumn.bind(this),IdentifierNode:this.transformIdentifier.bind(this),SchemableIdentifierNode:this.transformSchemableIdentifier.bind(this),RawNode:this.transformRaw.bind(this),ReferenceNode:this.transformReference.bind(this),SelectQueryNode:this.transformSelectQuery.bind(this),SelectionNode:this.transformSelection.bind(this),TableNode:this.transformTable.bind(this),FromNode:this.transformFrom.bind(this),SelectAllNode:this.transformSelectAll.bind(this),AndNode:this.transformAnd.bind(this),OrNode:this.transformOr.bind(this),ValueNode:this.transformValue.bind(this),ValueListNode:this.transformValueList.bind(this),PrimitiveValueListNode:this.transformPrimitiveValueList.bind(this),ParensNode:this.transformParens.bind(this),JoinNode:this.transformJoin.bind(this),OperatorNode:this.transformOperator.bind(this),WhereNode:this.transformWhere.bind(this),InsertQueryNode:this.transformInsertQuery.bind(this),DeleteQueryNode:this.transformDeleteQuery.bind(this),ReturningNode:this.transformReturning.bind(this),CreateTableNode:this.transformCreateTable.bind(this),AddColumnNode:this.transformAddColumn.bind(this),ColumnDefinitionNode:this.transformColumnDefinition.bind(this),DropTableNode:this.transformDropTable.bind(this),DataTypeNode:this.transformDataType.bind(this),OrderByNode:this.transformOrderBy.bind(this),OrderByItemNode:this.transformOrderByItem.bind(this),GroupByNode:this.transformGroupBy.bind(this),GroupByItemNode:this.transformGroupByItem.bind(this),UpdateQueryNode:this.transformUpdateQuery.bind(this),ColumnUpdateNode:this.transformColumnUpdate.bind(this),LimitNode:this.transformLimit.bind(this),OffsetNode:this.transformOffset.bind(this),OnConflictNode:this.transformOnConflict.bind(this),OnDuplicateKeyNode:this.transformOnDuplicateKey.bind(this),CreateIndexNode:this.transformCreateIndex.bind(this),DropIndexNode:this.transformDropIndex.bind(this),ListNode:this.transformList.bind(this),PrimaryKeyConstraintNode:this.transformPrimaryKeyConstraint.bind(this),UniqueConstraintNode:this.transformUniqueConstraint.bind(this),ReferencesNode:this.transformReferences.bind(this),CheckConstraintNode:this.transformCheckConstraint.bind(this),WithNode:this.transformWith.bind(this),CommonTableExpressionNode:this.transformCommonTableExpression.bind(this),CommonTableExpressionNameNode:this.transformCommonTableExpressionName.bind(this),HavingNode:this.transformHaving.bind(this),CreateSchemaNode:this.transformCreateSchema.bind(this),DropSchemaNode:this.transformDropSchema.bind(this),AlterTableNode:this.transformAlterTable.bind(this),DropColumnNode:this.transformDropColumn.bind(this),RenameColumnNode:this.transformRenameColumn.bind(this),AlterColumnNode:this.transformAlterColumn.bind(this),ModifyColumnNode:this.transformModifyColumn.bind(this),AddConstraintNode:this.transformAddConstraint.bind(this),DropConstraintNode:this.transformDropConstraint.bind(this),RenameConstraintNode:this.transformRenameConstraint.bind(this),ForeignKeyConstraintNode:this.transformForeignKeyConstraint.bind(this),CreateViewNode:this.transformCreateView.bind(this),RefreshMaterializedViewNode:this.transformRefreshMaterializedView.bind(this),DropViewNode:this.transformDropView.bind(this),GeneratedNode:this.transformGenerated.bind(this),DefaultValueNode:this.transformDefaultValue.bind(this),OnNode:this.transformOn.bind(this),ValuesNode:this.transformValues.bind(this),SelectModifierNode:this.transformSelectModifier.bind(this),CreateTypeNode:this.transformCreateType.bind(this),DropTypeNode:this.transformDropType.bind(this),ExplainNode:this.transformExplain.bind(this),DefaultInsertValueNode:this.transformDefaultInsertValue.bind(this),AggregateFunctionNode:this.transformAggregateFunction.bind(this),OverNode:this.transformOver.bind(this),PartitionByNode:this.transformPartitionBy.bind(this),PartitionByItemNode:this.transformPartitionByItem.bind(this),SetOperationNode:this.transformSetOperation.bind(this),BinaryOperationNode:this.transformBinaryOperation.bind(this),UnaryOperationNode:this.transformUnaryOperation.bind(this),UsingNode:this.transformUsing.bind(this),FunctionNode:this.transformFunction.bind(this),CaseNode:this.transformCase.bind(this),WhenNode:this.transformWhen.bind(this),JSONReferenceNode:this.transformJSONReference.bind(this),JSONPathNode:this.transformJSONPath.bind(this),JSONPathLegNode:this.transformJSONPathLeg.bind(this),JSONOperatorChainNode:this.transformJSONOperatorChain.bind(this),TupleNode:this.transformTuple.bind(this),MergeQueryNode:this.transformMergeQuery.bind(this),MatchedNode:this.transformMatched.bind(this),AddIndexNode:this.transformAddIndex.bind(this),CastNode:this.transformCast.bind(this),FetchNode:this.transformFetch.bind(this),TopNode:this.transformTop.bind(this),OutputNode:this.transformOutput.bind(this),OrActionNode:this.transformOrAction.bind(this),CollateNode:this.transformCollate.bind(this)});transformNode(e,r){if(!e)return e;this.nodeStack.push(e);let o=this.transformNodeImpl(e,r);return this.nodeStack.pop(),i(o)}transformNodeImpl(e,r){return this.#e[e.kind](e,r)}transformNodeList(e,r){return e&&i(e.map(o=>this.transformNode(o,r)))}transformSelectQuery(e,r){return{kind:"SelectQueryNode",from:this.transformNode(e.from,r),selections:this.transformNodeList(e.selections,r),distinctOn:this.transformNodeList(e.distinctOn,r),joins:this.transformNodeList(e.joins,r),groupBy:this.transformNode(e.groupBy,r),orderBy:this.transformNode(e.orderBy,r),where:this.transformNode(e.where,r),frontModifiers:this.transformNodeList(e.frontModifiers,r),endModifiers:this.transformNodeList(e.endModifiers,r),limit:this.transformNode(e.limit,r),offset:this.transformNode(e.offset,r),with:this.transformNode(e.with,r),having:this.transformNode(e.having,r),explain:this.transformNode(e.explain,r),setOperations:this.transformNodeList(e.setOperations,r),fetch:this.transformNode(e.fetch,r),top:this.transformNode(e.top,r)}}transformSelection(e,r){return{kind:"SelectionNode",selection:this.transformNode(e.selection,r)}}transformColumn(e,r){return{kind:"ColumnNode",column:this.transformNode(e.column,r)}}transformAlias(e,r){return{kind:"AliasNode",node:this.transformNode(e.node,r),alias:this.transformNode(e.alias,r)}}transformTable(e,r){return{kind:"TableNode",table:this.transformNode(e.table,r)}}transformFrom(e,r){return{kind:"FromNode",froms:this.transformNodeList(e.froms,r)}}transformReference(e,r){return{kind:"ReferenceNode",column:this.transformNode(e.column,r),table:this.transformNode(e.table,r)}}transformAnd(e,r){return{kind:"AndNode",left:this.transformNode(e.left,r),right:this.transformNode(e.right,r)}}transformOr(e,r){return{kind:"OrNode",left:this.transformNode(e.left,r),right:this.transformNode(e.right,r)}}transformValueList(e,r){return{kind:"ValueListNode",values:this.transformNodeList(e.values,r)}}transformParens(e,r){return{kind:"ParensNode",node:this.transformNode(e.node,r)}}transformJoin(e,r){return{kind:"JoinNode",joinType:e.joinType,table:this.transformNode(e.table,r),on:this.transformNode(e.on,r)}}transformRaw(e,r){return{kind:"RawNode",sqlFragments:i([...e.sqlFragments]),parameters:this.transformNodeList(e.parameters,r)}}transformWhere(e,r){return{kind:"WhereNode",where:this.transformNode(e.where,r)}}transformInsertQuery(e,r){return{kind:"InsertQueryNode",into:this.transformNode(e.into,r),columns:this.transformNodeList(e.columns,r),values:this.transformNode(e.values,r),returning:this.transformNode(e.returning,r),onConflict:this.transformNode(e.onConflict,r),onDuplicateKey:this.transformNode(e.onDuplicateKey,r),endModifiers:this.transformNodeList(e.endModifiers,r),with:this.transformNode(e.with,r),ignore:e.ignore,orAction:this.transformNode(e.orAction,r),replace:e.replace,explain:this.transformNode(e.explain,r),defaultValues:e.defaultValues,top:this.transformNode(e.top,r),output:this.transformNode(e.output,r)}}transformValues(e,r){return{kind:"ValuesNode",values:this.transformNodeList(e.values,r)}}transformDeleteQuery(e,r){return{kind:"DeleteQueryNode",from:this.transformNode(e.from,r),using:this.transformNode(e.using,r),joins:this.transformNodeList(e.joins,r),where:this.transformNode(e.where,r),returning:this.transformNode(e.returning,r),endModifiers:this.transformNodeList(e.endModifiers,r),with:this.transformNode(e.with,r),orderBy:this.transformNode(e.orderBy,r),limit:this.transformNode(e.limit,r),explain:this.transformNode(e.explain,r),top:this.transformNode(e.top,r),output:this.transformNode(e.output,r)}}transformReturning(e,r){return{kind:"ReturningNode",selections:this.transformNodeList(e.selections,r)}}transformCreateTable(e,r){return{kind:"CreateTableNode",table:this.transformNode(e.table,r),columns:this.transformNodeList(e.columns,r),constraints:this.transformNodeList(e.constraints,r),temporary:e.temporary,ifNotExists:e.ifNotExists,onCommit:e.onCommit,frontModifiers:this.transformNodeList(e.frontModifiers,r),endModifiers:this.transformNodeList(e.endModifiers,r),selectQuery:this.transformNode(e.selectQuery,r)}}transformColumnDefinition(e,r){return{kind:"ColumnDefinitionNode",column:this.transformNode(e.column,r),dataType:this.transformNode(e.dataType,r),references:this.transformNode(e.references,r),primaryKey:e.primaryKey,autoIncrement:e.autoIncrement,unique:e.unique,notNull:e.notNull,unsigned:e.unsigned,defaultTo:this.transformNode(e.defaultTo,r),check:this.transformNode(e.check,r),generated:this.transformNode(e.generated,r),frontModifiers:this.transformNodeList(e.frontModifiers,r),endModifiers:this.transformNodeList(e.endModifiers,r),nullsNotDistinct:e.nullsNotDistinct,identity:e.identity,ifNotExists:e.ifNotExists}}transformAddColumn(e,r){return{kind:"AddColumnNode",column:this.transformNode(e.column,r)}}transformDropTable(e,r){return{kind:"DropTableNode",table:this.transformNode(e.table,r),ifExists:e.ifExists,cascade:e.cascade}}transformOrderBy(e,r){return{kind:"OrderByNode",items:this.transformNodeList(e.items,r)}}transformOrderByItem(e,r){return{kind:"OrderByItemNode",orderBy:this.transformNode(e.orderBy,r),direction:this.transformNode(e.direction,r),collation:this.transformNode(e.collation,r),nulls:e.nulls}}transformGroupBy(e,r){return{kind:"GroupByNode",items:this.transformNodeList(e.items,r)}}transformGroupByItem(e,r){return{kind:"GroupByItemNode",groupBy:this.transformNode(e.groupBy,r)}}transformUpdateQuery(e,r){return{kind:"UpdateQueryNode",table:this.transformNode(e.table,r),from:this.transformNode(e.from,r),joins:this.transformNodeList(e.joins,r),where:this.transformNode(e.where,r),updates:this.transformNodeList(e.updates,r),returning:this.transformNode(e.returning,r),endModifiers:this.transformNodeList(e.endModifiers,r),with:this.transformNode(e.with,r),explain:this.transformNode(e.explain,r),limit:this.transformNode(e.limit,r),top:this.transformNode(e.top,r),output:this.transformNode(e.output,r),orderBy:this.transformNode(e.orderBy,r)}}transformColumnUpdate(e,r){return{kind:"ColumnUpdateNode",column:this.transformNode(e.column,r),value:this.transformNode(e.value,r)}}transformLimit(e,r){return{kind:"LimitNode",limit:this.transformNode(e.limit,r)}}transformOffset(e,r){return{kind:"OffsetNode",offset:this.transformNode(e.offset,r)}}transformOnConflict(e,r){return{kind:"OnConflictNode",columns:this.transformNodeList(e.columns,r),constraint:this.transformNode(e.constraint,r),indexExpression:this.transformNode(e.indexExpression,r),indexWhere:this.transformNode(e.indexWhere,r),updates:this.transformNodeList(e.updates,r),updateWhere:this.transformNode(e.updateWhere,r),doNothing:e.doNothing}}transformOnDuplicateKey(e,r){return{kind:"OnDuplicateKeyNode",updates:this.transformNodeList(e.updates,r)}}transformCreateIndex(e,r){return{kind:"CreateIndexNode",name:this.transformNode(e.name,r),table:this.transformNode(e.table,r),columns:this.transformNodeList(e.columns,r),unique:e.unique,using:this.transformNode(e.using,r),ifNotExists:e.ifNotExists,where:this.transformNode(e.where,r),nullsNotDistinct:e.nullsNotDistinct}}transformList(e,r){return{kind:"ListNode",items:this.transformNodeList(e.items,r)}}transformDropIndex(e,r){return{kind:"DropIndexNode",name:this.transformNode(e.name,r),table:this.transformNode(e.table,r),ifExists:e.ifExists,cascade:e.cascade}}transformPrimaryKeyConstraint(e,r){return{kind:"PrimaryKeyConstraintNode",columns:this.transformNodeList(e.columns,r),name:this.transformNode(e.name,r),deferrable:e.deferrable,initiallyDeferred:e.initiallyDeferred}}transformUniqueConstraint(e,r){return{kind:"UniqueConstraintNode",columns:this.transformNodeList(e.columns,r),name:this.transformNode(e.name,r),nullsNotDistinct:e.nullsNotDistinct,deferrable:e.deferrable,initiallyDeferred:e.initiallyDeferred}}transformForeignKeyConstraint(e,r){return{kind:"ForeignKeyConstraintNode",columns:this.transformNodeList(e.columns,r),references:this.transformNode(e.references,r),name:this.transformNode(e.name,r),onDelete:e.onDelete,onUpdate:e.onUpdate,deferrable:e.deferrable,initiallyDeferred:e.initiallyDeferred}}transformSetOperation(e,r){return{kind:"SetOperationNode",operator:e.operator,expression:this.transformNode(e.expression,r),all:e.all}}transformReferences(e,r){return{kind:"ReferencesNode",table:this.transformNode(e.table,r),columns:this.transformNodeList(e.columns,r),onDelete:e.onDelete,onUpdate:e.onUpdate}}transformCheckConstraint(e,r){return{kind:"CheckConstraintNode",expression:this.transformNode(e.expression,r),name:this.transformNode(e.name,r)}}transformWith(e,r){return{kind:"WithNode",expressions:this.transformNodeList(e.expressions,r),recursive:e.recursive}}transformCommonTableExpression(e,r){return{kind:"CommonTableExpressionNode",name:this.transformNode(e.name,r),materialized:e.materialized,expression:this.transformNode(e.expression,r)}}transformCommonTableExpressionName(e,r){return{kind:"CommonTableExpressionNameNode",table:this.transformNode(e.table,r),columns:this.transformNodeList(e.columns,r)}}transformHaving(e,r){return{kind:"HavingNode",having:this.transformNode(e.having,r)}}transformCreateSchema(e,r){return{kind:"CreateSchemaNode",schema:this.transformNode(e.schema,r),ifNotExists:e.ifNotExists}}transformDropSchema(e,r){return{kind:"DropSchemaNode",schema:this.transformNode(e.schema,r),ifExists:e.ifExists,cascade:e.cascade}}transformAlterTable(e,r){return{kind:"AlterTableNode",table:this.transformNode(e.table,r),renameTo:this.transformNode(e.renameTo,r),setSchema:this.transformNode(e.setSchema,r),columnAlterations:this.transformNodeList(e.columnAlterations,r),addConstraint:this.transformNode(e.addConstraint,r),dropConstraint:this.transformNode(e.dropConstraint,r),renameConstraint:this.transformNode(e.renameConstraint,r),addIndex:this.transformNode(e.addIndex,r),dropIndex:this.transformNode(e.dropIndex,r)}}transformDropColumn(e,r){return{kind:"DropColumnNode",column:this.transformNode(e.column,r)}}transformRenameColumn(e,r){return{kind:"RenameColumnNode",column:this.transformNode(e.column,r),renameTo:this.transformNode(e.renameTo,r)}}transformAlterColumn(e,r){return{kind:"AlterColumnNode",column:this.transformNode(e.column,r),dataType:this.transformNode(e.dataType,r),dataTypeExpression:this.transformNode(e.dataTypeExpression,r),setDefault:this.transformNode(e.setDefault,r),dropDefault:e.dropDefault,setNotNull:e.setNotNull,dropNotNull:e.dropNotNull}}transformModifyColumn(e,r){return{kind:"ModifyColumnNode",column:this.transformNode(e.column,r)}}transformAddConstraint(e,r){return{kind:"AddConstraintNode",constraint:this.transformNode(e.constraint,r)}}transformDropConstraint(e,r){return{kind:"DropConstraintNode",constraintName:this.transformNode(e.constraintName,r),ifExists:e.ifExists,modifier:e.modifier}}transformRenameConstraint(e,r){return{kind:"RenameConstraintNode",oldName:this.transformNode(e.oldName,r),newName:this.transformNode(e.newName,r)}}transformCreateView(e,r){return{kind:"CreateViewNode",name:this.transformNode(e.name,r),temporary:e.temporary,orReplace:e.orReplace,ifNotExists:e.ifNotExists,materialized:e.materialized,columns:this.transformNodeList(e.columns,r),as:this.transformNode(e.as,r)}}transformRefreshMaterializedView(e,r){return{kind:"RefreshMaterializedViewNode",name:this.transformNode(e.name,r),concurrently:e.concurrently,withNoData:e.withNoData}}transformDropView(e,r){return{kind:"DropViewNode",name:this.transformNode(e.name,r),ifExists:e.ifExists,materialized:e.materialized,cascade:e.cascade}}transformGenerated(e,r){return{kind:"GeneratedNode",byDefault:e.byDefault,always:e.always,identity:e.identity,stored:e.stored,expression:this.transformNode(e.expression,r)}}transformDefaultValue(e,r){return{kind:"DefaultValueNode",defaultValue:this.transformNode(e.defaultValue,r)}}transformOn(e,r){return{kind:"OnNode",on:this.transformNode(e.on,r)}}transformSelectModifier(e,r){return{kind:"SelectModifierNode",modifier:e.modifier,rawModifier:this.transformNode(e.rawModifier,r),of:this.transformNodeList(e.of,r)}}transformCreateType(e,r){return{kind:"CreateTypeNode",name:this.transformNode(e.name,r),enum:this.transformNode(e.enum,r)}}transformDropType(e,r){return{kind:"DropTypeNode",name:this.transformNode(e.name,r),ifExists:e.ifExists}}transformExplain(e,r){return{kind:"ExplainNode",format:e.format,options:this.transformNode(e.options,r)}}transformSchemableIdentifier(e,r){return{kind:"SchemableIdentifierNode",schema:this.transformNode(e.schema,r),identifier:this.transformNode(e.identifier,r)}}transformAggregateFunction(e,r){return{kind:"AggregateFunctionNode",func:e.func,aggregated:this.transformNodeList(e.aggregated,r),distinct:e.distinct,orderBy:this.transformNode(e.orderBy,r),withinGroup:this.transformNode(e.withinGroup,r),filter:this.transformNode(e.filter,r),over:this.transformNode(e.over,r)}}transformOver(e,r){return{kind:"OverNode",orderBy:this.transformNode(e.orderBy,r),partitionBy:this.transformNode(e.partitionBy,r)}}transformPartitionBy(e,r){return{kind:"PartitionByNode",items:this.transformNodeList(e.items,r)}}transformPartitionByItem(e,r){return{kind:"PartitionByItemNode",partitionBy:this.transformNode(e.partitionBy,r)}}transformBinaryOperation(e,r){return{kind:"BinaryOperationNode",leftOperand:this.transformNode(e.leftOperand,r),operator:this.transformNode(e.operator,r),rightOperand:this.transformNode(e.rightOperand,r)}}transformUnaryOperation(e,r){return{kind:"UnaryOperationNode",operator:this.transformNode(e.operator,r),operand:this.transformNode(e.operand,r)}}transformUsing(e,r){return{kind:"UsingNode",tables:this.transformNodeList(e.tables,r)}}transformFunction(e,r){return{kind:"FunctionNode",func:e.func,arguments:this.transformNodeList(e.arguments,r)}}transformCase(e,r){return{kind:"CaseNode",value:this.transformNode(e.value,r),when:this.transformNodeList(e.when,r),else:this.transformNode(e.else,r),isStatement:e.isStatement}}transformWhen(e,r){return{kind:"WhenNode",condition:this.transformNode(e.condition,r),result:this.transformNode(e.result,r)}}transformJSONReference(e,r){return{kind:"JSONReferenceNode",reference:this.transformNode(e.reference,r),traversal:this.transformNode(e.traversal,r)}}transformJSONPath(e,r){return{kind:"JSONPathNode",inOperator:this.transformNode(e.inOperator,r),pathLegs:this.transformNodeList(e.pathLegs,r)}}transformJSONPathLeg(e,r){return{kind:"JSONPathLegNode",type:e.type,value:e.value}}transformJSONOperatorChain(e,r){return{kind:"JSONOperatorChainNode",operator:this.transformNode(e.operator,r),values:this.transformNodeList(e.values,r)}}transformTuple(e,r){return{kind:"TupleNode",values:this.transformNodeList(e.values,r)}}transformMergeQuery(e,r){return{kind:"MergeQueryNode",into:this.transformNode(e.into,r),using:this.transformNode(e.using,r),whens:this.transformNodeList(e.whens,r),with:this.transformNode(e.with,r),top:this.transformNode(e.top,r),endModifiers:this.transformNodeList(e.endModifiers,r),output:this.transformNode(e.output,r),returning:this.transformNode(e.returning,r)}}transformMatched(e,r){return{kind:"MatchedNode",not:e.not,bySource:e.bySource}}transformAddIndex(e,r){return{kind:"AddIndexNode",name:this.transformNode(e.name,r),columns:this.transformNodeList(e.columns,r),unique:e.unique,using:this.transformNode(e.using,r),ifNotExists:e.ifNotExists}}transformCast(e,r){return{kind:"CastNode",expression:this.transformNode(e.expression,r),dataType:this.transformNode(e.dataType,r)}}transformFetch(e,r){return{kind:"FetchNode",rowCount:this.transformNode(e.rowCount,r),modifier:e.modifier}}transformTop(e,r){return{kind:"TopNode",expression:e.expression,modifiers:e.modifiers}}transformOutput(e,r){return{kind:"OutputNode",selections:this.transformNodeList(e.selections,r)}}transformDataType(e,r){return e}transformSelectAll(e,r){return e}transformIdentifier(e,r){return e}transformValue(e,r){return e}transformPrimitiveValueList(e,r){return e}transformOperator(e,r){return e}transformDefaultInsertValue(e,r){return e}transformOrAction(e,r){return e}transformCollate(e,r){return e}};var In=i({AlterTableNode:!0,CreateIndexNode:!0,CreateSchemaNode:!0,CreateTableNode:!0,CreateTypeNode:!0,CreateViewNode:!0,RefreshMaterializedViewNode:!0,DeleteQueryNode:!0,DropIndexNode:!0,DropSchemaNode:!0,DropTableNode:!0,DropTypeNode:!0,DropViewNode:!0,InsertQueryNode:!0,RawNode:!0,SelectQueryNode:!0,UpdateQueryNode:!0,MergeQueryNode:!0}),Dn={json_agg:!0,to_json:!0},hr=class extends qe{#e;#t=new Set;#r=new Set;constructor(e){super(),this.#e=e}transformNodeImpl(e,r){if(!this.#o(e))return super.transformNodeImpl(e,r);let o=this.#d(e);for(let d of o)this.#r.add(d);let n=this.#a(e);for(let d of n)this.#t.add(d);let a=super.transformNodeImpl(e,r);for(let d of n)this.#t.delete(d);for(let d of o)this.#r.delete(d);return a}transformSchemableIdentifier(e,r){let o=super.transformSchemableIdentifier(e,r);return o.schema||!this.#t.has(e.identifier.name)?o:{...o,schema:p.create(this.#e)}}transformReferences(e,r){let o=super.transformReferences(e,r);return o.table.table.schema?o:{...o,table:H.createWithSchema(this.#e,o.table.table.identifier.name)}}transformAggregateFunction(e,r){return{...super.transformAggregateFunction({...e,aggregated:[]},r),aggregated:this.#i(e,r,"aggregated")}}transformFunction(e,r){return{...super.transformFunction({...e,arguments:[]},r),arguments:this.#i(e,r,"arguments")}}#i(e,r,o){return Dn[e.func]?e[o].map(n=>!H.is(n)||n.table.schema?this.transformNode(n,r):{...n,table:this.transformIdentifier(n.table.identifier,r)}):this.transformNodeList(e[o],r)}#o(e){return e.kind in In}#a(e){let r=new Set;if("name"in e&&e.name&&V.is(e.name)&&this.#s(e.name,r),"from"in e&&e.from)for(let o of e.from.froms)this.#n(o,r);if("into"in e&&e.into&&this.#n(e.into,r),"table"in e&&e.table&&this.#n(e.table,r),"joins"in e&&e.joins)for(let o of e.joins)this.#n(o.table,r);return"using"in e&&e.using&&this.#n(e.using,r),r}#d(e){let r=new Set;return"with"in e&&e.with&&this.#u(e.with,r),r}#n(e,r){if(H.is(e))this.#s(e.table,r);else if(I.is(e)&&H.is(e.node))this.#s(e.node.table,r);else if(tr.is(e))for(let o of e.items)this.#n(o,r)}#s(e,r){let o=e.identifier.name;!this.#t.has(o)&&!this.#r.has(o)&&r.add(o)}#u(e,r){for(let o of e.expressions){let n=o.name.table.table.identifier.name;this.#r.has(n)||r.add(n)}}};var te=class{#e;constructor(e){this.#e=new hr(e)}transformQuery(e){return this.#e.transformNode(e.node,e.queryId)}async transformResult(e){return e.result}};var Ro=i({is(t){return t.kind==="MatchedNode"},create(t,e=!1){return i({kind:"MatchedNode",not:t,bySource:e})}});function vi(t,e,r){return be.create(it([Ro.create(!t.isMatched,t.bySource),...e&&e.length>0?[e.length===3&&r?D(e[0],e[1],e[2]):O(e)]:[]],"and",!1))}function ut(t){return C(t)?W.create([t],[]):b(t)?t.toOperationNode():t}var Mt=class{#e;#t;#r;constructor(){this.#e=new Promise((e,r)=>{this.#r=r,this.#t=e})}get promise(){return this.#e}resolve=e=>{this.#t&&this.#t(e)};reject=e=>{this.#r&&this.#r(e)}};async function mr(t){let e=new Mt,r=new Mt;return t.provideConnection(async o=>(e.resolve(o),await r.promise)).catch(o=>e.reject(o)),i({connection:await e.promise,release:r.resolve})}var qn=i([]),dt=class{#e;constructor(e=qn){this.#e=e}get plugins(){return this.#e}transformQuery(e,r){for(let o of this.#e){let n=o.transformQuery({node:e,queryId:r});if(n.kind===e.kind)e=n;else throw new Error(["KyselyPlugin.transformQuery must return a node","of the same kind that was given to it.",`The plugin was given a ${e.kind}`,`but it returned a ${n.kind}`].join(" "))}return e}async executeQuery(e,r){return await this.provideConnection(async o=>{let n=await o.executeQuery(e);return"numUpdatedOrDeletedRows"in n&&Ae("kysely:warning: outdated driver/plugin detected! `QueryResult.numUpdatedOrDeletedRows` has been replaced with `QueryResult.numAffectedRows`."),await this.#t(n,r)})}async*stream(e,r,o){let{connection:n,release:a}=await mr(this);try{for await(let d of n.streamQuery(e,r))yield await this.#t(d,o)}finally{a()}}async#t(e,r){for(let o of this.#e)e=await o.transformResult({result:e,queryId:r});return e}};var Ci=class t extends dt{get adapter(){throw new Error("this query cannot be compiled to SQL")}compileQuery(){throw new Error("this query cannot be compiled to SQL")}provideConnection(){throw new Error("this query cannot be executed")}withConnectionProvider(){throw new Error("this query cannot have a connection provider")}withPlugin(e){return new t([...this.plugins,e])}withPlugins(e){return new t([...this.plugins,...e])}withPluginAtFront(e){return new t([e,...this.plugins])}withoutPlugins(){return new t([])}},Be=new Ci;var lr=class{numChangedRows;constructor(e){this.numChangedRows=e}};var fr=class t{#e;constructor(e){this.#e=i(e)}modifyEnd(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,e.toOperationNode())})}top(e,r){return new t({...this.#e,queryNode:u.cloneWithTop(this.#e.queryNode,se(e,r))})}using(...e){return new Le({...this.#e,queryNode:q.cloneWithUsing(this.#e.queryNode,De("Using",e))})}returning(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,A(e))})}returningAll(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,B(e))})}output(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,A(e))})}outputAll(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,B(e))})}},Le=class t{#e;constructor(e){this.#e=i(e)}modifyEnd(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,e.toOperationNode())})}top(e,r){return new t({...this.#e,queryNode:u.cloneWithTop(this.#e.queryNode,se(e,r))})}whenMatched(){return this.#t([])}whenMatchedAnd(...e){return this.#t(e)}whenMatchedAndRef(e,r,o){return this.#t([e,r,o],!0)}#t(e,r){return new Nr({...this.#e,queryNode:q.cloneWithWhen(this.#e.queryNode,vi({isMatched:!0},e,r))})}whenNotMatched(){return this.#r([])}whenNotMatchedAnd(...e){return this.#r(e)}whenNotMatchedAndRef(e,r,o){return this.#r([e,r,o],!0)}whenNotMatchedBySource(){return this.#r([],!1,!0)}whenNotMatchedBySourceAnd(...e){return this.#r(e,!1,!0)}whenNotMatchedBySourceAndRef(e,r,o){return this.#r([e,r,o],!0,!0)}returning(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,A(e))})}returningAll(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,B(e))})}output(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,A(e))})}outputAll(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,B(e))})}#r(e,r=!1,o=!1){let n={...this.#e,queryNode:q.cloneWithWhen(this.#e.queryNode,vi({isMatched:!1,bySource:o},e,r))},a=o?Nr:Wi;return new a(n)}$call(e){return e(this)}$if(e,r){return e?r(this):new t({...this.#e})}toOperationNode(){return this.#e.executor.transformQuery(this.#e.queryNode,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){let e=this.compile(),r=await this.#e.executor.executeQuery(e,this.#e.queryId),{adapter:o}=this.#e.executor,n=e.query;return n.returning&&o.supportsReturning||n.output&&o.supportsOutput?r.rows:[new lr(r.numAffectedRows)]}async executeTakeFirst(){let[e]=await this.execute();return e}async executeTakeFirstOrThrow(e=ee){let r=await this.executeTakeFirst();if(r===void 0)throw fe(e)?new e(this.toOperationNode()):e(this.toOperationNode());return r}},Nr=class{#e;constructor(e){this.#e=i(e)}thenDelete(){return new Le({...this.#e,queryNode:q.cloneWithThen(this.#e.queryNode,ut("delete"))})}thenDoNothing(){return new Le({...this.#e,queryNode:q.cloneWithThen(this.#e.queryNode,ut("do nothing"))})}thenUpdate(e){return new Le({...this.#e,queryNode:q.cloneWithThen(this.#e.queryNode,ut(e(new st({queryId:this.#e.queryId,executor:Be,queryNode:le.createWithoutTable()}))))})}thenUpdateSet(...e){return this.thenUpdate(r=>r.set(...e))}},Wi=class{#e;constructor(e){this.#e=i(e)}thenDoNothing(){return new Le({...this.#e,queryNode:q.cloneWithThen(this.#e.queryNode,ut("do nothing"))})}thenInsertValues(e){let[r,o]=nr(e);return new Le({...this.#e,queryNode:q.cloneWithThen(this.#e.queryNode,ut(S.cloneWith(S.createWithoutInto(),{columns:r,values:o})))})}};var pt=class t{#e;constructor(e){this.#e=i(e)}selectFrom(e){return Ft({queryId:m(),executor:this.#e.executor,queryNode:x.createFrom(ae(e),this.#e.withNode)})}selectNoFrom(e){return Ft({queryId:m(),executor:this.#e.executor,queryNode:x.cloneWithSelections(x.create(this.#e.withNode),A(e))})}insertInto(e){return new Qt({queryId:m(),executor:this.#e.executor,queryNode:S.create(f(e),this.#e.withNode)})}replaceInto(e){return new Qt({queryId:m(),executor:this.#e.executor,queryNode:S.create(f(e),this.#e.withNode,!0)})}deleteFrom(e){return new dr({queryId:m(),executor:this.#e.executor,queryNode:Ie.create(ae(e),this.#e.withNode)})}updateTable(e){return new st({queryId:m(),executor:this.#e.executor,queryNode:le.create(ae(e),this.#e.withNode)})}mergeInto(e){return new fr({queryId:m(),executor:this.#e.executor,queryNode:q.create(Ti(e),this.#e.withNode)})}with(e,r){let o=Oi(e,r);return new t({...this.#e,withNode:this.#e.withNode?Pt.cloneWithExpression(this.#e.withNode,o):Pt.create(o)})}withRecursive(e,r){let o=Oi(e,r);return new t({...this.#e,withNode:this.#e.withNode?Pt.cloneWithExpression(this.#e.withNode,o):Pt.create(o,{recursive:!0})})}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}withoutPlugins(){return new t({...this.#e,executor:this.#e.executor.withoutPlugins()})}withSchema(e){return new t({...this.#e,executor:this.#e.executor.withPluginAtFront(new te(e))})}};function ko(){return new pt({executor:Be})}function Io(t,e){return new rr({joinNode:we.create(t,$e(e))})}function Do(){return new ir({overNode:Bt.create()})}function De(t,e){if(e.length===3)return Ln(t,e[0],e[1],e[2]);if(e.length===2)return Bn(t,e[0],e[1]);if(e.length===1)return Qn(t,e[0]);throw new Error("not implemented")}function Bn(t,e,r){return r(Io(t,e)).toOperationNode()}function Ln(t,e,r,o){return we.createWithOn(t,$e(e),D(r,"=",o))}function Qn(t,e){return we.create(t,$e(e))}var qo=i({is(t){return t.kind==="OffsetNode"},create(t){return i({kind:"OffsetNode",offset:t})}});var Bo=i({is(t){return t.kind==="GroupByItemNode"},create(t){return i({kind:"GroupByItemNode",groupBy:t})}});function Lo(t){return t=T(t)?t(ne()):t,ge(t).map(Bo.create)}var yr=i({is(t){return t.kind==="SetOperationNode"},create(t,e,r){return i({kind:"SetOperationNode",operator:t,expression:e,all:r})}});function Ke(t,e,r){return T(e)&&(e=e(wr())),F(e)||(e=[e]),e.map(o=>yr.create(t,G(o),r))}var w=class t{#e;constructor(e){this.#e=e}get expressionType(){}as(e){return new zt(this,e)}or(...e){return new Si(ie.create(this.#e,O(e)))}and(...e){return new ki(K.create(this.#e,O(e)))}$castTo(){return new t(this.#e)}$notNull(){return new t(this.#e)}toOperationNode(){return this.#e}},zt=class{#e;#t;constructor(e,r){this.#e=e,this.#t=r}get expression(){return this.#e}get alias(){return this.#t}toOperationNode(){return I.create(this.#e.toOperationNode(),b(this.#t)?this.#t.toOperationNode():p.create(this.#t))}},Si=class t{#e;constructor(e){this.#e=e}get expressionType(){}as(e){return new zt(this,e)}or(...e){return new t(ie.create(this.#e,O(e)))}$castTo(){return new t(this.#e)}toOperationNode(){return me.create(this.#e)}},ki=class t{#e;constructor(e){this.#e=e}get expressionType(){}as(e){return new zt(this,e)}and(...e){return new t(K.create(this.#e,O(e)))}$castTo(){return new t(this.#e)}toOperationNode(){return me.create(this.#e)}};var Qo={is(t){return t.kind==="FetchNode"},create(t,e){return{kind:"FetchNode",rowCount:k.create(t),modifier:e}}};function Po(t,e){if(!Se(t)&&!Ze(t))throw new Error(`Invalid fetch row count: ${t}`);if(!Pn(e))throw new Error(`Invalid fetch modifier: ${e}`);return Qo.create(t,e)}function Pn(t){return t==="only"||t==="with ties"}var Ei=class t{#e;constructor(e){this.#e=i(e)}get expressionType(){}get isSelectQueryBuilder(){return!0}where(...e){return new t({...this.#e,queryNode:u.cloneWithWhere(this.#e.queryNode,O(e))})}whereRef(e,r,o){return new t({...this.#e,queryNode:u.cloneWithWhere(this.#e.queryNode,D(e,r,o))})}having(...e){return new t({...this.#e,queryNode:x.cloneWithHaving(this.#e.queryNode,O(e))})}havingRef(e,r,o){return new t({...this.#e,queryNode:x.cloneWithHaving(this.#e.queryNode,D(e,r,o))})}select(e){return new t({...this.#e,queryNode:x.cloneWithSelections(this.#e.queryNode,A(e))})}distinctOn(e){return new t({...this.#e,queryNode:x.cloneWithDistinctOn(this.#e.queryNode,ge(e))})}modifyFront(e){return new t({...this.#e,queryNode:x.cloneWithFrontModifier(this.#e.queryNode,ce.createWithExpression(e.toOperationNode()))})}modifyEnd(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,ce.createWithExpression(e.toOperationNode()))})}distinct(){return new t({...this.#e,queryNode:x.cloneWithFrontModifier(this.#e.queryNode,ce.create("Distinct"))})}forUpdate(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,ce.create("ForUpdate",e?Rt(e).map(f):void 0))})}forShare(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,ce.create("ForShare",e?Rt(e).map(f):void 0))})}forKeyShare(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,ce.create("ForKeyShare",e?Rt(e).map(f):void 0))})}forNoKeyUpdate(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,ce.create("ForNoKeyUpdate",e?Rt(e).map(f):void 0))})}skipLocked(){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,ce.create("SkipLocked"))})}noWait(){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,ce.create("NoWait"))})}selectAll(e){return new t({...this.#e,queryNode:x.cloneWithSelections(this.#e.queryNode,B(e))})}innerJoin(...e){return this.#t("InnerJoin",e)}leftJoin(...e){return this.#t("LeftJoin",e)}rightJoin(...e){return this.#t("RightJoin",e)}fullJoin(...e){return this.#t("FullJoin",e)}crossJoin(...e){return this.#t("CrossJoin",e)}innerJoinLateral(...e){return this.#t("LateralInnerJoin",e)}leftJoinLateral(...e){return this.#t("LateralLeftJoin",e)}crossJoinLateral(...e){return this.#t("LateralCrossJoin",e)}crossApply(...e){return this.#t("CrossApply",e)}outerApply(...e){return this.#t("OuterApply",e)}#t(e,r){return new t({...this.#e,queryNode:u.cloneWithJoin(this.#e.queryNode,De(e,r))})}orderBy(...e){return new t({...this.#e,queryNode:u.cloneWithOrderByItems(this.#e.queryNode,Z(e))})}groupBy(e){return new t({...this.#e,queryNode:x.cloneWithGroupByItems(this.#e.queryNode,Lo(e))})}limit(e){return new t({...this.#e,queryNode:x.cloneWithLimit(this.#e.queryNode,nt.create(g(e)))})}offset(e){return new t({...this.#e,queryNode:x.cloneWithOffset(this.#e.queryNode,qo.create(g(e)))})}fetch(e,r="only"){return new t({...this.#e,queryNode:x.cloneWithFetch(this.#e.queryNode,Po(e,r))})}top(e,r){return new t({...this.#e,queryNode:u.cloneWithTop(this.#e.queryNode,se(e,r))})}union(e){return new t({...this.#e,queryNode:x.cloneWithSetOperations(this.#e.queryNode,Ke("union",e,!1))})}unionAll(e){return new t({...this.#e,queryNode:x.cloneWithSetOperations(this.#e.queryNode,Ke("union",e,!0))})}intersect(e){return new t({...this.#e,queryNode:x.cloneWithSetOperations(this.#e.queryNode,Ke("intersect",e,!1))})}intersectAll(e){return new t({...this.#e,queryNode:x.cloneWithSetOperations(this.#e.queryNode,Ke("intersect",e,!0))})}except(e){return new t({...this.#e,queryNode:x.cloneWithSetOperations(this.#e.queryNode,Ke("except",e,!1))})}exceptAll(e){return new t({...this.#e,queryNode:x.cloneWithSetOperations(this.#e.queryNode,Ke("except",e,!0))})}as(e){return new Ai(this,e)}clearSelect(){return new t({...this.#e,queryNode:x.cloneWithoutSelections(this.#e.queryNode)})}clearWhere(){return new t({...this.#e,queryNode:u.cloneWithoutWhere(this.#e.queryNode)})}clearLimit(){return new t({...this.#e,queryNode:x.cloneWithoutLimit(this.#e.queryNode)})}clearOffset(){return new t({...this.#e,queryNode:x.cloneWithoutOffset(this.#e.queryNode)})}clearOrderBy(){return new t({...this.#e,queryNode:u.cloneWithoutOrderBy(this.#e.queryNode)})}clearGroupBy(){return new t({...this.#e,queryNode:x.cloneWithoutGroupBy(this.#e.queryNode)})}$call(e){return e(this)}$if(e,r){return e?r(this):new t({...this.#e})}$castTo(){return new t(this.#e)}$narrowType(){return new t(this.#e)}$assertType(){return new t(this.#e)}$asTuple(){return new w(this.toOperationNode())}$asScalar(){return new w(this.toOperationNode())}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}toOperationNode(){return this.#e.executor.transformQuery(this.#e.queryNode,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){let e=this.compile();return(await this.#e.executor.executeQuery(e,this.#e.queryId)).rows}async executeTakeFirst(){let[e]=await this.execute();return e}async executeTakeFirstOrThrow(e=ee){let r=await this.executeTakeFirst();if(r===void 0)throw fe(e)?new e(this.toOperationNode()):e(this.toOperationNode());return r}async*stream(e=100){let r=this.compile(),o=this.#e.executor.stream(r,e,this.#e.queryId);for await(let n of o)yield*n.rows}async explain(e,r){return await new t({...this.#e,queryNode:u.cloneWithExplain(this.#e.queryNode,e,r)}).execute()}};function Ft(t){return new Ei(t)}var Ai=class{#e;#t;constructor(e,r){this.#e=e,this.#t=r}get expression(){return this.#e}get alias(){return this.#t}get isAliasedSelectQueryBuilder(){return!0}toOperationNode(){return I.create(this.#e.toOperationNode(),p.create(this.#t))}};var Ne=i({is(t){return t.kind==="AggregateFunctionNode"},create(t,e=[]){return i({kind:"AggregateFunctionNode",func:t,aggregated:e})},cloneWithDistinct(t){return i({...t,distinct:!0})},cloneWithOrderBy(t,e,r=!1){let o=r?"withinGroup":"orderBy";return i({...t,[o]:t[o]?Oe.cloneWithItems(t[o],e):Oe.create(e)})},cloneWithFilter(t,e){return i({...t,filter:t.filter?P.cloneWithOperation(t.filter,"And",e):P.create(e)})},cloneWithOrFilter(t,e){return i({...t,filter:t.filter?P.cloneWithOperation(t.filter,"Or",e):P.create(e)})},cloneWithOver(t,e){return i({...t,over:e})}});var Ri=i({is(t){return t.kind==="FunctionNode"},create(t,e){return i({kind:"FunctionNode",func:t,arguments:e})}});var ct=class t{#e;constructor(e){this.#e=i(e)}get expressionType(){}as(e){return new Ii(this,e)}distinct(){return new t({...this.#e,aggregateFunctionNode:Ne.cloneWithDistinct(this.#e.aggregateFunctionNode)})}orderBy(...e){return new t({...this.#e,aggregateFunctionNode:u.cloneWithOrderByItems(this.#e.aggregateFunctionNode,Z(e))})}clearOrderBy(){return new t({...this.#e,aggregateFunctionNode:u.cloneWithoutOrderBy(this.#e.aggregateFunctionNode)})}withinGroupOrderBy(...e){return new t({...this.#e,aggregateFunctionNode:Ne.cloneWithOrderBy(this.#e.aggregateFunctionNode,Z(e),!0)})}filterWhere(...e){return new t({...this.#e,aggregateFunctionNode:Ne.cloneWithFilter(this.#e.aggregateFunctionNode,O(e))})}filterWhereRef(e,r,o){return new t({...this.#e,aggregateFunctionNode:Ne.cloneWithFilter(this.#e.aggregateFunctionNode,D(e,r,o))})}over(e){let r=Do();return new t({...this.#e,aggregateFunctionNode:Ne.cloneWithOver(this.#e.aggregateFunctionNode,(e?e(r):r).toOperationNode())})}$call(e){return e(this)}$castTo(){return new t(this.#e)}$notNull(){return new t(this.#e)}toOperationNode(){return this.#e.aggregateFunctionNode}},Ii=class{#e;#t;constructor(e,r){this.#e=e,this.#t=r}get expression(){return this.#e}get alias(){return this.#t}toOperationNode(){return I.create(this.#e.toOperationNode(),p.create(this.#t))}};function xr(){let t=(r,o)=>new w(Ri.create(r,ge(o??[]))),e=(r,o)=>new ct({aggregateFunctionNode:Ne.create(r,o?ge(o):void 0)});return Object.assign(t,{agg:e,avg(r){return e("avg",[r])},coalesce(...r){return t("coalesce",r)},count(r){return e("count",[r])},countAll(r){return new ct({aggregateFunctionNode:Ne.create("count",B(r))})},max(r){return e("max",[r])},min(r){return e("min",[r])},sum(r){return e("sum",[r])},any(r){return t("any",[r])},jsonAgg(r){return new ct({aggregateFunctionNode:Ne.create("json_agg",[C(r)?f(r):r.toOperationNode()])})},toJson(r){return new w(Ri.create("to_json",[C(r)?f(r):r.toOperationNode()]))}})}var Mo=i({is(t){return t.kind==="UnaryOperationNode"},create(t,e){return i({kind:"UnaryOperationNode",operator:t,operand:e})}});function Fo(t,e){return Mo.create(Y.create(t),Q(e))}var _=i({is(t){return t.kind==="CaseNode"},create(t){return i({kind:"CaseNode",value:t})},cloneWithWhen(t,e){return i({...t,when:i(t.when?[...t.when,e]:[e])})},cloneWithThen(t,e){return i({...t,when:t.when?i([...t.when.slice(0,-1),be.cloneWithResult(t.when[t.when.length-1],e)]):void 0})},cloneWith(t,e){return i({...t,...e})}});var ht=class{#e;constructor(e){this.#e=i(e)}when(...e){return new gr({...this.#e,node:_.cloneWithWhen(this.#e.node,be.create(O(e)))})}},gr=class{#e;constructor(e){this.#e=i(e)}then(e){return new Di({...this.#e,node:_.cloneWithThen(this.#e.node,_t(e)?qt(e):g(e))})}},Di=class{#e;constructor(e){this.#e=i(e)}when(...e){return new gr({...this.#e,node:_.cloneWithWhen(this.#e.node,be.create(O(e)))})}else(e){return new qi({...this.#e,node:_.cloneWith(this.#e.node,{else:_t(e)?qt(e):g(e)})})}end(){return new w(_.cloneWith(this.#e.node,{isStatement:!1}))}endCase(){return new w(_.cloneWith(this.#e.node,{isStatement:!0}))}},qi=class{#e;constructor(e){this.#e=i(e)}end(){return new w(_.cloneWith(this.#e.node,{isStatement:!1}))}endCase(){return new w(_.cloneWith(this.#e.node,{isStatement:!0}))}};var Bi=i({is(t){return t.kind==="JSONPathLegNode"},create(t,e){return i({kind:"JSONPathLegNode",type:t,value:e})}});var mt=class{#e;constructor(e){this.#e=e}at(e){return this.#t("ArrayLocation",e)}key(e){return this.#t("Member",e)}#t(e,r){return tt.is(this.#e)?new Or(tt.cloneWithTraversal(this.#e,Re.is(this.#e.traversal)?Re.cloneWithLeg(this.#e.traversal,Bi.create(e,r)):Xt.cloneWithValue(this.#e.traversal,k.createImmediate(r)))):new Or(Re.cloneWithLeg(this.#e,Bi.create(e,r)))}},Or=class t extends mt{#e;constructor(e){super(e),this.#e=e}get expressionType(){}as(e){return new Li(this,e)}$castTo(){return new t(this.#e)}$notNull(){return new t(this.#e)}toOperationNode(){return this.#e}},Li=class{#e;#t;constructor(e,r){this.#e=e,this.#t=r}get expression(){return this.#e}get alias(){return this.#t}toOperationNode(){return I.create(this.#e.toOperationNode(),b(this.#t)?this.#t.toOperationNode():p.create(this.#t))}};var Qi=i({is(t){return t.kind==="TupleNode"},create(t){return i({kind:"TupleNode",values:i(t)})}});var Mn=["varchar","char","text","integer","int2","int4","int8","smallint","bigint","boolean","real","double precision","float4","float8","decimal","numeric","binary","bytea","date","datetime","time","timetz","timestamp","timestamptz","serial","bigserial","uuid","json","jsonb","blob","varbinary","int4range","int4multirange","int8range","int8multirange","numrange","nummultirange","tsrange","tsmultirange","tstzrange","tstzmultirange","daterange","datemultirange"],Fn=[/^varchar\(\d+\)$/,/^char\(\d+\)$/,/^decimal\(\d+, \d+\)$/,/^numeric\(\d+, \d+\)$/,/^binary\(\d+\)$/,/^datetime\(\d+\)$/,/^time\(\d+\)$/,/^timetz\(\d+\)$/,/^timestamp\(\d+\)$/,/^timestamptz\(\d+\)$/,/^varbinary\(\d+\)$/],zo=i({is(t){return t.kind==="DataTypeNode"},create(t){return i({kind:"DataTypeNode",dataType:t})}});function Vo(t){return!!(Mn.includes(t)||Fn.some(e=>e.test(t)))}function ue(t){if(b(t))return t.toOperationNode();if(Vo(t))return zo.create(t);throw new Error(`invalid column data type ${JSON.stringify(t)}`)}var Uo=i({is(t){return t.kind==="CastNode"},create(t,e){return i({kind:"CastNode",expression:t,dataType:e})}});function wr(t=Be){function e(n,a,d){return new w(er(n,a,d))}function r(n,a){return new w(Fo(n,a))}let o=Object.assign(e,{fn:void 0,eb:void 0,selectFrom(n){return Ft({queryId:m(),executor:t,queryNode:x.createFrom(ae(n))})},case(n){return new ht({node:_.create(j(n)?void 0:Q(n))})},ref(n,a){return j(a)?new w(X(n)):new mt(ho(n,a))},jsonPath(){return new mt(Re.create())},table(n){return new w(f(n))},val(n){return new w(g(n))},refTuple(...n){return new w(Qi.create(n.map(Q)))},tuple(...n){return new w(Qi.create(n.map(g)))},lit(n){return new w(qt(n))},unary:r,not(n){return r("not",n)},exists(n){return r("exists",n)},neg(n){return r("-",n)},between(n,a,d){return new w(Ee.create(Q(n),Y.create("between"),K.create(g(a),g(d))))},betweenSymmetric(n,a,d){return new w(Ee.create(Q(n),Y.create("between symmetric"),K.create(g(a),g(d))))},and(n){return F(n)?new w(it(n,"and")):new w(pi(n,"and"))},or(n){return F(n)?new w(it(n,"or")):new w(pi(n,"or"))},parens(...n){let a=O(n);return me.is(a)?new w(a):new w(me.create(a))},cast(n,a){return new w(Uo.create(Q(n),ue(a)))},withSchema(n){return wr(t.withPluginAtFront(new te(n)))}});return o.fn=xr(),o.eb=o,o}function ne(t){return wr()}function G(t){if(b(t))return t.toOperationNode();if(T(t))return t(ne()).toOperationNode();throw new Error(`invalid expression: ${JSON.stringify(t)}`)}function or(t){if(b(t))return t.toOperationNode();if(T(t))return t(ne()).toOperationNode();throw new Error(`invalid aliased expression: ${JSON.stringify(t)}`)}function xe(t){return Kt(t)||no(t)||T(t)}var br=class{#e;get table(){return this.#e}constructor(e){this.#e=e}as(e){return new Pi(this.#e,e)}},Pi=class{#e;#t;get table(){return this.#e}get alias(){return this.#t}constructor(e,r){this.#e=e,this.#t=r}toOperationNode(){return I.create(f(this.#e),p.create(this.#t))}};function Jo(t){return L(t)&&b(t)&&C(t.table)&&C(t.alias)}function ae(t){return F(t)?t.map(e=>$e(e)):[$e(t)]}function $e(t){return C(t)?Ti(t):Jo(t)?t.toOperationNode():or(t)}function Ti(t){let e=" as ";if(t.includes(e)){let[r,o]=t.split(e).map($o);return I.create(f(r),p.create(o))}else return f(t)}function f(t){let e=".";if(t.includes(e)){let[r,o]=t.split(e).map($o);return H.createWithSchema(r,o)}else return H.create(t)}function $o(t){return t.trim()}var Mi=i({is(t){return t.kind==="AddColumnNode"},create(t){return i({kind:"AddColumnNode",column:t})}});var v=i({is(t){return t.kind==="ColumnDefinitionNode"},create(t,e){return i({kind:"ColumnDefinitionNode",column:h.create(t),dataType:e})},cloneWithFrontModifier(t,e){return i({...t,frontModifiers:t.frontModifiers?i([...t.frontModifiers,e]):[e]})},cloneWithEndModifier(t,e){return i({...t,endModifiers:t.endModifiers?i([...t.endModifiers,e]):[e]})},cloneWith(t,e){return i({...t,...e})}});var Fi=i({is(t){return t.kind==="DropColumnNode"},create(t){return i({kind:"DropColumnNode",column:h.create(t)})}});var zi=i({is(t){return t.kind==="RenameColumnNode"},create(t,e){return i({kind:"RenameColumnNode",column:h.create(t),renameTo:h.create(e)})}});var lt=i({is(t){return t.kind==="CheckConstraintNode"},create(t,e){return i({kind:"CheckConstraintNode",expression:t,name:e?p.create(e):void 0})}});var Ko=["no action","restrict","cascade","set null","set default"],ft=i({is(t){return t.kind==="ReferencesNode"},create(t,e){return i({kind:"ReferencesNode",table:t,columns:i([...e])})},cloneWithOnDelete(t,e){return i({...t,onDelete:e})},cloneWithOnUpdate(t,e){return i({...t,onUpdate:e})}});function vr(t){return b(t)?t.toOperationNode():k.createImmediate(t)}var Vt=i({is(t){return t.kind==="GeneratedNode"},create(t){return i({kind:"GeneratedNode",...t})},createWithExpression(t){return i({kind:"GeneratedNode",always:!0,expression:t})},cloneWith(t,e){return i({...t,...e})}});var Go=i({is(t){return t.kind==="DefaultValueNode"},create(t){return i({kind:"DefaultValueNode",defaultValue:t})}});function Nt(t){if(Ko.includes(t))return t;throw new Error(`invalid OnModifyForeignAction ${t}`)}var ve=class t{#e;constructor(e){this.#e=e}autoIncrement(){return new t(v.cloneWith(this.#e,{autoIncrement:!0}))}identity(){return new t(v.cloneWith(this.#e,{identity:!0}))}primaryKey(){return new t(v.cloneWith(this.#e,{primaryKey:!0}))}references(e){let r=X(e);if(!r.table||_e.is(r.column))throw new Error(`invalid call references('${e}'). The reference must have format table.column or schema.table.column`);return new t(v.cloneWith(this.#e,{references:ft.create(r.table,[r.column])}))}onDelete(e){if(!this.#e.references)throw new Error("on delete constraint can only be added for foreign keys");return new t(v.cloneWith(this.#e,{references:ft.cloneWithOnDelete(this.#e.references,Nt(e))}))}onUpdate(e){if(!this.#e.references)throw new Error("on update constraint can only be added for foreign keys");return new t(v.cloneWith(this.#e,{references:ft.cloneWithOnUpdate(this.#e.references,Nt(e))}))}unique(){return new t(v.cloneWith(this.#e,{unique:!0}))}notNull(){return new t(v.cloneWith(this.#e,{notNull:!0}))}unsigned(){return new t(v.cloneWith(this.#e,{unsigned:!0}))}defaultTo(e){return new t(v.cloneWith(this.#e,{defaultTo:Go.create(vr(e))}))}check(e){return new t(v.cloneWith(this.#e,{check:lt.create(e.toOperationNode())}))}generatedAlwaysAs(e){return new t(v.cloneWith(this.#e,{generated:Vt.createWithExpression(e.toOperationNode())}))}generatedAlwaysAsIdentity(){return new t(v.cloneWith(this.#e,{generated:Vt.create({identity:!0,always:!0})}))}generatedByDefaultAsIdentity(){return new t(v.cloneWith(this.#e,{generated:Vt.create({identity:!0,byDefault:!0})}))}stored(){if(!this.#e.generated)throw new Error("stored() can only be called after generatedAlwaysAs");return new t(v.cloneWith(this.#e,{generated:Vt.cloneWith(this.#e.generated,{stored:!0})}))}modifyFront(e){return new t(v.cloneWithFrontModifier(this.#e,e.toOperationNode()))}nullsNotDistinct(){return new t(v.cloneWith(this.#e,{nullsNotDistinct:!0}))}ifNotExists(){return new t(v.cloneWith(this.#e,{ifNotExists:!0}))}modifyEnd(e){return new t(v.cloneWithEndModifier(this.#e,e.toOperationNode()))}$call(e){return e(this)}toOperationNode(){return this.#e}};var Vi=i({is(t){return t.kind==="ModifyColumnNode"},create(t){return i({kind:"ModifyColumnNode",column:t})}});var de=i({is(t){return t.kind==="ForeignKeyConstraintNode"},create(t,e,r,o){return i({kind:"ForeignKeyConstraintNode",columns:t,references:ft.create(e,r),name:o?p.create(o):void 0})},cloneWith(t,e){return i({...t,...e})}});var yt=class t{#e;constructor(e){this.#e=e}onDelete(e){return new t(de.cloneWith(this.#e,{onDelete:Nt(e)}))}onUpdate(e){return new t(de.cloneWith(this.#e,{onUpdate:Nt(e)}))}deferrable(){return new t(de.cloneWith(this.#e,{deferrable:!0}))}notDeferrable(){return new t(de.cloneWith(this.#e,{deferrable:!1}))}initiallyDeferred(){return new t(de.cloneWith(this.#e,{initiallyDeferred:!0}))}initiallyImmediate(){return new t(de.cloneWith(this.#e,{initiallyDeferred:!1}))}$call(e){return e(this)}toOperationNode(){return this.#e}};var wt=i({is(t){return t.kind==="AddConstraintNode"},create(t){return i({kind:"AddConstraintNode",constraint:t})}});var ye=i({is(t){return t.kind==="UniqueConstraintNode"},create(t,e,r){return i({kind:"UniqueConstraintNode",columns:i(t.map(h.create)),name:e?p.create(e):void 0,nullsNotDistinct:r})},cloneWith(t,e){return i({...t,...e})}});var xt=i({is(t){return t.kind==="DropConstraintNode"},create(t){return i({kind:"DropConstraintNode",constraintName:p.create(t)})},cloneWith(t,e){return i({...t,...e})}});var gt=i({is(t){return t.kind==="AlterColumnNode"},create(t,e,r){return i({kind:"AlterColumnNode",column:h.create(t),[e]:r})}});var Ut=class{#e;constructor(e){this.#e=e}setDataType(e){return new Ge(gt.create(this.#e,"dataType",ue(e)))}setDefault(e){return new Ge(gt.create(this.#e,"setDefault",vr(e)))}dropDefault(){return new Ge(gt.create(this.#e,"dropDefault",!0))}setNotNull(){return new Ge(gt.create(this.#e,"setNotNull",!0))}dropNotNull(){return new Ge(gt.create(this.#e,"dropNotNull",!0))}$call(e){return e(this)}},Ge=class{#e;constructor(e){this.#e=e}toOperationNode(){return this.#e}};var Ce=class{#e;constructor(e){this.#e=i(e)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Cr=class t{#e;constructor(e){this.#e=i(e)}onDelete(e){return new t({...this.#e,constraintBuilder:this.#e.constraintBuilder.onDelete(e)})}onUpdate(e){return new t({...this.#e,constraintBuilder:this.#e.constraintBuilder.onUpdate(e)})}deferrable(){return new t({...this.#e,constraintBuilder:this.#e.constraintBuilder.deferrable()})}notDeferrable(){return new t({...this.#e,constraintBuilder:this.#e.constraintBuilder.notDeferrable()})}initiallyDeferred(){return new t({...this.#e,constraintBuilder:this.#e.constraintBuilder.initiallyDeferred()})}initiallyImmediate(){return new t({...this.#e,constraintBuilder:this.#e.constraintBuilder.initiallyImmediate()})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(l.cloneWithTableProps(this.#e.node,{addConstraint:wt.create(this.#e.constraintBuilder.toOperationNode())}),this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Jt=class t{#e;constructor(e){this.#e=i(e)}ifExists(){return new t({...this.#e,node:l.cloneWithTableProps(this.#e.node,{dropConstraint:xt.cloneWith(this.#e.node.dropConstraint,{ifExists:!0})})})}cascade(){return new t({...this.#e,node:l.cloneWithTableProps(this.#e.node,{dropConstraint:xt.cloneWith(this.#e.node.dropConstraint,{modifier:"cascade"})})})}restrict(){return new t({...this.#e,node:l.cloneWithTableProps(this.#e.node,{dropConstraint:xt.cloneWith(this.#e.node.dropConstraint,{modifier:"restrict"})})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var We=i({is(t){return t.kind==="PrimaryKeyConstraintNode"},create(t,e){return i({kind:"PrimaryKeyConstraintNode",columns:i(t.map(h.create)),name:e?p.create(e):void 0})},cloneWith(t,e){return i({...t,...e})}});var Qe=i({is(t){return t.kind==="AddIndexNode"},create(t){return i({kind:"AddIndexNode",name:p.create(t)})},cloneWith(t,e){return i({...t,...e})},cloneWithColumns(t,e){return i({...t,columns:[...t.columns||[],...e]})}});var Wr=class t{#e;constructor(e){this.#e=i(e)}unique(){return new t({...this.#e,node:l.cloneWithTableProps(this.#e.node,{addIndex:Qe.cloneWith(this.#e.node.addIndex,{unique:!0})})})}column(e){return new t({...this.#e,node:l.cloneWithTableProps(this.#e.node,{addIndex:Qe.cloneWithColumns(this.#e.node.addIndex,[rt(e)])})})}columns(e){return new t({...this.#e,node:l.cloneWithTableProps(this.#e.node,{addIndex:Qe.cloneWithColumns(this.#e.node.addIndex,e.map(rt))})})}expression(e){return new t({...this.#e,node:l.cloneWithTableProps(this.#e.node,{addIndex:Qe.cloneWithColumns(this.#e.node.addIndex,[e.toOperationNode()])})})}using(e){return new t({...this.#e,node:l.cloneWithTableProps(this.#e.node,{addIndex:Qe.cloneWith(this.#e.node.addIndex,{using:W.createWithSql(e)})})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Ot=class t{#e;constructor(e){this.#e=e}nullsNotDistinct(){return new t(ye.cloneWith(this.#e,{nullsNotDistinct:!0}))}deferrable(){return new t(ye.cloneWith(this.#e,{deferrable:!0}))}notDeferrable(){return new t(ye.cloneWith(this.#e,{deferrable:!1}))}initiallyDeferred(){return new t(ye.cloneWith(this.#e,{initiallyDeferred:!0}))}initiallyImmediate(){return new t(ye.cloneWith(this.#e,{initiallyDeferred:!1}))}$call(e){return e(this)}toOperationNode(){return this.#e}};var bt=class t{#e;constructor(e){this.#e=e}deferrable(){return new t(We.cloneWith(this.#e,{deferrable:!0}))}notDeferrable(){return new t(We.cloneWith(this.#e,{deferrable:!1}))}initiallyDeferred(){return new t(We.cloneWith(this.#e,{initiallyDeferred:!0}))}initiallyImmediate(){return new t(We.cloneWith(this.#e,{initiallyDeferred:!1}))}$call(e){return e(this)}toOperationNode(){return this.#e}};var vt=class{#e;constructor(e){this.#e=e}$call(e){return e(this)}toOperationNode(){return this.#e}};var jo=i({is(t){return t.kind==="RenameConstraintNode"},create(t,e){return i({kind:"RenameConstraintNode",oldName:p.create(t),newName:p.create(e)})}});var Tr=class{#e;constructor(e){this.#e=i(e)}renameTo(e){return new Ce({...this.#e,node:l.cloneWithTableProps(this.#e.node,{renameTo:f(e)})})}setSchema(e){return new Ce({...this.#e,node:l.cloneWithTableProps(this.#e.node,{setSchema:p.create(e)})})}alterColumn(e,r){let o=r(new Ut(e));return new je({...this.#e,node:l.cloneWithColumnAlteration(this.#e.node,o.toOperationNode())})}dropColumn(e){return new je({...this.#e,node:l.cloneWithColumnAlteration(this.#e.node,Fi.create(e))})}renameColumn(e,r){return new je({...this.#e,node:l.cloneWithColumnAlteration(this.#e.node,zi.create(e,r))})}addColumn(e,r,o=U){let n=o(new ve(v.create(e,ue(r))));return new je({...this.#e,node:l.cloneWithColumnAlteration(this.#e.node,Mi.create(n.toOperationNode()))})}modifyColumn(e,r,o=U){let n=o(new ve(v.create(e,ue(r))));return new je({...this.#e,node:l.cloneWithColumnAlteration(this.#e.node,Vi.create(n.toOperationNode()))})}addUniqueConstraint(e,r,o=U){let n=o(new Ot(ye.create(r,e)));return new Ce({...this.#e,node:l.cloneWithTableProps(this.#e.node,{addConstraint:wt.create(n.toOperationNode())})})}addCheckConstraint(e,r,o=U){let n=o(new vt(lt.create(r.toOperationNode(),e)));return new Ce({...this.#e,node:l.cloneWithTableProps(this.#e.node,{addConstraint:wt.create(n.toOperationNode())})})}addForeignKeyConstraint(e,r,o,n,a=U){let d=a(new yt(de.create(r.map(h.create),f(o),n.map(h.create),e)));return new Cr({...this.#e,constraintBuilder:d})}addPrimaryKeyConstraint(e,r,o=U){let n=o(new bt(We.create(r,e)));return new Ce({...this.#e,node:l.cloneWithTableProps(this.#e.node,{addConstraint:wt.create(n.toOperationNode())})})}dropConstraint(e){return new Jt({...this.#e,node:l.cloneWithTableProps(this.#e.node,{dropConstraint:xt.create(e)})})}renameConstraint(e,r){return new Jt({...this.#e,node:l.cloneWithTableProps(this.#e.node,{renameConstraint:jo.create(e,r)})})}addIndex(e){return new Wr({...this.#e,node:l.cloneWithTableProps(this.#e.node,{addIndex:Qe.create(e)})})}dropIndex(e){return new Ce({...this.#e,node:l.cloneWithTableProps(this.#e.node,{dropIndex:ke.create(e)})})}$call(e){return e(this)}},je=class t{#e;constructor(e){this.#e=i(e)}alterColumn(e,r){let o=r(new Ut(e));return new t({...this.#e,node:l.cloneWithColumnAlteration(this.#e.node,o.toOperationNode())})}dropColumn(e){return new t({...this.#e,node:l.cloneWithColumnAlteration(this.#e.node,Fi.create(e))})}renameColumn(e,r){return new t({...this.#e,node:l.cloneWithColumnAlteration(this.#e.node,zi.create(e,r))})}addColumn(e,r,o=U){let n=o(new ve(v.create(e,ue(r))));return new t({...this.#e,node:l.cloneWithColumnAlteration(this.#e.node,Mi.create(n.toOperationNode()))})}modifyColumn(e,r,o=U){let n=o(new ve(v.create(e,ue(r))));return new t({...this.#e,node:l.cloneWithColumnAlteration(this.#e.node,Vi.create(n.toOperationNode()))})}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Ct=class extends qe{transformPrimitiveValueList(e){return he.create(e.values.map(k.createImmediate))}transformValue(e){return k.createImmediate(e.value)}};var Sr=class t{#e;constructor(e){this.#e=i(e)}ifNotExists(){return new t({...this.#e,node:re.cloneWith(this.#e.node,{ifNotExists:!0})})}unique(){return new t({...this.#e,node:re.cloneWith(this.#e.node,{unique:!0})})}nullsNotDistinct(){return new t({...this.#e,node:re.cloneWith(this.#e.node,{nullsNotDistinct:!0})})}on(e){return new t({...this.#e,node:re.cloneWith(this.#e.node,{table:f(e)})})}column(e){return new t({...this.#e,node:re.cloneWithColumns(this.#e.node,[rt(e)])})}columns(e){return new t({...this.#e,node:re.cloneWithColumns(this.#e.node,e.map(rt))})}expression(e){return new t({...this.#e,node:re.cloneWithColumns(this.#e.node,[e.toOperationNode()])})}using(e){return new t({...this.#e,node:re.cloneWith(this.#e.node,{using:W.createWithSql(e)})})}where(...e){let r=new Ct;return new t({...this.#e,node:u.cloneWithWhere(this.#e.node,r.transformNode(O(e),this.#e.queryId))})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var kr=class t{#e;constructor(e){this.#e=i(e)}ifNotExists(){return new t({...this.#e,node:$t.cloneWith(this.#e.node,{ifNotExists:!0})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};function Ho(t){if(oo.includes(t))return t;throw new Error(`invalid OnCommitAction ${t}`)}var Er=class t{#e;constructor(e){this.#e=i(e)}temporary(){return new t({...this.#e,node:z.cloneWith(this.#e.node,{temporary:!0})})}onCommit(e){return new t({...this.#e,node:z.cloneWith(this.#e.node,{onCommit:Ho(e)})})}ifNotExists(){return new t({...this.#e,node:z.cloneWith(this.#e.node,{ifNotExists:!0})})}addColumn(e,r,o=U){let n=o(new ve(v.create(e,ue(r))));return new t({...this.#e,node:z.cloneWithColumn(this.#e.node,n.toOperationNode())})}addPrimaryKeyConstraint(e,r,o=U){let n=o(new bt(We.create(r,e)));return new t({...this.#e,node:z.cloneWithConstraint(this.#e.node,n.toOperationNode())})}addUniqueConstraint(e,r,o=U){let n=o(new Ot(ye.create(r,e)));return new t({...this.#e,node:z.cloneWithConstraint(this.#e.node,n.toOperationNode())})}addCheckConstraint(e,r,o=U){let n=o(new vt(lt.create(r.toOperationNode(),e)));return new t({...this.#e,node:z.cloneWithConstraint(this.#e.node,n.toOperationNode())})}addForeignKeyConstraint(e,r,o,n,a=U){let d=a(new yt(de.create(r.map(h.create),f(o),n.map(h.create),e)));return new t({...this.#e,node:z.cloneWithConstraint(this.#e.node,d.toOperationNode())})}modifyFront(e){return new t({...this.#e,node:z.cloneWithFrontModifier(this.#e.node,e.toOperationNode())})}modifyEnd(e){return new t({...this.#e,node:z.cloneWithEndModifier(this.#e.node,e.toOperationNode())})}as(e){return new t({...this.#e,node:z.cloneWith(this.#e.node,{selectQuery:G(e)})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Ar=class t{#e;constructor(e){this.#e=i(e)}on(e){return new t({...this.#e,node:ke.cloneWith(this.#e.node,{table:f(e)})})}ifExists(){return new t({...this.#e,node:ke.cloneWith(this.#e.node,{ifExists:!0})})}cascade(){return new t({...this.#e,node:ke.cloneWith(this.#e.node,{cascade:!0})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Rr=class t{#e;constructor(e){this.#e=i(e)}ifExists(){return new t({...this.#e,node:It.cloneWith(this.#e.node,{ifExists:!0})})}cascade(){return new t({...this.#e,node:It.cloneWith(this.#e.node,{cascade:!0})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Ir=class t{#e;constructor(e){this.#e=i(e)}ifExists(){return new t({...this.#e,node:Dt.cloneWith(this.#e.node,{ifExists:!0})})}cascade(){return new t({...this.#e,node:Dt.cloneWith(this.#e.node,{cascade:!0})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var pe=i({is(t){return t.kind==="CreateViewNode"},create(t){return i({kind:"CreateViewNode",name:V.create(t)})},cloneWith(t,e){return i({...t,...e})}});var Dr=class{#e=new Ct;transformQuery(e){return this.#e.transformNode(e.node,e.queryId)}transformResult(e){return Promise.resolve(e.result)}};var qr=class t{#e;constructor(e){this.#e=i(e)}temporary(){return new t({...this.#e,node:pe.cloneWith(this.#e.node,{temporary:!0})})}materialized(){return new t({...this.#e,node:pe.cloneWith(this.#e.node,{materialized:!0})})}ifNotExists(){return new t({...this.#e,node:pe.cloneWith(this.#e.node,{ifNotExists:!0})})}orReplace(){return new t({...this.#e,node:pe.cloneWith(this.#e.node,{orReplace:!0})})}columns(e){return new t({...this.#e,node:pe.cloneWith(this.#e.node,{columns:e.map(ai)})})}as(e){let r=e.withPlugin(new Dr).toOperationNode();return new t({...this.#e,node:pe.cloneWith(this.#e.node,{as:r})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Wt=i({is(t){return t.kind==="DropViewNode"},create(t){return i({kind:"DropViewNode",name:V.create(t)})},cloneWith(t,e){return i({...t,...e})}});var Br=class t{#e;constructor(e){this.#e=i(e)}materialized(){return new t({...this.#e,node:Wt.cloneWith(this.#e.node,{materialized:!0})})}ifExists(){return new t({...this.#e,node:Wt.cloneWith(this.#e.node,{ifExists:!0})})}cascade(){return new t({...this.#e,node:Wt.cloneWith(this.#e.node,{cascade:!0})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Lr=i({is(t){return t.kind==="CreateTypeNode"},create(t){return i({kind:"CreateTypeNode",name:t})},cloneWithEnum(t,e){return i({...t,enum:he.create(e.map(k.createImmediate))})}});var Qr=class t{#e;constructor(e){this.#e=i(e)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}asEnum(e){return new t({...this.#e,node:Lr.cloneWithEnum(this.#e.node,e)})}$call(e){return e(this)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Pr=i({is(t){return t.kind==="DropTypeNode"},create(t){return i({kind:"DropTypeNode",name:t})},cloneWith(t,e){return i({...t,...e})}});var Mr=class t{#e;constructor(e){this.#e=i(e)}ifExists(){return new t({...this.#e,node:Pr.cloneWith(this.#e.node,{ifExists:!0})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};function Ui(t){let e=".";if(t.includes(e)){let r=t.split(e).map(zn);if(r.length===2)return V.createWithSchema(r[0],r[1]);throw new Error(`invalid schemable identifier ${t}`)}else return V.create(t)}function zn(t){return t.trim()}var Tt=i({is(t){return t.kind==="RefreshMaterializedViewNode"},create(t){return i({kind:"RefreshMaterializedViewNode",name:V.create(t)})},cloneWith(t,e){return i({...t,...e})}});var Fr=class t{#e;constructor(e){this.#e=i(e)}concurrently(){return new t({...this.#e,node:Tt.cloneWith(this.#e.node,{concurrently:!0,withNoData:!1})})}withData(){return new t({...this.#e,node:Tt.cloneWith(this.#e.node,{withNoData:!1})})}withNoData(){return new t({...this.#e,node:Tt.cloneWith(this.#e.node,{withNoData:!0,concurrently:!1})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var zr=class t{#e;constructor(e){this.#e=e}createTable(e){return new Er({queryId:m(),executor:this.#e,node:z.create(f(e))})}dropTable(e){return new Ir({queryId:m(),executor:this.#e,node:Dt.create(f(e))})}createIndex(e){return new Sr({queryId:m(),executor:this.#e,node:re.create(e)})}dropIndex(e){return new Ar({queryId:m(),executor:this.#e,node:ke.create(e)})}createSchema(e){return new kr({queryId:m(),executor:this.#e,node:$t.create(e)})}dropSchema(e){return new Rr({queryId:m(),executor:this.#e,node:It.create(e)})}alterTable(e){return new Tr({queryId:m(),executor:this.#e,node:l.create(f(e))})}createView(e){return new qr({queryId:m(),executor:this.#e,node:pe.create(e)})}refreshMaterializedView(e){return new Fr({queryId:m(),executor:this.#e,node:Tt.create(e)})}dropView(e){return new Br({queryId:m(),executor:this.#e,node:Wt.create(e)})}createType(e){return new Qr({queryId:m(),executor:this.#e,node:Lr.create(Ui(e))})}dropType(e){return new Mr({queryId:m(),executor:this.#e,node:Pr.create(Ui(e))})}withPlugin(e){return new t(this.#e.withPlugin(e))}withoutPlugins(){return new t(this.#e.withoutPlugins())}withSchema(e){return new t(this.#e.withPluginAtFront(new te(e)))}};var Vr=class{ref(e){return new jt(e)}table(e){return new br(e)}};var Ur=class{#e;constructor(e){this.#e=e}async provideConnection(e){let r=await this.#e.acquireConnection();try{return await e(r)}finally{await this.#e.releaseConnection(r)}}};var Jr=class t extends dt{#e;#t;#r;constructor(e,r,o,n=[]){super(n),this.#e=e,this.#t=r,this.#r=o}get adapter(){return this.#t}compileQuery(e,r){return this.#e.compileQuery(e,r)}provideConnection(e){return this.#r.provideConnection(e)}withPlugins(e){return new t(this.#e,this.#t,this.#r,[...this.plugins,...e])}withPlugin(e){return new t(this.#e,this.#t,this.#r,[...this.plugins,e])}withPluginAtFront(e){return new t(this.#e,this.#t,this.#r,[e,...this.plugins])}withConnectionProvider(e){return new t(this.#e,this.#t,e,[...this.plugins])}withoutPlugins(){return new t(this.#e,this.#t,this.#r,[])}};function $r(){return typeof performance<"u"&&T(performance.now)?performance.now():Date.now()}var Kr=class{#e;#t;#r;#i;#o;#a=new WeakSet;constructor(e,r){this.#i=!1,this.#e=e,this.#t=r}async init(){if(this.#o)throw new Error("driver has already been destroyed");this.#r||(this.#r=this.#e.init().then(()=>{this.#i=!0}).catch(e=>(this.#r=void 0,Promise.reject(e)))),await this.#r}async acquireConnection(){if(this.#o)throw new Error("driver has already been destroyed");this.#i||await this.init();let e=await this.#e.acquireConnection();return this.#a.has(e)||(this.#d()&&this.#n(e),this.#a.add(e)),e}async releaseConnection(e){await this.#e.releaseConnection(e)}beginTransaction(e,r){return this.#e.beginTransaction(e,r)}commitTransaction(e){return this.#e.commitTransaction(e)}rollbackTransaction(e){return this.#e.rollbackTransaction(e)}savepoint(e,r,o){if(this.#e.savepoint)return this.#e.savepoint(e,r,o);throw new Error("The `savepoint` method is not supported by this driver")}rollbackToSavepoint(e,r,o){if(this.#e.rollbackToSavepoint)return this.#e.rollbackToSavepoint(e,r,o);throw new Error("The `rollbackToSavepoint` method is not supported by this driver")}releaseSavepoint(e,r,o){if(this.#e.releaseSavepoint)return this.#e.releaseSavepoint(e,r,o);throw new Error("The `releaseSavepoint` method is not supported by this driver")}async destroy(){this.#r&&(await this.#r,this.#o||(this.#o=this.#e.destroy().catch(e=>(this.#o=void 0,Promise.reject(e)))),await this.#o)}#d(){return this.#t.isLevelEnabled("query")||this.#t.isLevelEnabled("error")}#n(e){let r=e.executeQuery,o=e.streamQuery,n=this;e.executeQuery=async a=>{let d,c=$r();try{return await r.call(e,a)}catch(N){throw d=N,await n.#s(N,a,c),N}finally{d||await n.#u(a,c)}},e.streamQuery=async function*(a,d){let c,N=$r();try{for await(let y of o.call(e,a,d))yield y}catch(y){throw c=y,await n.#s(y,a,N),y}finally{c||await n.#u(a,N,!0)}}}async#s(e,r,o){await this.#t.error(()=>({level:"error",error:e,query:r,queryDurationMillis:this.#p(o)}))}async#u(e,r,o=!1){await this.#t.query(()=>({level:"query",isStream:o,query:e,queryDurationMillis:this.#p(r)}))}#p(e){return $r()-e}};var Vn=()=>{},St=class{#e;#t;constructor(e){this.#e=e}async provideConnection(e){for(;this.#t;)await this.#t.catch(Vn);return this.#t=this.#r(e).finally(()=>{this.#t=void 0}),this.#t}async#r(e){return await e(this.#e)}};var Un=["read only","read write"],Jn=["read uncommitted","read committed","repeatable read","serializable","snapshot"];function Ji(t){if(t.accessMode&&!Un.includes(t.accessMode))throw new Error(`invalid transaction access mode ${t.accessMode}`);if(t.isolationLevel&&!Jn.includes(t.isolationLevel))throw new Error(`invalid transaction isolation level ${t.isolationLevel}`)}var VC=i(["query","error"]),Gr=class{#e;#t;constructor(e){T(e)?(this.#t=e,this.#e=i({query:!0,error:!0})):(this.#t=$n,this.#e=i({query:e.includes("query"),error:e.includes("error")}))}isLevelEnabled(e){return this.#e[e]}async query(e){this.#e.query&&await this.#t(e())}async error(e){this.#e.error&&await this.#t(e())}};function $n(t){if(t.level==="query"){let e=`kysely:query:${t.isStream?"stream:":""}`;console.log(`${e} ${t.query.sql}`),console.log(`${e} duration: ${t.queryDurationMillis.toFixed(1)}ms`)}else t.level==="error"&&(t.error instanceof Error?console.error(`kysely:error: ${t.error.stack??t.error.message}`):console.error(`kysely:error: ${JSON.stringify({error:t.error,query:t.query.sql,queryDurationMillis:t.queryDurationMillis})}`))}function Yo(t){return L(t)&&T(t.compile)}Symbol.asyncDispose??=Symbol("Symbol.asyncDispose");var kt=class t extends pt{#e;constructor(e){let r,o;if(Kn(e))r={executor:e.executor},o={...e};else{let n=e.dialect,a=n.createDriver(),d=n.createQueryCompiler(),c=n.createAdapter(),N=new Gr(e.log??[]),y=new Kr(a,N),R=new Ur(y),E=new Jr(d,c,R,e.plugins??[]);r={executor:E},o={config:e,executor:E,dialect:n,driver:y}}super(r),this.#e=i(o)}get schema(){return new zr(this.#e.executor)}get dynamic(){return new Vr}get introspection(){return this.#e.dialect.createIntrospector(this.withoutPlugins())}case(e){return new ht({node:_.create(j(e)?void 0:G(e))})}get fn(){return xr()}transaction(){return new Ki({...this.#e})}startTransaction(){return new Gi({...this.#e})}connection(){return new $i({...this.#e})}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}withoutPlugins(){return new t({...this.#e,executor:this.#e.executor.withoutPlugins()})}withSchema(e){return new t({...this.#e,executor:this.#e.executor.withPluginAtFront(new te(e))})}withTables(){return new t({...this.#e})}async destroy(){await this.#e.driver.destroy()}get isTransaction(){return!1}getExecutor(){return this.#e.executor}executeQuery(e,r=m()){let o=Yo(e)?e.compile():e;return this.getExecutor().executeQuery(o,r)}async[Symbol.asyncDispose](){await this.destroy()}},jr=class t extends kt{#e;constructor(e){super(e),this.#e=e}get isTransaction(){return!0}transaction(){throw new Error("calling the transaction method for a Transaction is not supported")}connection(){throw new Error("calling the connection method for a Transaction is not supported")}async destroy(){throw new Error("calling the destroy method for a Transaction is not supported")}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}withoutPlugins(){return new t({...this.#e,executor:this.#e.executor.withoutPlugins()})}withSchema(e){return new t({...this.#e,executor:this.#e.executor.withPluginAtFront(new te(e))})}withTables(){return new t({...this.#e})}};function Kn(t){return L(t)&&L(t.config)&&L(t.driver)&&L(t.executor)&&L(t.dialect)}var $i=class{#e;constructor(e){this.#e=i(e)}async execute(e){return this.#e.executor.provideConnection(async r=>{let o=this.#e.executor.withConnectionProvider(new St(r)),n=new kt({...this.#e,executor:o});return await e(n)})}},Ki=class t{#e;constructor(e){this.#e=i(e)}setAccessMode(e){return new t({...this.#e,accessMode:e})}setIsolationLevel(e){return new t({...this.#e,isolationLevel:e})}async execute(e){let{isolationLevel:r,accessMode:o,...n}=this.#e,a={isolationLevel:r,accessMode:o};return Ji(a),this.#e.executor.provideConnection(async d=>{let c=this.#e.executor.withConnectionProvider(new St(d)),N=new jr({...n,executor:c});try{await this.#e.driver.beginTransaction(d,a);let y=await e(N);return await this.#e.driver.commitTransaction(d),y}catch(y){throw await this.#e.driver.rollbackTransaction(d),y}})}},Gi=class t{#e;constructor(e){this.#e=i(e)}setAccessMode(e){return new t({...this.#e,accessMode:e})}setIsolationLevel(e){return new t({...this.#e,isolationLevel:e})}async execute(){let{isolationLevel:e,accessMode:r,...o}=this.#e,n={isolationLevel:e,accessMode:r};Ji(n);let a=await mr(this.#e.executor);return await this.#e.driver.beginTransaction(a.connection,n),new ji({...o,connection:a,executor:this.#e.executor.withConnectionProvider(new St(a.connection))})}},ji=class t extends jr{#e;#t;#r;constructor(e){let r={isCommitted:!1,isRolledBack:!1};e={...e,executor:new Hi(e.executor,r)};let{connection:o,...n}=e;super(n),this.#e=i(e),this.#r=r;let a=m();this.#t=d=>e.executor.compileQuery(d,a)}get isCommitted(){return this.#r.isCommitted}get isRolledBack(){return this.#r.isRolledBack}commit(){return Ye(this.#r),new He(async()=>{await this.#e.driver.commitTransaction(this.#e.connection.connection),this.#r.isCommitted=!0,this.#e.connection.release()})}rollback(){return Ye(this.#r),new He(async()=>{await this.#e.driver.rollbackTransaction(this.#e.connection.connection),this.#r.isRolledBack=!0,this.#e.connection.release()})}savepoint(e){return Ye(this.#r),new He(async()=>(await this.#e.driver.savepoint?.(this.#e.connection.connection,e,this.#t),new t({...this.#e})))}rollbackToSavepoint(e){return Ye(this.#r),new He(async()=>(await this.#e.driver.rollbackToSavepoint?.(this.#e.connection.connection,e,this.#t),new t({...this.#e})))}releaseSavepoint(e){return Ye(this.#r),new He(async()=>(await this.#e.driver.releaseSavepoint?.(this.#e.connection.connection,e,this.#t),new t({...this.#e})))}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}withoutPlugins(){return new t({...this.#e,executor:this.#e.executor.withoutPlugins()})}withSchema(e){return new t({...this.#e,executor:this.#e.executor.withPluginAtFront(new te(e))})}withTables(){return new t({...this.#e})}},He=class{#e;constructor(e){this.#e=e}async execute(){return await this.#e()}};function Ye(t){if(t.isCommitted)throw new Error("Transaction is already committed");if(t.isRolledBack)throw new Error("Transaction is already rolled back")}var Hi=class t{#e;#t;constructor(e,r){e instanceof t?this.#e=e.#e:this.#e=e,this.#t=r}get adapter(){return this.#e.adapter}get plugins(){return this.#e.plugins}transformQuery(e,r){return this.#e.transformQuery(e,r)}compileQuery(e,r){return this.#e.compileQuery(e,r)}provideConnection(e){return this.#e.provideConnection(e)}executeQuery(e,r){return Ye(this.#t),this.#e.executeQuery(e,r)}stream(e,r,o){return Ye(this.#t),this.#e.stream(e,r,o)}withConnectionProvider(e){return new t(this.#e.withConnectionProvider(e),this.#t)}withPlugin(e){return new t(this.#e.withPlugin(e),this.#t)}withPlugins(e){return new t(this.#e.withPlugins(e),this.#t)}withPluginAtFront(e){return new t(this.#e.withPluginAtFront(e),this.#t)}withoutPlugins(){return new t(this.#e.withoutPlugins(),this.#t)}};var Yi=class t{#e;constructor(e){this.#e=i(e)}get expressionType(){}get isRawBuilder(){return!0}as(e){return new Xi(this,e)}$castTo(){return new t({...this.#e})}$notNull(){return new t(this.#e)}withPlugin(e){return new t({...this.#e,plugins:this.#e.plugins!==void 0?i([...this.#e.plugins,e]):i([e])})}toOperationNode(){return this.#r(this.#t())}compile(e){return this.#i(this.#t(e))}async execute(e){let r=this.#t(e);return r.executeQuery(this.#i(r),this.#e.queryId)}#t(e){let r=e!==void 0?e.getExecutor():Be;return this.#e.plugins!==void 0?r.withPlugins(this.#e.plugins):r}#r(e){return e.transformQuery(this.#e.rawNode,this.#e.queryId)}#i(e){return e.compileQuery(this.#r(e),this.#e.queryId)}};function Te(t){return new Yi(t)}var Xi=class{#e;#t;constructor(e,r){this.#e=e,this.#t=r}get expression(){return this.#e}get alias(){return this.#t}get rawBuilder(){return this.#e}toOperationNode(){return I.create(this.#e.toOperationNode(),b(this.#t)?this.#t.toOperationNode():p.create(this.#t))}};var $=Object.assign((t,...e)=>Te({queryId:m(),rawNode:W.create(t,e?.map(Xo)??[])}),{ref(t){return Te({queryId:m(),rawNode:W.createWithChild(X(t))})},val(t){return Te({queryId:m(),rawNode:W.createWithChild(g(t))})},value(t){return this.val(t)},table(t){return Te({queryId:m(),rawNode:W.createWithChild(f(t))})},id(...t){let e=new Array(t.length+1).fill(".");return e[0]="",e[e.length-1]="",Te({queryId:m(),rawNode:W.create(e,t.map(p.create))})},lit(t){return Te({queryId:m(),rawNode:W.createWithChild(k.createImmediate(t))})},literal(t){return this.lit(t)},raw(t){return Te({queryId:m(),rawNode:W.createWithSql(t)})},join(t,e=$`, `){let r=new Array(Math.max(2*t.length-1,0)),o=e.toOperationNode();for(let n=0;n<t.length;++n)r[2*n]=Xo(t[n]),n!==t.length-1&&(r[2*n+1]=o);return Te({queryId:m(),rawNode:W.createWithChildren(r)})}});function Xo(t){return b(t)?t.toOperationNode():g(t)}var Hr=class{nodeStack=[];get parentNode(){return this.nodeStack[this.nodeStack.length-2]}#e=i({AliasNode:this.visitAlias.bind(this),ColumnNode:this.visitColumn.bind(this),IdentifierNode:this.visitIdentifier.bind(this),SchemableIdentifierNode:this.visitSchemableIdentifier.bind(this),RawNode:this.visitRaw.bind(this),ReferenceNode:this.visitReference.bind(this),SelectQueryNode:this.visitSelectQuery.bind(this),SelectionNode:this.visitSelection.bind(this),TableNode:this.visitTable.bind(this),FromNode:this.visitFrom.bind(this),SelectAllNode:this.visitSelectAll.bind(this),AndNode:this.visitAnd.bind(this),OrNode:this.visitOr.bind(this),ValueNode:this.visitValue.bind(this),ValueListNode:this.visitValueList.bind(this),PrimitiveValueListNode:this.visitPrimitiveValueList.bind(this),ParensNode:this.visitParens.bind(this),JoinNode:this.visitJoin.bind(this),OperatorNode:this.visitOperator.bind(this),WhereNode:this.visitWhere.bind(this),InsertQueryNode:this.visitInsertQuery.bind(this),DeleteQueryNode:this.visitDeleteQuery.bind(this),ReturningNode:this.visitReturning.bind(this),CreateTableNode:this.visitCreateTable.bind(this),AddColumnNode:this.visitAddColumn.bind(this),ColumnDefinitionNode:this.visitColumnDefinition.bind(this),DropTableNode:this.visitDropTable.bind(this),DataTypeNode:this.visitDataType.bind(this),OrderByNode:this.visitOrderBy.bind(this),OrderByItemNode:this.visitOrderByItem.bind(this),GroupByNode:this.visitGroupBy.bind(this),GroupByItemNode:this.visitGroupByItem.bind(this),UpdateQueryNode:this.visitUpdateQuery.bind(this),ColumnUpdateNode:this.visitColumnUpdate.bind(this),LimitNode:this.visitLimit.bind(this),OffsetNode:this.visitOffset.bind(this),OnConflictNode:this.visitOnConflict.bind(this),OnDuplicateKeyNode:this.visitOnDuplicateKey.bind(this),CreateIndexNode:this.visitCreateIndex.bind(this),DropIndexNode:this.visitDropIndex.bind(this),ListNode:this.visitList.bind(this),PrimaryKeyConstraintNode:this.visitPrimaryKeyConstraint.bind(this),UniqueConstraintNode:this.visitUniqueConstraint.bind(this),ReferencesNode:this.visitReferences.bind(this),CheckConstraintNode:this.visitCheckConstraint.bind(this),WithNode:this.visitWith.bind(this),CommonTableExpressionNode:this.visitCommonTableExpression.bind(this),CommonTableExpressionNameNode:this.visitCommonTableExpressionName.bind(this),HavingNode:this.visitHaving.bind(this),CreateSchemaNode:this.visitCreateSchema.bind(this),DropSchemaNode:this.visitDropSchema.bind(this),AlterTableNode:this.visitAlterTable.bind(this),DropColumnNode:this.visitDropColumn.bind(this),RenameColumnNode:this.visitRenameColumn.bind(this),AlterColumnNode:this.visitAlterColumn.bind(this),ModifyColumnNode:this.visitModifyColumn.bind(this),AddConstraintNode:this.visitAddConstraint.bind(this),DropConstraintNode:this.visitDropConstraint.bind(this),RenameConstraintNode:this.visitRenameConstraint.bind(this),ForeignKeyConstraintNode:this.visitForeignKeyConstraint.bind(this),CreateViewNode:this.visitCreateView.bind(this),RefreshMaterializedViewNode:this.visitRefreshMaterializedView.bind(this),DropViewNode:this.visitDropView.bind(this),GeneratedNode:this.visitGenerated.bind(this),DefaultValueNode:this.visitDefaultValue.bind(this),OnNode:this.visitOn.bind(this),ValuesNode:this.visitValues.bind(this),SelectModifierNode:this.visitSelectModifier.bind(this),CreateTypeNode:this.visitCreateType.bind(this),DropTypeNode:this.visitDropType.bind(this),ExplainNode:this.visitExplain.bind(this),DefaultInsertValueNode:this.visitDefaultInsertValue.bind(this),AggregateFunctionNode:this.visitAggregateFunction.bind(this),OverNode:this.visitOver.bind(this),PartitionByNode:this.visitPartitionBy.bind(this),PartitionByItemNode:this.visitPartitionByItem.bind(this),SetOperationNode:this.visitSetOperation.bind(this),BinaryOperationNode:this.visitBinaryOperation.bind(this),UnaryOperationNode:this.visitUnaryOperation.bind(this),UsingNode:this.visitUsing.bind(this),FunctionNode:this.visitFunction.bind(this),CaseNode:this.visitCase.bind(this),WhenNode:this.visitWhen.bind(this),JSONReferenceNode:this.visitJSONReference.bind(this),JSONPathNode:this.visitJSONPath.bind(this),JSONPathLegNode:this.visitJSONPathLeg.bind(this),JSONOperatorChainNode:this.visitJSONOperatorChain.bind(this),TupleNode:this.visitTuple.bind(this),MergeQueryNode:this.visitMergeQuery.bind(this),MatchedNode:this.visitMatched.bind(this),AddIndexNode:this.visitAddIndex.bind(this),CastNode:this.visitCast.bind(this),FetchNode:this.visitFetch.bind(this),TopNode:this.visitTop.bind(this),OutputNode:this.visitOutput.bind(this),OrActionNode:this.visitOrAction.bind(this),CollateNode:this.visitCollate.bind(this)});visitNode=e=>{this.nodeStack.push(e),this.#e[e.kind](e),this.nodeStack.pop()}};var Gn=/'/g,Yr=class extends Hr{#e="";#t=[];get numParameters(){return this.#t.length}compileQuery(e,r){return this.#e="",this.#t=[],this.nodeStack.splice(0,this.nodeStack.length),this.visitNode(e),i({query:e,queryId:r,sql:this.getSql(),parameters:[...this.#t]})}getSql(){return this.#e}visitSelectQuery(e){let r=this.parentNode!==void 0&&!me.is(this.parentNode)&&!S.is(this.parentNode)&&!z.is(this.parentNode)&&!pe.is(this.parentNode)&&!yr.is(this.parentNode);this.parentNode===void 0&&e.explain&&(this.visitNode(e.explain),this.append(" ")),r&&this.append("("),e.with&&(this.visitNode(e.with),this.append(" ")),this.append("select"),e.distinctOn&&(this.append(" "),this.compileDistinctOn(e.distinctOn)),e.frontModifiers?.length&&(this.append(" "),this.compileList(e.frontModifiers," ")),e.top&&(this.append(" "),this.visitNode(e.top)),e.selections&&(this.append(" "),this.compileList(e.selections)),e.from&&(this.append(" "),this.visitNode(e.from)),e.joins&&(this.append(" "),this.compileList(e.joins," ")),e.where&&(this.append(" "),this.visitNode(e.where)),e.groupBy&&(this.append(" "),this.visitNode(e.groupBy)),e.having&&(this.append(" "),this.visitNode(e.having)),e.setOperations&&(this.append(" "),this.compileList(e.setOperations," ")),e.orderBy&&(this.append(" "),this.visitNode(e.orderBy)),e.limit&&(this.append(" "),this.visitNode(e.limit)),e.offset&&(this.append(" "),this.visitNode(e.offset)),e.fetch&&(this.append(" "),this.visitNode(e.fetch)),e.endModifiers?.length&&(this.append(" "),this.compileList(this.sortSelectModifiers([...e.endModifiers])," ")),r&&this.append(")")}visitFrom(e){this.append("from "),this.compileList(e.froms)}visitSelection(e){this.visitNode(e.selection)}visitColumn(e){this.visitNode(e.column)}compileDistinctOn(e){this.append("distinct on ("),this.compileList(e),this.append(")")}compileList(e,r=", "){let o=e.length-1;for(let n=0;n<=o;n++)this.visitNode(e[n]),n<o&&this.append(r)}visitWhere(e){this.append("where "),this.visitNode(e.where)}visitHaving(e){this.append("having "),this.visitNode(e.having)}visitInsertQuery(e){let r=this.nodeStack.find(u.is),o=r!==e;!o&&e.explain&&(this.visitNode(e.explain),this.append(" ")),o&&!q.is(r)&&this.append("("),e.with&&(this.visitNode(e.with),this.append(" ")),this.append(e.replace?"replace":"insert"),e.ignore&&(Ae("`InsertQueryNode.ignore` is deprecated. Use `InsertQueryNode.orAction` instead."),this.append(" ignore")),e.orAction&&(this.append(" "),this.visitNode(e.orAction)),e.top&&(this.append(" "),this.visitNode(e.top)),e.into&&(this.append(" into "),this.visitNode(e.into)),e.columns&&(this.append(" ("),this.compileList(e.columns),this.append(")")),e.output&&(this.append(" "),this.visitNode(e.output)),e.values&&(this.append(" "),this.visitNode(e.values)),e.defaultValues&&(this.append(" "),this.append("default values")),e.onConflict&&(this.append(" "),this.visitNode(e.onConflict)),e.onDuplicateKey&&(this.append(" "),this.visitNode(e.onDuplicateKey)),e.returning&&(this.append(" "),this.visitNode(e.returning)),o&&!q.is(r)&&this.append(")"),e.endModifiers?.length&&(this.append(" "),this.compileList(e.endModifiers," "))}visitValues(e){this.append("values "),this.compileList(e.values)}visitDeleteQuery(e){let r=this.nodeStack.find(u.is)!==e;!r&&e.explain&&(this.visitNode(e.explain),this.append(" ")),r&&this.append("("),e.with&&(this.visitNode(e.with),this.append(" ")),this.append("delete "),e.top&&(this.visitNode(e.top),this.append(" ")),this.visitNode(e.from),e.output&&(this.append(" "),this.visitNode(e.output)),e.using&&(this.append(" "),this.visitNode(e.using)),e.joins&&(this.append(" "),this.compileList(e.joins," ")),e.where&&(this.append(" "),this.visitNode(e.where)),e.orderBy&&(this.append(" "),this.visitNode(e.orderBy)),e.limit&&(this.append(" "),this.visitNode(e.limit)),e.returning&&(this.append(" "),this.visitNode(e.returning)),r&&this.append(")"),e.endModifiers?.length&&(this.append(" "),this.compileList(e.endModifiers," "))}visitReturning(e){this.append("returning "),this.compileList(e.selections)}visitAlias(e){this.visitNode(e.node),this.append(" as "),this.visitNode(e.alias)}visitReference(e){e.table&&(this.visitNode(e.table),this.append(".")),this.visitNode(e.column)}visitSelectAll(e){this.append("*")}visitIdentifier(e){this.append(this.getLeftIdentifierWrapper()),this.compileUnwrappedIdentifier(e),this.append(this.getRightIdentifierWrapper())}compileUnwrappedIdentifier(e){if(!C(e.name))throw new Error("a non-string identifier was passed to compileUnwrappedIdentifier.");this.append(this.sanitizeIdentifier(e.name))}visitAnd(e){this.visitNode(e.left),this.append(" and "),this.visitNode(e.right)}visitOr(e){this.visitNode(e.left),this.append(" or "),this.visitNode(e.right)}visitValue(e){e.immediate?this.appendImmediateValue(e.value):this.appendValue(e.value)}visitValueList(e){this.append("("),this.compileList(e.values),this.append(")")}visitTuple(e){this.append("("),this.compileList(e.values),this.append(")")}visitPrimitiveValueList(e){this.append("(");let{values:r}=e;for(let o=0;o<r.length;++o)this.appendValue(r[o]),o!==r.length-1&&this.append(", ");this.append(")")}visitParens(e){this.append("("),this.visitNode(e.node),this.append(")")}visitJoin(e){this.append(Hn[e.joinType]),this.append(" "),this.visitNode(e.table),e.on&&(this.append(" "),this.visitNode(e.on))}visitOn(e){this.append("on "),this.visitNode(e.on)}visitRaw(e){let{sqlFragments:r,parameters:o}=e;for(let n=0;n<r.length;++n)this.append(r[n]),o.length>n&&this.visitNode(o[n])}visitOperator(e){this.append(e.operator)}visitTable(e){this.visitNode(e.table)}visitSchemableIdentifier(e){e.schema&&(this.visitNode(e.schema),this.append(".")),this.visitNode(e.identifier)}visitCreateTable(e){this.append("create "),e.frontModifiers&&e.frontModifiers.length>0&&(this.compileList(e.frontModifiers," "),this.append(" ")),e.temporary&&this.append("temporary "),this.append("table "),e.ifNotExists&&this.append("if not exists "),this.visitNode(e.table),e.selectQuery?(this.append(" as "),this.visitNode(e.selectQuery)):(this.append(" ("),this.compileList([...e.columns,...e.constraints??[]]),this.append(")"),e.onCommit&&(this.append(" on commit "),this.append(e.onCommit)),e.endModifiers&&e.endModifiers.length>0&&(this.append(" "),this.compileList(e.endModifiers," ")))}visitColumnDefinition(e){e.ifNotExists&&this.append("if not exists "),this.visitNode(e.column),this.append(" "),this.visitNode(e.dataType),e.unsigned&&this.append(" unsigned"),e.frontModifiers&&e.frontModifiers.length>0&&(this.append(" "),this.compileList(e.frontModifiers," ")),e.generated&&(this.append(" "),this.visitNode(e.generated)),e.identity&&this.append(" identity"),e.defaultTo&&(this.append(" "),this.visitNode(e.defaultTo)),e.notNull&&this.append(" not null"),e.unique&&this.append(" unique"),e.nullsNotDistinct&&this.append(" nulls not distinct"),e.primaryKey&&this.append(" primary key"),e.autoIncrement&&(this.append(" "),this.append(this.getAutoIncrement())),e.references&&(this.append(" "),this.visitNode(e.references)),e.check&&(this.append(" "),this.visitNode(e.check)),e.endModifiers&&e.endModifiers.length>0&&(this.append(" "),this.compileList(e.endModifiers," "))}getAutoIncrement(){return"auto_increment"}visitReferences(e){this.append("references "),this.visitNode(e.table),this.append(" ("),this.compileList(e.columns),this.append(")"),e.onDelete&&(this.append(" on delete "),this.append(e.onDelete)),e.onUpdate&&(this.append(" on update "),this.append(e.onUpdate))}visitDropTable(e){this.append("drop table "),e.ifExists&&this.append("if exists "),this.visitNode(e.table),e.cascade&&this.append(" cascade")}visitDataType(e){this.append(e.dataType)}visitOrderBy(e){this.append("order by "),this.compileList(e.items)}visitOrderByItem(e){this.visitNode(e.orderBy),e.collation&&(this.append(" "),this.visitNode(e.collation)),e.direction&&(this.append(" "),this.visitNode(e.direction)),e.nulls&&(this.append(" nulls "),this.append(e.nulls))}visitGroupBy(e){this.append("group by "),this.compileList(e.items)}visitGroupByItem(e){this.visitNode(e.groupBy)}visitUpdateQuery(e){let r=this.nodeStack.find(u.is),o=r!==e;if(!o&&e.explain&&(this.visitNode(e.explain),this.append(" ")),o&&!q.is(r)&&this.append("("),e.with&&(this.visitNode(e.with),this.append(" ")),this.append("update "),e.top&&(this.visitNode(e.top),this.append(" ")),e.table&&(this.visitNode(e.table),this.append(" ")),this.append("set "),e.updates&&this.compileList(e.updates),e.output&&(this.append(" "),this.visitNode(e.output)),e.from&&(this.append(" "),this.visitNode(e.from)),e.joins){if(!e.from)throw new Error("Joins in an update query are only supported as a part of a PostgreSQL 'update set from join' query. If you want to create a MySQL 'update join set' query, see https://kysely.dev/docs/examples/update/my-sql-joins");this.append(" "),this.compileList(e.joins," ")}e.where&&(this.append(" "),this.visitNode(e.where)),e.orderBy&&(this.append(" "),this.visitNode(e.orderBy)),e.limit&&(this.append(" "),this.visitNode(e.limit)),e.returning&&(this.append(" "),this.visitNode(e.returning)),o&&!q.is(r)&&this.append(")"),e.endModifiers?.length&&(this.append(" "),this.compileList(e.endModifiers," "))}visitColumnUpdate(e){this.visitNode(e.column),this.append(" = "),this.visitNode(e.value)}visitLimit(e){this.append("limit "),this.visitNode(e.limit)}visitOffset(e){this.append("offset "),this.visitNode(e.offset)}visitOnConflict(e){this.append("on conflict"),e.columns?(this.append(" ("),this.compileList(e.columns),this.append(")")):e.constraint?(this.append(" on constraint "),this.visitNode(e.constraint)):e.indexExpression&&(this.append(" ("),this.visitNode(e.indexExpression),this.append(")")),e.indexWhere&&(this.append(" "),this.visitNode(e.indexWhere)),e.doNothing===!0?this.append(" do nothing"):e.updates&&(this.append(" do update set "),this.compileList(e.updates),e.updateWhere&&(this.append(" "),this.visitNode(e.updateWhere)))}visitOnDuplicateKey(e){this.append("on duplicate key update "),this.compileList(e.updates)}visitCreateIndex(e){this.append("create "),e.unique&&this.append("unique "),this.append("index "),e.ifNotExists&&this.append("if not exists "),this.visitNode(e.name),e.table&&(this.append(" on "),this.visitNode(e.table)),e.using&&(this.append(" using "),this.visitNode(e.using)),e.columns&&(this.append(" ("),this.compileList(e.columns),this.append(")")),e.nullsNotDistinct&&this.append(" nulls not distinct"),e.where&&(this.append(" "),this.visitNode(e.where))}visitDropIndex(e){this.append("drop index "),e.ifExists&&this.append("if exists "),this.visitNode(e.name),e.table&&(this.append(" on "),this.visitNode(e.table)),e.cascade&&this.append(" cascade")}visitCreateSchema(e){this.append("create schema "),e.ifNotExists&&this.append("if not exists "),this.visitNode(e.schema)}visitDropSchema(e){this.append("drop schema "),e.ifExists&&this.append("if exists "),this.visitNode(e.schema),e.cascade&&this.append(" cascade")}visitPrimaryKeyConstraint(e){e.name&&(this.append("constraint "),this.visitNode(e.name),this.append(" ")),this.append("primary key ("),this.compileList(e.columns),this.append(")"),this.buildDeferrable(e)}buildDeferrable(e){e.deferrable!==void 0&&(e.deferrable?this.append(" deferrable"):this.append(" not deferrable")),e.initiallyDeferred!==void 0&&(e.initiallyDeferred?this.append(" initially deferred"):this.append(" initially immediate"))}visitUniqueConstraint(e){e.name&&(this.append("constraint "),this.visitNode(e.name),this.append(" ")),this.append("unique"),e.nullsNotDistinct&&this.append(" nulls not distinct"),this.append(" ("),this.compileList(e.columns),this.append(")"),this.buildDeferrable(e)}visitCheckConstraint(e){e.name&&(this.append("constraint "),this.visitNode(e.name),this.append(" ")),this.append("check ("),this.visitNode(e.expression),this.append(")")}visitForeignKeyConstraint(e){e.name&&(this.append("constraint "),this.visitNode(e.name),this.append(" ")),this.append("foreign key ("),this.compileList(e.columns),this.append(") "),this.visitNode(e.references),e.onDelete&&(this.append(" on delete "),this.append(e.onDelete)),e.onUpdate&&(this.append(" on update "),this.append(e.onUpdate)),this.buildDeferrable(e)}visitList(e){this.compileList(e.items)}visitWith(e){this.append("with "),e.recursive&&this.append("recursive "),this.compileList(e.expressions)}visitCommonTableExpression(e){this.visitNode(e.name),this.append(" as "),Ve(e.materialized)&&(e.materialized||this.append("not "),this.append("materialized ")),this.visitNode(e.expression)}visitCommonTableExpressionName(e){this.visitNode(e.table),e.columns&&(this.append("("),this.compileList(e.columns),this.append(")"))}visitAlterTable(e){this.append("alter table "),this.visitNode(e.table),this.append(" "),e.renameTo&&(this.append("rename to "),this.visitNode(e.renameTo)),e.setSchema&&(this.append("set schema "),this.visitNode(e.setSchema)),e.addConstraint&&this.visitNode(e.addConstraint),e.dropConstraint&&this.visitNode(e.dropConstraint),e.renameConstraint&&this.visitNode(e.renameConstraint),e.columnAlterations&&this.compileColumnAlterations(e.columnAlterations),e.addIndex&&this.visitNode(e.addIndex),e.dropIndex&&this.visitNode(e.dropIndex)}visitAddColumn(e){this.append("add column "),this.visitNode(e.column)}visitRenameColumn(e){this.append("rename column "),this.visitNode(e.column),this.append(" to "),this.visitNode(e.renameTo)}visitDropColumn(e){this.append("drop column "),this.visitNode(e.column)}visitAlterColumn(e){this.append("alter column "),this.visitNode(e.column),this.append(" "),e.dataType&&(this.announcesNewColumnDataType()&&this.append("type "),this.visitNode(e.dataType),e.dataTypeExpression&&(this.append("using "),this.visitNode(e.dataTypeExpression))),e.setDefault&&(this.append("set default "),this.visitNode(e.setDefault)),e.dropDefault&&this.append("drop default"),e.setNotNull&&this.append("set not null"),e.dropNotNull&&this.append("drop not null")}visitModifyColumn(e){this.append("modify column "),this.visitNode(e.column)}visitAddConstraint(e){this.append("add "),this.visitNode(e.constraint)}visitDropConstraint(e){this.append("drop constraint "),e.ifExists&&this.append("if exists "),this.visitNode(e.constraintName),e.modifier==="cascade"?this.append(" cascade"):e.modifier==="restrict"&&this.append(" restrict")}visitRenameConstraint(e){this.append("rename constraint "),this.visitNode(e.oldName),this.append(" to "),this.visitNode(e.newName)}visitSetOperation(e){this.append(e.operator),this.append(" "),e.all&&this.append("all "),this.visitNode(e.expression)}visitCreateView(e){this.append("create "),e.orReplace&&this.append("or replace "),e.materialized&&this.append("materialized "),e.temporary&&this.append("temporary "),this.append("view "),e.ifNotExists&&this.append("if not exists "),this.visitNode(e.name),this.append(" "),e.columns&&(this.append("("),this.compileList(e.columns),this.append(") ")),e.as&&(this.append("as "),this.visitNode(e.as))}visitRefreshMaterializedView(e){this.append("refresh materialized view "),e.concurrently&&this.append("concurrently "),this.visitNode(e.name),e.withNoData?this.append(" with no data"):this.append(" with data")}visitDropView(e){this.append("drop "),e.materialized&&this.append("materialized "),this.append("view "),e.ifExists&&this.append("if exists "),this.visitNode(e.name),e.cascade&&this.append(" cascade")}visitGenerated(e){this.append("generated "),e.always&&this.append("always "),e.byDefault&&this.append("by default "),this.append("as "),e.identity&&this.append("identity"),e.expression&&(this.append("("),this.visitNode(e.expression),this.append(")")),e.stored&&this.append(" stored")}visitDefaultValue(e){this.append("default "),this.visitNode(e.defaultValue)}visitSelectModifier(e){e.rawModifier?this.visitNode(e.rawModifier):this.append(jn[e.modifier]),e.of&&(this.append(" of "),this.compileList(e.of,", "))}visitCreateType(e){this.append("create type "),this.visitNode(e.name),e.enum&&(this.append(" as enum "),this.visitNode(e.enum))}visitDropType(e){this.append("drop type "),e.ifExists&&this.append("if exists "),this.visitNode(e.name)}visitExplain(e){this.append("explain"),(e.options||e.format)&&(this.append(" "),this.append(this.getLeftExplainOptionsWrapper()),e.options&&(this.visitNode(e.options),e.format&&this.append(this.getExplainOptionsDelimiter())),e.format&&(this.append("format"),this.append(this.getExplainOptionAssignment()),this.append(e.format)),this.append(this.getRightExplainOptionsWrapper()))}visitDefaultInsertValue(e){this.append("default")}visitAggregateFunction(e){this.append(e.func),this.append("("),e.distinct&&this.append("distinct "),this.compileList(e.aggregated),e.orderBy&&(this.append(" "),this.visitNode(e.orderBy)),this.append(")"),e.withinGroup&&(this.append(" within group ("),this.visitNode(e.withinGroup),this.append(")")),e.filter&&(this.append(" filter("),this.visitNode(e.filter),this.append(")")),e.over&&(this.append(" "),this.visitNode(e.over))}visitOver(e){this.append("over("),e.partitionBy&&(this.visitNode(e.partitionBy),e.orderBy&&this.append(" ")),e.orderBy&&this.visitNode(e.orderBy),this.append(")")}visitPartitionBy(e){this.append("partition by "),this.compileList(e.items)}visitPartitionByItem(e){this.visitNode(e.partitionBy)}visitBinaryOperation(e){this.visitNode(e.leftOperand),this.append(" "),this.visitNode(e.operator),this.append(" "),this.visitNode(e.rightOperand)}visitUnaryOperation(e){this.visitNode(e.operator),this.isMinusOperator(e.operator)||this.append(" "),this.visitNode(e.operand)}isMinusOperator(e){return Y.is(e)&&e.operator==="-"}visitUsing(e){this.append("using "),this.compileList(e.tables)}visitFunction(e){this.append(e.func),this.append("("),this.compileList(e.arguments),this.append(")")}visitCase(e){this.append("case"),e.value&&(this.append(" "),this.visitNode(e.value)),e.when&&(this.append(" "),this.compileList(e.when," ")),e.else&&(this.append(" else "),this.visitNode(e.else)),this.append(" end"),e.isStatement&&this.append(" case")}visitWhen(e){this.append("when "),this.visitNode(e.condition),e.result&&(this.append(" then "),this.visitNode(e.result))}visitJSONReference(e){this.visitNode(e.reference),this.visitNode(e.traversal)}visitJSONPath(e){e.inOperator&&this.visitNode(e.inOperator),this.append("'$");for(let r of e.pathLegs)this.visitNode(r);this.append("'")}visitJSONPathLeg(e){let r=e.type==="ArrayLocation";this.append(r?"[":"."),this.append(String(e.value)),r&&this.append("]")}visitJSONOperatorChain(e){for(let r=0,o=e.values.length;r<o;r++)r===o-1?this.visitNode(e.operator):this.append("->"),this.visitNode(e.values[r])}visitMergeQuery(e){e.with&&(this.visitNode(e.with),this.append(" ")),this.append("merge "),e.top&&(this.visitNode(e.top),this.append(" ")),this.append("into "),this.visitNode(e.into),e.using&&(this.append(" "),this.visitNode(e.using)),e.whens&&(this.append(" "),this.compileList(e.whens," ")),e.returning&&(this.append(" "),this.visitNode(e.returning)),e.output&&(this.append(" "),this.visitNode(e.output)),e.endModifiers?.length&&(this.append(" "),this.compileList(e.endModifiers," "))}visitMatched(e){e.not&&this.append("not "),this.append("matched"),e.bySource&&this.append(" by source")}visitAddIndex(e){this.append("add "),e.unique&&this.append("unique "),this.append("index "),this.visitNode(e.name),e.columns&&(this.append(" ("),this.compileList(e.columns),this.append(")")),e.using&&(this.append(" using "),this.visitNode(e.using))}visitCast(e){this.append("cast("),this.visitNode(e.expression),this.append(" as "),this.visitNode(e.dataType),this.append(")")}visitFetch(e){this.append("fetch next "),this.visitNode(e.rowCount),this.append(` rows ${e.modifier}`)}visitOutput(e){this.append("output "),this.compileList(e.selections)}visitTop(e){this.append(`top(${e.expression})`),e.modifiers&&this.append(` ${e.modifiers}`)}visitOrAction(e){this.append(e.action)}visitCollate(e){this.append("collate "),this.visitNode(e.collation)}append(e){this.#e+=e}appendValue(e){this.addParameter(e),this.append(this.getCurrentParameterPlaceholder())}getLeftIdentifierWrapper(){return'"'}getRightIdentifierWrapper(){return'"'}getCurrentParameterPlaceholder(){return"$"+this.numParameters}getLeftExplainOptionsWrapper(){return"("}getExplainOptionAssignment(){return" "}getExplainOptionsDelimiter(){return", "}getRightExplainOptionsWrapper(){return")"}sanitizeIdentifier(e){let r=this.getLeftIdentifierWrapper(),o=this.getRightIdentifierWrapper(),n="";for(let a of e)n+=a,a===r?n+=r:a===o&&(n+=o);return n}sanitizeStringLiteral(e){return e.replace(Gn,"''")}addParameter(e){this.#t.push(e)}appendImmediateValue(e){if(C(e))this.appendStringLiteral(e);else if(Se(e)||Ve(e))this.append(e.toString());else if(Xe(e))this.append("null");else if(io(e))this.appendImmediateValue(e.toISOString());else if(Ze(e))this.appendImmediateValue(e.toString());else throw new Error(`invalid immediate value ${e}`)}appendStringLiteral(e){this.append("'"),this.append(this.sanitizeStringLiteral(e)),this.append("'")}sortSelectModifiers(e){return e.sort((r,o)=>r.modifier&&o.modifier?Zo[r.modifier]-Zo[o.modifier]:1),i(e)}compileColumnAlterations(e){this.compileList(e)}announcesNewColumnDataType(){return!0}},jn=i({ForKeyShare:"for key share",ForNoKeyUpdate:"for no key update",ForUpdate:"for update",ForShare:"for share",NoWait:"nowait",SkipLocked:"skip locked",Distinct:"distinct"}),Zo=i({ForKeyShare:1,ForNoKeyUpdate:1,ForUpdate:1,ForShare:1,NoWait:2,SkipLocked:2,Distinct:0}),Hn=i({InnerJoin:"inner join",LeftJoin:"left join",RightJoin:"right join",FullJoin:"full join",CrossJoin:"cross join",LateralInnerJoin:"inner join lateral",LateralLeftJoin:"left join lateral",LateralCrossJoin:"cross join lateral",OuterApply:"outer apply",CrossApply:"cross apply",Using:"using"});var Xr=class{async init(){}async acquireConnection(){return new Zi}async beginTransaction(){}async commitTransaction(){}async rollbackTransaction(){}async releaseConnection(){}async destroy(){}async releaseSavepoint(){}async rollbackToSavepoint(){}async savepoint(){}},Zi=class{async executeQuery(){return{rows:[]}}async*streamQuery(){}};var Zr=class{get supportsCreateIfNotExists(){return!0}get supportsTransactionalDdl(){return!1}get supportsReturning(){return!1}get supportsOutput(){return!1}};var Yn=/"/g,_r=class extends Yr{sanitizeIdentifier(e){return e.replace(Yn,'""')}};var Xn=BigInt("3853314791062309107"),ei=class extends Zr{get supportsTransactionalDdl(){return!0}get supportsReturning(){return!0}async acquireMigrationLock(e,r){await $`select pg_advisory_xact_lock(${$.lit(Xn)})`.execute(e)}async releaseMigrationLock(e,r){}};function _o(t){return new kt({dialect:{createAdapter:()=>new t.Adapter,createDriver:()=>new Xr,createIntrospector:()=>null,createQueryCompiler:()=>new t.QueryCompiler},plugins:[...t.noParameters?[new _i]:[]]})}var _i=class{#e=new eo;transformQuery(e){return this.#e.transformNode(e.node)}transformResult(e){return Promise.resolve(e.result)}},eo=class extends qe{transformPrimitiveValueList(e){return he.create(e.values.map(k.createImmediate))}transformValue(e){return{...super.transformValue(e),immediate:!0}}};function Pe(t){let e=t.compile();return{parameters:e.parameters,sql:e.sql}}function to(t,e){let r=_n(t,e);return o=>o.where(n=>n.or(r.map(a=>n.and(a.map(([d,c])=>n(d,c===null?"is":"=",c))))))}function Zn(t,e){return Object.entries(Object.values(e).reduce((r,o)=>{let{isInPrimaryKey:n,name:a}=o;return n&&(r[a]=t[a]??null),r},{}))}function _n(t,e){return t.map(r=>Zn(r,e))}function Me(t){return _o({...t,Adapter:ei,QueryCompiler:_r})}function en(t,e){let{table:r,rows:o}=t,{name:n,schema:a,columns:d}=r,c=Me(e),N=Object.keys(d),y={[N[0]]:$`default`};return Pe(c.withSchema(a).insertInto(n).values(o.map(R=>Object.keys(R).length===0?y:R)).returning(N).returning(R=>R.cast("ctid","text").as("ctid")))}function tn(t,e){let{pageIndex:r,pageSize:o,sortOrder:n,table:{name:a,schema:d,columns:c}}=t,N=Me(e),y=Object.keys(c),R=N.withSchema(d).selectFrom(a).select(E=>E.cast(E.fn.coalesce(E.fn.countAll(),$.lit(0)),"text").as("oid"));return Pe(N.with("count",()=>R).withSchema(d).selectFrom([a,"count"]).select($.ref("count.oid").$castTo().as("oid")).select(E=>E.cast("ctid","text").as("ctid")).select(y).$call(E=>n.reduce((Fe,M)=>Fe.orderBy(M.column,M.direction),E)).limit(o).offset($.lit(BigInt(r)*BigInt(o))))}function rn(t,e){let{changes:r,row:o,table:{columns:n,name:a,schema:d}}=t,c=Me(e),N=Object.keys(n);return Pe(c.withSchema(d).updateTable(a).set(r).$call(to([o],n)).returning(N).returning(y=>[y.cast("ctid","text").as("ctid"),y.cast(y.fn("floor",[y(y.fn("extract",[$`epoch from now()`]),"*",1e6)]),"text").as("__ps_updated_at__")]))}function on(t,e){let{rows:r,table:{columns:o,name:n,schema:a}}=t,d=Me(e);return Pe(d.withSchema(a).deleteFrom(n).$call(to(r,o)))}function nn(t){return $`(select coalesce(json_agg(agg), '[]') from ${t} as agg)`}var es="r",ts="v",rs=[es,ts];function sn(t){return Pe(Me(t).selectFrom("pg_catalog.pg_class as cls").innerJoin("pg_catalog.pg_namespace as ns","cls.relnamespace","ns.oid").$call(is).where("cls.relkind","in",rs).select(e=>["ns.nspname as schema","cls.relname as name",nn(e.selectFrom("pg_catalog.pg_attribute as att").innerJoin("pg_catalog.pg_type as typ","typ.oid","att.atttypid").innerJoin("pg_catalog.pg_namespace as tns","tns.oid","typ.typnamespace").leftJoin("pg_catalog.pg_constraint as con",r=>r.on("con.contype","=","p").onRef("con.conrelid","=","cls.oid").on(o=>o("att.attnum","=",o.fn.any("con.conkey")))).whereRef("att.attrelid","=","cls.oid").where("att.attnum",">=",0).where("att.attisdropped","!=",!0).where("att.attgenerated","=","").select(["att.attname as name","typ.typname as datatype","tns.nspname as datatype_schema"]).select(r=>[r("con.conkey","is not",null).$castTo().as("pk"),r("att.attgenerated","!=","").$castTo().as("computed"),r("att.attnotnull","!=",!0).$castTo().as("nullable"),r.fn.coalesce(r.selectFrom("pg_catalog.pg_enum as enm").whereRef("enm.enumtypid","=","typ.oid").select(o=>o.fn.jsonAgg(o.ref("enm.enumlabel")).as("o")),$`'[]'`).as("options")])).as("columns")]))}function an(){let t=Me();return Pe(t.selectNoFrom(t.fn("current_setting",[$.lit("timezone")]).as("timezone")))}function is(t){return t.where("ns.nspname","!~","^pg_").where("ns.nspname","!=","information_schema")}function un(t){let{executor:e,...r}=t;return{defaultSchema:"public",async introspect(o){try{let n=sn(r),a=an(),[[d,c],[N,y]]=await Promise.all([e.execute(n,o),e.execute(a,o)]),R=d||N;if(R)return[R];let[E]=y;return E?[null,os(c,E.timezone)]:[new Error("Timezone not found")]}catch(n){return[n]}},async query(o,n){try{let a=tn(o,r),[d,c]=await e.execute(a,n);return d?[d]:[null,{filteredRowCount:c[0]?.oid||"0",rows:c}]}catch(a){return[a]}},async insert(o,n){try{let a=en(o,r),[d,c]=await e.execute(a,n);return d?[d]:[null,{rows:c}]}catch(a){return[a]}},async update(o,n){try{let a=rn(o,r),[d,c]=await e.execute(a,n);if(d)return[d];let[N]=c;return N?[null,{row:N}]:[new Error("Update failed")]}catch(a){return[a]}},async delete(o,n){try{let a=on(o,r),[d]=await e.execute(a,n);return d?[d]:[null,o]}catch(a){return[a]}}}}function os(t,e){return t.reduce((r,o)=>{let{schemas:n}=r,{columns:a,name:d,schema:c}=o,N=a.reduce((y,R)=>{let{datatype:E,datatype_schema:Fe,name:M,options:ze,nullable:ti}=R,Et=E.startsWith("_"),At=Et?E.slice(1):E;return{...y,[M]:{datatype:{...ro[At]||{group:ze.length>0?"enum":"raw"},isArray:Et,isNative:Fe==="pg_catalog",name:Et?`${At}[]`:At,options:ze,schema:Fe},isComputed:R.computed,isInPrimaryKey:R.pk,name:M,nullable:ti,schema:c,table:d}}},{});return(n[c]||={tables:{}}).tables[d]={columns:N,name:d,schema:c},r},{schemas:{public:{tables:{}}},timezone:e})}function dn(t,e){let{addDelay:r=0,logging:o=!1}=e??{};return{execute:async(n,a)=>{let{abortSignal:d}=a||{},c,N=new Promise((M,ze)=>c=ze);function y(){let M=new Error("This operation was aborted");M.name="AbortError",c(M)}d?.addEventListener("abort",y);let R=typeof r=="function"?r(n):r,E=()=>t.query(n.sql,n.parameters,{rowMode:"object"}),Fe=R>0?()=>new Promise(M=>setTimeout(M,R)).then(()=>E()):E;try{let M=typeof o=="function"?o(n):o,ze;M&&console.log("PGLiteExecutor: Executing query:",ze=JSON.stringify(n,null,2));let ti=Date.now(),Et=await Promise.race([Fe(),N]),At=Date.now()-ti;return M&&console.log("PGLiteExecutor: Query executed in",At,"ms:",ze),[null,Et.rows]}catch(M){return[M]}finally{d?.removeEventListener("abort",y)}}}}function ns(t,e){return un({executor:dn(t,e)})}0&&(module.exports={createPGLiteAdapter,createPGLiteExecutor});
1
+ "use strict";var ni=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var fn=Object.getOwnPropertyNames;var Nn=Object.prototype.hasOwnProperty;var yn=(t,e)=>{for(var r in e)ni(t,r,{get:e[r],enumerable:!0})},wn=(t,e,r,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of fn(e))!Nn.call(t,n)&&n!==r&&ni(t,n,{get:()=>e[n],enumerable:!(o=mn(e,n))||o.enumerable});return t};var xn=t=>wn(ni({},"__esModule",{value:!0}),t);var hs={};yn(hs,{createPGLiteAdapter:()=>cs,createPGLiteExecutor:()=>ln});module.exports=xn(hs);function G(t){let{error:e,query:r}=t,o=e;return o.query=r,[o]}var no={bool:{group:"boolean"},boolean:{group:"boolean"},bytea:{group:"string"},char:{group:"string"},citext:{group:"string"},date:{group:"datetime"},interval:{group:"string"},name:{group:"string"},varchar:{group:"string"},text:{group:"string"},time:{group:"time"},timestamp:{group:"datetime"},timestamptz:{group:"datetime"},"timestamp without time zone":{group:"datetime"},"timestamp with time zone":{group:"datetime"},timetz:{group:"time"},"time without time zone":{group:"time"},"time with time zone":{group:"datetime"},uuid:{group:"string"},int2:{group:"numeric"},int4:{group:"numeric"},int8:{group:"numeric"},smallint:{group:"numeric"},integer:{group:"numeric"},bigint:{group:"numeric"},decimal:{group:"numeric"},numeric:{group:"numeric"},real:{group:"numeric"},float4:{group:"numeric"},float8:{group:"numeric"},"double precision":{group:"numeric"},json:{group:"json"},jsonb:{group:"json"}};function H(t){return typeof t>"u"||t===void 0}function v(t){return typeof t=="string"}function Ee(t){return typeof t=="number"}function Ue(t){return typeof t=="boolean"}function Ze(t){return t===null}function so(t){return t instanceof Date}function _e(t){return typeof t=="bigint"}function k(t){return typeof t=="function"}function q(t){return typeof t=="object"&&t!==null}function i(t){return Object.freeze(t)}function Et(t){return M(t)?t:[t]}function M(t){return Array.isArray(t)}function J(t){return t}var N=i({is(t){return t.kind==="AlterTableNode"},create(t){return i({kind:"AlterTableNode",table:t})},cloneWithTableProps(t,e){return i({...t,...e})},cloneWithColumnAlteration(t,e){return i({...t,columnAlterations:t.columnAlterations?[...t.columnAlterations,e]:[e]})}});var p=i({is(t){return t.kind==="IdentifierNode"},create(t){return i({kind:"IdentifierNode",name:t})}});var ie=i({is(t){return t.kind==="CreateIndexNode"},create(t){return i({kind:"CreateIndexNode",name:p.create(t)})},cloneWith(t,e){return i({...t,...e})},cloneWithColumns(t,e){return i({...t,columns:[...t.columns||[],...e]})}});var Gt=i({is(t){return t.kind==="CreateSchemaNode"},create(t,e){return i({kind:"CreateSchemaNode",schema:p.create(t),...e})},cloneWith(t,e){return i({...t,...e})}});var ao=["preserve rows","delete rows","drop"],z=i({is(t){return t.kind==="CreateTableNode"},create(t){return i({kind:"CreateTableNode",table:t,columns:i([])})},cloneWithColumn(t,e){return i({...t,columns:i([...t.columns,e])})},cloneWithConstraint(t,e){return i({...t,constraints:t.constraints?i([...t.constraints,e]):i([e])})},cloneWithFrontModifier(t,e){return i({...t,frontModifiers:t.frontModifiers?i([...t.frontModifiers,e]):i([e])})},cloneWithEndModifier(t,e){return i({...t,endModifiers:t.endModifiers?i([...t.endModifiers,e]):i([e])})},cloneWith(t,e){return i({...t,...e})}});var V=i({is(t){return t.kind==="SchemableIdentifierNode"},create(t){return i({kind:"SchemableIdentifierNode",identifier:p.create(t)})},createWithSchema(t,e){return i({kind:"SchemableIdentifierNode",schema:p.create(t),identifier:p.create(e)})}});var Re=i({is(t){return t.kind==="DropIndexNode"},create(t,e){return i({kind:"DropIndexNode",name:V.create(t),...e})},cloneWith(t,e){return i({...t,...e})}});var Rt=i({is(t){return t.kind==="DropSchemaNode"},create(t,e){return i({kind:"DropSchemaNode",schema:p.create(t),...e})},cloneWith(t,e){return i({...t,...e})}});var It=i({is(t){return t.kind==="DropTableNode"},create(t,e){return i({kind:"DropTableNode",table:t,...e})},cloneWith(t,e){return i({...t,...e})}});var E=i({is(t){return t.kind==="AliasNode"},create(t,e){return i({kind:"AliasNode",node:t,alias:e})}});var Y=i({is(t){return t.kind==="TableNode"},create(t){return i({kind:"TableNode",table:V.create(t)})},createWithSchema(t,e){return i({kind:"TableNode",table:V.createWithSchema(t,e)})}});function b(t){return q(t)&&k(t.toOperationNode)}function Kt(t){return q(t)&&"expressionType"in t&&b(t)}function uo(t){return q(t)&&"expression"in t&&v(t.alias)&&b(t)}var le=i({is(t){return t.kind==="SelectModifierNode"},create(t,e){return i({kind:"SelectModifierNode",modifier:t,of:e})},createWithExpression(t){return i({kind:"SelectModifierNode",rawModifier:t})}});var K=i({is(t){return t.kind==="AndNode"},create(t,e){return i({kind:"AndNode",left:t,right:e})}});var oe=i({is(t){return t.kind==="OrNode"},create(t,e){return i({kind:"OrNode",left:t,right:e})}});var jt=i({is(t){return t.kind==="OnNode"},create(t){return i({kind:"OnNode",on:t})},cloneWithOperation(t,e,r){return i({...t,on:e==="And"?K.create(t.on,r):oe.create(t.on,r)})}});var Oe=i({is(t){return t.kind==="JoinNode"},create(t,e){return i({kind:"JoinNode",joinType:t,table:e,on:void 0})},createWithOn(t,e,r){return i({kind:"JoinNode",joinType:t,table:e,on:jt.create(r)})},cloneWithOn(t,e){return i({...t,on:t.on?jt.cloneWithOperation(t.on,"And",e):jt.create(e)})}});var Ie=i({is(t){return t.kind==="BinaryOperationNode"},create(t,e,r){return i({kind:"BinaryOperationNode",leftOperand:t,operator:e,rightOperand:r})}});var gn=["=","==","!=","<>",">",">=","<","<=","in","not in","is","is not","like","not like","match","ilike","not ilike","@>","<@","^@","&&","?","?&","?|","!<","!>","<=>","!~","~","~*","!~*","@@","@@@","!!","<->","regexp","is distinct from","is not distinct from"],On=["+","-","*","/","%","^","&","|","#","<<",">>"],po=["->","->>"],bn=[...gn,...On,"&&","||"],Cn=["exists","not exists"],vn=["not","-",...Cn],co=[...bn,...po,...vn,"between","between symmetric"],X=i({is(t){return t.kind==="OperatorNode"},create(t){return i({kind:"OperatorNode",operator:t})}});function si(t){return v(t)&&po.includes(t)}var m=i({is(t){return t.kind==="ColumnNode"},create(t){return i({kind:"ColumnNode",column:p.create(t)})}});var et=i({is(t){return t.kind==="SelectAllNode"},create(){return i({kind:"SelectAllNode"})}});var tt=i({is(t){return t.kind==="ReferenceNode"},create(t,e){return i({kind:"ReferenceNode",table:e,column:t})},createSelectAll(t){return i({kind:"ReferenceNode",table:t,column:et.create()})}});var Ht=class{#e;get dynamicReference(){return this.#e}get refType(){}constructor(e){this.#e=e}toOperationNode(){return ai(this.#e)}};function Yt(t){return q(t)&&b(t)&&v(t.dynamicReference)}var ne=i({is(t){return t.kind==="OrderByItemNode"},create(t,e){return i({kind:"OrderByItemNode",orderBy:t,direction:e})},cloneWith(t,e){return i({...t,...e})}});var W=i({is(t){return t.kind==="RawNode"},create(t,e){return i({kind:"RawNode",sqlFragments:i(t),parameters:i(e)})},createWithSql(t){return W.create([t],[])},createWithChild(t){return W.create(["",""],[t])},createWithChildren(t){return W.create(new Array(t.length+1).fill(""),t)}});var ho={is(t){return t.kind==="CollateNode"},create(t){return i({kind:"CollateNode",collation:p.create(t)})}};var Xt=class t{#e;constructor(e){this.#e=i(e)}desc(){return new t({node:ne.cloneWith(this.#e.node,{direction:W.createWithSql("desc")})})}asc(){return new t({node:ne.cloneWith(this.#e.node,{direction:W.createWithSql("asc")})})}nullsLast(){return new t({node:ne.cloneWith(this.#e.node,{nulls:"last"})})}nullsFirst(){return new t({node:ne.cloneWith(this.#e.node,{nulls:"first"})})}collate(e){return new t({node:ne.cloneWith(this.#e.node,{collation:ho.create(e)})})}toOperationNode(){return this.#e.node}};var lo=new Set;function De(t){lo.has(t)||(lo.add(t),console.log(t))}function di(t){return t==="asc"||t==="desc"}function _(t){if(t.length===2)return[ui(t[0],t[1])];if(t.length===1){let[e]=t;return Array.isArray(e)?(De("orderBy(array) is deprecated, use multiple orderBy calls instead."),e.map(r=>ui(r))):[ui(e)]}throw new Error(`Invalid number of arguments at order by! expected 1-2, received ${t.length}`)}function ui(t,e){let r=Wn(t);if(ne.is(r)){if(e)throw new Error("Cannot specify direction twice!");return r}return mo(r,e)}function Wn(t){if(be(t))return j(t);if(Yt(t))return t.toOperationNode();let[e,r]=t.split(" ");return r?(De("`orderBy('column asc')` is deprecated. Use `orderBy('column', 'asc')` instead."),mo(Z(e),r)):Z(t)}function mo(t,e){if(typeof e=="string"){if(!di(e))throw new Error(`Invalid order by direction: ${e}`);return ne.create(t,W.createWithSql(e))}if(Kt(e))return De("`orderBy(..., expr)` is deprecated. Use `orderBy(..., 'asc')` or `orderBy(..., (ob) => ...)` instead."),ne.create(t,e.toOperationNode());let r=ne.create(t);return e?e(new Xt({node:r})).toOperationNode():r}var rt=i({is(t){return t.kind==="JSONReferenceNode"},create(t,e){return i({kind:"JSONReferenceNode",reference:t,traversal:e})},cloneWithTraversal(t,e){return i({...t,traversal:e})}});var Zt=i({is(t){return t.kind==="JSONOperatorChainNode"},create(t){return i({kind:"JSONOperatorChainNode",operator:t,values:i([])})},cloneWithValue(t,e){return i({...t,values:i([...t.values,e])})}});var qe=i({is(t){return t.kind==="JSONPathNode"},create(t){return i({kind:"JSONPathNode",inOperator:t,pathLegs:i([])})},cloneWithLeg(t,e){return i({...t,pathLegs:i([...t.pathLegs,e])})}});function ai(t){return v(t)?Z(t):t.toOperationNode()}function Ce(t){return M(t)?t.map(e=>B(e)):[B(t)]}function B(t){return be(t)?j(t):ai(t)}function fo(t,e){let r=Z(t);if(si(e))return rt.create(r,Zt.create(X.create(e)));let o=e.slice(0,-1);if(si(o))return rt.create(r,qe.create(X.create(o)));throw new Error(`Invalid JSON operator: ${e}`)}function Z(t){let e=".";if(!t.includes(e))return tt.create(m.create(t));let r=t.split(e).map(ci);if(r.length===3)return kn(r);if(r.length===2)return Tn(r);throw new Error(`invalid column reference ${t}`)}function No(t){let e=" as ";if(t.includes(e)){let[r,o]=t.split(e).map(ci);return E.create(Z(r),p.create(o))}else return Z(t)}function pi(t){return m.create(t)}function it(t){let e=" ";if(t.includes(e)){let[r,o]=t.split(e).map(ci);if(!di(o))throw new Error(`invalid order direction "${o}" next to "${r}"`);return _([r,o])[0]}else return pi(t)}function kn(t){let[e,r,o]=t;return tt.create(m.create(o),Y.createWithSchema(e,r))}function Tn(t){let[e,r]=t;return tt.create(m.create(r),Y.create(e))}function ci(t){return t.trim()}var _t=i({is(t){return t.kind==="PrimitiveValueListNode"},create(t){return i({kind:"PrimitiveValueListNode",values:i([...t])})}});var me=i({is(t){return t.kind==="ValueListNode"},create(t){return i({kind:"ValueListNode",values:i(t)})}});var S=i({is(t){return t.kind==="ValueNode"},create(t){return i({kind:"ValueNode",value:t})},createImmediate(t){return i({kind:"ValueNode",value:t,immediate:!0})}});function yo(t){return M(t)?Sn(t):g(t)}function g(t){return be(t)?j(t):S.create(t)}function er(t){return Ee(t)||Ue(t)||Ze(t)}function Dt(t){if(!er(t))throw new Error(`unsafe immediate value ${JSON.stringify(t)}`);return S.createImmediate(t)}function Sn(t){return t.some(be)?me.create(t.map(e=>g(e))):_t.create(t)}var fe=i({is(t){return t.kind==="ParensNode"},create(t){return i({kind:"ParensNode",node:t})}});function O(t){if(t.length===3)return tr(t[0],t[1],t[2]);if(t.length===1)return g(t[0]);throw new Error(`invalid arguments: ${JSON.stringify(t)}`)}function tr(t,e,r){return An(e)&&xo(r)?Ie.create(B(t),hi(e),S.createImmediate(r)):Ie.create(B(t),hi(e),yo(r))}function R(t,e,r){return Ie.create(B(t),hi(e),B(r))}function li(t,e){return ot(Object.entries(t).filter(([,r])=>!H(r)).map(([r,o])=>tr(r,xo(o)?"is":"=",o)),e)}function ot(t,e,r=!0){let o=e==="and"?K.create:oe.create;if(t.length===0)return Ie.create(S.createImmediate(1),X.create("="),S.createImmediate(e==="and"?1:0));let n=wo(t[0]);for(let a=1;a<t.length;++a)n=o(n,wo(t[a]));return t.length>1&&r?fe.create(n):n}function An(t){return t==="is"||t==="is not"}function xo(t){return Ze(t)||Ue(t)}function hi(t){if(v(t)&&co.includes(t))return X.create(t);if(b(t))return t.toOperationNode();throw new Error(`invalid operator ${JSON.stringify(t)}`)}function wo(t){return b(t)?t.toOperationNode():t}var ve=i({is(t){return t.kind==="OrderByNode"},create(t){return i({kind:"OrderByNode",items:i([...t])})},cloneWithItems(t,e){return i({...t,items:i([...t.items,...e])})}});var mi=i({is(t){return t.kind==="PartitionByNode"},create(t){return i({kind:"PartitionByNode",items:i(t)})},cloneWithItems(t,e){return i({...t,items:i([...t.items,...e])})}});var qt=i({is(t){return t.kind==="OverNode"},create(){return i({kind:"OverNode"})},cloneWithOrderByItems(t,e){return i({...t,orderBy:t.orderBy?ve.cloneWithItems(t.orderBy,e):ve.create(e)})},cloneWithPartitionByItems(t,e){return i({...t,partitionBy:t.partitionBy?mi.cloneWithItems(t.partitionBy,e):mi.create(e)})}});var Je=i({is(t){return t.kind==="FromNode"},create(t){return i({kind:"FromNode",froms:i(t)})},cloneWithFroms(t,e){return i({...t,froms:i([...t.froms,...e])})}});var fi=i({is(t){return t.kind==="GroupByNode"},create(t){return i({kind:"GroupByNode",items:i(t)})},cloneWithItems(t,e){return i({...t,items:i([...t.items,...e])})}});var Ni=i({is(t){return t.kind==="HavingNode"},create(t){return i({kind:"HavingNode",having:t})},cloneWithOperation(t,e,r){return i({...t,having:e==="And"?K.create(t.having,r):oe.create(t.having,r)})}});var T=i({is(t){return t.kind==="InsertQueryNode"},create(t,e,r){return i({kind:"InsertQueryNode",into:t,...e&&{with:e},replace:r})},createWithoutInto(){return i({kind:"InsertQueryNode"})},cloneWith(t,e){return i({...t,...e})}});var rr=i({is(t){return t.kind==="ListNode"},create(t){return i({kind:"ListNode",items:i(t)})}});var Ne=i({is(t){return t.kind==="UpdateQueryNode"},create(t,e){return i({kind:"UpdateQueryNode",table:t.length===1?t[0]:rr.create(t),...e&&{with:e}})},createWithoutTable(){return i({kind:"UpdateQueryNode"})},cloneWithFromItems(t,e){return i({...t,from:t.from?Je.cloneWithFroms(t.from,e):Je.create(e)})},cloneWithUpdates(t,e){return i({...t,updates:t.updates?i([...t.updates,...e]):e})},cloneWithLimit(t,e){return i({...t,limit:e})}});var yi=i({is(t){return t.kind==="UsingNode"},create(t){return i({kind:"UsingNode",tables:i(t)})},cloneWithTables(t,e){return i({...t,tables:i([...t.tables,...e])})}});var Be=i({is(t){return t.kind==="DeleteQueryNode"},create(t,e){return i({kind:"DeleteQueryNode",from:Je.create(t),...e&&{with:e}})},cloneWithOrderByItems:(t,e)=>u.cloneWithOrderByItems(t,e),cloneWithoutOrderBy:t=>u.cloneWithoutOrderBy(t),cloneWithLimit(t,e){return i({...t,limit:e})},cloneWithoutLimit(t){return i({...t,limit:void 0})},cloneWithUsing(t,e){return i({...t,using:t.using!==void 0?yi.cloneWithTables(t.using,e):yi.create(e)})}});var Q=i({is(t){return t.kind==="WhereNode"},create(t){return i({kind:"WhereNode",where:t})},cloneWithOperation(t,e,r){return i({...t,where:e==="And"?K.create(t.where,r):oe.create(t.where,r)})}});var wi=i({is(t){return t.kind==="ReturningNode"},create(t){return i({kind:"ReturningNode",selections:i(t)})},cloneWithSelections(t,e){return i({...t,selections:t.selections?i([...t.selections,...e]):i(e)})}});var go=i({is(t){return t.kind==="ExplainNode"},create(t,e){return i({kind:"ExplainNode",format:t,options:e})}});var We=i({is(t){return t.kind==="WhenNode"},create(t){return i({kind:"WhenNode",condition:t})},cloneWithResult(t,e){return i({...t,result:e})}});var I=i({is(t){return t.kind==="MergeQueryNode"},create(t,e){return i({kind:"MergeQueryNode",into:t,...e&&{with:e}})},cloneWithUsing(t,e){return i({...t,using:e})},cloneWithWhen(t,e){return i({...t,whens:t.whens?i([...t.whens,e]):i([e])})},cloneWithThen(t,e){return i({...t,whens:t.whens?i([...t.whens.slice(0,-1),We.cloneWithResult(t.whens[t.whens.length-1],e)]):void 0})}});var xi=i({is(t){return t.kind==="OutputNode"},create(t){return i({kind:"OutputNode",selections:i(t)})},cloneWithSelections(t,e){return i({...t,selections:t.selections?i([...t.selections,...e]):i(e)})}});var u=i({is(t){return x.is(t)||T.is(t)||Ne.is(t)||Be.is(t)||I.is(t)},cloneWithEndModifier(t,e){return i({...t,endModifiers:t.endModifiers?i([...t.endModifiers,e]):i([e])})},cloneWithWhere(t,e){return i({...t,where:t.where?Q.cloneWithOperation(t.where,"And",e):Q.create(e)})},cloneWithJoin(t,e){return i({...t,joins:t.joins?i([...t.joins,e]):i([e])})},cloneWithReturning(t,e){return i({...t,returning:t.returning?wi.cloneWithSelections(t.returning,e):wi.create(e)})},cloneWithoutReturning(t){return i({...t,returning:void 0})},cloneWithoutWhere(t){return i({...t,where:void 0})},cloneWithExplain(t,e,r){return i({...t,explain:go.create(e,r?.toOperationNode())})},cloneWithTop(t,e){return i({...t,top:e})},cloneWithOutput(t,e){return i({...t,output:t.output?xi.cloneWithSelections(t.output,e):xi.create(e)})},cloneWithOrderByItems(t,e){return i({...t,orderBy:t.orderBy?ve.cloneWithItems(t.orderBy,e):ve.create(e)})},cloneWithoutOrderBy(t){return i({...t,orderBy:void 0})}});var x=i({is(t){return t.kind==="SelectQueryNode"},create(t){return i({kind:"SelectQueryNode",...t&&{with:t}})},createFrom(t,e){return i({kind:"SelectQueryNode",from:Je.create(t),...e&&{with:e}})},cloneWithSelections(t,e){return i({...t,selections:t.selections?i([...t.selections,...e]):i(e)})},cloneWithDistinctOn(t,e){return i({...t,distinctOn:t.distinctOn?i([...t.distinctOn,...e]):i(e)})},cloneWithFrontModifier(t,e){return i({...t,frontModifiers:t.frontModifiers?i([...t.frontModifiers,e]):i([e])})},cloneWithOrderByItems:(t,e)=>u.cloneWithOrderByItems(t,e),cloneWithGroupByItems(t,e){return i({...t,groupBy:t.groupBy?fi.cloneWithItems(t.groupBy,e):fi.create(e)})},cloneWithLimit(t,e){return i({...t,limit:e})},cloneWithOffset(t,e){return i({...t,offset:e})},cloneWithFetch(t,e){return i({...t,fetch:e})},cloneWithHaving(t,e){return i({...t,having:t.having?Ni.cloneWithOperation(t.having,"And",e):Ni.create(e)})},cloneWithSetOperations(t,e){return i({...t,setOperations:t.setOperations?i([...t.setOperations,...e]):i([...e])})},cloneWithoutSelections(t){return i({...t,selections:[]})},cloneWithoutLimit(t){return i({...t,limit:void 0})},cloneWithoutOffset(t){return i({...t,offset:void 0})},cloneWithoutOrderBy:t=>u.cloneWithoutOrderBy(t),cloneWithoutGroupBy(t){return i({...t,groupBy:void 0})}});var ir=class t{#e;constructor(e){this.#e=i(e)}on(...e){return new t({...this.#e,joinNode:Oe.cloneWithOn(this.#e.joinNode,O(e))})}onRef(e,r,o){return new t({...this.#e,joinNode:Oe.cloneWithOn(this.#e.joinNode,R(e,r,o))})}onTrue(){return new t({...this.#e,joinNode:Oe.cloneWithOn(this.#e.joinNode,W.createWithSql("true"))})}$call(e){return e(this)}toOperationNode(){return this.#e.joinNode}};var Oo=i({is(t){return t.kind==="PartitionByItemNode"},create(t){return i({kind:"PartitionByItemNode",partitionBy:t})}});function bo(t){return Ce(t).map(Oo.create)}var or=class t{#e;constructor(e){this.#e=i(e)}orderBy(...e){return new t({overNode:qt.cloneWithOrderByItems(this.#e.overNode,_(e))})}clearOrderBy(){return new t({overNode:u.cloneWithoutOrderBy(this.#e.overNode)})}partitionBy(e){return new t({overNode:qt.cloneWithPartitionByItems(this.#e.overNode,bo(e))})}$call(e){return e(this)}toOperationNode(){return this.#e.overNode}};var nt=i({is(t){return t.kind==="SelectionNode"},create(t){return i({kind:"SelectionNode",selection:t})},createSelectAll(){return i({kind:"SelectionNode",selection:et.create()})},createSelectAllFromTable(t){return i({kind:"SelectionNode",selection:tt.createSelectAll(t)})}});function A(t){return k(t)?A(t(se())):M(t)?t.map(e=>Co(e)):[Co(t)]}function Co(t){return v(t)?nt.create(No(t)):Yt(t)?nt.create(t.toOperationNode()):nt.create(nr(t))}function D(t){return t?Array.isArray(t)?t.map(vo):[vo(t)]:[nt.createSelectAll()]}function vo(t){if(v(t))return nt.createSelectAllFromTable(y(t));throw new Error(`invalid value selectAll expression: ${JSON.stringify(t)}`)}var Wo=i({is(t){return t.kind==="ValuesNode"},create(t){return i({kind:"ValuesNode",values:i(t)})}});var ko=i({is(t){return t.kind==="DefaultInsertValueNode"},create(){return i({kind:"DefaultInsertValueNode"})}});function sr(t){let e=k(t)?t(se()):t,r=M(e)?e:i([e]);return En(r)}function En(t){let e=Rn(t);return[i([...e.keys()].map(m.create)),Wo.create(t.map(r=>In(r,e)))]}function Rn(t){let e=new Map;for(let r of t){let o=Object.keys(r);for(let n of o)!e.has(n)&&r[n]!==void 0&&e.set(n,e.size)}return e}function In(t,e){let r=Object.keys(t),o=Array.from({length:e.size}),n=!1,a=r.length;for(let c of r){let l=e.get(c);if(H(l)){a--;continue}let h=t[c];(H(h)||be(h))&&(n=!0),o[l]=h}if(a<e.size||n){let c=ko.create();return me.create(o.map(l=>H(l)?c:g(l)))}return _t.create(o)}var gi=i({is(t){return t.kind==="ColumnUpdateNode"},create(t,e){return i({kind:"ColumnUpdateNode",column:t,value:e})}});function To(...t){return t.length===2?[gi.create(B(t[0]),g(t[1]))]:Bt(t[0])}function Bt(t){let e=k(t)?t(se()):t;return Object.entries(e).filter(([r,o])=>o!==void 0).map(([r,o])=>gi.create(m.create(r),g(o)))}var So=i({is(t){return t.kind==="OnDuplicateKeyNode"},create(t){return i({kind:"OnDuplicateKeyNode",updates:t})}});var ar=class{insertId;numInsertedOrUpdatedRows;constructor(e,r){this.insertId=e,this.numInsertedOrUpdatedRows=r}};var te=class extends Error{node;constructor(e){super("no result"),this.node=e}};function ye(t){return Object.prototype.hasOwnProperty.call(t,"prototype")}var $=i({is(t){return t.kind==="OnConflictNode"},create(){return i({kind:"OnConflictNode"})},cloneWith(t,e){return i({...t,...e})},cloneWithIndexWhere(t,e){return i({...t,indexWhere:t.indexWhere?Q.cloneWithOperation(t.indexWhere,"And",e):Q.create(e)})},cloneWithIndexOrWhere(t,e){return i({...t,indexWhere:t.indexWhere?Q.cloneWithOperation(t.indexWhere,"Or",e):Q.create(e)})},cloneWithUpdateWhere(t,e){return i({...t,updateWhere:t.updateWhere?Q.cloneWithOperation(t.updateWhere,"And",e):Q.create(e)})},cloneWithUpdateOrWhere(t,e){return i({...t,updateWhere:t.updateWhere?Q.cloneWithOperation(t.updateWhere,"Or",e):Q.create(e)})},cloneWithoutIndexWhere(t){return i({...t,indexWhere:void 0})},cloneWithoutUpdateWhere(t){return i({...t,updateWhere:void 0})}});var ur=class t{#e;constructor(e){this.#e=i(e)}column(e){let r=m.create(e);return new t({...this.#e,onConflictNode:$.cloneWith(this.#e.onConflictNode,{columns:this.#e.onConflictNode.columns?i([...this.#e.onConflictNode.columns,r]):i([r])})})}columns(e){let r=e.map(m.create);return new t({...this.#e,onConflictNode:$.cloneWith(this.#e.onConflictNode,{columns:this.#e.onConflictNode.columns?i([...this.#e.onConflictNode.columns,...r]):i(r)})})}constraint(e){return new t({...this.#e,onConflictNode:$.cloneWith(this.#e.onConflictNode,{constraint:p.create(e)})})}expression(e){return new t({...this.#e,onConflictNode:$.cloneWith(this.#e.onConflictNode,{indexExpression:e.toOperationNode()})})}where(...e){return new t({...this.#e,onConflictNode:$.cloneWithIndexWhere(this.#e.onConflictNode,O(e))})}whereRef(e,r,o){return new t({...this.#e,onConflictNode:$.cloneWithIndexWhere(this.#e.onConflictNode,R(e,r,o))})}clearWhere(){return new t({...this.#e,onConflictNode:$.cloneWithoutIndexWhere(this.#e.onConflictNode)})}doNothing(){return new Oi({...this.#e,onConflictNode:$.cloneWith(this.#e.onConflictNode,{doNothing:!0})})}doUpdateSet(e){return new bi({...this.#e,onConflictNode:$.cloneWith(this.#e.onConflictNode,{updates:Bt(e)})})}$call(e){return e(this)}},Oi=class{#e;constructor(e){this.#e=i(e)}toOperationNode(){return this.#e.onConflictNode}},bi=class t{#e;constructor(e){this.#e=i(e)}where(...e){return new t({...this.#e,onConflictNode:$.cloneWithUpdateWhere(this.#e.onConflictNode,O(e))})}whereRef(e,r,o){return new t({...this.#e,onConflictNode:$.cloneWithUpdateWhere(this.#e.onConflictNode,R(e,r,o))})}clearWhere(){return new t({...this.#e,onConflictNode:$.cloneWithoutUpdateWhere(this.#e.onConflictNode)})}$call(e){return e(this)}toOperationNode(){return this.#e.onConflictNode}};var Ao=i({is(t){return t.kind==="TopNode"},create(t,e){return i({kind:"TopNode",expression:t,modifiers:e})}});function ae(t,e){if(!Ee(t)&&!_e(t))throw new Error(`Invalid top expression: ${t}`);if(!H(e)&&!Dn(e))throw new Error(`Invalid top modifiers: ${e}`);return Ao.create(t,e)}function Dn(t){return t==="percent"||t==="with ties"||t==="percent with ties"}var $e=i({is(t){return t.kind==="OrActionNode"},create(t){return i({kind:"OrActionNode",action:t})}});var Qt=class t{#e;constructor(e){this.#e=i(e)}values(e){let[r,o]=sr(e);return new t({...this.#e,queryNode:T.cloneWith(this.#e.queryNode,{columns:r,values:o})})}columns(e){return new t({...this.#e,queryNode:T.cloneWith(this.#e.queryNode,{columns:i(e.map(m.create))})})}expression(e){return new t({...this.#e,queryNode:T.cloneWith(this.#e.queryNode,{values:j(e)})})}defaultValues(){return new t({...this.#e,queryNode:T.cloneWith(this.#e.queryNode,{defaultValues:!0})})}modifyEnd(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,e.toOperationNode())})}ignore(){return new t({...this.#e,queryNode:T.cloneWith(this.#e.queryNode,{orAction:$e.create("ignore")})})}orIgnore(){return new t({...this.#e,queryNode:T.cloneWith(this.#e.queryNode,{orAction:$e.create("ignore")})})}orAbort(){return new t({...this.#e,queryNode:T.cloneWith(this.#e.queryNode,{orAction:$e.create("abort")})})}orFail(){return new t({...this.#e,queryNode:T.cloneWith(this.#e.queryNode,{orAction:$e.create("fail")})})}orReplace(){return new t({...this.#e,queryNode:T.cloneWith(this.#e.queryNode,{orAction:$e.create("replace")})})}orRollback(){return new t({...this.#e,queryNode:T.cloneWith(this.#e.queryNode,{orAction:$e.create("rollback")})})}top(e,r){return new t({...this.#e,queryNode:u.cloneWithTop(this.#e.queryNode,ae(e,r))})}onConflict(e){return new t({...this.#e,queryNode:T.cloneWith(this.#e.queryNode,{onConflict:e(new ur({onConflictNode:$.create()})).toOperationNode()})})}onDuplicateKeyUpdate(e){return new t({...this.#e,queryNode:T.cloneWith(this.#e.queryNode,{onDuplicateKey:So.create(Bt(e))})})}returning(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,A(e))})}returningAll(){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,D())})}output(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,A(e))})}outputAll(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,D(e))})}clearReturning(){return new t({...this.#e,queryNode:u.cloneWithoutReturning(this.#e.queryNode)})}$call(e){return e(this)}$if(e,r){return e?r(this):new t({...this.#e})}$castTo(){return new t(this.#e)}$narrowType(){return new t(this.#e)}$assertType(){return new t(this.#e)}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}toOperationNode(){return this.#e.executor.transformQuery(this.#e.queryNode,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){let e=this.compile(),r=await this.#e.executor.executeQuery(e,this.#e.queryId),{adapter:o}=this.#e.executor,n=e.query;return n.returning&&o.supportsReturning||n.output&&o.supportsOutput?r.rows:[new ar(r.insertId,r.numAffectedRows??BigInt(0))]}async executeTakeFirst(){let[e]=await this.execute();return e}async executeTakeFirstOrThrow(e=te){let r=await this.executeTakeFirst();if(r===void 0)throw ye(e)?new e(this.toOperationNode()):e(this.toOperationNode());return r}async*stream(e=100){let r=this.compile(),o=this.#e.executor.stream(r,e,this.#e.queryId);for await(let n of o)yield*n.rows}async explain(e,r){return await new t({...this.#e,queryNode:u.cloneWithExplain(this.#e.queryNode,e,r)}).execute()}};var dr=class{numDeletedRows;constructor(e){this.numDeletedRows=e}};var st=i({is(t){return t.kind==="LimitNode"},create(t){return i({kind:"LimitNode",limit:t})}});var pr=class t{#e;constructor(e){this.#e=i(e)}where(...e){return new t({...this.#e,queryNode:u.cloneWithWhere(this.#e.queryNode,O(e))})}whereRef(e,r,o){return new t({...this.#e,queryNode:u.cloneWithWhere(this.#e.queryNode,R(e,r,o))})}clearWhere(){return new t({...this.#e,queryNode:u.cloneWithoutWhere(this.#e.queryNode)})}top(e,r){return new t({...this.#e,queryNode:u.cloneWithTop(this.#e.queryNode,ae(e,r))})}using(e){return new t({...this.#e,queryNode:Be.cloneWithUsing(this.#e.queryNode,ue(e))})}innerJoin(...e){return this.#t("InnerJoin",e)}leftJoin(...e){return this.#t("LeftJoin",e)}rightJoin(...e){return this.#t("RightJoin",e)}fullJoin(...e){return this.#t("FullJoin",e)}#t(e,r){return new t({...this.#e,queryNode:u.cloneWithJoin(this.#e.queryNode,Qe(e,r))})}returning(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,A(e))})}returningAll(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,D(e))})}output(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,A(e))})}outputAll(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,D(e))})}clearReturning(){return new t({...this.#e,queryNode:u.cloneWithoutReturning(this.#e.queryNode)})}clearLimit(){return new t({...this.#e,queryNode:Be.cloneWithoutLimit(this.#e.queryNode)})}orderBy(...e){return new t({...this.#e,queryNode:u.cloneWithOrderByItems(this.#e.queryNode,_(e))})}clearOrderBy(){return new t({...this.#e,queryNode:u.cloneWithoutOrderBy(this.#e.queryNode)})}limit(e){return new t({...this.#e,queryNode:Be.cloneWithLimit(this.#e.queryNode,st.create(g(e)))})}modifyEnd(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,e.toOperationNode())})}$call(e){return e(this)}$if(e,r){return e?r(this):new t({...this.#e})}$castTo(){return new t(this.#e)}$narrowType(){return new t(this.#e)}$assertType(){return new t(this.#e)}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}toOperationNode(){return this.#e.executor.transformQuery(this.#e.queryNode,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){let e=this.compile(),r=await this.#e.executor.executeQuery(e,this.#e.queryId),{adapter:o}=this.#e.executor,n=e.query;return n.returning&&o.supportsReturning||n.output&&o.supportsOutput?r.rows:[new dr(r.numAffectedRows??BigInt(0))]}async executeTakeFirst(){let[e]=await this.execute();return e}async executeTakeFirstOrThrow(e=te){let r=await this.executeTakeFirst();if(r===void 0)throw ye(e)?new e(this.toOperationNode()):e(this.toOperationNode());return r}async*stream(e=100){let r=this.compile(),o=this.#e.executor.stream(r,e,this.#e.queryId);for await(let n of o)yield*n.rows}async explain(e,r){return await new t({...this.#e,queryNode:u.cloneWithExplain(this.#e.queryNode,e,r)}).execute()}};var cr=class{numUpdatedRows;numChangedRows;constructor(e,r){this.numUpdatedRows=e,this.numChangedRows=r}};var at=class t{#e;constructor(e){this.#e=i(e)}where(...e){return new t({...this.#e,queryNode:u.cloneWithWhere(this.#e.queryNode,O(e))})}whereRef(e,r,o){return new t({...this.#e,queryNode:u.cloneWithWhere(this.#e.queryNode,R(e,r,o))})}clearWhere(){return new t({...this.#e,queryNode:u.cloneWithoutWhere(this.#e.queryNode)})}top(e,r){return new t({...this.#e,queryNode:u.cloneWithTop(this.#e.queryNode,ae(e,r))})}from(e){return new t({...this.#e,queryNode:Ne.cloneWithFromItems(this.#e.queryNode,ue(e))})}innerJoin(...e){return this.#t("InnerJoin",e)}leftJoin(...e){return this.#t("LeftJoin",e)}rightJoin(...e){return this.#t("RightJoin",e)}fullJoin(...e){return this.#t("FullJoin",e)}#t(e,r){return new t({...this.#e,queryNode:u.cloneWithJoin(this.#e.queryNode,Qe(e,r))})}orderBy(...e){return new t({...this.#e,queryNode:u.cloneWithOrderByItems(this.#e.queryNode,_(e))})}clearOrderBy(){return new t({...this.#e,queryNode:u.cloneWithoutOrderBy(this.#e.queryNode)})}limit(e){return new t({...this.#e,queryNode:Ne.cloneWithLimit(this.#e.queryNode,st.create(g(e)))})}set(...e){return new t({...this.#e,queryNode:Ne.cloneWithUpdates(this.#e.queryNode,To(...e))})}returning(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,A(e))})}returningAll(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,D(e))})}output(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,A(e))})}outputAll(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,D(e))})}modifyEnd(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,e.toOperationNode())})}clearReturning(){return new t({...this.#e,queryNode:u.cloneWithoutReturning(this.#e.queryNode)})}$call(e){return e(this)}$if(e,r){return e?r(this):new t({...this.#e})}$castTo(){return new t(this.#e)}$narrowType(){return new t(this.#e)}$assertType(){return new t(this.#e)}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}toOperationNode(){return this.#e.executor.transformQuery(this.#e.queryNode,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){let e=this.compile(),r=await this.#e.executor.executeQuery(e,this.#e.queryId),{adapter:o}=this.#e.executor,n=e.query;return n.returning&&o.supportsReturning||n.output&&o.supportsOutput?r.rows:[new cr(r.numAffectedRows??BigInt(0),r.numChangedRows)]}async executeTakeFirst(){let[e]=await this.execute();return e}async executeTakeFirstOrThrow(e=te){let r=await this.executeTakeFirst();if(r===void 0)throw ye(e)?new e(this.toOperationNode()):e(this.toOperationNode());return r}async*stream(e=100){let r=this.compile(),o=this.#e.executor.stream(r,e,this.#e.queryId);for await(let n of o)yield*n.rows}async explain(e,r){return await new t({...this.#e,queryNode:u.cloneWithExplain(this.#e.queryNode,e,r)}).execute()}};var Ci=i({is(t){return t.kind==="CommonTableExpressionNameNode"},create(t,e){return i({kind:"CommonTableExpressionNameNode",table:Y.create(t),columns:e?i(e.map(m.create)):void 0})}});var ut=i({is(t){return t.kind==="CommonTableExpressionNode"},create(t,e){return i({kind:"CommonTableExpressionNode",name:t,expression:e})},cloneWith(t,e){return i({...t,...e})}});var hr=class t{#e;constructor(e){this.#e=i(e)}materialized(){return new t({...this.#e,node:ut.cloneWith(this.#e.node,{materialized:!0})})}notMaterialized(){return new t({...this.#e,node:ut.cloneWith(this.#e.node,{materialized:!1})})}toOperationNode(){return this.#e.node}};function vi(t,e){let r=e(Ro()).toOperationNode();return k(t)?t(qn(r)).toOperationNode():ut.create(Eo(t),r)}function qn(t){return e=>new hr({node:ut.create(Eo(e),t)})}function Eo(t){if(t.includes("(")){let e=t.split(/[\(\)]/),r=e[0],o=e[1].split(",").map(n=>n.trim());return Ci.create(r,o)}else return Ci.create(t)}var Lt=i({is(t){return t.kind==="WithNode"},create(t,e){return i({kind:"WithNode",expressions:i([t]),...e})},cloneWithExpression(t,e){return i({...t,expressions:i([...t.expressions,e])})}});var Io=["A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z","a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z","0","1","2","3","4","5","6","7","8","9"];function Do(t){let e="";for(let r=0;r<t;++r)e+=Bn();return e}function Bn(){return Io[~~(Math.random()*Io.length)]}function f(){return new Wi}var Wi=class{#e;get queryId(){return this.#e===void 0&&(this.#e=Do(8)),this.#e}};var Le=class{nodeStack=[];#e=i({AliasNode:this.transformAlias.bind(this),ColumnNode:this.transformColumn.bind(this),IdentifierNode:this.transformIdentifier.bind(this),SchemableIdentifierNode:this.transformSchemableIdentifier.bind(this),RawNode:this.transformRaw.bind(this),ReferenceNode:this.transformReference.bind(this),SelectQueryNode:this.transformSelectQuery.bind(this),SelectionNode:this.transformSelection.bind(this),TableNode:this.transformTable.bind(this),FromNode:this.transformFrom.bind(this),SelectAllNode:this.transformSelectAll.bind(this),AndNode:this.transformAnd.bind(this),OrNode:this.transformOr.bind(this),ValueNode:this.transformValue.bind(this),ValueListNode:this.transformValueList.bind(this),PrimitiveValueListNode:this.transformPrimitiveValueList.bind(this),ParensNode:this.transformParens.bind(this),JoinNode:this.transformJoin.bind(this),OperatorNode:this.transformOperator.bind(this),WhereNode:this.transformWhere.bind(this),InsertQueryNode:this.transformInsertQuery.bind(this),DeleteQueryNode:this.transformDeleteQuery.bind(this),ReturningNode:this.transformReturning.bind(this),CreateTableNode:this.transformCreateTable.bind(this),AddColumnNode:this.transformAddColumn.bind(this),ColumnDefinitionNode:this.transformColumnDefinition.bind(this),DropTableNode:this.transformDropTable.bind(this),DataTypeNode:this.transformDataType.bind(this),OrderByNode:this.transformOrderBy.bind(this),OrderByItemNode:this.transformOrderByItem.bind(this),GroupByNode:this.transformGroupBy.bind(this),GroupByItemNode:this.transformGroupByItem.bind(this),UpdateQueryNode:this.transformUpdateQuery.bind(this),ColumnUpdateNode:this.transformColumnUpdate.bind(this),LimitNode:this.transformLimit.bind(this),OffsetNode:this.transformOffset.bind(this),OnConflictNode:this.transformOnConflict.bind(this),OnDuplicateKeyNode:this.transformOnDuplicateKey.bind(this),CreateIndexNode:this.transformCreateIndex.bind(this),DropIndexNode:this.transformDropIndex.bind(this),ListNode:this.transformList.bind(this),PrimaryKeyConstraintNode:this.transformPrimaryKeyConstraint.bind(this),UniqueConstraintNode:this.transformUniqueConstraint.bind(this),ReferencesNode:this.transformReferences.bind(this),CheckConstraintNode:this.transformCheckConstraint.bind(this),WithNode:this.transformWith.bind(this),CommonTableExpressionNode:this.transformCommonTableExpression.bind(this),CommonTableExpressionNameNode:this.transformCommonTableExpressionName.bind(this),HavingNode:this.transformHaving.bind(this),CreateSchemaNode:this.transformCreateSchema.bind(this),DropSchemaNode:this.transformDropSchema.bind(this),AlterTableNode:this.transformAlterTable.bind(this),DropColumnNode:this.transformDropColumn.bind(this),RenameColumnNode:this.transformRenameColumn.bind(this),AlterColumnNode:this.transformAlterColumn.bind(this),ModifyColumnNode:this.transformModifyColumn.bind(this),AddConstraintNode:this.transformAddConstraint.bind(this),DropConstraintNode:this.transformDropConstraint.bind(this),RenameConstraintNode:this.transformRenameConstraint.bind(this),ForeignKeyConstraintNode:this.transformForeignKeyConstraint.bind(this),CreateViewNode:this.transformCreateView.bind(this),RefreshMaterializedViewNode:this.transformRefreshMaterializedView.bind(this),DropViewNode:this.transformDropView.bind(this),GeneratedNode:this.transformGenerated.bind(this),DefaultValueNode:this.transformDefaultValue.bind(this),OnNode:this.transformOn.bind(this),ValuesNode:this.transformValues.bind(this),SelectModifierNode:this.transformSelectModifier.bind(this),CreateTypeNode:this.transformCreateType.bind(this),DropTypeNode:this.transformDropType.bind(this),ExplainNode:this.transformExplain.bind(this),DefaultInsertValueNode:this.transformDefaultInsertValue.bind(this),AggregateFunctionNode:this.transformAggregateFunction.bind(this),OverNode:this.transformOver.bind(this),PartitionByNode:this.transformPartitionBy.bind(this),PartitionByItemNode:this.transformPartitionByItem.bind(this),SetOperationNode:this.transformSetOperation.bind(this),BinaryOperationNode:this.transformBinaryOperation.bind(this),UnaryOperationNode:this.transformUnaryOperation.bind(this),UsingNode:this.transformUsing.bind(this),FunctionNode:this.transformFunction.bind(this),CaseNode:this.transformCase.bind(this),WhenNode:this.transformWhen.bind(this),JSONReferenceNode:this.transformJSONReference.bind(this),JSONPathNode:this.transformJSONPath.bind(this),JSONPathLegNode:this.transformJSONPathLeg.bind(this),JSONOperatorChainNode:this.transformJSONOperatorChain.bind(this),TupleNode:this.transformTuple.bind(this),MergeQueryNode:this.transformMergeQuery.bind(this),MatchedNode:this.transformMatched.bind(this),AddIndexNode:this.transformAddIndex.bind(this),CastNode:this.transformCast.bind(this),FetchNode:this.transformFetch.bind(this),TopNode:this.transformTop.bind(this),OutputNode:this.transformOutput.bind(this),OrActionNode:this.transformOrAction.bind(this),CollateNode:this.transformCollate.bind(this)});transformNode(e,r){if(!e)return e;this.nodeStack.push(e);let o=this.transformNodeImpl(e,r);return this.nodeStack.pop(),i(o)}transformNodeImpl(e,r){return this.#e[e.kind](e,r)}transformNodeList(e,r){return e&&i(e.map(o=>this.transformNode(o,r)))}transformSelectQuery(e,r){return{kind:"SelectQueryNode",from:this.transformNode(e.from,r),selections:this.transformNodeList(e.selections,r),distinctOn:this.transformNodeList(e.distinctOn,r),joins:this.transformNodeList(e.joins,r),groupBy:this.transformNode(e.groupBy,r),orderBy:this.transformNode(e.orderBy,r),where:this.transformNode(e.where,r),frontModifiers:this.transformNodeList(e.frontModifiers,r),endModifiers:this.transformNodeList(e.endModifiers,r),limit:this.transformNode(e.limit,r),offset:this.transformNode(e.offset,r),with:this.transformNode(e.with,r),having:this.transformNode(e.having,r),explain:this.transformNode(e.explain,r),setOperations:this.transformNodeList(e.setOperations,r),fetch:this.transformNode(e.fetch,r),top:this.transformNode(e.top,r)}}transformSelection(e,r){return{kind:"SelectionNode",selection:this.transformNode(e.selection,r)}}transformColumn(e,r){return{kind:"ColumnNode",column:this.transformNode(e.column,r)}}transformAlias(e,r){return{kind:"AliasNode",node:this.transformNode(e.node,r),alias:this.transformNode(e.alias,r)}}transformTable(e,r){return{kind:"TableNode",table:this.transformNode(e.table,r)}}transformFrom(e,r){return{kind:"FromNode",froms:this.transformNodeList(e.froms,r)}}transformReference(e,r){return{kind:"ReferenceNode",column:this.transformNode(e.column,r),table:this.transformNode(e.table,r)}}transformAnd(e,r){return{kind:"AndNode",left:this.transformNode(e.left,r),right:this.transformNode(e.right,r)}}transformOr(e,r){return{kind:"OrNode",left:this.transformNode(e.left,r),right:this.transformNode(e.right,r)}}transformValueList(e,r){return{kind:"ValueListNode",values:this.transformNodeList(e.values,r)}}transformParens(e,r){return{kind:"ParensNode",node:this.transformNode(e.node,r)}}transformJoin(e,r){return{kind:"JoinNode",joinType:e.joinType,table:this.transformNode(e.table,r),on:this.transformNode(e.on,r)}}transformRaw(e,r){return{kind:"RawNode",sqlFragments:i([...e.sqlFragments]),parameters:this.transformNodeList(e.parameters,r)}}transformWhere(e,r){return{kind:"WhereNode",where:this.transformNode(e.where,r)}}transformInsertQuery(e,r){return{kind:"InsertQueryNode",into:this.transformNode(e.into,r),columns:this.transformNodeList(e.columns,r),values:this.transformNode(e.values,r),returning:this.transformNode(e.returning,r),onConflict:this.transformNode(e.onConflict,r),onDuplicateKey:this.transformNode(e.onDuplicateKey,r),endModifiers:this.transformNodeList(e.endModifiers,r),with:this.transformNode(e.with,r),ignore:e.ignore,orAction:this.transformNode(e.orAction,r),replace:e.replace,explain:this.transformNode(e.explain,r),defaultValues:e.defaultValues,top:this.transformNode(e.top,r),output:this.transformNode(e.output,r)}}transformValues(e,r){return{kind:"ValuesNode",values:this.transformNodeList(e.values,r)}}transformDeleteQuery(e,r){return{kind:"DeleteQueryNode",from:this.transformNode(e.from,r),using:this.transformNode(e.using,r),joins:this.transformNodeList(e.joins,r),where:this.transformNode(e.where,r),returning:this.transformNode(e.returning,r),endModifiers:this.transformNodeList(e.endModifiers,r),with:this.transformNode(e.with,r),orderBy:this.transformNode(e.orderBy,r),limit:this.transformNode(e.limit,r),explain:this.transformNode(e.explain,r),top:this.transformNode(e.top,r),output:this.transformNode(e.output,r)}}transformReturning(e,r){return{kind:"ReturningNode",selections:this.transformNodeList(e.selections,r)}}transformCreateTable(e,r){return{kind:"CreateTableNode",table:this.transformNode(e.table,r),columns:this.transformNodeList(e.columns,r),constraints:this.transformNodeList(e.constraints,r),temporary:e.temporary,ifNotExists:e.ifNotExists,onCommit:e.onCommit,frontModifiers:this.transformNodeList(e.frontModifiers,r),endModifiers:this.transformNodeList(e.endModifiers,r),selectQuery:this.transformNode(e.selectQuery,r)}}transformColumnDefinition(e,r){return{kind:"ColumnDefinitionNode",column:this.transformNode(e.column,r),dataType:this.transformNode(e.dataType,r),references:this.transformNode(e.references,r),primaryKey:e.primaryKey,autoIncrement:e.autoIncrement,unique:e.unique,notNull:e.notNull,unsigned:e.unsigned,defaultTo:this.transformNode(e.defaultTo,r),check:this.transformNode(e.check,r),generated:this.transformNode(e.generated,r),frontModifiers:this.transformNodeList(e.frontModifiers,r),endModifiers:this.transformNodeList(e.endModifiers,r),nullsNotDistinct:e.nullsNotDistinct,identity:e.identity,ifNotExists:e.ifNotExists}}transformAddColumn(e,r){return{kind:"AddColumnNode",column:this.transformNode(e.column,r)}}transformDropTable(e,r){return{kind:"DropTableNode",table:this.transformNode(e.table,r),ifExists:e.ifExists,cascade:e.cascade}}transformOrderBy(e,r){return{kind:"OrderByNode",items:this.transformNodeList(e.items,r)}}transformOrderByItem(e,r){return{kind:"OrderByItemNode",orderBy:this.transformNode(e.orderBy,r),direction:this.transformNode(e.direction,r),collation:this.transformNode(e.collation,r),nulls:e.nulls}}transformGroupBy(e,r){return{kind:"GroupByNode",items:this.transformNodeList(e.items,r)}}transformGroupByItem(e,r){return{kind:"GroupByItemNode",groupBy:this.transformNode(e.groupBy,r)}}transformUpdateQuery(e,r){return{kind:"UpdateQueryNode",table:this.transformNode(e.table,r),from:this.transformNode(e.from,r),joins:this.transformNodeList(e.joins,r),where:this.transformNode(e.where,r),updates:this.transformNodeList(e.updates,r),returning:this.transformNode(e.returning,r),endModifiers:this.transformNodeList(e.endModifiers,r),with:this.transformNode(e.with,r),explain:this.transformNode(e.explain,r),limit:this.transformNode(e.limit,r),top:this.transformNode(e.top,r),output:this.transformNode(e.output,r),orderBy:this.transformNode(e.orderBy,r)}}transformColumnUpdate(e,r){return{kind:"ColumnUpdateNode",column:this.transformNode(e.column,r),value:this.transformNode(e.value,r)}}transformLimit(e,r){return{kind:"LimitNode",limit:this.transformNode(e.limit,r)}}transformOffset(e,r){return{kind:"OffsetNode",offset:this.transformNode(e.offset,r)}}transformOnConflict(e,r){return{kind:"OnConflictNode",columns:this.transformNodeList(e.columns,r),constraint:this.transformNode(e.constraint,r),indexExpression:this.transformNode(e.indexExpression,r),indexWhere:this.transformNode(e.indexWhere,r),updates:this.transformNodeList(e.updates,r),updateWhere:this.transformNode(e.updateWhere,r),doNothing:e.doNothing}}transformOnDuplicateKey(e,r){return{kind:"OnDuplicateKeyNode",updates:this.transformNodeList(e.updates,r)}}transformCreateIndex(e,r){return{kind:"CreateIndexNode",name:this.transformNode(e.name,r),table:this.transformNode(e.table,r),columns:this.transformNodeList(e.columns,r),unique:e.unique,using:this.transformNode(e.using,r),ifNotExists:e.ifNotExists,where:this.transformNode(e.where,r),nullsNotDistinct:e.nullsNotDistinct}}transformList(e,r){return{kind:"ListNode",items:this.transformNodeList(e.items,r)}}transformDropIndex(e,r){return{kind:"DropIndexNode",name:this.transformNode(e.name,r),table:this.transformNode(e.table,r),ifExists:e.ifExists,cascade:e.cascade}}transformPrimaryKeyConstraint(e,r){return{kind:"PrimaryKeyConstraintNode",columns:this.transformNodeList(e.columns,r),name:this.transformNode(e.name,r),deferrable:e.deferrable,initiallyDeferred:e.initiallyDeferred}}transformUniqueConstraint(e,r){return{kind:"UniqueConstraintNode",columns:this.transformNodeList(e.columns,r),name:this.transformNode(e.name,r),nullsNotDistinct:e.nullsNotDistinct,deferrable:e.deferrable,initiallyDeferred:e.initiallyDeferred}}transformForeignKeyConstraint(e,r){return{kind:"ForeignKeyConstraintNode",columns:this.transformNodeList(e.columns,r),references:this.transformNode(e.references,r),name:this.transformNode(e.name,r),onDelete:e.onDelete,onUpdate:e.onUpdate,deferrable:e.deferrable,initiallyDeferred:e.initiallyDeferred}}transformSetOperation(e,r){return{kind:"SetOperationNode",operator:e.operator,expression:this.transformNode(e.expression,r),all:e.all}}transformReferences(e,r){return{kind:"ReferencesNode",table:this.transformNode(e.table,r),columns:this.transformNodeList(e.columns,r),onDelete:e.onDelete,onUpdate:e.onUpdate}}transformCheckConstraint(e,r){return{kind:"CheckConstraintNode",expression:this.transformNode(e.expression,r),name:this.transformNode(e.name,r)}}transformWith(e,r){return{kind:"WithNode",expressions:this.transformNodeList(e.expressions,r),recursive:e.recursive}}transformCommonTableExpression(e,r){return{kind:"CommonTableExpressionNode",name:this.transformNode(e.name,r),materialized:e.materialized,expression:this.transformNode(e.expression,r)}}transformCommonTableExpressionName(e,r){return{kind:"CommonTableExpressionNameNode",table:this.transformNode(e.table,r),columns:this.transformNodeList(e.columns,r)}}transformHaving(e,r){return{kind:"HavingNode",having:this.transformNode(e.having,r)}}transformCreateSchema(e,r){return{kind:"CreateSchemaNode",schema:this.transformNode(e.schema,r),ifNotExists:e.ifNotExists}}transformDropSchema(e,r){return{kind:"DropSchemaNode",schema:this.transformNode(e.schema,r),ifExists:e.ifExists,cascade:e.cascade}}transformAlterTable(e,r){return{kind:"AlterTableNode",table:this.transformNode(e.table,r),renameTo:this.transformNode(e.renameTo,r),setSchema:this.transformNode(e.setSchema,r),columnAlterations:this.transformNodeList(e.columnAlterations,r),addConstraint:this.transformNode(e.addConstraint,r),dropConstraint:this.transformNode(e.dropConstraint,r),renameConstraint:this.transformNode(e.renameConstraint,r),addIndex:this.transformNode(e.addIndex,r),dropIndex:this.transformNode(e.dropIndex,r)}}transformDropColumn(e,r){return{kind:"DropColumnNode",column:this.transformNode(e.column,r)}}transformRenameColumn(e,r){return{kind:"RenameColumnNode",column:this.transformNode(e.column,r),renameTo:this.transformNode(e.renameTo,r)}}transformAlterColumn(e,r){return{kind:"AlterColumnNode",column:this.transformNode(e.column,r),dataType:this.transformNode(e.dataType,r),dataTypeExpression:this.transformNode(e.dataTypeExpression,r),setDefault:this.transformNode(e.setDefault,r),dropDefault:e.dropDefault,setNotNull:e.setNotNull,dropNotNull:e.dropNotNull}}transformModifyColumn(e,r){return{kind:"ModifyColumnNode",column:this.transformNode(e.column,r)}}transformAddConstraint(e,r){return{kind:"AddConstraintNode",constraint:this.transformNode(e.constraint,r)}}transformDropConstraint(e,r){return{kind:"DropConstraintNode",constraintName:this.transformNode(e.constraintName,r),ifExists:e.ifExists,modifier:e.modifier}}transformRenameConstraint(e,r){return{kind:"RenameConstraintNode",oldName:this.transformNode(e.oldName,r),newName:this.transformNode(e.newName,r)}}transformCreateView(e,r){return{kind:"CreateViewNode",name:this.transformNode(e.name,r),temporary:e.temporary,orReplace:e.orReplace,ifNotExists:e.ifNotExists,materialized:e.materialized,columns:this.transformNodeList(e.columns,r),as:this.transformNode(e.as,r)}}transformRefreshMaterializedView(e,r){return{kind:"RefreshMaterializedViewNode",name:this.transformNode(e.name,r),concurrently:e.concurrently,withNoData:e.withNoData}}transformDropView(e,r){return{kind:"DropViewNode",name:this.transformNode(e.name,r),ifExists:e.ifExists,materialized:e.materialized,cascade:e.cascade}}transformGenerated(e,r){return{kind:"GeneratedNode",byDefault:e.byDefault,always:e.always,identity:e.identity,stored:e.stored,expression:this.transformNode(e.expression,r)}}transformDefaultValue(e,r){return{kind:"DefaultValueNode",defaultValue:this.transformNode(e.defaultValue,r)}}transformOn(e,r){return{kind:"OnNode",on:this.transformNode(e.on,r)}}transformSelectModifier(e,r){return{kind:"SelectModifierNode",modifier:e.modifier,rawModifier:this.transformNode(e.rawModifier,r),of:this.transformNodeList(e.of,r)}}transformCreateType(e,r){return{kind:"CreateTypeNode",name:this.transformNode(e.name,r),enum:this.transformNode(e.enum,r)}}transformDropType(e,r){return{kind:"DropTypeNode",name:this.transformNode(e.name,r),ifExists:e.ifExists}}transformExplain(e,r){return{kind:"ExplainNode",format:e.format,options:this.transformNode(e.options,r)}}transformSchemableIdentifier(e,r){return{kind:"SchemableIdentifierNode",schema:this.transformNode(e.schema,r),identifier:this.transformNode(e.identifier,r)}}transformAggregateFunction(e,r){return{kind:"AggregateFunctionNode",func:e.func,aggregated:this.transformNodeList(e.aggregated,r),distinct:e.distinct,orderBy:this.transformNode(e.orderBy,r),withinGroup:this.transformNode(e.withinGroup,r),filter:this.transformNode(e.filter,r),over:this.transformNode(e.over,r)}}transformOver(e,r){return{kind:"OverNode",orderBy:this.transformNode(e.orderBy,r),partitionBy:this.transformNode(e.partitionBy,r)}}transformPartitionBy(e,r){return{kind:"PartitionByNode",items:this.transformNodeList(e.items,r)}}transformPartitionByItem(e,r){return{kind:"PartitionByItemNode",partitionBy:this.transformNode(e.partitionBy,r)}}transformBinaryOperation(e,r){return{kind:"BinaryOperationNode",leftOperand:this.transformNode(e.leftOperand,r),operator:this.transformNode(e.operator,r),rightOperand:this.transformNode(e.rightOperand,r)}}transformUnaryOperation(e,r){return{kind:"UnaryOperationNode",operator:this.transformNode(e.operator,r),operand:this.transformNode(e.operand,r)}}transformUsing(e,r){return{kind:"UsingNode",tables:this.transformNodeList(e.tables,r)}}transformFunction(e,r){return{kind:"FunctionNode",func:e.func,arguments:this.transformNodeList(e.arguments,r)}}transformCase(e,r){return{kind:"CaseNode",value:this.transformNode(e.value,r),when:this.transformNodeList(e.when,r),else:this.transformNode(e.else,r),isStatement:e.isStatement}}transformWhen(e,r){return{kind:"WhenNode",condition:this.transformNode(e.condition,r),result:this.transformNode(e.result,r)}}transformJSONReference(e,r){return{kind:"JSONReferenceNode",reference:this.transformNode(e.reference,r),traversal:this.transformNode(e.traversal,r)}}transformJSONPath(e,r){return{kind:"JSONPathNode",inOperator:this.transformNode(e.inOperator,r),pathLegs:this.transformNodeList(e.pathLegs,r)}}transformJSONPathLeg(e,r){return{kind:"JSONPathLegNode",type:e.type,value:e.value}}transformJSONOperatorChain(e,r){return{kind:"JSONOperatorChainNode",operator:this.transformNode(e.operator,r),values:this.transformNodeList(e.values,r)}}transformTuple(e,r){return{kind:"TupleNode",values:this.transformNodeList(e.values,r)}}transformMergeQuery(e,r){return{kind:"MergeQueryNode",into:this.transformNode(e.into,r),using:this.transformNode(e.using,r),whens:this.transformNodeList(e.whens,r),with:this.transformNode(e.with,r),top:this.transformNode(e.top,r),endModifiers:this.transformNodeList(e.endModifiers,r),output:this.transformNode(e.output,r),returning:this.transformNode(e.returning,r)}}transformMatched(e,r){return{kind:"MatchedNode",not:e.not,bySource:e.bySource}}transformAddIndex(e,r){return{kind:"AddIndexNode",name:this.transformNode(e.name,r),columns:this.transformNodeList(e.columns,r),unique:e.unique,using:this.transformNode(e.using,r),ifNotExists:e.ifNotExists}}transformCast(e,r){return{kind:"CastNode",expression:this.transformNode(e.expression,r),dataType:this.transformNode(e.dataType,r)}}transformFetch(e,r){return{kind:"FetchNode",rowCount:this.transformNode(e.rowCount,r),modifier:e.modifier}}transformTop(e,r){return{kind:"TopNode",expression:e.expression,modifiers:e.modifiers}}transformOutput(e,r){return{kind:"OutputNode",selections:this.transformNodeList(e.selections,r)}}transformDataType(e,r){return e}transformSelectAll(e,r){return e}transformIdentifier(e,r){return e}transformValue(e,r){return e}transformPrimitiveValueList(e,r){return e}transformOperator(e,r){return e}transformDefaultInsertValue(e,r){return e}transformOrAction(e,r){return e}transformCollate(e,r){return e}};var Qn=i({AlterTableNode:!0,CreateIndexNode:!0,CreateSchemaNode:!0,CreateTableNode:!0,CreateTypeNode:!0,CreateViewNode:!0,RefreshMaterializedViewNode:!0,DeleteQueryNode:!0,DropIndexNode:!0,DropSchemaNode:!0,DropTableNode:!0,DropTypeNode:!0,DropViewNode:!0,InsertQueryNode:!0,RawNode:!0,SelectQueryNode:!0,UpdateQueryNode:!0,MergeQueryNode:!0}),Ln={json_agg:!0,to_json:!0},lr=class extends Le{#e;#t=new Set;#r=new Set;constructor(e){super(),this.#e=e}transformNodeImpl(e,r){if(!this.#o(e))return super.transformNodeImpl(e,r);let o=this.#d(e);for(let d of o)this.#r.add(d);let n=this.#a(e);for(let d of n)this.#t.add(d);let a=super.transformNodeImpl(e,r);for(let d of n)this.#t.delete(d);for(let d of o)this.#r.delete(d);return a}transformSchemableIdentifier(e,r){let o=super.transformSchemableIdentifier(e,r);return o.schema||!this.#t.has(e.identifier.name)?o:{...o,schema:p.create(this.#e)}}transformReferences(e,r){let o=super.transformReferences(e,r);return o.table.table.schema?o:{...o,table:Y.createWithSchema(this.#e,o.table.table.identifier.name)}}transformAggregateFunction(e,r){return{...super.transformAggregateFunction({...e,aggregated:[]},r),aggregated:this.#i(e,r,"aggregated")}}transformFunction(e,r){return{...super.transformFunction({...e,arguments:[]},r),arguments:this.#i(e,r,"arguments")}}#i(e,r,o){return Ln[e.func]?e[o].map(n=>!Y.is(n)||n.table.schema?this.transformNode(n,r):{...n,table:this.transformIdentifier(n.table.identifier,r)}):this.transformNodeList(e[o],r)}#o(e){return e.kind in Qn}#a(e){let r=new Set;if("name"in e&&e.name&&V.is(e.name)&&this.#s(e.name,r),"from"in e&&e.from)for(let o of e.from.froms)this.#n(o,r);if("into"in e&&e.into&&this.#n(e.into,r),"table"in e&&e.table&&this.#n(e.table,r),"joins"in e&&e.joins)for(let o of e.joins)this.#n(o.table,r);return"using"in e&&e.using&&this.#n(e.using,r),r}#d(e){let r=new Set;return"with"in e&&e.with&&this.#u(e.with,r),r}#n(e,r){if(Y.is(e))this.#s(e.table,r);else if(E.is(e)&&Y.is(e.node))this.#s(e.node.table,r);else if(rr.is(e))for(let o of e.items)this.#n(o,r)}#s(e,r){let o=e.identifier.name;!this.#t.has(o)&&!this.#r.has(o)&&r.add(o)}#u(e,r){for(let o of e.expressions){let n=o.name.table.table.identifier.name;this.#r.has(n)||r.add(n)}}};var re=class{#e;constructor(e){this.#e=new lr(e)}transformQuery(e){return this.#e.transformNode(e.node,e.queryId)}async transformResult(e){return e.result}};var qo=i({is(t){return t.kind==="MatchedNode"},create(t,e=!1){return i({kind:"MatchedNode",not:t,bySource:e})}});function ki(t,e,r){return We.create(ot([qo.create(!t.isMatched,t.bySource),...e&&e.length>0?[e.length===3&&r?R(e[0],e[1],e[2]):O(e)]:[]],"and",!1))}function dt(t){return v(t)?W.create([t],[]):b(t)?t.toOperationNode():t}var Pt=class{#e;#t;#r;constructor(){this.#e=new Promise((e,r)=>{this.#r=r,this.#t=e})}get promise(){return this.#e}resolve=e=>{this.#t&&this.#t(e)};reject=e=>{this.#r&&this.#r(e)}};async function mr(t){let e=new Pt,r=new Pt;return t.provideConnection(async o=>(e.resolve(o),await r.promise)).catch(o=>e.reject(o)),i({connection:await e.promise,release:r.resolve})}var Pn=i([]),pt=class{#e;constructor(e=Pn){this.#e=e}get plugins(){return this.#e}transformQuery(e,r){for(let o of this.#e){let n=o.transformQuery({node:e,queryId:r});if(n.kind===e.kind)e=n;else throw new Error(["KyselyPlugin.transformQuery must return a node","of the same kind that was given to it.",`The plugin was given a ${e.kind}`,`but it returned a ${n.kind}`].join(" "))}return e}async executeQuery(e,r){return await this.provideConnection(async o=>{let n=await o.executeQuery(e);return"numUpdatedOrDeletedRows"in n&&De("kysely:warning: outdated driver/plugin detected! `QueryResult.numUpdatedOrDeletedRows` has been replaced with `QueryResult.numAffectedRows`."),await this.#t(n,r)})}async*stream(e,r,o){let{connection:n,release:a}=await mr(this);try{for await(let d of n.streamQuery(e,r))yield await this.#t(d,o)}finally{a()}}async#t(e,r){for(let o of this.#e)e=await o.transformResult({result:e,queryId:r});return e}};var Ti=class t extends pt{get adapter(){throw new Error("this query cannot be compiled to SQL")}compileQuery(){throw new Error("this query cannot be compiled to SQL")}provideConnection(){throw new Error("this query cannot be executed")}withConnectionProvider(){throw new Error("this query cannot have a connection provider")}withPlugin(e){return new t([...this.plugins,e])}withPlugins(e){return new t([...this.plugins,...e])}withPluginAtFront(e){return new t([e,...this.plugins])}withoutPlugins(){return new t([])}},Pe=new Ti;var fr=class{numChangedRows;constructor(e){this.numChangedRows=e}};var Nr=class t{#e;constructor(e){this.#e=i(e)}modifyEnd(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,e.toOperationNode())})}top(e,r){return new t({...this.#e,queryNode:u.cloneWithTop(this.#e.queryNode,ae(e,r))})}using(...e){return new Fe({...this.#e,queryNode:I.cloneWithUsing(this.#e.queryNode,Qe("Using",e))})}returning(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,A(e))})}returningAll(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,D(e))})}output(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,A(e))})}outputAll(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,D(e))})}},Fe=class t{#e;constructor(e){this.#e=i(e)}modifyEnd(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,e.toOperationNode())})}top(e,r){return new t({...this.#e,queryNode:u.cloneWithTop(this.#e.queryNode,ae(e,r))})}whenMatched(){return this.#t([])}whenMatchedAnd(...e){return this.#t(e)}whenMatchedAndRef(e,r,o){return this.#t([e,r,o],!0)}#t(e,r){return new yr({...this.#e,queryNode:I.cloneWithWhen(this.#e.queryNode,ki({isMatched:!0},e,r))})}whenNotMatched(){return this.#r([])}whenNotMatchedAnd(...e){return this.#r(e)}whenNotMatchedAndRef(e,r,o){return this.#r([e,r,o],!0)}whenNotMatchedBySource(){return this.#r([],!1,!0)}whenNotMatchedBySourceAnd(...e){return this.#r(e,!1,!0)}whenNotMatchedBySourceAndRef(e,r,o){return this.#r([e,r,o],!0,!0)}returning(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,A(e))})}returningAll(e){return new t({...this.#e,queryNode:u.cloneWithReturning(this.#e.queryNode,D(e))})}output(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,A(e))})}outputAll(e){return new t({...this.#e,queryNode:u.cloneWithOutput(this.#e.queryNode,D(e))})}#r(e,r=!1,o=!1){let n={...this.#e,queryNode:I.cloneWithWhen(this.#e.queryNode,ki({isMatched:!1,bySource:o},e,r))},a=o?yr:Si;return new a(n)}$call(e){return e(this)}$if(e,r){return e?r(this):new t({...this.#e})}toOperationNode(){return this.#e.executor.transformQuery(this.#e.queryNode,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){let e=this.compile(),r=await this.#e.executor.executeQuery(e,this.#e.queryId),{adapter:o}=this.#e.executor,n=e.query;return n.returning&&o.supportsReturning||n.output&&o.supportsOutput?r.rows:[new fr(r.numAffectedRows)]}async executeTakeFirst(){let[e]=await this.execute();return e}async executeTakeFirstOrThrow(e=te){let r=await this.executeTakeFirst();if(r===void 0)throw ye(e)?new e(this.toOperationNode()):e(this.toOperationNode());return r}},yr=class{#e;constructor(e){this.#e=i(e)}thenDelete(){return new Fe({...this.#e,queryNode:I.cloneWithThen(this.#e.queryNode,dt("delete"))})}thenDoNothing(){return new Fe({...this.#e,queryNode:I.cloneWithThen(this.#e.queryNode,dt("do nothing"))})}thenUpdate(e){return new Fe({...this.#e,queryNode:I.cloneWithThen(this.#e.queryNode,dt(e(new at({queryId:this.#e.queryId,executor:Pe,queryNode:Ne.createWithoutTable()}))))})}thenUpdateSet(...e){return this.thenUpdate(r=>r.set(...e))}},Si=class{#e;constructor(e){this.#e=i(e)}thenDoNothing(){return new Fe({...this.#e,queryNode:I.cloneWithThen(this.#e.queryNode,dt("do nothing"))})}thenInsertValues(e){let[r,o]=sr(e);return new Fe({...this.#e,queryNode:I.cloneWithThen(this.#e.queryNode,dt(T.cloneWith(T.createWithoutInto(),{columns:r,values:o})))})}};var ct=class t{#e;constructor(e){this.#e=i(e)}selectFrom(e){return Ft({queryId:f(),executor:this.#e.executor,queryNode:x.createFrom(ue(e),this.#e.withNode)})}selectNoFrom(e){return Ft({queryId:f(),executor:this.#e.executor,queryNode:x.cloneWithSelections(x.create(this.#e.withNode),A(e))})}insertInto(e){return new Qt({queryId:f(),executor:this.#e.executor,queryNode:T.create(y(e),this.#e.withNode)})}replaceInto(e){return new Qt({queryId:f(),executor:this.#e.executor,queryNode:T.create(y(e),this.#e.withNode,!0)})}deleteFrom(e){return new pr({queryId:f(),executor:this.#e.executor,queryNode:Be.create(ue(e),this.#e.withNode)})}updateTable(e){return new at({queryId:f(),executor:this.#e.executor,queryNode:Ne.create(ue(e),this.#e.withNode)})}mergeInto(e){return new Nr({queryId:f(),executor:this.#e.executor,queryNode:I.create(Ai(e),this.#e.withNode)})}with(e,r){let o=vi(e,r);return new t({...this.#e,withNode:this.#e.withNode?Lt.cloneWithExpression(this.#e.withNode,o):Lt.create(o)})}withRecursive(e,r){let o=vi(e,r);return new t({...this.#e,withNode:this.#e.withNode?Lt.cloneWithExpression(this.#e.withNode,o):Lt.create(o,{recursive:!0})})}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}withoutPlugins(){return new t({...this.#e,executor:this.#e.executor.withoutPlugins()})}withSchema(e){return new t({...this.#e,executor:this.#e.executor.withPluginAtFront(new re(e))})}};function Ro(){return new ct({executor:Pe})}function Bo(t,e){return new ir({joinNode:Oe.create(t,Ge(e))})}function Qo(){return new or({overNode:qt.create()})}function Qe(t,e){if(e.length===3)return Mn(t,e[0],e[1],e[2]);if(e.length===2)return Fn(t,e[0],e[1]);if(e.length===1)return zn(t,e[0]);throw new Error("not implemented")}function Fn(t,e,r){return r(Bo(t,e)).toOperationNode()}function Mn(t,e,r,o){return Oe.createWithOn(t,Ge(e),R(r,"=",o))}function zn(t,e){return Oe.create(t,Ge(e))}var Lo=i({is(t){return t.kind==="OffsetNode"},create(t){return i({kind:"OffsetNode",offset:t})}});var Po=i({is(t){return t.kind==="GroupByItemNode"},create(t){return i({kind:"GroupByItemNode",groupBy:t})}});function Fo(t){return t=k(t)?t(se()):t,Ce(t).map(Po.create)}var wr=i({is(t){return t.kind==="SetOperationNode"},create(t,e,r){return i({kind:"SetOperationNode",operator:t,expression:e,all:r})}});function Ke(t,e,r){return k(e)&&(e=e(xr())),M(e)||(e=[e]),e.map(o=>wr.create(t,j(o),r))}var w=class t{#e;constructor(e){this.#e=e}get expressionType(){}as(e){return new Mt(this,e)}or(...e){return new Ei(oe.create(this.#e,O(e)))}and(...e){return new Ri(K.create(this.#e,O(e)))}$castTo(){return new t(this.#e)}$notNull(){return new t(this.#e)}toOperationNode(){return this.#e}},Mt=class{#e;#t;constructor(e,r){this.#e=e,this.#t=r}get expression(){return this.#e}get alias(){return this.#t}toOperationNode(){return E.create(this.#e.toOperationNode(),b(this.#t)?this.#t.toOperationNode():p.create(this.#t))}},Ei=class t{#e;constructor(e){this.#e=e}get expressionType(){}as(e){return new Mt(this,e)}or(...e){return new t(oe.create(this.#e,O(e)))}$castTo(){return new t(this.#e)}toOperationNode(){return fe.create(this.#e)}},Ri=class t{#e;constructor(e){this.#e=e}get expressionType(){}as(e){return new Mt(this,e)}and(...e){return new t(K.create(this.#e,O(e)))}$castTo(){return new t(this.#e)}toOperationNode(){return fe.create(this.#e)}};var Mo={is(t){return t.kind==="FetchNode"},create(t,e){return{kind:"FetchNode",rowCount:S.create(t),modifier:e}}};function zo(t,e){if(!Ee(t)&&!_e(t))throw new Error(`Invalid fetch row count: ${t}`);if(!Vn(e))throw new Error(`Invalid fetch modifier: ${e}`);return Mo.create(t,e)}function Vn(t){return t==="only"||t==="with ties"}var Ii=class t{#e;constructor(e){this.#e=i(e)}get expressionType(){}get isSelectQueryBuilder(){return!0}where(...e){return new t({...this.#e,queryNode:u.cloneWithWhere(this.#e.queryNode,O(e))})}whereRef(e,r,o){return new t({...this.#e,queryNode:u.cloneWithWhere(this.#e.queryNode,R(e,r,o))})}having(...e){return new t({...this.#e,queryNode:x.cloneWithHaving(this.#e.queryNode,O(e))})}havingRef(e,r,o){return new t({...this.#e,queryNode:x.cloneWithHaving(this.#e.queryNode,R(e,r,o))})}select(e){return new t({...this.#e,queryNode:x.cloneWithSelections(this.#e.queryNode,A(e))})}distinctOn(e){return new t({...this.#e,queryNode:x.cloneWithDistinctOn(this.#e.queryNode,Ce(e))})}modifyFront(e){return new t({...this.#e,queryNode:x.cloneWithFrontModifier(this.#e.queryNode,le.createWithExpression(e.toOperationNode()))})}modifyEnd(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,le.createWithExpression(e.toOperationNode()))})}distinct(){return new t({...this.#e,queryNode:x.cloneWithFrontModifier(this.#e.queryNode,le.create("Distinct"))})}forUpdate(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,le.create("ForUpdate",e?Et(e).map(y):void 0))})}forShare(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,le.create("ForShare",e?Et(e).map(y):void 0))})}forKeyShare(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,le.create("ForKeyShare",e?Et(e).map(y):void 0))})}forNoKeyUpdate(e){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,le.create("ForNoKeyUpdate",e?Et(e).map(y):void 0))})}skipLocked(){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,le.create("SkipLocked"))})}noWait(){return new t({...this.#e,queryNode:u.cloneWithEndModifier(this.#e.queryNode,le.create("NoWait"))})}selectAll(e){return new t({...this.#e,queryNode:x.cloneWithSelections(this.#e.queryNode,D(e))})}innerJoin(...e){return this.#t("InnerJoin",e)}leftJoin(...e){return this.#t("LeftJoin",e)}rightJoin(...e){return this.#t("RightJoin",e)}fullJoin(...e){return this.#t("FullJoin",e)}crossJoin(...e){return this.#t("CrossJoin",e)}innerJoinLateral(...e){return this.#t("LateralInnerJoin",e)}leftJoinLateral(...e){return this.#t("LateralLeftJoin",e)}crossJoinLateral(...e){return this.#t("LateralCrossJoin",e)}crossApply(...e){return this.#t("CrossApply",e)}outerApply(...e){return this.#t("OuterApply",e)}#t(e,r){return new t({...this.#e,queryNode:u.cloneWithJoin(this.#e.queryNode,Qe(e,r))})}orderBy(...e){return new t({...this.#e,queryNode:u.cloneWithOrderByItems(this.#e.queryNode,_(e))})}groupBy(e){return new t({...this.#e,queryNode:x.cloneWithGroupByItems(this.#e.queryNode,Fo(e))})}limit(e){return new t({...this.#e,queryNode:x.cloneWithLimit(this.#e.queryNode,st.create(g(e)))})}offset(e){return new t({...this.#e,queryNode:x.cloneWithOffset(this.#e.queryNode,Lo.create(g(e)))})}fetch(e,r="only"){return new t({...this.#e,queryNode:x.cloneWithFetch(this.#e.queryNode,zo(e,r))})}top(e,r){return new t({...this.#e,queryNode:u.cloneWithTop(this.#e.queryNode,ae(e,r))})}union(e){return new t({...this.#e,queryNode:x.cloneWithSetOperations(this.#e.queryNode,Ke("union",e,!1))})}unionAll(e){return new t({...this.#e,queryNode:x.cloneWithSetOperations(this.#e.queryNode,Ke("union",e,!0))})}intersect(e){return new t({...this.#e,queryNode:x.cloneWithSetOperations(this.#e.queryNode,Ke("intersect",e,!1))})}intersectAll(e){return new t({...this.#e,queryNode:x.cloneWithSetOperations(this.#e.queryNode,Ke("intersect",e,!0))})}except(e){return new t({...this.#e,queryNode:x.cloneWithSetOperations(this.#e.queryNode,Ke("except",e,!1))})}exceptAll(e){return new t({...this.#e,queryNode:x.cloneWithSetOperations(this.#e.queryNode,Ke("except",e,!0))})}as(e){return new Di(this,e)}clearSelect(){return new t({...this.#e,queryNode:x.cloneWithoutSelections(this.#e.queryNode)})}clearWhere(){return new t({...this.#e,queryNode:u.cloneWithoutWhere(this.#e.queryNode)})}clearLimit(){return new t({...this.#e,queryNode:x.cloneWithoutLimit(this.#e.queryNode)})}clearOffset(){return new t({...this.#e,queryNode:x.cloneWithoutOffset(this.#e.queryNode)})}clearOrderBy(){return new t({...this.#e,queryNode:u.cloneWithoutOrderBy(this.#e.queryNode)})}clearGroupBy(){return new t({...this.#e,queryNode:x.cloneWithoutGroupBy(this.#e.queryNode)})}$call(e){return e(this)}$if(e,r){return e?r(this):new t({...this.#e})}$castTo(){return new t(this.#e)}$narrowType(){return new t(this.#e)}$assertType(){return new t(this.#e)}$asTuple(){return new w(this.toOperationNode())}$asScalar(){return new w(this.toOperationNode())}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}toOperationNode(){return this.#e.executor.transformQuery(this.#e.queryNode,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){let e=this.compile();return(await this.#e.executor.executeQuery(e,this.#e.queryId)).rows}async executeTakeFirst(){let[e]=await this.execute();return e}async executeTakeFirstOrThrow(e=te){let r=await this.executeTakeFirst();if(r===void 0)throw ye(e)?new e(this.toOperationNode()):e(this.toOperationNode());return r}async*stream(e=100){let r=this.compile(),o=this.#e.executor.stream(r,e,this.#e.queryId);for await(let n of o)yield*n.rows}async explain(e,r){return await new t({...this.#e,queryNode:u.cloneWithExplain(this.#e.queryNode,e,r)}).execute()}};function Ft(t){return new Ii(t)}var Di=class{#e;#t;constructor(e,r){this.#e=e,this.#t=r}get expression(){return this.#e}get alias(){return this.#t}get isAliasedSelectQueryBuilder(){return!0}toOperationNode(){return E.create(this.#e.toOperationNode(),p.create(this.#t))}};var we=i({is(t){return t.kind==="AggregateFunctionNode"},create(t,e=[]){return i({kind:"AggregateFunctionNode",func:t,aggregated:e})},cloneWithDistinct(t){return i({...t,distinct:!0})},cloneWithOrderBy(t,e,r=!1){let o=r?"withinGroup":"orderBy";return i({...t,[o]:t[o]?ve.cloneWithItems(t[o],e):ve.create(e)})},cloneWithFilter(t,e){return i({...t,filter:t.filter?Q.cloneWithOperation(t.filter,"And",e):Q.create(e)})},cloneWithOrFilter(t,e){return i({...t,filter:t.filter?Q.cloneWithOperation(t.filter,"Or",e):Q.create(e)})},cloneWithOver(t,e){return i({...t,over:e})}});var qi=i({is(t){return t.kind==="FunctionNode"},create(t,e){return i({kind:"FunctionNode",func:t,arguments:e})}});var ht=class t{#e;constructor(e){this.#e=i(e)}get expressionType(){}as(e){return new Bi(this,e)}distinct(){return new t({...this.#e,aggregateFunctionNode:we.cloneWithDistinct(this.#e.aggregateFunctionNode)})}orderBy(...e){return new t({...this.#e,aggregateFunctionNode:u.cloneWithOrderByItems(this.#e.aggregateFunctionNode,_(e))})}clearOrderBy(){return new t({...this.#e,aggregateFunctionNode:u.cloneWithoutOrderBy(this.#e.aggregateFunctionNode)})}withinGroupOrderBy(...e){return new t({...this.#e,aggregateFunctionNode:we.cloneWithOrderBy(this.#e.aggregateFunctionNode,_(e),!0)})}filterWhere(...e){return new t({...this.#e,aggregateFunctionNode:we.cloneWithFilter(this.#e.aggregateFunctionNode,O(e))})}filterWhereRef(e,r,o){return new t({...this.#e,aggregateFunctionNode:we.cloneWithFilter(this.#e.aggregateFunctionNode,R(e,r,o))})}over(e){let r=Qo();return new t({...this.#e,aggregateFunctionNode:we.cloneWithOver(this.#e.aggregateFunctionNode,(e?e(r):r).toOperationNode())})}$call(e){return e(this)}$castTo(){return new t(this.#e)}$notNull(){return new t(this.#e)}toOperationNode(){return this.#e.aggregateFunctionNode}},Bi=class{#e;#t;constructor(e,r){this.#e=e,this.#t=r}get expression(){return this.#e}get alias(){return this.#t}toOperationNode(){return E.create(this.#e.toOperationNode(),p.create(this.#t))}};function gr(){let t=(r,o)=>new w(qi.create(r,Ce(o??[]))),e=(r,o)=>new ht({aggregateFunctionNode:we.create(r,o?Ce(o):void 0)});return Object.assign(t,{agg:e,avg(r){return e("avg",[r])},coalesce(...r){return t("coalesce",r)},count(r){return e("count",[r])},countAll(r){return new ht({aggregateFunctionNode:we.create("count",D(r))})},max(r){return e("max",[r])},min(r){return e("min",[r])},sum(r){return e("sum",[r])},any(r){return t("any",[r])},jsonAgg(r){return new ht({aggregateFunctionNode:we.create("json_agg",[v(r)?y(r):r.toOperationNode()])})},toJson(r){return new w(qi.create("to_json",[v(r)?y(r):r.toOperationNode()]))}})}var Vo=i({is(t){return t.kind==="UnaryOperationNode"},create(t,e){return i({kind:"UnaryOperationNode",operator:t,operand:e})}});function Uo(t,e){return Vo.create(X.create(t),B(e))}var ee=i({is(t){return t.kind==="CaseNode"},create(t){return i({kind:"CaseNode",value:t})},cloneWithWhen(t,e){return i({...t,when:i(t.when?[...t.when,e]:[e])})},cloneWithThen(t,e){return i({...t,when:t.when?i([...t.when.slice(0,-1),We.cloneWithResult(t.when[t.when.length-1],e)]):void 0})},cloneWith(t,e){return i({...t,...e})}});var lt=class{#e;constructor(e){this.#e=i(e)}when(...e){return new Or({...this.#e,node:ee.cloneWithWhen(this.#e.node,We.create(O(e)))})}},Or=class{#e;constructor(e){this.#e=i(e)}then(e){return new Qi({...this.#e,node:ee.cloneWithThen(this.#e.node,er(e)?Dt(e):g(e))})}},Qi=class{#e;constructor(e){this.#e=i(e)}when(...e){return new Or({...this.#e,node:ee.cloneWithWhen(this.#e.node,We.create(O(e)))})}else(e){return new Li({...this.#e,node:ee.cloneWith(this.#e.node,{else:er(e)?Dt(e):g(e)})})}end(){return new w(ee.cloneWith(this.#e.node,{isStatement:!1}))}endCase(){return new w(ee.cloneWith(this.#e.node,{isStatement:!0}))}},Li=class{#e;constructor(e){this.#e=i(e)}end(){return new w(ee.cloneWith(this.#e.node,{isStatement:!1}))}endCase(){return new w(ee.cloneWith(this.#e.node,{isStatement:!0}))}};var Pi=i({is(t){return t.kind==="JSONPathLegNode"},create(t,e){return i({kind:"JSONPathLegNode",type:t,value:e})}});var mt=class{#e;constructor(e){this.#e=e}at(e){return this.#t("ArrayLocation",e)}key(e){return this.#t("Member",e)}#t(e,r){return rt.is(this.#e)?new br(rt.cloneWithTraversal(this.#e,qe.is(this.#e.traversal)?qe.cloneWithLeg(this.#e.traversal,Pi.create(e,r)):Zt.cloneWithValue(this.#e.traversal,S.createImmediate(r)))):new br(qe.cloneWithLeg(this.#e,Pi.create(e,r)))}},br=class t extends mt{#e;constructor(e){super(e),this.#e=e}get expressionType(){}as(e){return new Fi(this,e)}$castTo(){return new t(this.#e)}$notNull(){return new t(this.#e)}toOperationNode(){return this.#e}},Fi=class{#e;#t;constructor(e,r){this.#e=e,this.#t=r}get expression(){return this.#e}get alias(){return this.#t}toOperationNode(){return E.create(this.#e.toOperationNode(),b(this.#t)?this.#t.toOperationNode():p.create(this.#t))}};var Mi=i({is(t){return t.kind==="TupleNode"},create(t){return i({kind:"TupleNode",values:i(t)})}});var Un=["varchar","char","text","integer","int2","int4","int8","smallint","bigint","boolean","real","double precision","float4","float8","decimal","numeric","binary","bytea","date","datetime","time","timetz","timestamp","timestamptz","serial","bigserial","uuid","json","jsonb","blob","varbinary","int4range","int4multirange","int8range","int8multirange","numrange","nummultirange","tsrange","tsmultirange","tstzrange","tstzmultirange","daterange","datemultirange"],Jn=[/^varchar\(\d+\)$/,/^char\(\d+\)$/,/^decimal\(\d+, \d+\)$/,/^numeric\(\d+, \d+\)$/,/^binary\(\d+\)$/,/^datetime\(\d+\)$/,/^time\(\d+\)$/,/^timetz\(\d+\)$/,/^timestamp\(\d+\)$/,/^timestamptz\(\d+\)$/,/^varbinary\(\d+\)$/],Jo=i({is(t){return t.kind==="DataTypeNode"},create(t){return i({kind:"DataTypeNode",dataType:t})}});function $o(t){return!!(Un.includes(t)||Jn.some(e=>e.test(t)))}function de(t){if(b(t))return t.toOperationNode();if($o(t))return Jo.create(t);throw new Error(`invalid column data type ${JSON.stringify(t)}`)}var Go=i({is(t){return t.kind==="CastNode"},create(t,e){return i({kind:"CastNode",expression:t,dataType:e})}});function xr(t=Pe){function e(n,a,d){return new w(tr(n,a,d))}function r(n,a){return new w(Uo(n,a))}let o=Object.assign(e,{fn:void 0,eb:void 0,selectFrom(n){return Ft({queryId:f(),executor:t,queryNode:x.createFrom(ue(n))})},case(n){return new lt({node:ee.create(H(n)?void 0:B(n))})},ref(n,a){return H(a)?new w(Z(n)):new mt(fo(n,a))},jsonPath(){return new mt(qe.create())},table(n){return new w(y(n))},val(n){return new w(g(n))},refTuple(...n){return new w(Mi.create(n.map(B)))},tuple(...n){return new w(Mi.create(n.map(g)))},lit(n){return new w(Dt(n))},unary:r,not(n){return r("not",n)},exists(n){return r("exists",n)},neg(n){return r("-",n)},between(n,a,d){return new w(Ie.create(B(n),X.create("between"),K.create(g(a),g(d))))},betweenSymmetric(n,a,d){return new w(Ie.create(B(n),X.create("between symmetric"),K.create(g(a),g(d))))},and(n){return M(n)?new w(ot(n,"and")):new w(li(n,"and"))},or(n){return M(n)?new w(ot(n,"or")):new w(li(n,"or"))},parens(...n){let a=O(n);return fe.is(a)?new w(a):new w(fe.create(a))},cast(n,a){return new w(Go.create(B(n),de(a)))},withSchema(n){return xr(t.withPluginAtFront(new re(n)))}});return o.fn=gr(),o.eb=o,o}function se(t){return xr()}function j(t){if(b(t))return t.toOperationNode();if(k(t))return t(se()).toOperationNode();throw new Error(`invalid expression: ${JSON.stringify(t)}`)}function nr(t){if(b(t))return t.toOperationNode();if(k(t))return t(se()).toOperationNode();throw new Error(`invalid aliased expression: ${JSON.stringify(t)}`)}function be(t){return Kt(t)||uo(t)||k(t)}var Cr=class{#e;get table(){return this.#e}constructor(e){this.#e=e}as(e){return new zi(this.#e,e)}},zi=class{#e;#t;get table(){return this.#e}get alias(){return this.#t}constructor(e,r){this.#e=e,this.#t=r}toOperationNode(){return E.create(y(this.#e),p.create(this.#t))}};function Ko(t){return q(t)&&b(t)&&v(t.table)&&v(t.alias)}function ue(t){return M(t)?t.map(e=>Ge(e)):[Ge(t)]}function Ge(t){return v(t)?Ai(t):Ko(t)?t.toOperationNode():nr(t)}function Ai(t){let e=" as ";if(t.includes(e)){let[r,o]=t.split(e).map(jo);return E.create(y(r),p.create(o))}else return y(t)}function y(t){let e=".";if(t.includes(e)){let[r,o]=t.split(e).map(jo);return Y.createWithSchema(r,o)}else return Y.create(t)}function jo(t){return t.trim()}var Vi=i({is(t){return t.kind==="AddColumnNode"},create(t){return i({kind:"AddColumnNode",column:t})}});var C=i({is(t){return t.kind==="ColumnDefinitionNode"},create(t,e){return i({kind:"ColumnDefinitionNode",column:m.create(t),dataType:e})},cloneWithFrontModifier(t,e){return i({...t,frontModifiers:t.frontModifiers?i([...t.frontModifiers,e]):[e]})},cloneWithEndModifier(t,e){return i({...t,endModifiers:t.endModifiers?i([...t.endModifiers,e]):[e]})},cloneWith(t,e){return i({...t,...e})}});var Ui=i({is(t){return t.kind==="DropColumnNode"},create(t){return i({kind:"DropColumnNode",column:m.create(t)})}});var Ji=i({is(t){return t.kind==="RenameColumnNode"},create(t,e){return i({kind:"RenameColumnNode",column:m.create(t),renameTo:m.create(e)})}});var ft=i({is(t){return t.kind==="CheckConstraintNode"},create(t,e){return i({kind:"CheckConstraintNode",expression:t,name:e?p.create(e):void 0})}});var Ho=["no action","restrict","cascade","set null","set default"],Nt=i({is(t){return t.kind==="ReferencesNode"},create(t,e){return i({kind:"ReferencesNode",table:t,columns:i([...e])})},cloneWithOnDelete(t,e){return i({...t,onDelete:e})},cloneWithOnUpdate(t,e){return i({...t,onUpdate:e})}});function vr(t){return b(t)?t.toOperationNode():S.createImmediate(t)}var zt=i({is(t){return t.kind==="GeneratedNode"},create(t){return i({kind:"GeneratedNode",...t})},createWithExpression(t){return i({kind:"GeneratedNode",always:!0,expression:t})},cloneWith(t,e){return i({...t,...e})}});var Yo=i({is(t){return t.kind==="DefaultValueNode"},create(t){return i({kind:"DefaultValueNode",defaultValue:t})}});function yt(t){if(Ho.includes(t))return t;throw new Error(`invalid OnModifyForeignAction ${t}`)}var ke=class t{#e;constructor(e){this.#e=e}autoIncrement(){return new t(C.cloneWith(this.#e,{autoIncrement:!0}))}identity(){return new t(C.cloneWith(this.#e,{identity:!0}))}primaryKey(){return new t(C.cloneWith(this.#e,{primaryKey:!0}))}references(e){let r=Z(e);if(!r.table||et.is(r.column))throw new Error(`invalid call references('${e}'). The reference must have format table.column or schema.table.column`);return new t(C.cloneWith(this.#e,{references:Nt.create(r.table,[r.column])}))}onDelete(e){if(!this.#e.references)throw new Error("on delete constraint can only be added for foreign keys");return new t(C.cloneWith(this.#e,{references:Nt.cloneWithOnDelete(this.#e.references,yt(e))}))}onUpdate(e){if(!this.#e.references)throw new Error("on update constraint can only be added for foreign keys");return new t(C.cloneWith(this.#e,{references:Nt.cloneWithOnUpdate(this.#e.references,yt(e))}))}unique(){return new t(C.cloneWith(this.#e,{unique:!0}))}notNull(){return new t(C.cloneWith(this.#e,{notNull:!0}))}unsigned(){return new t(C.cloneWith(this.#e,{unsigned:!0}))}defaultTo(e){return new t(C.cloneWith(this.#e,{defaultTo:Yo.create(vr(e))}))}check(e){return new t(C.cloneWith(this.#e,{check:ft.create(e.toOperationNode())}))}generatedAlwaysAs(e){return new t(C.cloneWith(this.#e,{generated:zt.createWithExpression(e.toOperationNode())}))}generatedAlwaysAsIdentity(){return new t(C.cloneWith(this.#e,{generated:zt.create({identity:!0,always:!0})}))}generatedByDefaultAsIdentity(){return new t(C.cloneWith(this.#e,{generated:zt.create({identity:!0,byDefault:!0})}))}stored(){if(!this.#e.generated)throw new Error("stored() can only be called after generatedAlwaysAs");return new t(C.cloneWith(this.#e,{generated:zt.cloneWith(this.#e.generated,{stored:!0})}))}modifyFront(e){return new t(C.cloneWithFrontModifier(this.#e,e.toOperationNode()))}nullsNotDistinct(){return new t(C.cloneWith(this.#e,{nullsNotDistinct:!0}))}ifNotExists(){return new t(C.cloneWith(this.#e,{ifNotExists:!0}))}modifyEnd(e){return new t(C.cloneWithEndModifier(this.#e,e.toOperationNode()))}$call(e){return e(this)}toOperationNode(){return this.#e}};var $i=i({is(t){return t.kind==="ModifyColumnNode"},create(t){return i({kind:"ModifyColumnNode",column:t})}});var pe=i({is(t){return t.kind==="ForeignKeyConstraintNode"},create(t,e,r,o){return i({kind:"ForeignKeyConstraintNode",columns:t,references:Nt.create(e,r),name:o?p.create(o):void 0})},cloneWith(t,e){return i({...t,...e})}});var wt=class t{#e;constructor(e){this.#e=e}onDelete(e){return new t(pe.cloneWith(this.#e,{onDelete:yt(e)}))}onUpdate(e){return new t(pe.cloneWith(this.#e,{onUpdate:yt(e)}))}deferrable(){return new t(pe.cloneWith(this.#e,{deferrable:!0}))}notDeferrable(){return new t(pe.cloneWith(this.#e,{deferrable:!1}))}initiallyDeferred(){return new t(pe.cloneWith(this.#e,{initiallyDeferred:!0}))}initiallyImmediate(){return new t(pe.cloneWith(this.#e,{initiallyDeferred:!1}))}$call(e){return e(this)}toOperationNode(){return this.#e}};var xt=i({is(t){return t.kind==="AddConstraintNode"},create(t){return i({kind:"AddConstraintNode",constraint:t})}});var xe=i({is(t){return t.kind==="UniqueConstraintNode"},create(t,e,r){return i({kind:"UniqueConstraintNode",columns:i(t.map(m.create)),name:e?p.create(e):void 0,nullsNotDistinct:r})},cloneWith(t,e){return i({...t,...e})}});var gt=i({is(t){return t.kind==="DropConstraintNode"},create(t){return i({kind:"DropConstraintNode",constraintName:p.create(t)})},cloneWith(t,e){return i({...t,...e})}});var Ot=i({is(t){return t.kind==="AlterColumnNode"},create(t,e,r){return i({kind:"AlterColumnNode",column:m.create(t),[e]:r})}});var Vt=class{#e;constructor(e){this.#e=e}setDataType(e){return new je(Ot.create(this.#e,"dataType",de(e)))}setDefault(e){return new je(Ot.create(this.#e,"setDefault",vr(e)))}dropDefault(){return new je(Ot.create(this.#e,"dropDefault",!0))}setNotNull(){return new je(Ot.create(this.#e,"setNotNull",!0))}dropNotNull(){return new je(Ot.create(this.#e,"dropNotNull",!0))}$call(e){return e(this)}},je=class{#e;constructor(e){this.#e=e}toOperationNode(){return this.#e}};var Te=class{#e;constructor(e){this.#e=i(e)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Wr=class t{#e;constructor(e){this.#e=i(e)}onDelete(e){return new t({...this.#e,constraintBuilder:this.#e.constraintBuilder.onDelete(e)})}onUpdate(e){return new t({...this.#e,constraintBuilder:this.#e.constraintBuilder.onUpdate(e)})}deferrable(){return new t({...this.#e,constraintBuilder:this.#e.constraintBuilder.deferrable()})}notDeferrable(){return new t({...this.#e,constraintBuilder:this.#e.constraintBuilder.notDeferrable()})}initiallyDeferred(){return new t({...this.#e,constraintBuilder:this.#e.constraintBuilder.initiallyDeferred()})}initiallyImmediate(){return new t({...this.#e,constraintBuilder:this.#e.constraintBuilder.initiallyImmediate()})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(N.cloneWithTableProps(this.#e.node,{addConstraint:xt.create(this.#e.constraintBuilder.toOperationNode())}),this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Ut=class t{#e;constructor(e){this.#e=i(e)}ifExists(){return new t({...this.#e,node:N.cloneWithTableProps(this.#e.node,{dropConstraint:gt.cloneWith(this.#e.node.dropConstraint,{ifExists:!0})})})}cascade(){return new t({...this.#e,node:N.cloneWithTableProps(this.#e.node,{dropConstraint:gt.cloneWith(this.#e.node.dropConstraint,{modifier:"cascade"})})})}restrict(){return new t({...this.#e,node:N.cloneWithTableProps(this.#e.node,{dropConstraint:gt.cloneWith(this.#e.node.dropConstraint,{modifier:"restrict"})})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Se=i({is(t){return t.kind==="PrimaryKeyConstraintNode"},create(t,e){return i({kind:"PrimaryKeyConstraintNode",columns:i(t.map(m.create)),name:e?p.create(e):void 0})},cloneWith(t,e){return i({...t,...e})}});var Me=i({is(t){return t.kind==="AddIndexNode"},create(t){return i({kind:"AddIndexNode",name:p.create(t)})},cloneWith(t,e){return i({...t,...e})},cloneWithColumns(t,e){return i({...t,columns:[...t.columns||[],...e]})}});var kr=class t{#e;constructor(e){this.#e=i(e)}unique(){return new t({...this.#e,node:N.cloneWithTableProps(this.#e.node,{addIndex:Me.cloneWith(this.#e.node.addIndex,{unique:!0})})})}column(e){return new t({...this.#e,node:N.cloneWithTableProps(this.#e.node,{addIndex:Me.cloneWithColumns(this.#e.node.addIndex,[it(e)])})})}columns(e){return new t({...this.#e,node:N.cloneWithTableProps(this.#e.node,{addIndex:Me.cloneWithColumns(this.#e.node.addIndex,e.map(it))})})}expression(e){return new t({...this.#e,node:N.cloneWithTableProps(this.#e.node,{addIndex:Me.cloneWithColumns(this.#e.node.addIndex,[e.toOperationNode()])})})}using(e){return new t({...this.#e,node:N.cloneWithTableProps(this.#e.node,{addIndex:Me.cloneWith(this.#e.node.addIndex,{using:W.createWithSql(e)})})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var bt=class t{#e;constructor(e){this.#e=e}nullsNotDistinct(){return new t(xe.cloneWith(this.#e,{nullsNotDistinct:!0}))}deferrable(){return new t(xe.cloneWith(this.#e,{deferrable:!0}))}notDeferrable(){return new t(xe.cloneWith(this.#e,{deferrable:!1}))}initiallyDeferred(){return new t(xe.cloneWith(this.#e,{initiallyDeferred:!0}))}initiallyImmediate(){return new t(xe.cloneWith(this.#e,{initiallyDeferred:!1}))}$call(e){return e(this)}toOperationNode(){return this.#e}};var Ct=class t{#e;constructor(e){this.#e=e}deferrable(){return new t(Se.cloneWith(this.#e,{deferrable:!0}))}notDeferrable(){return new t(Se.cloneWith(this.#e,{deferrable:!1}))}initiallyDeferred(){return new t(Se.cloneWith(this.#e,{initiallyDeferred:!0}))}initiallyImmediate(){return new t(Se.cloneWith(this.#e,{initiallyDeferred:!1}))}$call(e){return e(this)}toOperationNode(){return this.#e}};var vt=class{#e;constructor(e){this.#e=e}$call(e){return e(this)}toOperationNode(){return this.#e}};var Xo=i({is(t){return t.kind==="RenameConstraintNode"},create(t,e){return i({kind:"RenameConstraintNode",oldName:p.create(t),newName:p.create(e)})}});var Tr=class{#e;constructor(e){this.#e=i(e)}renameTo(e){return new Te({...this.#e,node:N.cloneWithTableProps(this.#e.node,{renameTo:y(e)})})}setSchema(e){return new Te({...this.#e,node:N.cloneWithTableProps(this.#e.node,{setSchema:p.create(e)})})}alterColumn(e,r){let o=r(new Vt(e));return new He({...this.#e,node:N.cloneWithColumnAlteration(this.#e.node,o.toOperationNode())})}dropColumn(e){return new He({...this.#e,node:N.cloneWithColumnAlteration(this.#e.node,Ui.create(e))})}renameColumn(e,r){return new He({...this.#e,node:N.cloneWithColumnAlteration(this.#e.node,Ji.create(e,r))})}addColumn(e,r,o=J){let n=o(new ke(C.create(e,de(r))));return new He({...this.#e,node:N.cloneWithColumnAlteration(this.#e.node,Vi.create(n.toOperationNode()))})}modifyColumn(e,r,o=J){let n=o(new ke(C.create(e,de(r))));return new He({...this.#e,node:N.cloneWithColumnAlteration(this.#e.node,$i.create(n.toOperationNode()))})}addUniqueConstraint(e,r,o=J){let n=o(new bt(xe.create(r,e)));return new Te({...this.#e,node:N.cloneWithTableProps(this.#e.node,{addConstraint:xt.create(n.toOperationNode())})})}addCheckConstraint(e,r,o=J){let n=o(new vt(ft.create(r.toOperationNode(),e)));return new Te({...this.#e,node:N.cloneWithTableProps(this.#e.node,{addConstraint:xt.create(n.toOperationNode())})})}addForeignKeyConstraint(e,r,o,n,a=J){let d=a(new wt(pe.create(r.map(m.create),y(o),n.map(m.create),e)));return new Wr({...this.#e,constraintBuilder:d})}addPrimaryKeyConstraint(e,r,o=J){let n=o(new Ct(Se.create(r,e)));return new Te({...this.#e,node:N.cloneWithTableProps(this.#e.node,{addConstraint:xt.create(n.toOperationNode())})})}dropConstraint(e){return new Ut({...this.#e,node:N.cloneWithTableProps(this.#e.node,{dropConstraint:gt.create(e)})})}renameConstraint(e,r){return new Ut({...this.#e,node:N.cloneWithTableProps(this.#e.node,{renameConstraint:Xo.create(e,r)})})}addIndex(e){return new kr({...this.#e,node:N.cloneWithTableProps(this.#e.node,{addIndex:Me.create(e)})})}dropIndex(e){return new Te({...this.#e,node:N.cloneWithTableProps(this.#e.node,{dropIndex:Re.create(e)})})}$call(e){return e(this)}},He=class t{#e;constructor(e){this.#e=i(e)}alterColumn(e,r){let o=r(new Vt(e));return new t({...this.#e,node:N.cloneWithColumnAlteration(this.#e.node,o.toOperationNode())})}dropColumn(e){return new t({...this.#e,node:N.cloneWithColumnAlteration(this.#e.node,Ui.create(e))})}renameColumn(e,r){return new t({...this.#e,node:N.cloneWithColumnAlteration(this.#e.node,Ji.create(e,r))})}addColumn(e,r,o=J){let n=o(new ke(C.create(e,de(r))));return new t({...this.#e,node:N.cloneWithColumnAlteration(this.#e.node,Vi.create(n.toOperationNode()))})}modifyColumn(e,r,o=J){let n=o(new ke(C.create(e,de(r))));return new t({...this.#e,node:N.cloneWithColumnAlteration(this.#e.node,$i.create(n.toOperationNode()))})}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Wt=class extends Le{transformPrimitiveValueList(e){return me.create(e.values.map(S.createImmediate))}transformValue(e){return S.createImmediate(e.value)}};var Sr=class t{#e;constructor(e){this.#e=i(e)}ifNotExists(){return new t({...this.#e,node:ie.cloneWith(this.#e.node,{ifNotExists:!0})})}unique(){return new t({...this.#e,node:ie.cloneWith(this.#e.node,{unique:!0})})}nullsNotDistinct(){return new t({...this.#e,node:ie.cloneWith(this.#e.node,{nullsNotDistinct:!0})})}on(e){return new t({...this.#e,node:ie.cloneWith(this.#e.node,{table:y(e)})})}column(e){return new t({...this.#e,node:ie.cloneWithColumns(this.#e.node,[it(e)])})}columns(e){return new t({...this.#e,node:ie.cloneWithColumns(this.#e.node,e.map(it))})}expression(e){return new t({...this.#e,node:ie.cloneWithColumns(this.#e.node,[e.toOperationNode()])})}using(e){return new t({...this.#e,node:ie.cloneWith(this.#e.node,{using:W.createWithSql(e)})})}where(...e){let r=new Wt;return new t({...this.#e,node:u.cloneWithWhere(this.#e.node,r.transformNode(O(e),this.#e.queryId))})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Ar=class t{#e;constructor(e){this.#e=i(e)}ifNotExists(){return new t({...this.#e,node:Gt.cloneWith(this.#e.node,{ifNotExists:!0})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};function Zo(t){if(ao.includes(t))return t;throw new Error(`invalid OnCommitAction ${t}`)}var Er=class t{#e;constructor(e){this.#e=i(e)}temporary(){return new t({...this.#e,node:z.cloneWith(this.#e.node,{temporary:!0})})}onCommit(e){return new t({...this.#e,node:z.cloneWith(this.#e.node,{onCommit:Zo(e)})})}ifNotExists(){return new t({...this.#e,node:z.cloneWith(this.#e.node,{ifNotExists:!0})})}addColumn(e,r,o=J){let n=o(new ke(C.create(e,de(r))));return new t({...this.#e,node:z.cloneWithColumn(this.#e.node,n.toOperationNode())})}addPrimaryKeyConstraint(e,r,o=J){let n=o(new Ct(Se.create(r,e)));return new t({...this.#e,node:z.cloneWithConstraint(this.#e.node,n.toOperationNode())})}addUniqueConstraint(e,r,o=J){let n=o(new bt(xe.create(r,e)));return new t({...this.#e,node:z.cloneWithConstraint(this.#e.node,n.toOperationNode())})}addCheckConstraint(e,r,o=J){let n=o(new vt(ft.create(r.toOperationNode(),e)));return new t({...this.#e,node:z.cloneWithConstraint(this.#e.node,n.toOperationNode())})}addForeignKeyConstraint(e,r,o,n,a=J){let d=a(new wt(pe.create(r.map(m.create),y(o),n.map(m.create),e)));return new t({...this.#e,node:z.cloneWithConstraint(this.#e.node,d.toOperationNode())})}modifyFront(e){return new t({...this.#e,node:z.cloneWithFrontModifier(this.#e.node,e.toOperationNode())})}modifyEnd(e){return new t({...this.#e,node:z.cloneWithEndModifier(this.#e.node,e.toOperationNode())})}as(e){return new t({...this.#e,node:z.cloneWith(this.#e.node,{selectQuery:j(e)})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Rr=class t{#e;constructor(e){this.#e=i(e)}on(e){return new t({...this.#e,node:Re.cloneWith(this.#e.node,{table:y(e)})})}ifExists(){return new t({...this.#e,node:Re.cloneWith(this.#e.node,{ifExists:!0})})}cascade(){return new t({...this.#e,node:Re.cloneWith(this.#e.node,{cascade:!0})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Ir=class t{#e;constructor(e){this.#e=i(e)}ifExists(){return new t({...this.#e,node:Rt.cloneWith(this.#e.node,{ifExists:!0})})}cascade(){return new t({...this.#e,node:Rt.cloneWith(this.#e.node,{cascade:!0})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Dr=class t{#e;constructor(e){this.#e=i(e)}ifExists(){return new t({...this.#e,node:It.cloneWith(this.#e.node,{ifExists:!0})})}cascade(){return new t({...this.#e,node:It.cloneWith(this.#e.node,{cascade:!0})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var ce=i({is(t){return t.kind==="CreateViewNode"},create(t){return i({kind:"CreateViewNode",name:V.create(t)})},cloneWith(t,e){return i({...t,...e})}});var qr=class{#e=new Wt;transformQuery(e){return this.#e.transformNode(e.node,e.queryId)}transformResult(e){return Promise.resolve(e.result)}};var Br=class t{#e;constructor(e){this.#e=i(e)}temporary(){return new t({...this.#e,node:ce.cloneWith(this.#e.node,{temporary:!0})})}materialized(){return new t({...this.#e,node:ce.cloneWith(this.#e.node,{materialized:!0})})}ifNotExists(){return new t({...this.#e,node:ce.cloneWith(this.#e.node,{ifNotExists:!0})})}orReplace(){return new t({...this.#e,node:ce.cloneWith(this.#e.node,{orReplace:!0})})}columns(e){return new t({...this.#e,node:ce.cloneWith(this.#e.node,{columns:e.map(pi)})})}as(e){let r=e.withPlugin(new qr).toOperationNode();return new t({...this.#e,node:ce.cloneWith(this.#e.node,{as:r})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var kt=i({is(t){return t.kind==="DropViewNode"},create(t){return i({kind:"DropViewNode",name:V.create(t)})},cloneWith(t,e){return i({...t,...e})}});var Qr=class t{#e;constructor(e){this.#e=i(e)}materialized(){return new t({...this.#e,node:kt.cloneWith(this.#e.node,{materialized:!0})})}ifExists(){return new t({...this.#e,node:kt.cloneWith(this.#e.node,{ifExists:!0})})}cascade(){return new t({...this.#e,node:kt.cloneWith(this.#e.node,{cascade:!0})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Lr=i({is(t){return t.kind==="CreateTypeNode"},create(t){return i({kind:"CreateTypeNode",name:t})},cloneWithEnum(t,e){return i({...t,enum:me.create(e.map(S.createImmediate))})}});var Pr=class t{#e;constructor(e){this.#e=i(e)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}asEnum(e){return new t({...this.#e,node:Lr.cloneWithEnum(this.#e.node,e)})}$call(e){return e(this)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Fr=i({is(t){return t.kind==="DropTypeNode"},create(t){return i({kind:"DropTypeNode",name:t})},cloneWith(t,e){return i({...t,...e})}});var Mr=class t{#e;constructor(e){this.#e=i(e)}ifExists(){return new t({...this.#e,node:Fr.cloneWith(this.#e.node,{ifExists:!0})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};function Gi(t){let e=".";if(t.includes(e)){let r=t.split(e).map($n);if(r.length===2)return V.createWithSchema(r[0],r[1]);throw new Error(`invalid schemable identifier ${t}`)}else return V.create(t)}function $n(t){return t.trim()}var Tt=i({is(t){return t.kind==="RefreshMaterializedViewNode"},create(t){return i({kind:"RefreshMaterializedViewNode",name:V.create(t)})},cloneWith(t,e){return i({...t,...e})}});var zr=class t{#e;constructor(e){this.#e=i(e)}concurrently(){return new t({...this.#e,node:Tt.cloneWith(this.#e.node,{concurrently:!0,withNoData:!1})})}withData(){return new t({...this.#e,node:Tt.cloneWith(this.#e.node,{withNoData:!1})})}withNoData(){return new t({...this.#e,node:Tt.cloneWith(this.#e.node,{withNoData:!0,concurrently:!1})})}$call(e){return e(this)}toOperationNode(){return this.#e.executor.transformQuery(this.#e.node,this.#e.queryId)}compile(){return this.#e.executor.compileQuery(this.toOperationNode(),this.#e.queryId)}async execute(){await this.#e.executor.executeQuery(this.compile(),this.#e.queryId)}};var Vr=class t{#e;constructor(e){this.#e=e}createTable(e){return new Er({queryId:f(),executor:this.#e,node:z.create(y(e))})}dropTable(e){return new Dr({queryId:f(),executor:this.#e,node:It.create(y(e))})}createIndex(e){return new Sr({queryId:f(),executor:this.#e,node:ie.create(e)})}dropIndex(e){return new Rr({queryId:f(),executor:this.#e,node:Re.create(e)})}createSchema(e){return new Ar({queryId:f(),executor:this.#e,node:Gt.create(e)})}dropSchema(e){return new Ir({queryId:f(),executor:this.#e,node:Rt.create(e)})}alterTable(e){return new Tr({queryId:f(),executor:this.#e,node:N.create(y(e))})}createView(e){return new Br({queryId:f(),executor:this.#e,node:ce.create(e)})}refreshMaterializedView(e){return new zr({queryId:f(),executor:this.#e,node:Tt.create(e)})}dropView(e){return new Qr({queryId:f(),executor:this.#e,node:kt.create(e)})}createType(e){return new Pr({queryId:f(),executor:this.#e,node:Lr.create(Gi(e))})}dropType(e){return new Mr({queryId:f(),executor:this.#e,node:Fr.create(Gi(e))})}withPlugin(e){return new t(this.#e.withPlugin(e))}withoutPlugins(){return new t(this.#e.withoutPlugins())}withSchema(e){return new t(this.#e.withPluginAtFront(new re(e)))}};var Ur=class{ref(e){return new Ht(e)}table(e){return new Cr(e)}};var Jr=class{#e;constructor(e){this.#e=e}async provideConnection(e){let r=await this.#e.acquireConnection();try{return await e(r)}finally{await this.#e.releaseConnection(r)}}};var $r=class t extends pt{#e;#t;#r;constructor(e,r,o,n=[]){super(n),this.#e=e,this.#t=r,this.#r=o}get adapter(){return this.#t}compileQuery(e,r){return this.#e.compileQuery(e,r)}provideConnection(e){return this.#r.provideConnection(e)}withPlugins(e){return new t(this.#e,this.#t,this.#r,[...this.plugins,...e])}withPlugin(e){return new t(this.#e,this.#t,this.#r,[...this.plugins,e])}withPluginAtFront(e){return new t(this.#e,this.#t,this.#r,[e,...this.plugins])}withConnectionProvider(e){return new t(this.#e,this.#t,e,[...this.plugins])}withoutPlugins(){return new t(this.#e,this.#t,this.#r,[])}};function Gr(){return typeof performance<"u"&&k(performance.now)?performance.now():Date.now()}var Kr=class{#e;#t;#r;#i;#o;#a=new WeakSet;constructor(e,r){this.#i=!1,this.#e=e,this.#t=r}async init(){if(this.#o)throw new Error("driver has already been destroyed");this.#r||(this.#r=this.#e.init().then(()=>{this.#i=!0}).catch(e=>(this.#r=void 0,Promise.reject(e)))),await this.#r}async acquireConnection(){if(this.#o)throw new Error("driver has already been destroyed");this.#i||await this.init();let e=await this.#e.acquireConnection();return this.#a.has(e)||(this.#d()&&this.#n(e),this.#a.add(e)),e}async releaseConnection(e){await this.#e.releaseConnection(e)}beginTransaction(e,r){return this.#e.beginTransaction(e,r)}commitTransaction(e){return this.#e.commitTransaction(e)}rollbackTransaction(e){return this.#e.rollbackTransaction(e)}savepoint(e,r,o){if(this.#e.savepoint)return this.#e.savepoint(e,r,o);throw new Error("The `savepoint` method is not supported by this driver")}rollbackToSavepoint(e,r,o){if(this.#e.rollbackToSavepoint)return this.#e.rollbackToSavepoint(e,r,o);throw new Error("The `rollbackToSavepoint` method is not supported by this driver")}releaseSavepoint(e,r,o){if(this.#e.releaseSavepoint)return this.#e.releaseSavepoint(e,r,o);throw new Error("The `releaseSavepoint` method is not supported by this driver")}async destroy(){this.#r&&(await this.#r,this.#o||(this.#o=this.#e.destroy().catch(e=>(this.#o=void 0,Promise.reject(e)))),await this.#o)}#d(){return this.#t.isLevelEnabled("query")||this.#t.isLevelEnabled("error")}#n(e){let r=e.executeQuery,o=e.streamQuery,n=this;e.executeQuery=async a=>{let d,c=Gr();try{return await r.call(e,a)}catch(l){throw d=l,await n.#s(l,a,c),l}finally{d||await n.#u(a,c)}},e.streamQuery=async function*(a,d){let c,l=Gr();try{for await(let h of o.call(e,a,d))yield h}catch(h){throw c=h,await n.#s(h,a,l),h}finally{c||await n.#u(a,l,!0)}}}async#s(e,r,o){await this.#t.error(()=>({level:"error",error:e,query:r,queryDurationMillis:this.#p(o)}))}async#u(e,r,o=!1){await this.#t.query(()=>({level:"query",isStream:o,query:e,queryDurationMillis:this.#p(r)}))}#p(e){return Gr()-e}};var Gn=()=>{},St=class{#e;#t;constructor(e){this.#e=e}async provideConnection(e){for(;this.#t;)await this.#t.catch(Gn);return this.#t=this.#r(e).finally(()=>{this.#t=void 0}),this.#t}async#r(e){return await e(this.#e)}};var Kn=["read only","read write"],jn=["read uncommitted","read committed","repeatable read","serializable","snapshot"];function Ki(t){if(t.accessMode&&!Kn.includes(t.accessMode))throw new Error(`invalid transaction access mode ${t.accessMode}`);if(t.isolationLevel&&!jn.includes(t.isolationLevel))throw new Error(`invalid transaction isolation level ${t.isolationLevel}`)}var Yv=i(["query","error"]),jr=class{#e;#t;constructor(e){k(e)?(this.#t=e,this.#e=i({query:!0,error:!0})):(this.#t=Hn,this.#e=i({query:e.includes("query"),error:e.includes("error")}))}isLevelEnabled(e){return this.#e[e]}async query(e){this.#e.query&&await this.#t(e())}async error(e){this.#e.error&&await this.#t(e())}};function Hn(t){if(t.level==="query"){let e=`kysely:query:${t.isStream?"stream:":""}`;console.log(`${e} ${t.query.sql}`),console.log(`${e} duration: ${t.queryDurationMillis.toFixed(1)}ms`)}else t.level==="error"&&(t.error instanceof Error?console.error(`kysely:error: ${t.error.stack??t.error.message}`):console.error(`kysely:error: ${JSON.stringify({error:t.error,query:t.query.sql,queryDurationMillis:t.queryDurationMillis})}`))}function _o(t){return q(t)&&k(t.compile)}Symbol.asyncDispose??=Symbol("Symbol.asyncDispose");var At=class t extends ct{#e;constructor(e){let r,o;if(Yn(e))r={executor:e.executor},o={...e};else{let n=e.dialect,a=n.createDriver(),d=n.createQueryCompiler(),c=n.createAdapter(),l=new jr(e.log??[]),h=new Kr(a,l),L=new Jr(h),ge=new $r(d,c,L,e.plugins??[]);r={executor:ge},o={config:e,executor:ge,dialect:n,driver:h}}super(r),this.#e=i(o)}get schema(){return new Vr(this.#e.executor)}get dynamic(){return new Ur}get introspection(){return this.#e.dialect.createIntrospector(this.withoutPlugins())}case(e){return new lt({node:ee.create(H(e)?void 0:j(e))})}get fn(){return gr()}transaction(){return new Hi({...this.#e})}startTransaction(){return new Yi({...this.#e})}connection(){return new ji({...this.#e})}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}withoutPlugins(){return new t({...this.#e,executor:this.#e.executor.withoutPlugins()})}withSchema(e){return new t({...this.#e,executor:this.#e.executor.withPluginAtFront(new re(e))})}withTables(){return new t({...this.#e})}async destroy(){await this.#e.driver.destroy()}get isTransaction(){return!1}getExecutor(){return this.#e.executor}executeQuery(e,r=f()){let o=_o(e)?e.compile():e;return this.getExecutor().executeQuery(o,r)}async[Symbol.asyncDispose](){await this.destroy()}},Hr=class t extends At{#e;constructor(e){super(e),this.#e=e}get isTransaction(){return!0}transaction(){throw new Error("calling the transaction method for a Transaction is not supported")}connection(){throw new Error("calling the connection method for a Transaction is not supported")}async destroy(){throw new Error("calling the destroy method for a Transaction is not supported")}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}withoutPlugins(){return new t({...this.#e,executor:this.#e.executor.withoutPlugins()})}withSchema(e){return new t({...this.#e,executor:this.#e.executor.withPluginAtFront(new re(e))})}withTables(){return new t({...this.#e})}};function Yn(t){return q(t)&&q(t.config)&&q(t.driver)&&q(t.executor)&&q(t.dialect)}var ji=class{#e;constructor(e){this.#e=i(e)}async execute(e){return this.#e.executor.provideConnection(async r=>{let o=this.#e.executor.withConnectionProvider(new St(r)),n=new At({...this.#e,executor:o});return await e(n)})}},Hi=class t{#e;constructor(e){this.#e=i(e)}setAccessMode(e){return new t({...this.#e,accessMode:e})}setIsolationLevel(e){return new t({...this.#e,isolationLevel:e})}async execute(e){let{isolationLevel:r,accessMode:o,...n}=this.#e,a={isolationLevel:r,accessMode:o};return Ki(a),this.#e.executor.provideConnection(async d=>{let c=this.#e.executor.withConnectionProvider(new St(d)),l=new Hr({...n,executor:c});try{await this.#e.driver.beginTransaction(d,a);let h=await e(l);return await this.#e.driver.commitTransaction(d),h}catch(h){throw await this.#e.driver.rollbackTransaction(d),h}})}},Yi=class t{#e;constructor(e){this.#e=i(e)}setAccessMode(e){return new t({...this.#e,accessMode:e})}setIsolationLevel(e){return new t({...this.#e,isolationLevel:e})}async execute(){let{isolationLevel:e,accessMode:r,...o}=this.#e,n={isolationLevel:e,accessMode:r};Ki(n);let a=await mr(this.#e.executor);return await this.#e.driver.beginTransaction(a.connection,n),new Xi({...o,connection:a,executor:this.#e.executor.withConnectionProvider(new St(a.connection))})}},Xi=class t extends Hr{#e;#t;#r;constructor(e){let r={isCommitted:!1,isRolledBack:!1};e={...e,executor:new Zi(e.executor,r)};let{connection:o,...n}=e;super(n),this.#e=i(e),this.#r=r;let a=f();this.#t=d=>e.executor.compileQuery(d,a)}get isCommitted(){return this.#r.isCommitted}get isRolledBack(){return this.#r.isRolledBack}commit(){return Xe(this.#r),new Ye(async()=>{await this.#e.driver.commitTransaction(this.#e.connection.connection),this.#r.isCommitted=!0,this.#e.connection.release()})}rollback(){return Xe(this.#r),new Ye(async()=>{await this.#e.driver.rollbackTransaction(this.#e.connection.connection),this.#r.isRolledBack=!0,this.#e.connection.release()})}savepoint(e){return Xe(this.#r),new Ye(async()=>(await this.#e.driver.savepoint?.(this.#e.connection.connection,e,this.#t),new t({...this.#e})))}rollbackToSavepoint(e){return Xe(this.#r),new Ye(async()=>(await this.#e.driver.rollbackToSavepoint?.(this.#e.connection.connection,e,this.#t),new t({...this.#e})))}releaseSavepoint(e){return Xe(this.#r),new Ye(async()=>(await this.#e.driver.releaseSavepoint?.(this.#e.connection.connection,e,this.#t),new t({...this.#e})))}withPlugin(e){return new t({...this.#e,executor:this.#e.executor.withPlugin(e)})}withoutPlugins(){return new t({...this.#e,executor:this.#e.executor.withoutPlugins()})}withSchema(e){return new t({...this.#e,executor:this.#e.executor.withPluginAtFront(new re(e))})}withTables(){return new t({...this.#e})}},Ye=class{#e;constructor(e){this.#e=e}async execute(){return await this.#e()}};function Xe(t){if(t.isCommitted)throw new Error("Transaction is already committed");if(t.isRolledBack)throw new Error("Transaction is already rolled back")}var Zi=class t{#e;#t;constructor(e,r){e instanceof t?this.#e=e.#e:this.#e=e,this.#t=r}get adapter(){return this.#e.adapter}get plugins(){return this.#e.plugins}transformQuery(e,r){return this.#e.transformQuery(e,r)}compileQuery(e,r){return this.#e.compileQuery(e,r)}provideConnection(e){return this.#e.provideConnection(e)}executeQuery(e,r){return Xe(this.#t),this.#e.executeQuery(e,r)}stream(e,r,o){return Xe(this.#t),this.#e.stream(e,r,o)}withConnectionProvider(e){return new t(this.#e.withConnectionProvider(e),this.#t)}withPlugin(e){return new t(this.#e.withPlugin(e),this.#t)}withPlugins(e){return new t(this.#e.withPlugins(e),this.#t)}withPluginAtFront(e){return new t(this.#e.withPluginAtFront(e),this.#t)}withoutPlugins(){return new t(this.#e.withoutPlugins(),this.#t)}};var _i=class t{#e;constructor(e){this.#e=i(e)}get expressionType(){}get isRawBuilder(){return!0}as(e){return new eo(this,e)}$castTo(){return new t({...this.#e})}$notNull(){return new t(this.#e)}withPlugin(e){return new t({...this.#e,plugins:this.#e.plugins!==void 0?i([...this.#e.plugins,e]):i([e])})}toOperationNode(){return this.#r(this.#t())}compile(e){return this.#i(this.#t(e))}async execute(e){let r=this.#t(e);return r.executeQuery(this.#i(r),this.#e.queryId)}#t(e){let r=e!==void 0?e.getExecutor():Pe;return this.#e.plugins!==void 0?r.withPlugins(this.#e.plugins):r}#r(e){return e.transformQuery(this.#e.rawNode,this.#e.queryId)}#i(e){return e.compileQuery(this.#r(e),this.#e.queryId)}};function Ae(t){return new _i(t)}var eo=class{#e;#t;constructor(e,r){this.#e=e,this.#t=r}get expression(){return this.#e}get alias(){return this.#t}get rawBuilder(){return this.#e}toOperationNode(){return E.create(this.#e.toOperationNode(),b(this.#t)?this.#t.toOperationNode():p.create(this.#t))}};var U=Object.assign((t,...e)=>Ae({queryId:f(),rawNode:W.create(t,e?.map(en)??[])}),{ref(t){return Ae({queryId:f(),rawNode:W.createWithChild(Z(t))})},val(t){return Ae({queryId:f(),rawNode:W.createWithChild(g(t))})},value(t){return this.val(t)},table(t){return Ae({queryId:f(),rawNode:W.createWithChild(y(t))})},id(...t){let e=new Array(t.length+1).fill(".");return e[0]="",e[e.length-1]="",Ae({queryId:f(),rawNode:W.create(e,t.map(p.create))})},lit(t){return Ae({queryId:f(),rawNode:W.createWithChild(S.createImmediate(t))})},literal(t){return this.lit(t)},raw(t){return Ae({queryId:f(),rawNode:W.createWithSql(t)})},join(t,e=U`, `){let r=new Array(Math.max(2*t.length-1,0)),o=e.toOperationNode();for(let n=0;n<t.length;++n)r[2*n]=en(t[n]),n!==t.length-1&&(r[2*n+1]=o);return Ae({queryId:f(),rawNode:W.createWithChildren(r)})}});function en(t){return b(t)?t.toOperationNode():g(t)}var Yr=class{nodeStack=[];get parentNode(){return this.nodeStack[this.nodeStack.length-2]}#e=i({AliasNode:this.visitAlias.bind(this),ColumnNode:this.visitColumn.bind(this),IdentifierNode:this.visitIdentifier.bind(this),SchemableIdentifierNode:this.visitSchemableIdentifier.bind(this),RawNode:this.visitRaw.bind(this),ReferenceNode:this.visitReference.bind(this),SelectQueryNode:this.visitSelectQuery.bind(this),SelectionNode:this.visitSelection.bind(this),TableNode:this.visitTable.bind(this),FromNode:this.visitFrom.bind(this),SelectAllNode:this.visitSelectAll.bind(this),AndNode:this.visitAnd.bind(this),OrNode:this.visitOr.bind(this),ValueNode:this.visitValue.bind(this),ValueListNode:this.visitValueList.bind(this),PrimitiveValueListNode:this.visitPrimitiveValueList.bind(this),ParensNode:this.visitParens.bind(this),JoinNode:this.visitJoin.bind(this),OperatorNode:this.visitOperator.bind(this),WhereNode:this.visitWhere.bind(this),InsertQueryNode:this.visitInsertQuery.bind(this),DeleteQueryNode:this.visitDeleteQuery.bind(this),ReturningNode:this.visitReturning.bind(this),CreateTableNode:this.visitCreateTable.bind(this),AddColumnNode:this.visitAddColumn.bind(this),ColumnDefinitionNode:this.visitColumnDefinition.bind(this),DropTableNode:this.visitDropTable.bind(this),DataTypeNode:this.visitDataType.bind(this),OrderByNode:this.visitOrderBy.bind(this),OrderByItemNode:this.visitOrderByItem.bind(this),GroupByNode:this.visitGroupBy.bind(this),GroupByItemNode:this.visitGroupByItem.bind(this),UpdateQueryNode:this.visitUpdateQuery.bind(this),ColumnUpdateNode:this.visitColumnUpdate.bind(this),LimitNode:this.visitLimit.bind(this),OffsetNode:this.visitOffset.bind(this),OnConflictNode:this.visitOnConflict.bind(this),OnDuplicateKeyNode:this.visitOnDuplicateKey.bind(this),CreateIndexNode:this.visitCreateIndex.bind(this),DropIndexNode:this.visitDropIndex.bind(this),ListNode:this.visitList.bind(this),PrimaryKeyConstraintNode:this.visitPrimaryKeyConstraint.bind(this),UniqueConstraintNode:this.visitUniqueConstraint.bind(this),ReferencesNode:this.visitReferences.bind(this),CheckConstraintNode:this.visitCheckConstraint.bind(this),WithNode:this.visitWith.bind(this),CommonTableExpressionNode:this.visitCommonTableExpression.bind(this),CommonTableExpressionNameNode:this.visitCommonTableExpressionName.bind(this),HavingNode:this.visitHaving.bind(this),CreateSchemaNode:this.visitCreateSchema.bind(this),DropSchemaNode:this.visitDropSchema.bind(this),AlterTableNode:this.visitAlterTable.bind(this),DropColumnNode:this.visitDropColumn.bind(this),RenameColumnNode:this.visitRenameColumn.bind(this),AlterColumnNode:this.visitAlterColumn.bind(this),ModifyColumnNode:this.visitModifyColumn.bind(this),AddConstraintNode:this.visitAddConstraint.bind(this),DropConstraintNode:this.visitDropConstraint.bind(this),RenameConstraintNode:this.visitRenameConstraint.bind(this),ForeignKeyConstraintNode:this.visitForeignKeyConstraint.bind(this),CreateViewNode:this.visitCreateView.bind(this),RefreshMaterializedViewNode:this.visitRefreshMaterializedView.bind(this),DropViewNode:this.visitDropView.bind(this),GeneratedNode:this.visitGenerated.bind(this),DefaultValueNode:this.visitDefaultValue.bind(this),OnNode:this.visitOn.bind(this),ValuesNode:this.visitValues.bind(this),SelectModifierNode:this.visitSelectModifier.bind(this),CreateTypeNode:this.visitCreateType.bind(this),DropTypeNode:this.visitDropType.bind(this),ExplainNode:this.visitExplain.bind(this),DefaultInsertValueNode:this.visitDefaultInsertValue.bind(this),AggregateFunctionNode:this.visitAggregateFunction.bind(this),OverNode:this.visitOver.bind(this),PartitionByNode:this.visitPartitionBy.bind(this),PartitionByItemNode:this.visitPartitionByItem.bind(this),SetOperationNode:this.visitSetOperation.bind(this),BinaryOperationNode:this.visitBinaryOperation.bind(this),UnaryOperationNode:this.visitUnaryOperation.bind(this),UsingNode:this.visitUsing.bind(this),FunctionNode:this.visitFunction.bind(this),CaseNode:this.visitCase.bind(this),WhenNode:this.visitWhen.bind(this),JSONReferenceNode:this.visitJSONReference.bind(this),JSONPathNode:this.visitJSONPath.bind(this),JSONPathLegNode:this.visitJSONPathLeg.bind(this),JSONOperatorChainNode:this.visitJSONOperatorChain.bind(this),TupleNode:this.visitTuple.bind(this),MergeQueryNode:this.visitMergeQuery.bind(this),MatchedNode:this.visitMatched.bind(this),AddIndexNode:this.visitAddIndex.bind(this),CastNode:this.visitCast.bind(this),FetchNode:this.visitFetch.bind(this),TopNode:this.visitTop.bind(this),OutputNode:this.visitOutput.bind(this),OrActionNode:this.visitOrAction.bind(this),CollateNode:this.visitCollate.bind(this)});visitNode=e=>{this.nodeStack.push(e),this.#e[e.kind](e),this.nodeStack.pop()}};var Xn=/'/g,Xr=class extends Yr{#e="";#t=[];get numParameters(){return this.#t.length}compileQuery(e,r){return this.#e="",this.#t=[],this.nodeStack.splice(0,this.nodeStack.length),this.visitNode(e),i({query:e,queryId:r,sql:this.getSql(),parameters:[...this.#t]})}getSql(){return this.#e}visitSelectQuery(e){let r=this.parentNode!==void 0&&!fe.is(this.parentNode)&&!T.is(this.parentNode)&&!z.is(this.parentNode)&&!ce.is(this.parentNode)&&!wr.is(this.parentNode);this.parentNode===void 0&&e.explain&&(this.visitNode(e.explain),this.append(" ")),r&&this.append("("),e.with&&(this.visitNode(e.with),this.append(" ")),this.append("select"),e.distinctOn&&(this.append(" "),this.compileDistinctOn(e.distinctOn)),e.frontModifiers?.length&&(this.append(" "),this.compileList(e.frontModifiers," ")),e.top&&(this.append(" "),this.visitNode(e.top)),e.selections&&(this.append(" "),this.compileList(e.selections)),e.from&&(this.append(" "),this.visitNode(e.from)),e.joins&&(this.append(" "),this.compileList(e.joins," ")),e.where&&(this.append(" "),this.visitNode(e.where)),e.groupBy&&(this.append(" "),this.visitNode(e.groupBy)),e.having&&(this.append(" "),this.visitNode(e.having)),e.setOperations&&(this.append(" "),this.compileList(e.setOperations," ")),e.orderBy&&(this.append(" "),this.visitNode(e.orderBy)),e.limit&&(this.append(" "),this.visitNode(e.limit)),e.offset&&(this.append(" "),this.visitNode(e.offset)),e.fetch&&(this.append(" "),this.visitNode(e.fetch)),e.endModifiers?.length&&(this.append(" "),this.compileList(this.sortSelectModifiers([...e.endModifiers])," ")),r&&this.append(")")}visitFrom(e){this.append("from "),this.compileList(e.froms)}visitSelection(e){this.visitNode(e.selection)}visitColumn(e){this.visitNode(e.column)}compileDistinctOn(e){this.append("distinct on ("),this.compileList(e),this.append(")")}compileList(e,r=", "){let o=e.length-1;for(let n=0;n<=o;n++)this.visitNode(e[n]),n<o&&this.append(r)}visitWhere(e){this.append("where "),this.visitNode(e.where)}visitHaving(e){this.append("having "),this.visitNode(e.having)}visitInsertQuery(e){let r=this.nodeStack.find(u.is),o=r!==e;!o&&e.explain&&(this.visitNode(e.explain),this.append(" ")),o&&!I.is(r)&&this.append("("),e.with&&(this.visitNode(e.with),this.append(" ")),this.append(e.replace?"replace":"insert"),e.ignore&&(De("`InsertQueryNode.ignore` is deprecated. Use `InsertQueryNode.orAction` instead."),this.append(" ignore")),e.orAction&&(this.append(" "),this.visitNode(e.orAction)),e.top&&(this.append(" "),this.visitNode(e.top)),e.into&&(this.append(" into "),this.visitNode(e.into)),e.columns&&(this.append(" ("),this.compileList(e.columns),this.append(")")),e.output&&(this.append(" "),this.visitNode(e.output)),e.values&&(this.append(" "),this.visitNode(e.values)),e.defaultValues&&(this.append(" "),this.append("default values")),e.onConflict&&(this.append(" "),this.visitNode(e.onConflict)),e.onDuplicateKey&&(this.append(" "),this.visitNode(e.onDuplicateKey)),e.returning&&(this.append(" "),this.visitNode(e.returning)),o&&!I.is(r)&&this.append(")"),e.endModifiers?.length&&(this.append(" "),this.compileList(e.endModifiers," "))}visitValues(e){this.append("values "),this.compileList(e.values)}visitDeleteQuery(e){let r=this.nodeStack.find(u.is)!==e;!r&&e.explain&&(this.visitNode(e.explain),this.append(" ")),r&&this.append("("),e.with&&(this.visitNode(e.with),this.append(" ")),this.append("delete "),e.top&&(this.visitNode(e.top),this.append(" ")),this.visitNode(e.from),e.output&&(this.append(" "),this.visitNode(e.output)),e.using&&(this.append(" "),this.visitNode(e.using)),e.joins&&(this.append(" "),this.compileList(e.joins," ")),e.where&&(this.append(" "),this.visitNode(e.where)),e.orderBy&&(this.append(" "),this.visitNode(e.orderBy)),e.limit&&(this.append(" "),this.visitNode(e.limit)),e.returning&&(this.append(" "),this.visitNode(e.returning)),r&&this.append(")"),e.endModifiers?.length&&(this.append(" "),this.compileList(e.endModifiers," "))}visitReturning(e){this.append("returning "),this.compileList(e.selections)}visitAlias(e){this.visitNode(e.node),this.append(" as "),this.visitNode(e.alias)}visitReference(e){e.table&&(this.visitNode(e.table),this.append(".")),this.visitNode(e.column)}visitSelectAll(e){this.append("*")}visitIdentifier(e){this.append(this.getLeftIdentifierWrapper()),this.compileUnwrappedIdentifier(e),this.append(this.getRightIdentifierWrapper())}compileUnwrappedIdentifier(e){if(!v(e.name))throw new Error("a non-string identifier was passed to compileUnwrappedIdentifier.");this.append(this.sanitizeIdentifier(e.name))}visitAnd(e){this.visitNode(e.left),this.append(" and "),this.visitNode(e.right)}visitOr(e){this.visitNode(e.left),this.append(" or "),this.visitNode(e.right)}visitValue(e){e.immediate?this.appendImmediateValue(e.value):this.appendValue(e.value)}visitValueList(e){this.append("("),this.compileList(e.values),this.append(")")}visitTuple(e){this.append("("),this.compileList(e.values),this.append(")")}visitPrimitiveValueList(e){this.append("(");let{values:r}=e;for(let o=0;o<r.length;++o)this.appendValue(r[o]),o!==r.length-1&&this.append(", ");this.append(")")}visitParens(e){this.append("("),this.visitNode(e.node),this.append(")")}visitJoin(e){this.append(_n[e.joinType]),this.append(" "),this.visitNode(e.table),e.on&&(this.append(" "),this.visitNode(e.on))}visitOn(e){this.append("on "),this.visitNode(e.on)}visitRaw(e){let{sqlFragments:r,parameters:o}=e;for(let n=0;n<r.length;++n)this.append(r[n]),o.length>n&&this.visitNode(o[n])}visitOperator(e){this.append(e.operator)}visitTable(e){this.visitNode(e.table)}visitSchemableIdentifier(e){e.schema&&(this.visitNode(e.schema),this.append(".")),this.visitNode(e.identifier)}visitCreateTable(e){this.append("create "),e.frontModifiers&&e.frontModifiers.length>0&&(this.compileList(e.frontModifiers," "),this.append(" ")),e.temporary&&this.append("temporary "),this.append("table "),e.ifNotExists&&this.append("if not exists "),this.visitNode(e.table),e.selectQuery?(this.append(" as "),this.visitNode(e.selectQuery)):(this.append(" ("),this.compileList([...e.columns,...e.constraints??[]]),this.append(")"),e.onCommit&&(this.append(" on commit "),this.append(e.onCommit)),e.endModifiers&&e.endModifiers.length>0&&(this.append(" "),this.compileList(e.endModifiers," ")))}visitColumnDefinition(e){e.ifNotExists&&this.append("if not exists "),this.visitNode(e.column),this.append(" "),this.visitNode(e.dataType),e.unsigned&&this.append(" unsigned"),e.frontModifiers&&e.frontModifiers.length>0&&(this.append(" "),this.compileList(e.frontModifiers," ")),e.generated&&(this.append(" "),this.visitNode(e.generated)),e.identity&&this.append(" identity"),e.defaultTo&&(this.append(" "),this.visitNode(e.defaultTo)),e.notNull&&this.append(" not null"),e.unique&&this.append(" unique"),e.nullsNotDistinct&&this.append(" nulls not distinct"),e.primaryKey&&this.append(" primary key"),e.autoIncrement&&(this.append(" "),this.append(this.getAutoIncrement())),e.references&&(this.append(" "),this.visitNode(e.references)),e.check&&(this.append(" "),this.visitNode(e.check)),e.endModifiers&&e.endModifiers.length>0&&(this.append(" "),this.compileList(e.endModifiers," "))}getAutoIncrement(){return"auto_increment"}visitReferences(e){this.append("references "),this.visitNode(e.table),this.append(" ("),this.compileList(e.columns),this.append(")"),e.onDelete&&(this.append(" on delete "),this.append(e.onDelete)),e.onUpdate&&(this.append(" on update "),this.append(e.onUpdate))}visitDropTable(e){this.append("drop table "),e.ifExists&&this.append("if exists "),this.visitNode(e.table),e.cascade&&this.append(" cascade")}visitDataType(e){this.append(e.dataType)}visitOrderBy(e){this.append("order by "),this.compileList(e.items)}visitOrderByItem(e){this.visitNode(e.orderBy),e.collation&&(this.append(" "),this.visitNode(e.collation)),e.direction&&(this.append(" "),this.visitNode(e.direction)),e.nulls&&(this.append(" nulls "),this.append(e.nulls))}visitGroupBy(e){this.append("group by "),this.compileList(e.items)}visitGroupByItem(e){this.visitNode(e.groupBy)}visitUpdateQuery(e){let r=this.nodeStack.find(u.is),o=r!==e;if(!o&&e.explain&&(this.visitNode(e.explain),this.append(" ")),o&&!I.is(r)&&this.append("("),e.with&&(this.visitNode(e.with),this.append(" ")),this.append("update "),e.top&&(this.visitNode(e.top),this.append(" ")),e.table&&(this.visitNode(e.table),this.append(" ")),this.append("set "),e.updates&&this.compileList(e.updates),e.output&&(this.append(" "),this.visitNode(e.output)),e.from&&(this.append(" "),this.visitNode(e.from)),e.joins){if(!e.from)throw new Error("Joins in an update query are only supported as a part of a PostgreSQL 'update set from join' query. If you want to create a MySQL 'update join set' query, see https://kysely.dev/docs/examples/update/my-sql-joins");this.append(" "),this.compileList(e.joins," ")}e.where&&(this.append(" "),this.visitNode(e.where)),e.orderBy&&(this.append(" "),this.visitNode(e.orderBy)),e.limit&&(this.append(" "),this.visitNode(e.limit)),e.returning&&(this.append(" "),this.visitNode(e.returning)),o&&!I.is(r)&&this.append(")"),e.endModifiers?.length&&(this.append(" "),this.compileList(e.endModifiers," "))}visitColumnUpdate(e){this.visitNode(e.column),this.append(" = "),this.visitNode(e.value)}visitLimit(e){this.append("limit "),this.visitNode(e.limit)}visitOffset(e){this.append("offset "),this.visitNode(e.offset)}visitOnConflict(e){this.append("on conflict"),e.columns?(this.append(" ("),this.compileList(e.columns),this.append(")")):e.constraint?(this.append(" on constraint "),this.visitNode(e.constraint)):e.indexExpression&&(this.append(" ("),this.visitNode(e.indexExpression),this.append(")")),e.indexWhere&&(this.append(" "),this.visitNode(e.indexWhere)),e.doNothing===!0?this.append(" do nothing"):e.updates&&(this.append(" do update set "),this.compileList(e.updates),e.updateWhere&&(this.append(" "),this.visitNode(e.updateWhere)))}visitOnDuplicateKey(e){this.append("on duplicate key update "),this.compileList(e.updates)}visitCreateIndex(e){this.append("create "),e.unique&&this.append("unique "),this.append("index "),e.ifNotExists&&this.append("if not exists "),this.visitNode(e.name),e.table&&(this.append(" on "),this.visitNode(e.table)),e.using&&(this.append(" using "),this.visitNode(e.using)),e.columns&&(this.append(" ("),this.compileList(e.columns),this.append(")")),e.nullsNotDistinct&&this.append(" nulls not distinct"),e.where&&(this.append(" "),this.visitNode(e.where))}visitDropIndex(e){this.append("drop index "),e.ifExists&&this.append("if exists "),this.visitNode(e.name),e.table&&(this.append(" on "),this.visitNode(e.table)),e.cascade&&this.append(" cascade")}visitCreateSchema(e){this.append("create schema "),e.ifNotExists&&this.append("if not exists "),this.visitNode(e.schema)}visitDropSchema(e){this.append("drop schema "),e.ifExists&&this.append("if exists "),this.visitNode(e.schema),e.cascade&&this.append(" cascade")}visitPrimaryKeyConstraint(e){e.name&&(this.append("constraint "),this.visitNode(e.name),this.append(" ")),this.append("primary key ("),this.compileList(e.columns),this.append(")"),this.buildDeferrable(e)}buildDeferrable(e){e.deferrable!==void 0&&(e.deferrable?this.append(" deferrable"):this.append(" not deferrable")),e.initiallyDeferred!==void 0&&(e.initiallyDeferred?this.append(" initially deferred"):this.append(" initially immediate"))}visitUniqueConstraint(e){e.name&&(this.append("constraint "),this.visitNode(e.name),this.append(" ")),this.append("unique"),e.nullsNotDistinct&&this.append(" nulls not distinct"),this.append(" ("),this.compileList(e.columns),this.append(")"),this.buildDeferrable(e)}visitCheckConstraint(e){e.name&&(this.append("constraint "),this.visitNode(e.name),this.append(" ")),this.append("check ("),this.visitNode(e.expression),this.append(")")}visitForeignKeyConstraint(e){e.name&&(this.append("constraint "),this.visitNode(e.name),this.append(" ")),this.append("foreign key ("),this.compileList(e.columns),this.append(") "),this.visitNode(e.references),e.onDelete&&(this.append(" on delete "),this.append(e.onDelete)),e.onUpdate&&(this.append(" on update "),this.append(e.onUpdate)),this.buildDeferrable(e)}visitList(e){this.compileList(e.items)}visitWith(e){this.append("with "),e.recursive&&this.append("recursive "),this.compileList(e.expressions)}visitCommonTableExpression(e){this.visitNode(e.name),this.append(" as "),Ue(e.materialized)&&(e.materialized||this.append("not "),this.append("materialized ")),this.visitNode(e.expression)}visitCommonTableExpressionName(e){this.visitNode(e.table),e.columns&&(this.append("("),this.compileList(e.columns),this.append(")"))}visitAlterTable(e){this.append("alter table "),this.visitNode(e.table),this.append(" "),e.renameTo&&(this.append("rename to "),this.visitNode(e.renameTo)),e.setSchema&&(this.append("set schema "),this.visitNode(e.setSchema)),e.addConstraint&&this.visitNode(e.addConstraint),e.dropConstraint&&this.visitNode(e.dropConstraint),e.renameConstraint&&this.visitNode(e.renameConstraint),e.columnAlterations&&this.compileColumnAlterations(e.columnAlterations),e.addIndex&&this.visitNode(e.addIndex),e.dropIndex&&this.visitNode(e.dropIndex)}visitAddColumn(e){this.append("add column "),this.visitNode(e.column)}visitRenameColumn(e){this.append("rename column "),this.visitNode(e.column),this.append(" to "),this.visitNode(e.renameTo)}visitDropColumn(e){this.append("drop column "),this.visitNode(e.column)}visitAlterColumn(e){this.append("alter column "),this.visitNode(e.column),this.append(" "),e.dataType&&(this.announcesNewColumnDataType()&&this.append("type "),this.visitNode(e.dataType),e.dataTypeExpression&&(this.append("using "),this.visitNode(e.dataTypeExpression))),e.setDefault&&(this.append("set default "),this.visitNode(e.setDefault)),e.dropDefault&&this.append("drop default"),e.setNotNull&&this.append("set not null"),e.dropNotNull&&this.append("drop not null")}visitModifyColumn(e){this.append("modify column "),this.visitNode(e.column)}visitAddConstraint(e){this.append("add "),this.visitNode(e.constraint)}visitDropConstraint(e){this.append("drop constraint "),e.ifExists&&this.append("if exists "),this.visitNode(e.constraintName),e.modifier==="cascade"?this.append(" cascade"):e.modifier==="restrict"&&this.append(" restrict")}visitRenameConstraint(e){this.append("rename constraint "),this.visitNode(e.oldName),this.append(" to "),this.visitNode(e.newName)}visitSetOperation(e){this.append(e.operator),this.append(" "),e.all&&this.append("all "),this.visitNode(e.expression)}visitCreateView(e){this.append("create "),e.orReplace&&this.append("or replace "),e.materialized&&this.append("materialized "),e.temporary&&this.append("temporary "),this.append("view "),e.ifNotExists&&this.append("if not exists "),this.visitNode(e.name),this.append(" "),e.columns&&(this.append("("),this.compileList(e.columns),this.append(") ")),e.as&&(this.append("as "),this.visitNode(e.as))}visitRefreshMaterializedView(e){this.append("refresh materialized view "),e.concurrently&&this.append("concurrently "),this.visitNode(e.name),e.withNoData?this.append(" with no data"):this.append(" with data")}visitDropView(e){this.append("drop "),e.materialized&&this.append("materialized "),this.append("view "),e.ifExists&&this.append("if exists "),this.visitNode(e.name),e.cascade&&this.append(" cascade")}visitGenerated(e){this.append("generated "),e.always&&this.append("always "),e.byDefault&&this.append("by default "),this.append("as "),e.identity&&this.append("identity"),e.expression&&(this.append("("),this.visitNode(e.expression),this.append(")")),e.stored&&this.append(" stored")}visitDefaultValue(e){this.append("default "),this.visitNode(e.defaultValue)}visitSelectModifier(e){e.rawModifier?this.visitNode(e.rawModifier):this.append(Zn[e.modifier]),e.of&&(this.append(" of "),this.compileList(e.of,", "))}visitCreateType(e){this.append("create type "),this.visitNode(e.name),e.enum&&(this.append(" as enum "),this.visitNode(e.enum))}visitDropType(e){this.append("drop type "),e.ifExists&&this.append("if exists "),this.visitNode(e.name)}visitExplain(e){this.append("explain"),(e.options||e.format)&&(this.append(" "),this.append(this.getLeftExplainOptionsWrapper()),e.options&&(this.visitNode(e.options),e.format&&this.append(this.getExplainOptionsDelimiter())),e.format&&(this.append("format"),this.append(this.getExplainOptionAssignment()),this.append(e.format)),this.append(this.getRightExplainOptionsWrapper()))}visitDefaultInsertValue(e){this.append("default")}visitAggregateFunction(e){this.append(e.func),this.append("("),e.distinct&&this.append("distinct "),this.compileList(e.aggregated),e.orderBy&&(this.append(" "),this.visitNode(e.orderBy)),this.append(")"),e.withinGroup&&(this.append(" within group ("),this.visitNode(e.withinGroup),this.append(")")),e.filter&&(this.append(" filter("),this.visitNode(e.filter),this.append(")")),e.over&&(this.append(" "),this.visitNode(e.over))}visitOver(e){this.append("over("),e.partitionBy&&(this.visitNode(e.partitionBy),e.orderBy&&this.append(" ")),e.orderBy&&this.visitNode(e.orderBy),this.append(")")}visitPartitionBy(e){this.append("partition by "),this.compileList(e.items)}visitPartitionByItem(e){this.visitNode(e.partitionBy)}visitBinaryOperation(e){this.visitNode(e.leftOperand),this.append(" "),this.visitNode(e.operator),this.append(" "),this.visitNode(e.rightOperand)}visitUnaryOperation(e){this.visitNode(e.operator),this.isMinusOperator(e.operator)||this.append(" "),this.visitNode(e.operand)}isMinusOperator(e){return X.is(e)&&e.operator==="-"}visitUsing(e){this.append("using "),this.compileList(e.tables)}visitFunction(e){this.append(e.func),this.append("("),this.compileList(e.arguments),this.append(")")}visitCase(e){this.append("case"),e.value&&(this.append(" "),this.visitNode(e.value)),e.when&&(this.append(" "),this.compileList(e.when," ")),e.else&&(this.append(" else "),this.visitNode(e.else)),this.append(" end"),e.isStatement&&this.append(" case")}visitWhen(e){this.append("when "),this.visitNode(e.condition),e.result&&(this.append(" then "),this.visitNode(e.result))}visitJSONReference(e){this.visitNode(e.reference),this.visitNode(e.traversal)}visitJSONPath(e){e.inOperator&&this.visitNode(e.inOperator),this.append("'$");for(let r of e.pathLegs)this.visitNode(r);this.append("'")}visitJSONPathLeg(e){let r=e.type==="ArrayLocation";this.append(r?"[":"."),this.append(String(e.value)),r&&this.append("]")}visitJSONOperatorChain(e){for(let r=0,o=e.values.length;r<o;r++)r===o-1?this.visitNode(e.operator):this.append("->"),this.visitNode(e.values[r])}visitMergeQuery(e){e.with&&(this.visitNode(e.with),this.append(" ")),this.append("merge "),e.top&&(this.visitNode(e.top),this.append(" ")),this.append("into "),this.visitNode(e.into),e.using&&(this.append(" "),this.visitNode(e.using)),e.whens&&(this.append(" "),this.compileList(e.whens," ")),e.returning&&(this.append(" "),this.visitNode(e.returning)),e.output&&(this.append(" "),this.visitNode(e.output)),e.endModifiers?.length&&(this.append(" "),this.compileList(e.endModifiers," "))}visitMatched(e){e.not&&this.append("not "),this.append("matched"),e.bySource&&this.append(" by source")}visitAddIndex(e){this.append("add "),e.unique&&this.append("unique "),this.append("index "),this.visitNode(e.name),e.columns&&(this.append(" ("),this.compileList(e.columns),this.append(")")),e.using&&(this.append(" using "),this.visitNode(e.using))}visitCast(e){this.append("cast("),this.visitNode(e.expression),this.append(" as "),this.visitNode(e.dataType),this.append(")")}visitFetch(e){this.append("fetch next "),this.visitNode(e.rowCount),this.append(` rows ${e.modifier}`)}visitOutput(e){this.append("output "),this.compileList(e.selections)}visitTop(e){this.append(`top(${e.expression})`),e.modifiers&&this.append(` ${e.modifiers}`)}visitOrAction(e){this.append(e.action)}visitCollate(e){this.append("collate "),this.visitNode(e.collation)}append(e){this.#e+=e}appendValue(e){this.addParameter(e),this.append(this.getCurrentParameterPlaceholder())}getLeftIdentifierWrapper(){return'"'}getRightIdentifierWrapper(){return'"'}getCurrentParameterPlaceholder(){return"$"+this.numParameters}getLeftExplainOptionsWrapper(){return"("}getExplainOptionAssignment(){return" "}getExplainOptionsDelimiter(){return", "}getRightExplainOptionsWrapper(){return")"}sanitizeIdentifier(e){let r=this.getLeftIdentifierWrapper(),o=this.getRightIdentifierWrapper(),n="";for(let a of e)n+=a,a===r?n+=r:a===o&&(n+=o);return n}sanitizeStringLiteral(e){return e.replace(Xn,"''")}addParameter(e){this.#t.push(e)}appendImmediateValue(e){if(v(e))this.appendStringLiteral(e);else if(Ee(e)||Ue(e))this.append(e.toString());else if(Ze(e))this.append("null");else if(so(e))this.appendImmediateValue(e.toISOString());else if(_e(e))this.appendImmediateValue(e.toString());else throw new Error(`invalid immediate value ${e}`)}appendStringLiteral(e){this.append("'"),this.append(this.sanitizeStringLiteral(e)),this.append("'")}sortSelectModifiers(e){return e.sort((r,o)=>r.modifier&&o.modifier?tn[r.modifier]-tn[o.modifier]:1),i(e)}compileColumnAlterations(e){this.compileList(e)}announcesNewColumnDataType(){return!0}},Zn=i({ForKeyShare:"for key share",ForNoKeyUpdate:"for no key update",ForUpdate:"for update",ForShare:"for share",NoWait:"nowait",SkipLocked:"skip locked",Distinct:"distinct"}),tn=i({ForKeyShare:1,ForNoKeyUpdate:1,ForUpdate:1,ForShare:1,NoWait:2,SkipLocked:2,Distinct:0}),_n=i({InnerJoin:"inner join",LeftJoin:"left join",RightJoin:"right join",FullJoin:"full join",CrossJoin:"cross join",LateralInnerJoin:"inner join lateral",LateralLeftJoin:"left join lateral",LateralCrossJoin:"cross join lateral",OuterApply:"outer apply",CrossApply:"cross apply",Using:"using"});var Zr=class{async init(){}async acquireConnection(){return new to}async beginTransaction(){}async commitTransaction(){}async rollbackTransaction(){}async releaseConnection(){}async destroy(){}async releaseSavepoint(){}async rollbackToSavepoint(){}async savepoint(){}},to=class{async executeQuery(){return{rows:[]}}async*streamQuery(){}};var _r=class{get supportsCreateIfNotExists(){return!0}get supportsTransactionalDdl(){return!1}get supportsReturning(){return!1}get supportsOutput(){return!1}};var es=/"/g,ei=class extends Xr{sanitizeIdentifier(e){return e.replace(es,'""')}};var ts=BigInt("3853314791062309107"),ti=class extends _r{get supportsTransactionalDdl(){return!0}get supportsReturning(){return!0}async acquireMigrationLock(e,r){await U`select pg_advisory_xact_lock(${U.lit(ts)})`.execute(e)}async releaseMigrationLock(e,r){}};function rn(t){return new At({dialect:{createAdapter:()=>new t.Adapter,createDriver:()=>new Zr,createIntrospector:()=>null,createQueryCompiler:()=>new t.QueryCompiler},plugins:[...t.noParameters?[new ro]:[]]})}var ro=class{#e=new io;transformQuery(e){return this.#e.transformNode(e.node)}transformResult(e){return Promise.resolve(e.result)}},io=class extends Le{transformPrimitiveValueList(e){return me.create(e.values.map(S.createImmediate))}transformValue(e){return{...super.transformValue(e),immediate:!0}}};function ze(t){let e=t.compile();return{parameters:e.parameters,sql:e.sql}}function oo(t,e){let r=is(t,e);return o=>o.where(n=>n.or(r.map(a=>n.and(a.map(([d,c])=>n(d,c===null?"is":"=",c))))))}function rs(t,e){return Object.entries(Object.values(e).reduce((r,o)=>{let{isInPrimaryKey:n,name:a}=o;return n&&(r[a]=t[a]??null),r},{}))}function is(t,e){return t.map(r=>rs(r,e))}function Ve(t){return rn({...t,Adapter:ti,QueryCompiler:ei})}function on(t,e){let{table:r,rows:o}=t,{name:n,schema:a,columns:d}=r,c=Ve(e),l=Object.keys(d),h={[l[0]]:U`default`};return ze(c.withSchema(a).insertInto(n).values(o.map(L=>Object.keys(L).length===0?h:L)).returning(l).returning(L=>L.cast("ctid","text").as("ctid")))}function nn(t,e){let{pageIndex:r,pageSize:o,sortOrder:n,table:{name:a,schema:d,columns:c},filter:l={kind:"FilterGroup",after:"and",filters:[]}}=t,h=Ve(e),L=Object.keys(c),ge=h.withSchema(d).selectFrom(a).select(P=>P.cast(P.fn.coalesce(P.fn.countAll(),U.lit(0)),"text").as("oid"));return ze(h.with("count",()=>ge).withSchema(d).selectFrom([a,"count"]).select(U.ref("count.oid").$castTo().as("oid")).select(P=>P.cast("ctid","text").as("ctid")).select(L).$call(P=>n.reduce((F,he)=>F.orderBy(he.column,he.direction),P)).where(sn(l.filters,c)).limit(o).offset(U.lit(BigInt(r)*BigInt(o))))}function os(t,e){return t.kind==="ColumnFilter"?r=>{let{column:o,operator:n,value:a}=t,d=U.ref(o),c=e[o]?.datatype.group==="enum"?r.cast(d,"text"):d;return r(c,n,a)}:sn(t.filters,e)}function sn(t,e){if(t.length===0)return n=>n.lit(!0);let r=[],o=[];for(let n=0;n<t.length;n++)o.push(os(t[n],e)),(n===t.length-1||t[n].after==="or")&&(r.push(o),o=[]);return n=>{let a=r.map(d=>n.and(d.map(c=>c(n))));return n.or(a)}}function an(t,e){let{changes:r,row:o,table:{columns:n,name:a,schema:d}}=t,c=Ve(e),l=Object.keys(n);return ze(c.withSchema(d).updateTable(a).set(r).$call(oo([o],n)).returning(l).returning(h=>[h.cast("ctid","text").as("ctid"),h.cast(h.fn("floor",[h(h.fn("extract",[U`epoch from now()`]),"*",1e6)]),"text").as("__ps_updated_at__")]))}function un(t,e){let{rows:r,table:{columns:o,name:n,schema:a}}=t,d=Ve(e);return ze(d.withSchema(a).deleteFrom(n).$call(oo(r,o)))}function dn(t){return U`(select coalesce(json_agg(agg), '[]') from ${t} as agg)`}var ns="r",ss="v",as=[ns,ss];function pn(t){return ze(Ve(t).selectFrom("pg_catalog.pg_class as cls").innerJoin("pg_catalog.pg_namespace as ns","cls.relnamespace","ns.oid").$call(us).where("cls.relkind","in",as).select(e=>["ns.nspname as schema","cls.relname as name",dn(e.selectFrom("pg_catalog.pg_attribute as att").innerJoin("pg_catalog.pg_type as typ","typ.oid","att.atttypid").innerJoin("pg_catalog.pg_namespace as tns","tns.oid","typ.typnamespace").leftJoin("pg_catalog.pg_constraint as pk_con",r=>r.on("pk_con.contype","=","p").onRef("pk_con.conrelid","=","cls.oid").on(o=>o("att.attnum","=",o.fn.any("pk_con.conkey")))).leftJoin("pg_catalog.pg_constraint as fk_con",r=>r.on("fk_con.contype","=","f").onRef("fk_con.conrelid","=","cls.oid").on(o=>o("att.attnum","=",o.fn.any("fk_con.conkey")))).leftJoin("pg_catalog.pg_class as fk_cls","fk_cls.oid","fk_con.confrelid").leftJoin("pg_catalog.pg_namespace as fk_ns","fk_ns.oid","fk_cls.relnamespace").leftJoin("pg_catalog.pg_attribute as fk_att",r=>r.onRef("fk_att.attrelid","=","fk_cls.oid").on(o=>o("fk_att.attnum","=",o.fn.any("fk_con.confkey")))).whereRef("att.attrelid","=","cls.oid").where("att.attnum",">=",0).where("att.attisdropped","!=",!0).select(["att.attname as name","typ.typname as datatype","tns.nspname as datatype_schema","fk_ns.nspname as foreign_key_schema","fk_cls.relname as foreign_key_table","fk_att.attname as foreign_key_column"]).select(r=>[r("pk_con.conkey","is not",null).$castTo().as("pk"),r("att.attgenerated","!=","").$castTo().as("computed"),r("att.attnotnull","!=",!0).$castTo().as("nullable"),r.fn.coalesce(r.selectFrom("pg_catalog.pg_enum as enm").whereRef("enm.enumtypid","=","typ.oid").select(o=>o.fn.jsonAgg(o.ref("enm.enumlabel")).as("o")),U`'[]'`).as("options")])).as("columns")]))}function cn(){let t=Ve();return ze(t.selectNoFrom(t.fn("current_setting",[U.lit("timezone")]).as("timezone")))}function us(t){return t.where("ns.nspname","!~","^pg_").where("ns.nspname","!=","information_schema")}function hn(t){let{executor:e,...r}=t;return{defaultSchema:"public",async introspect(o){try{let n=pn(r),a=cn(),[[d,c],[l,h]]=await Promise.all([e.execute(n,o),e.execute(a,o)]);if(d)return G({error:d,query:n});if(l)return G({error:l,query:a});let L=h[0]?.timezone;return L?[null,ds({tables:c,timezone:L,query:n})]:G({error:new Error("Timezone not found"),query:a})}catch(n){return G({error:n})}},async query(o,n){try{let a=nn(o,r),[d,c]=await e.execute(a,n);return d?G({error:d,query:a}):[null,{filteredRowCount:c[0]?.oid||"0",rows:c,query:a}]}catch(a){return G({error:a})}},async insert(o,n){try{let a=on(o,r),[d,c]=await e.execute(a,n);return d?G({error:d,query:a}):[null,{rows:c,query:a}]}catch(a){return G({error:a})}},async update(o,n){try{let a=an(o,r),[d,c]=await e.execute(a,n);if(d)return G({error:d,query:a});let[l]=c;return l?[null,{row:l,query:a}]:G({error:new Error("Update failed"),query:a})}catch(a){return G({error:a})}},async delete(o,n){try{let a=un(o,r),[d]=await e.execute(a,n);return d?G({error:d,query:a}):[null,{...o,query:a}]}catch(a){return G({error:a})}}}}function ds(t){let{tables:e,timezone:r,query:o}=t;return e.reduce((n,a)=>{let{schemas:d}=n,{columns:c,name:l,schema:h}=a,L=c.reduce((ge,P)=>{let{datatype:F,datatype_schema:he,name:Jt,options:$t,nullable:ri}=P,ii=F.startsWith("_"),oi=ii?F.slice(1):F;return{...ge,[Jt]:{datatype:{...no[oi]||{group:$t.length>0?"enum":"raw"},isArray:ii,isNative:he==="pg_catalog",name:ii?`${oi}[]`:oi,options:$t,schema:he},isComputed:P.computed,isInPrimaryKey:P.pk,name:Jt,nullable:ri,schema:h,table:l,fkSchema:P.foreign_key_schema,fkTable:P.foreign_key_table,fkColumn:P.foreign_key_column}}},{});return d[h]===void 0&&(d[h]={name:h,tables:{}}),d[h].tables[l]={columns:L,name:l,schema:h},n},{schemas:{public:{tables:{},name:"public"}},timezone:r,filterOperators:ps,query:o})}var ps=["=","!=",">",">=","<","<=","is","is not","like","not like","ilike","not ilike"];function ln(t,e){let{addDelay:r=0,logging:o=!1}=e??{};return{execute:async(n,a)=>{let{abortSignal:d}=a||{},c,l=new Promise((F,he)=>c=he);function h(){let F=new Error("This operation was aborted");F.name="AbortError",c(F)}d?.addEventListener("abort",h);let L=typeof r=="function"?r(n):r,ge=()=>t.query(n.sql,n.parameters,{rowMode:"object"}),P=L>0?()=>new Promise(F=>setTimeout(F,L)).then(()=>ge()):ge;try{let F=typeof o=="function"?o(n):o,he;F&&console.log("PGLiteExecutor: Executing query:",he=JSON.stringify(n,null,2));let Jt=Date.now(),$t=await Promise.race([P(),l]),ri=Date.now()-Jt;return F&&console.log("PGLiteExecutor: Query executed in",ri,"ms:",he),[null,$t.rows]}catch(F){return[F]}finally{d?.removeEventListener("abort",h)}}}}function cs(t,e){return hn({executor:ln(t,e)})}
2
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/pglite/index.ts", "../../../data/adapter.ts", "../../../data/postgres-core/datatype.ts", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/util/object-utils.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/alter-table-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/identifier-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/create-index-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/create-schema-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/create-table-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/schemable-identifier-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/drop-index-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/drop-schema-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/drop-table-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/alias-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/table-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/operation-node-source.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/expression/expression.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/select-modifier-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/and-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/or-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/on-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/join-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/binary-operation-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/operator-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/column-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/select-all-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/reference-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/dynamic/dynamic-reference-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/order-by-item-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/raw-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/collate-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/order-by-item-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/util/log-once.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/order-by-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/json-reference-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/json-operator-chain-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/json-path-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/reference-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/primitive-value-list-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/value-list-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/value-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/value-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/parens-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/binary-operation-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/order-by-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/partition-by-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/over-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/from-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/group-by-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/having-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/insert-query-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/list-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/update-query-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/using-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/delete-query-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/where-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/returning-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/explain-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/when-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/merge-query-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/output-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/query-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/select-query-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/join-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/partition-by-item-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/partition-by-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/over-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/selection-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/select-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/values-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/default-insert-value-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/insert-values-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/column-update-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/update-set-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/on-duplicate-key-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/insert-result.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/no-result-error.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/on-conflict-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/on-conflict-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/top-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/top-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/or-action-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/insert-query-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/delete-result.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/limit-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/delete-query-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/update-result.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/update-query-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/common-table-expression-name-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/common-table-expression-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/cte-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/with-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/with-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/util/random-string.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/util/query-id.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/operation-node-transformer.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/plugin/with-schema/with-schema-transformer.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/plugin/with-schema/with-schema-plugin.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/matched-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/merge-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/util/deferred.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/util/provide-controlled-connection.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-executor/query-executor-base.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-executor/noop-query-executor.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/merge-result.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/merge-query-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-creator.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/parse-utils.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/join-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/offset-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/group-by-item-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/group-by-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/set-operation-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/set-operation-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/expression/expression-wrapper.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/fetch-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/fetch-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/select-query-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/aggregate-function-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/function-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/aggregate-function-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/function-module.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/unary-operation-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/unary-operation-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/case-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/case-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/json-path-leg-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-builder/json-path-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/tuple-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/data-type-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/data-type-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/cast-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/expression/expression-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/expression-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/dynamic/dynamic-table-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/table-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/add-column-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/column-definition-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/drop-column-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/rename-column-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/check-constraint-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/references-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/default-value-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/generated-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/default-value-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/on-modify-action-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/column-definition-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/modify-column-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/foreign-key-constraint-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/foreign-key-constraint-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/add-constraint-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/unique-constraint-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/drop-constraint-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/alter-column-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/alter-column-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/alter-table-executor.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/alter-table-add-foreign-key-constraint-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/alter-table-drop-constraint-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/primary-key-constraint-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/add-index-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/alter-table-add-index-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/unique-constraint-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/primary-key-constraint-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/check-constraint-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/rename-constraint-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/alter-table-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/plugin/immediate-value/immediate-value-transformer.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/create-index-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/create-schema-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/on-commit-action-parse.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/create-table-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/drop-index-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/drop-schema-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/drop-table-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/create-view-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/plugin/immediate-value/immediate-value-plugin.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/create-view-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/drop-view-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/drop-view-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/create-type-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/create-type-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/drop-type-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/drop-type-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/parser/identifier-parser.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/refresh-materialized-view-node.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/refresh-materialized-view-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/schema/schema.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/dynamic/dynamic.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/driver/default-connection-provider.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-executor/default-query-executor.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/util/performance-now.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/driver/runtime-driver.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/driver/single-connection-provider.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/driver/driver.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/util/log.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/util/compilable.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/kysely.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/raw-builder/raw-builder.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/raw-builder/sql.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/operation-node/operation-node-visitor.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/query-compiler/default-query-compiler.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/driver/dummy-driver.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/dialect/dialect-adapter-base.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/dialect/postgres/postgres-query-compiler.js", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/dialect/postgres/postgres-adapter.js", "../../../data/query.ts", "../../../data/postgres-core/builder.ts", "../../../data/postgres-core/dml.ts", "../../../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/helpers/postgres.js", "../../../data/postgres-core/introspection.ts", "../../../data/postgres-core/adapter.ts"],
  "sourcesContent": ["import type { PGlite } from \"@electric-sql/pglite\";\n\nimport type { Adapter } from \"../adapter\";\nimport type { Executor } from \"../executor\";\nimport { createPostgresAdapter } from \"../postgres-core\";\nimport { Query } from \"../query\";\n\nexport interface PGLiteExecutorOptions {\n  /**\n   * Delay in milliseconds to add before executing the query.\n   * This can be a static number or a function that takes the query as an argument and returns a number.\n   *\n   * This is useful for simulating network latency or for debugging purposes.\n   */\n  addDelay?: number | ((query: Query) => number);\n\n  /**\n   * Whether to log the query and its parameters.\n   *\n   * Defaults to `false`.\n   */\n  logging?: boolean | ((query: Query) => boolean);\n}\n\nexport function createPGLiteExecutor(pglite: PGlite, options?: PGLiteExecutorOptions): Executor {\n  const { addDelay = 0, logging = false } = options ?? {};\n\n  return {\n    execute: async (query, options) => {\n      const { abortSignal } = options || {};\n\n      let abort: (reason?: unknown) => void;\n      const abortionPromise = new Promise<never>((_, reject) => (abort = reject));\n\n      function abortListener(): void {\n        const error = new Error(\"This operation was aborted\");\n        error.name = \"AbortError\";\n        abort(error);\n      }\n\n      abortSignal?.addEventListener(\"abort\", abortListener);\n\n      const addedDelay = typeof addDelay === \"function\" ? addDelay(query) : addDelay;\n\n      const queryPGLite = () => pglite.query(query.sql, query.parameters as never[], { rowMode: \"object\" });\n\n      const queryPGLitePossiblyDelayed =\n        addedDelay > 0\n          ? () => new Promise((resolve) => setTimeout(resolve, addedDelay)).then(() => queryPGLite())\n          : queryPGLite;\n\n      try {\n        const shouldLog = typeof logging === \"function\" ? logging(query) : logging;\n\n        let loggableQuery: string;\n        if (shouldLog) {\n          console.log(\"PGLiteExecutor: Executing query:\", (loggableQuery = JSON.stringify(query, null, 2)));\n        }\n        const now = Date.now();\n\n        const result = await Promise.race([queryPGLitePossiblyDelayed(), abortionPromise]);\n\n        const duration = Date.now() - now;\n\n        if (shouldLog) {\n          console.log(\"PGLiteExecutor: Query executed in\", duration, \"ms:\", loggableQuery!);\n        }\n\n        return [null, result.rows as never];\n      } catch (error: unknown) {\n        return [error as Error];\n      } finally {\n        abortSignal?.removeEventListener(\"abort\", abortListener);\n      }\n    },\n  };\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface PGLiteAdapterOptions extends PGLiteExecutorOptions {}\n\nexport function createPGLiteAdapter(pglite: PGlite, options?: PGLiteAdapterOptions): Adapter {\n  return createPostgresAdapter({\n    executor: createPGLiteExecutor(pglite, options),\n  });\n}\n", "import { Query } from \"./query\";\nimport type { BigIntString, Either, NumericString } from \"./type-utils\";\n\nexport interface Adapter {\n  /**\n   * The schema studio will choose by default.\n   *\n   * e.g. `public` for PostgreSQL\n   */\n  readonly defaultSchema?: string;\n\n  /**\n   * Introspects the database and returns structured information about the schemas, tables, etc.\n   *\n   * @param options - Options for the introspection request.\n   */\n  introspect(options: AdapterIntrospectOptions): Promise<Either<AdapterError, AdapterIntrospectResult>>;\n\n  /**\n   * Executes a structured query against the database.\n   */\n  query(details: AdapterQueryDetails, options: AdapterQueryOptions): Promise<Either<AdapterError, AdapterQueryResult>>;\n\n  /**\n   * Inserts a single row into the database.\n   */\n  insert(\n    details: AdapterInsertDetails,\n    options: AdapterInsertOptions,\n  ): Promise<Either<AdapterError, AdapterInsertResult>>;\n\n  /**\n   * Updates a given row in the database with given changes.\n   */\n  update(\n    details: AdapterUpdateDetails,\n    options: AdapterUpdateOptions,\n  ): Promise<Either<AdapterError, AdapterUpdateResult>>;\n\n  /**\n   * Deletes given rows from the database.\n   */\n  delete(\n    details: AdapterDeleteDetails,\n    options: AdapterDeleteOptions,\n  ): Promise<Either<AdapterError, AdapterDeleteResult>>;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterBaseOptions {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterIntrospectOptions extends AdapterBaseOptions {}\n\nexport interface AdapterQueryOptions extends AdapterBaseOptions {\n  abortSignal: AbortSignal;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterInsertOptions extends AdapterBaseOptions {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterUpdateOptions extends AdapterBaseOptions {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterDeleteOptions extends AdapterBaseOptions {}\n\ntype SchemaName = string;\n\nexport interface AdapterIntrospectResult {\n  schemas: Record<SchemaName, Schema>;\n  timezone: string;\n  filterOperators: FilterOperator[];\n  query: Query;\n}\n\ntype TableName = string;\n\nexport interface Schema {\n  name: string;\n  tables: Record<TableName, Table>;\n}\n\ntype ColumnName = string;\n\nexport interface Table {\n  columns: Record<ColumnName, Column>;\n  name: TableName;\n  schema: SchemaName;\n}\n\nexport interface Column {\n  datatype: DataType;\n  isComputed: boolean;\n  isInPrimaryKey: boolean;\n  name: ColumnName;\n  nullable: boolean;\n  schema: SchemaName;\n  table: TableName;\n  fkSchema: SchemaName | null;\n  fkColumn: ColumnName | null;\n  fkTable: TableName | null;\n}\n\nexport interface DataType {\n  /**\n   * A simplification/normalization for UI usage.\n   *\n   * e.g. varchar and char are strings.\n   */\n  group: DataTypeGroup;\n\n  /**\n   * Is this a native array type?\n   */\n  isArray: boolean;\n\n  /**\n   * Is a native database datatype or a user-defined datatype?\n   *\n   * e.g. PostgreSQL enums are user-defined datatypes, but `int4` is a native datatype.\n   */\n  isNative: boolean;\n\n  /**\n   * Will be displayed as-is.\n   */\n  name: string;\n\n  /**\n   * Enum values for enum types.\n   */\n  options: string[];\n\n  /**\n   * The schema the datatype belongs to.\n   */\n  schema: string;\n}\n\nexport type DataTypeGroup = \"string\" | \"datetime\" | \"boolean\" | \"enum\" | \"time\" | \"raw\" | \"numeric\" | \"json\";\n\nexport interface AdapterQueryDetails {\n  /**\n   * Zero-based index of the page to fetch.\n   */\n  pageIndex: number;\n\n  /**\n   * Maximum number of rows to fetch from the database.\n   */\n  pageSize: number;\n\n  /**\n   * Sort order for the query.\n   */\n  sortOrder: SortOrderItem[];\n\n  /**\n   * The table to select from.\n   */\n  table: Table;\n\n  /**\n   * The filter to be applied.\n   */\n  filter?: FilterGroup;\n}\n\nexport type FilterOperator =\n  | \"=\"\n  | \"!=\"\n  | \">\"\n  | \">=\"\n  | \"<\"\n  | \"<=\"\n  | \"is\"\n  | \"is not\"\n  | \"like\"\n  | \"not like\"\n  | \"ilike\"\n  | \"not ilike\";\n\nexport interface ColumnFilter {\n  kind: \"ColumnFilter\";\n  column: string;\n  operator: FilterOperator;\n  value: unknown;\n  after: \"and\" | \"or\";\n  id: string;\n}\n\nexport interface FilterGroup {\n  kind: \"FilterGroup\";\n  filters: (ColumnFilter | FilterGroup)[];\n  after: \"and\" | \"or\";\n  id: string;\n}\n\nexport interface SortOrderItem {\n  /**\n   * The column to sort by.\n   */\n  column: ColumnName;\n\n  /**\n   * The direction to sort the column by.\n   */\n  direction: SortDirection;\n}\n\nexport type SortDirection = \"asc\" | \"desc\";\n\nexport class AdapterError extends Error {\n  query?: Query;\n}\n\nexport interface AdapterQueryResult {\n  /**\n   * The total number of rows the query would return if not limited.\n   *\n   * If the database does not support counting rows, this should be set to `Infinity`.\n   */\n  filteredRowCount: number | bigint | NumericString | BigIntString;\n\n  /**\n   * The rows returned by the query.\n   */\n  rows: Record<ColumnName, unknown>[];\n\n  /**\n   * The executed query string.\n   */\n  query: Query;\n}\n\nexport interface AdapterInsertDetails {\n  /**\n   * The table to insert into.\n   */\n  table: Table;\n\n  /**\n   * The values to insert into the table.\n   * - The keys should match the column names in the table.\n   * - The values should be the values to insert into the table.\n   */\n  rows: Record<string, unknown>[];\n}\n\nexport interface AdapterInsertResult {\n  /**\n   * The freshly inserted row data.\n   */\n  rows: Record<string, unknown>[];\n\n  /**\n   * The executed query string.\n   */\n  query: Query;\n}\n\nexport interface AdapterUpdateDetails {\n  /**\n   * Changes to apply to the row.\n   */\n  changes: Record<ColumnName, unknown>;\n\n  /**\n   * The row to update.\n   */\n  row: Record<ColumnName, unknown>;\n\n  /**\n   * The table to update in.\n   */\n  table: Table;\n}\n\nexport interface AdapterUpdateResult {\n  /**\n   * The updated row data.\n   */\n  row: Record<ColumnName, unknown> & {\n    /**\n     * When the changes were applied in database time.\n     */\n    __ps_updated_at__: string | number | Date;\n  };\n\n  /**\n   * The executed query string.\n   */\n  query: Query;\n}\n\nexport interface AdapterDeleteDetails {\n  /**\n   * The rows to delete.\n   */\n  rows: Record<ColumnName, unknown>[];\n\n  /**\n   * The table to delete from.\n   */\n  table: Table;\n}\n\nexport interface AdapterDeleteResult {\n  rows: Record<ColumnName, unknown>[];\n\n  /**\n   * The executed query string.\n   */\n  query: Query;\n}\n\nexport function createAdapterError(args: { error: Error; query?: Query }) {\n  const { error, query } = args;\n\n  const adapterError = error as AdapterError;\n\n  adapterError.query = query;\n\n  return [adapterError] as [AdapterError];\n}\n", "import { DataType } from \"../adapter\";\n\nexport const POSTGRESQL_DATA_TYPES_TO_METADATA: Record<string, Pick<DataType, \"group\">> = {\n  bool: {\n    group: \"boolean\",\n  },\n  boolean: {\n    group: \"boolean\",\n  },\n  bytea: {\n    group: \"string\",\n  },\n  char: {\n    group: \"string\",\n  },\n  citext: {\n    group: \"string\",\n  },\n  /**\n   * @example '2025-04-14'\n   */\n  date: {\n    group: \"datetime\",\n  },\n  /**\n   * @example '1 day 2 hours'\n   */\n  interval: {\n    group: \"string\",\n  },\n  name: {\n    group: \"string\",\n  },\n  varchar: {\n    group: \"string\",\n  },\n  text: {\n    group: \"string\",\n  },\n  /**\n   * short form of `time without time zone`.\n   *\n   * @example '14:30:00'\n   */\n  time: {\n    group: \"time\",\n  },\n  /**\n   * short form of `timestamp without time zone`.\n   *\n   * @example '2025-04-14 14:30:00'\n   */\n  timestamp: {\n    group: \"datetime\",\n  },\n  /**\n   * short form of `timestamp with time zone`.\n   *\n   * @example '2025-04-14 14:30:00+00'\n   */\n  timestamptz: {\n    group: \"datetime\",\n  },\n  /**\n   * long form of `timestamp`.\n   *\n   * @example '2025-04-14 14:30:00'\n   */\n  \"timestamp without time zone\": {\n    group: \"datetime\",\n  },\n  /**\n   * long form of `timestamptz`.\n   *\n   * @example '2025-04-14 14:30:00+00'\n   */\n  \"timestamp with time zone\": {\n    group: \"datetime\",\n  },\n  /**\n   * short form of `time with time zone`.\n   *\n   * @example '14:30:00+00:00'\n   */\n  timetz: {\n    group: \"time\",\n  },\n  /**\n   * long form of `time`.\n   *\n   * @example '14:30:00'\n   */\n  \"time without time zone\": {\n    group: \"time\",\n  },\n  /**\n   * long form of `timetz`.\n   *\n   * @example '2025-04-14 14:30:00+00'\n   */\n  \"time with time zone\": {\n    group: \"datetime\",\n  },\n  uuid: {\n    group: \"string\",\n  },\n  // Numeric types\n  int2: {\n    group: \"numeric\",\n  },\n  int4: {\n    group: \"numeric\",\n  },\n  int8: {\n    group: \"numeric\",\n  },\n  smallint: {\n    group: \"numeric\",\n  },\n  integer: {\n    group: \"numeric\",\n  },\n  bigint: {\n    group: \"numeric\",\n  },\n  decimal: {\n    group: \"numeric\",\n  },\n  numeric: {\n    group: \"numeric\",\n  },\n  real: {\n    group: \"numeric\",\n  },\n  float4: {\n    group: \"numeric\",\n  },\n  float8: {\n    group: \"numeric\",\n  },\n  \"double precision\": {\n    group: \"numeric\",\n  },\n  json: {\n    group: \"json\",\n  },\n  jsonb: {\n    group: \"json\",\n  },\n};\n", "/// <reference types=\"./object-utils.d.ts\" />\nexport function isEmpty(obj) {\n    if (Array.isArray(obj) || isString(obj) || isBuffer(obj)) {\n        return obj.length === 0;\n    }\n    else if (obj) {\n        return Object.keys(obj).length === 0;\n    }\n    return false;\n}\nexport function isUndefined(obj) {\n    return typeof obj === 'undefined' || obj === undefined;\n}\nexport function isString(obj) {\n    return typeof obj === 'string';\n}\nexport function isNumber(obj) {\n    return typeof obj === 'number';\n}\nexport function isBoolean(obj) {\n    return typeof obj === 'boolean';\n}\nexport function isNull(obj) {\n    return obj === null;\n}\nexport function isDate(obj) {\n    return obj instanceof Date;\n}\nexport function isBigInt(obj) {\n    return typeof obj === 'bigint';\n}\n// Don't change the returnd type to `obj is Buffer` to not create a\n// hard dependency to node.\nexport function isBuffer(obj) {\n    return typeof Buffer !== 'undefined' && Buffer.isBuffer(obj);\n}\nexport function isFunction(obj) {\n    return typeof obj === 'function';\n}\nexport function isObject(obj) {\n    return typeof obj === 'object' && obj !== null;\n}\nexport function isArrayBufferOrView(obj) {\n    return obj instanceof ArrayBuffer || ArrayBuffer.isView(obj);\n}\nexport function isPlainObject(obj) {\n    if (!isObject(obj) || getTag(obj) !== '[object Object]') {\n        return false;\n    }\n    if (Object.getPrototypeOf(obj) === null) {\n        return true;\n    }\n    let proto = obj;\n    while (Object.getPrototypeOf(proto) !== null) {\n        proto = Object.getPrototypeOf(proto);\n    }\n    return Object.getPrototypeOf(obj) === proto;\n}\nexport function getLast(arr) {\n    return arr[arr.length - 1];\n}\nexport function freeze(obj) {\n    return Object.freeze(obj);\n}\nexport function asArray(arg) {\n    if (isReadonlyArray(arg)) {\n        return arg;\n    }\n    else {\n        return [arg];\n    }\n}\nexport function asReadonlyArray(arg) {\n    if (isReadonlyArray(arg)) {\n        return arg;\n    }\n    else {\n        return freeze([arg]);\n    }\n}\nexport function isReadonlyArray(arg) {\n    return Array.isArray(arg);\n}\nexport function noop(obj) {\n    return obj;\n}\nexport function compare(obj1, obj2) {\n    if (isReadonlyArray(obj1) && isReadonlyArray(obj2)) {\n        return compareArrays(obj1, obj2);\n    }\n    else if (isObject(obj1) && isObject(obj2)) {\n        return compareObjects(obj1, obj2);\n    }\n    return obj1 === obj2;\n}\nfunction compareArrays(arr1, arr2) {\n    if (arr1.length !== arr2.length) {\n        return false;\n    }\n    for (let i = 0; i < arr1.length; ++i) {\n        if (!compare(arr1[i], arr2[i])) {\n            return false;\n        }\n    }\n    return true;\n}\nfunction compareObjects(obj1, obj2) {\n    if (isBuffer(obj1) && isBuffer(obj2)) {\n        return compareBuffers(obj1, obj2);\n    }\n    else if (isDate(obj1) && isDate(obj2)) {\n        return compareDates(obj1, obj2);\n    }\n    return compareGenericObjects(obj1, obj2);\n}\nfunction compareBuffers(buf1, buf2) {\n    return Buffer.compare(buf1, buf2) === 0;\n}\nfunction compareDates(date1, date2) {\n    return date1.getTime() === date2.getTime();\n}\nfunction compareGenericObjects(obj1, obj2) {\n    const keys1 = Object.keys(obj1);\n    const keys2 = Object.keys(obj2);\n    if (keys1.length !== keys2.length) {\n        return false;\n    }\n    for (const key of keys1) {\n        if (!compare(obj1[key], obj2[key])) {\n            return false;\n        }\n    }\n    return true;\n}\nconst toString = Object.prototype.toString;\nfunction getTag(value) {\n    if (value == null) {\n        return value === undefined ? '[object Undefined]' : '[object Null]';\n    }\n    return toString.call(value);\n}\n", "/// <reference types=\"./alter-table-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const AlterTableNode = freeze({\n    is(node) {\n        return node.kind === 'AlterTableNode';\n    },\n    create(table) {\n        return freeze({\n            kind: 'AlterTableNode',\n            table,\n        });\n    },\n    cloneWithTableProps(node, props) {\n        return freeze({\n            ...node,\n            ...props,\n        });\n    },\n    cloneWithColumnAlteration(node, columnAlteration) {\n        return freeze({\n            ...node,\n            columnAlterations: node.columnAlterations\n                ? [...node.columnAlterations, columnAlteration]\n                : [columnAlteration],\n        });\n    },\n});\n", "/// <reference types=\"./identifier-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const IdentifierNode = freeze({\n    is(node) {\n        return node.kind === 'IdentifierNode';\n    },\n    create(name) {\n        return freeze({\n            kind: 'IdentifierNode',\n            name,\n        });\n    },\n});\n", "/// <reference types=\"./create-index-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const CreateIndexNode = freeze({\n    is(node) {\n        return node.kind === 'CreateIndexNode';\n    },\n    create(name) {\n        return freeze({\n            kind: 'CreateIndexNode',\n            name: IdentifierNode.create(name),\n        });\n    },\n    cloneWith(node, props) {\n        return freeze({\n            ...node,\n            ...props,\n        });\n    },\n    cloneWithColumns(node, columns) {\n        return freeze({\n            ...node,\n            columns: [...(node.columns || []), ...columns],\n        });\n    },\n});\n", "/// <reference types=\"./create-schema-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const CreateSchemaNode = freeze({\n    is(node) {\n        return node.kind === 'CreateSchemaNode';\n    },\n    create(schema, params) {\n        return freeze({\n            kind: 'CreateSchemaNode',\n            schema: IdentifierNode.create(schema),\n            ...params,\n        });\n    },\n    cloneWith(createSchema, params) {\n        return freeze({\n            ...createSchema,\n            ...params,\n        });\n    },\n});\n", "/// <reference types=\"./create-table-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nexport const ON_COMMIT_ACTIONS = ['preserve rows', 'delete rows', 'drop'];\n/**\n * @internal\n */\nexport const CreateTableNode = freeze({\n    is(node) {\n        return node.kind === 'CreateTableNode';\n    },\n    create(table) {\n        return freeze({\n            kind: 'CreateTableNode',\n            table,\n            columns: freeze([]),\n        });\n    },\n    cloneWithColumn(createTable, column) {\n        return freeze({\n            ...createTable,\n            columns: freeze([...createTable.columns, column]),\n        });\n    },\n    cloneWithConstraint(createTable, constraint) {\n        return freeze({\n            ...createTable,\n            constraints: createTable.constraints\n                ? freeze([...createTable.constraints, constraint])\n                : freeze([constraint]),\n        });\n    },\n    cloneWithFrontModifier(createTable, modifier) {\n        return freeze({\n            ...createTable,\n            frontModifiers: createTable.frontModifiers\n                ? freeze([...createTable.frontModifiers, modifier])\n                : freeze([modifier]),\n        });\n    },\n    cloneWithEndModifier(createTable, modifier) {\n        return freeze({\n            ...createTable,\n            endModifiers: createTable.endModifiers\n                ? freeze([...createTable.endModifiers, modifier])\n                : freeze([modifier]),\n        });\n    },\n    cloneWith(createTable, params) {\n        return freeze({\n            ...createTable,\n            ...params,\n        });\n    },\n});\n", "/// <reference types=\"./schemable-identifier-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const SchemableIdentifierNode = freeze({\n    is(node) {\n        return node.kind === 'SchemableIdentifierNode';\n    },\n    create(identifier) {\n        return freeze({\n            kind: 'SchemableIdentifierNode',\n            identifier: IdentifierNode.create(identifier),\n        });\n    },\n    createWithSchema(schema, identifier) {\n        return freeze({\n            kind: 'SchemableIdentifierNode',\n            schema: IdentifierNode.create(schema),\n            identifier: IdentifierNode.create(identifier),\n        });\n    },\n});\n", "/// <reference types=\"./drop-index-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { SchemableIdentifierNode } from './schemable-identifier-node.js';\n/**\n * @internal\n */\nexport const DropIndexNode = freeze({\n    is(node) {\n        return node.kind === 'DropIndexNode';\n    },\n    create(name, params) {\n        return freeze({\n            kind: 'DropIndexNode',\n            name: SchemableIdentifierNode.create(name),\n            ...params,\n        });\n    },\n    cloneWith(dropIndex, props) {\n        return freeze({\n            ...dropIndex,\n            ...props,\n        });\n    },\n});\n", "/// <reference types=\"./drop-schema-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const DropSchemaNode = freeze({\n    is(node) {\n        return node.kind === 'DropSchemaNode';\n    },\n    create(schema, params) {\n        return freeze({\n            kind: 'DropSchemaNode',\n            schema: IdentifierNode.create(schema),\n            ...params,\n        });\n    },\n    cloneWith(dropSchema, params) {\n        return freeze({\n            ...dropSchema,\n            ...params,\n        });\n    },\n});\n", "/// <reference types=\"./drop-table-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const DropTableNode = freeze({\n    is(node) {\n        return node.kind === 'DropTableNode';\n    },\n    create(table, params) {\n        return freeze({\n            kind: 'DropTableNode',\n            table,\n            ...params,\n        });\n    },\n    cloneWith(dropIndex, params) {\n        return freeze({\n            ...dropIndex,\n            ...params,\n        });\n    },\n});\n", "/// <reference types=\"./alias-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const AliasNode = freeze({\n    is(node) {\n        return node.kind === 'AliasNode';\n    },\n    create(node, alias) {\n        return freeze({\n            kind: 'AliasNode',\n            node,\n            alias,\n        });\n    },\n});\n", "/// <reference types=\"./table-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { SchemableIdentifierNode } from './schemable-identifier-node.js';\n/**\n * @internal\n */\nexport const TableNode = freeze({\n    is(node) {\n        return node.kind === 'TableNode';\n    },\n    create(table) {\n        return freeze({\n            kind: 'TableNode',\n            table: SchemableIdentifierNode.create(table),\n        });\n    },\n    createWithSchema(schema, table) {\n        return freeze({\n            kind: 'TableNode',\n            table: SchemableIdentifierNode.createWithSchema(schema, table),\n        });\n    },\n});\n", "/// <reference types=\"./operation-node-source.d.ts\" />\nimport { isFunction, isObject } from '../util/object-utils.js';\nexport function isOperationNodeSource(obj) {\n    return isObject(obj) && isFunction(obj.toOperationNode);\n}\n", "/// <reference types=\"./expression.d.ts\" />\nimport { isOperationNodeSource, } from '../operation-node/operation-node-source.js';\nimport { isObject, isString } from '../util/object-utils.js';\nexport function isExpression(obj) {\n    return isObject(obj) && 'expressionType' in obj && isOperationNodeSource(obj);\n}\nexport function isAliasedExpression(obj) {\n    return (isObject(obj) &&\n        'expression' in obj &&\n        isString(obj.alias) &&\n        isOperationNodeSource(obj));\n}\n", "/// <reference types=\"./select-modifier-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const SelectModifierNode = freeze({\n    is(node) {\n        return node.kind === 'SelectModifierNode';\n    },\n    create(modifier, of) {\n        return freeze({\n            kind: 'SelectModifierNode',\n            modifier,\n            of,\n        });\n    },\n    createWithExpression(modifier) {\n        return freeze({\n            kind: 'SelectModifierNode',\n            rawModifier: modifier,\n        });\n    },\n});\n", "/// <reference types=\"./and-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const AndNode = freeze({\n    is(node) {\n        return node.kind === 'AndNode';\n    },\n    create(left, right) {\n        return freeze({\n            kind: 'AndNode',\n            left,\n            right,\n        });\n    },\n});\n", "/// <reference types=\"./or-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OrNode = freeze({\n    is(node) {\n        return node.kind === 'OrNode';\n    },\n    create(left, right) {\n        return freeze({\n            kind: 'OrNode',\n            left,\n            right,\n        });\n    },\n});\n", "/// <reference types=\"./on-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { AndNode } from './and-node.js';\nimport { OrNode } from './or-node.js';\n/**\n * @internal\n */\nexport const OnNode = freeze({\n    is(node) {\n        return node.kind === 'OnNode';\n    },\n    create(filter) {\n        return freeze({\n            kind: 'OnNode',\n            on: filter,\n        });\n    },\n    cloneWithOperation(onNode, operator, operation) {\n        return freeze({\n            ...onNode,\n            on: operator === 'And'\n                ? AndNode.create(onNode.on, operation)\n                : OrNode.create(onNode.on, operation),\n        });\n    },\n});\n", "/// <reference types=\"./join-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { OnNode } from './on-node.js';\n/**\n * @internal\n */\nexport const JoinNode = freeze({\n    is(node) {\n        return node.kind === 'JoinNode';\n    },\n    create(joinType, table) {\n        return freeze({\n            kind: 'JoinNode',\n            joinType,\n            table,\n            on: undefined,\n        });\n    },\n    createWithOn(joinType, table, on) {\n        return freeze({\n            kind: 'JoinNode',\n            joinType,\n            table,\n            on: OnNode.create(on),\n        });\n    },\n    cloneWithOn(joinNode, operation) {\n        return freeze({\n            ...joinNode,\n            on: joinNode.on\n                ? OnNode.cloneWithOperation(joinNode.on, 'And', operation)\n                : OnNode.create(operation),\n        });\n    },\n});\n", "/// <reference types=\"./binary-operation-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const BinaryOperationNode = freeze({\n    is(node) {\n        return node.kind === 'BinaryOperationNode';\n    },\n    create(leftOperand, operator, rightOperand) {\n        return freeze({\n            kind: 'BinaryOperationNode',\n            leftOperand,\n            operator,\n            rightOperand,\n        });\n    },\n});\n", "/// <reference types=\"./operator-node.d.ts\" />\nimport { freeze, isString } from '../util/object-utils.js';\nexport const COMPARISON_OPERATORS = [\n    '=',\n    '==',\n    '!=',\n    '<>',\n    '>',\n    '>=',\n    '<',\n    '<=',\n    'in',\n    'not in',\n    'is',\n    'is not',\n    'like',\n    'not like',\n    'match',\n    'ilike',\n    'not ilike',\n    '@>',\n    '<@',\n    '^@',\n    '&&',\n    '?',\n    '?&',\n    '?|',\n    '!<',\n    '!>',\n    '<=>',\n    '!~',\n    '~',\n    '~*',\n    '!~*',\n    '@@',\n    '@@@',\n    '!!',\n    '<->',\n    'regexp',\n    'is distinct from',\n    'is not distinct from',\n];\nexport const ARITHMETIC_OPERATORS = [\n    '+',\n    '-',\n    '*',\n    '/',\n    '%',\n    '^',\n    '&',\n    '|',\n    '#',\n    '<<',\n    '>>',\n];\nexport const JSON_OPERATORS = ['->', '->>'];\nexport const BINARY_OPERATORS = [\n    ...COMPARISON_OPERATORS,\n    ...ARITHMETIC_OPERATORS,\n    '&&',\n    '||',\n];\nexport const UNARY_FILTER_OPERATORS = ['exists', 'not exists'];\nexport const UNARY_OPERATORS = ['not', '-', ...UNARY_FILTER_OPERATORS];\nexport const OPERATORS = [\n    ...BINARY_OPERATORS,\n    ...JSON_OPERATORS,\n    ...UNARY_OPERATORS,\n    'between',\n    'between symmetric',\n];\n/**\n * @internal\n */\nexport const OperatorNode = freeze({\n    is(node) {\n        return node.kind === 'OperatorNode';\n    },\n    create(operator) {\n        return freeze({\n            kind: 'OperatorNode',\n            operator,\n        });\n    },\n});\nexport function isOperator(op) {\n    return isString(op) && OPERATORS.includes(op);\n}\nexport function isBinaryOperator(op) {\n    return isString(op) && BINARY_OPERATORS.includes(op);\n}\nexport function isComparisonOperator(op) {\n    return isString(op) && COMPARISON_OPERATORS.includes(op);\n}\nexport function isArithmeticOperator(op) {\n    return isString(op) && ARITHMETIC_OPERATORS.includes(op);\n}\nexport function isJSONOperator(op) {\n    return isString(op) && JSON_OPERATORS.includes(op);\n}\n", "/// <reference types=\"./column-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const ColumnNode = freeze({\n    is(node) {\n        return node.kind === 'ColumnNode';\n    },\n    create(column) {\n        return freeze({\n            kind: 'ColumnNode',\n            column: IdentifierNode.create(column),\n        });\n    },\n});\n", "/// <reference types=\"./select-all-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const SelectAllNode = freeze({\n    is(node) {\n        return node.kind === 'SelectAllNode';\n    },\n    create() {\n        return freeze({\n            kind: 'SelectAllNode',\n        });\n    },\n});\n", "/// <reference types=\"./reference-node.d.ts\" />\nimport { SelectAllNode } from './select-all-node.js';\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ReferenceNode = freeze({\n    is(node) {\n        return node.kind === 'ReferenceNode';\n    },\n    create(column, table) {\n        return freeze({\n            kind: 'ReferenceNode',\n            table,\n            column,\n        });\n    },\n    createSelectAll(table) {\n        return freeze({\n            kind: 'ReferenceNode',\n            table,\n            column: SelectAllNode.create(),\n        });\n    },\n});\n", "/// <reference types=\"./dynamic-reference-builder.d.ts\" />\nimport { isOperationNodeSource, } from '../operation-node/operation-node-source.js';\nimport { parseSimpleReferenceExpression } from '../parser/reference-parser.js';\nimport { isObject, isString } from '../util/object-utils.js';\nexport class DynamicReferenceBuilder {\n    #dynamicReference;\n    get dynamicReference() {\n        return this.#dynamicReference;\n    }\n    /**\n     * @private\n     *\n     * This needs to be here just so that the typings work. Without this\n     * the generated .d.ts file contains no reference to the type param R\n     * which causes this type to be equal to DynamicReferenceBuilder with\n     * any R.\n     */\n    get refType() {\n        return undefined;\n    }\n    constructor(reference) {\n        this.#dynamicReference = reference;\n    }\n    toOperationNode() {\n        return parseSimpleReferenceExpression(this.#dynamicReference);\n    }\n}\nexport function isDynamicReferenceBuilder(obj) {\n    return (isObject(obj) &&\n        isOperationNodeSource(obj) &&\n        isString(obj.dynamicReference));\n}\n", "/// <reference types=\"./order-by-item-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OrderByItemNode = freeze({\n    is(node) {\n        return node.kind === 'OrderByItemNode';\n    },\n    create(orderBy, direction) {\n        return freeze({\n            kind: 'OrderByItemNode',\n            orderBy,\n            direction,\n        });\n    },\n    cloneWith(node, props) {\n        return freeze({\n            ...node,\n            ...props,\n        });\n    },\n});\n", "/// <reference types=\"./raw-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const RawNode = freeze({\n    is(node) {\n        return node.kind === 'RawNode';\n    },\n    create(sqlFragments, parameters) {\n        return freeze({\n            kind: 'RawNode',\n            sqlFragments: freeze(sqlFragments),\n            parameters: freeze(parameters),\n        });\n    },\n    createWithSql(sql) {\n        return RawNode.create([sql], []);\n    },\n    createWithChild(child) {\n        return RawNode.create(['', ''], [child]);\n    },\n    createWithChildren(children) {\n        return RawNode.create(new Array(children.length + 1).fill(''), children);\n    },\n});\n", "/// <reference types=\"./collate-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const CollateNode = {\n    is(node) {\n        return node.kind === 'CollateNode';\n    },\n    create(collation) {\n        return freeze({\n            kind: 'CollateNode',\n            collation: IdentifierNode.create(collation),\n        });\n    },\n};\n", "/// <reference types=\"./order-by-item-builder.d.ts\" />\nimport { CollateNode } from '../operation-node/collate-node.js';\nimport { OrderByItemNode } from '../operation-node/order-by-item-node.js';\nimport { RawNode } from '../operation-node/raw-node.js';\nimport { freeze } from '../util/object-utils.js';\nexport class OrderByItemBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * Adds `desc` to the `order by` item.\n     *\n     * See {@link asc} for the opposite.\n     */\n    desc() {\n        return new OrderByItemBuilder({\n            node: OrderByItemNode.cloneWith(this.#props.node, {\n                direction: RawNode.createWithSql('desc'),\n            }),\n        });\n    }\n    /**\n     * Adds `asc` to the `order by` item.\n     *\n     * See {@link desc} for the opposite.\n     */\n    asc() {\n        return new OrderByItemBuilder({\n            node: OrderByItemNode.cloneWith(this.#props.node, {\n                direction: RawNode.createWithSql('asc'),\n            }),\n        });\n    }\n    /**\n     * Adds `nulls last` to the `order by` item.\n     *\n     * This is only supported by some dialects like PostgreSQL and SQLite.\n     *\n     * See {@link nullsFirst} for the opposite.\n     */\n    nullsLast() {\n        return new OrderByItemBuilder({\n            node: OrderByItemNode.cloneWith(this.#props.node, { nulls: 'last' }),\n        });\n    }\n    /**\n     * Adds `nulls first` to the `order by` item.\n     *\n     * This is only supported by some dialects like PostgreSQL and SQLite.\n     *\n     * See {@link nullsLast} for the opposite.\n     */\n    nullsFirst() {\n        return new OrderByItemBuilder({\n            node: OrderByItemNode.cloneWith(this.#props.node, { nulls: 'first' }),\n        });\n    }\n    /**\n     * Adds `collate <collationName>` to the `order by` item.\n     */\n    collate(collation) {\n        return new OrderByItemBuilder({\n            node: OrderByItemNode.cloneWith(this.#props.node, {\n                collation: CollateNode.create(collation),\n            }),\n        });\n    }\n    toOperationNode() {\n        return this.#props.node;\n    }\n}\n", "/// <reference types=\"./log-once.d.ts\" />\nconst LOGGED_MESSAGES = new Set();\n/**\n * Use for system-level logging, such as deprecation messages.\n * Logs a message and ensures it won't be logged again.\n */\nexport function logOnce(message) {\n    if (LOGGED_MESSAGES.has(message)) {\n        return;\n    }\n    LOGGED_MESSAGES.add(message);\n    console.log(message);\n}\n", "/// <reference types=\"./order-by-parser.d.ts\" />\nimport { isDynamicReferenceBuilder, } from '../dynamic/dynamic-reference-builder.js';\nimport { isExpression } from '../expression/expression.js';\nimport { OrderByItemNode } from '../operation-node/order-by-item-node.js';\nimport { RawNode } from '../operation-node/raw-node.js';\nimport { OrderByItemBuilder } from '../query-builder/order-by-item-builder.js';\nimport { logOnce } from '../util/log-once.js';\nimport { isExpressionOrFactory, parseExpression, } from './expression-parser.js';\nimport { parseStringReference, } from './reference-parser.js';\nexport function isOrderByDirection(thing) {\n    return thing === 'asc' || thing === 'desc';\n}\nexport function parseOrderBy(args) {\n    if (args.length === 2) {\n        return [parseOrderByItem(args[0], args[1])];\n    }\n    if (args.length === 1) {\n        const [orderBy] = args;\n        if (Array.isArray(orderBy)) {\n            logOnce('orderBy(array) is deprecated, use multiple orderBy calls instead.');\n            return orderBy.map((item) => parseOrderByItem(item));\n        }\n        return [parseOrderByItem(orderBy)];\n    }\n    throw new Error(`Invalid number of arguments at order by! expected 1-2, received ${args.length}`);\n}\nexport function parseOrderByItem(expr, modifiers) {\n    const parsedRef = parseOrderByExpression(expr);\n    if (OrderByItemNode.is(parsedRef)) {\n        if (modifiers) {\n            throw new Error('Cannot specify direction twice!');\n        }\n        return parsedRef;\n    }\n    return parseOrderByWithModifiers(parsedRef, modifiers);\n}\nfunction parseOrderByExpression(expr) {\n    if (isExpressionOrFactory(expr)) {\n        return parseExpression(expr);\n    }\n    if (isDynamicReferenceBuilder(expr)) {\n        return expr.toOperationNode();\n    }\n    const [ref, direction] = expr.split(' ');\n    if (direction) {\n        logOnce(\"`orderBy('column asc')` is deprecated. Use `orderBy('column', 'asc')` instead.\");\n        return parseOrderByWithModifiers(parseStringReference(ref), direction);\n    }\n    return parseStringReference(expr);\n}\nfunction parseOrderByWithModifiers(expr, modifiers) {\n    if (typeof modifiers === 'string') {\n        if (!isOrderByDirection(modifiers)) {\n            throw new Error(`Invalid order by direction: ${modifiers}`);\n        }\n        return OrderByItemNode.create(expr, RawNode.createWithSql(modifiers));\n    }\n    if (isExpression(modifiers)) {\n        logOnce(\"`orderBy(..., expr)` is deprecated. Use `orderBy(..., 'asc')` or `orderBy(..., (ob) => ...)` instead.\");\n        return OrderByItemNode.create(expr, modifiers.toOperationNode());\n    }\n    const node = OrderByItemNode.create(expr);\n    if (!modifiers) {\n        return node;\n    }\n    return modifiers(new OrderByItemBuilder({ node })).toOperationNode();\n}\n", "/// <reference types=\"./json-reference-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const JSONReferenceNode = freeze({\n    is(node) {\n        return node.kind === 'JSONReferenceNode';\n    },\n    create(reference, traversal) {\n        return freeze({\n            kind: 'JSONReferenceNode',\n            reference,\n            traversal,\n        });\n    },\n    cloneWithTraversal(node, traversal) {\n        return freeze({\n            ...node,\n            traversal,\n        });\n    },\n});\n", "/// <reference types=\"./json-operator-chain-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const JSONOperatorChainNode = freeze({\n    is(node) {\n        return node.kind === 'JSONOperatorChainNode';\n    },\n    create(operator) {\n        return freeze({\n            kind: 'JSONOperatorChainNode',\n            operator,\n            values: freeze([]),\n        });\n    },\n    cloneWithValue(node, value) {\n        return freeze({\n            ...node,\n            values: freeze([...node.values, value]),\n        });\n    },\n});\n", "/// <reference types=\"./json-path-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const JSONPathNode = freeze({\n    is(node) {\n        return node.kind === 'JSONPathNode';\n    },\n    create(inOperator) {\n        return freeze({\n            kind: 'JSONPathNode',\n            inOperator,\n            pathLegs: freeze([]),\n        });\n    },\n    cloneWithLeg(jsonPathNode, pathLeg) {\n        return freeze({\n            ...jsonPathNode,\n            pathLegs: freeze([...jsonPathNode.pathLegs, pathLeg]),\n        });\n    },\n});\n", "/// <reference types=\"./reference-parser.d.ts\" />\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { ColumnNode } from '../operation-node/column-node.js';\nimport { ReferenceNode } from '../operation-node/reference-node.js';\nimport { TableNode } from '../operation-node/table-node.js';\nimport { isReadonlyArray, isString } from '../util/object-utils.js';\nimport { parseExpression, isExpressionOrFactory, } from './expression-parser.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { isOrderByDirection, parseOrderBy, } from './order-by-parser.js';\nimport { OperatorNode, isJSONOperator, } from '../operation-node/operator-node.js';\nimport { JSONReferenceNode } from '../operation-node/json-reference-node.js';\nimport { JSONOperatorChainNode } from '../operation-node/json-operator-chain-node.js';\nimport { JSONPathNode } from '../operation-node/json-path-node.js';\nexport function parseSimpleReferenceExpression(exp) {\n    if (isString(exp)) {\n        return parseStringReference(exp);\n    }\n    return exp.toOperationNode();\n}\nexport function parseReferenceExpressionOrList(arg) {\n    if (isReadonlyArray(arg)) {\n        return arg.map((it) => parseReferenceExpression(it));\n    }\n    else {\n        return [parseReferenceExpression(arg)];\n    }\n}\nexport function parseReferenceExpression(exp) {\n    if (isExpressionOrFactory(exp)) {\n        return parseExpression(exp);\n    }\n    return parseSimpleReferenceExpression(exp);\n}\nexport function parseJSONReference(ref, op) {\n    const referenceNode = parseStringReference(ref);\n    if (isJSONOperator(op)) {\n        return JSONReferenceNode.create(referenceNode, JSONOperatorChainNode.create(OperatorNode.create(op)));\n    }\n    const opWithoutLastChar = op.slice(0, -1);\n    if (isJSONOperator(opWithoutLastChar)) {\n        return JSONReferenceNode.create(referenceNode, JSONPathNode.create(OperatorNode.create(opWithoutLastChar)));\n    }\n    throw new Error(`Invalid JSON operator: ${op}`);\n}\nexport function parseStringReference(ref) {\n    const COLUMN_SEPARATOR = '.';\n    if (!ref.includes(COLUMN_SEPARATOR)) {\n        return ReferenceNode.create(ColumnNode.create(ref));\n    }\n    const parts = ref.split(COLUMN_SEPARATOR).map(trim);\n    if (parts.length === 3) {\n        return parseStringReferenceWithTableAndSchema(parts);\n    }\n    if (parts.length === 2) {\n        return parseStringReferenceWithTable(parts);\n    }\n    throw new Error(`invalid column reference ${ref}`);\n}\nexport function parseAliasedStringReference(ref) {\n    const ALIAS_SEPARATOR = ' as ';\n    if (ref.includes(ALIAS_SEPARATOR)) {\n        const [columnRef, alias] = ref.split(ALIAS_SEPARATOR).map(trim);\n        return AliasNode.create(parseStringReference(columnRef), IdentifierNode.create(alias));\n    }\n    else {\n        return parseStringReference(ref);\n    }\n}\nexport function parseColumnName(column) {\n    return ColumnNode.create(column);\n}\nexport function parseOrderedColumnName(column) {\n    const ORDER_SEPARATOR = ' ';\n    if (column.includes(ORDER_SEPARATOR)) {\n        const [columnName, order] = column.split(ORDER_SEPARATOR).map(trim);\n        if (!isOrderByDirection(order)) {\n            throw new Error(`invalid order direction \"${order}\" next to \"${columnName}\"`);\n        }\n        return parseOrderBy([columnName, order])[0];\n    }\n    else {\n        return parseColumnName(column);\n    }\n}\nfunction parseStringReferenceWithTableAndSchema(parts) {\n    const [schema, table, column] = parts;\n    return ReferenceNode.create(ColumnNode.create(column), TableNode.createWithSchema(schema, table));\n}\nfunction parseStringReferenceWithTable(parts) {\n    const [table, column] = parts;\n    return ReferenceNode.create(ColumnNode.create(column), TableNode.create(table));\n}\nfunction trim(str) {\n    return str.trim();\n}\n", "/// <reference types=\"./primitive-value-list-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const PrimitiveValueListNode = freeze({\n    is(node) {\n        return node.kind === 'PrimitiveValueListNode';\n    },\n    create(values) {\n        return freeze({\n            kind: 'PrimitiveValueListNode',\n            values: freeze([...values]),\n        });\n    },\n});\n", "/// <reference types=\"./value-list-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ValueListNode = freeze({\n    is(node) {\n        return node.kind === 'ValueListNode';\n    },\n    create(values) {\n        return freeze({\n            kind: 'ValueListNode',\n            values: freeze(values),\n        });\n    },\n});\n", "/// <reference types=\"./value-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ValueNode = freeze({\n    is(node) {\n        return node.kind === 'ValueNode';\n    },\n    create(value) {\n        return freeze({\n            kind: 'ValueNode',\n            value,\n        });\n    },\n    createImmediate(value) {\n        return freeze({\n            kind: 'ValueNode',\n            value,\n            immediate: true,\n        });\n    },\n});\n", "/// <reference types=\"./value-parser.d.ts\" />\nimport { PrimitiveValueListNode } from '../operation-node/primitive-value-list-node.js';\nimport { ValueListNode } from '../operation-node/value-list-node.js';\nimport { ValueNode } from '../operation-node/value-node.js';\nimport { isBoolean, isNull, isNumber, isReadonlyArray, } from '../util/object-utils.js';\nimport { parseExpression, isExpressionOrFactory, } from './expression-parser.js';\nexport function parseValueExpressionOrList(arg) {\n    if (isReadonlyArray(arg)) {\n        return parseValueExpressionList(arg);\n    }\n    return parseValueExpression(arg);\n}\nexport function parseValueExpression(exp) {\n    if (isExpressionOrFactory(exp)) {\n        return parseExpression(exp);\n    }\n    return ValueNode.create(exp);\n}\nexport function isSafeImmediateValue(value) {\n    return isNumber(value) || isBoolean(value) || isNull(value);\n}\nexport function parseSafeImmediateValue(value) {\n    if (!isSafeImmediateValue(value)) {\n        throw new Error(`unsafe immediate value ${JSON.stringify(value)}`);\n    }\n    return ValueNode.createImmediate(value);\n}\nfunction parseValueExpressionList(arg) {\n    if (arg.some(isExpressionOrFactory)) {\n        return ValueListNode.create(arg.map((it) => parseValueExpression(it)));\n    }\n    return PrimitiveValueListNode.create(arg);\n}\n", "/// <reference types=\"./parens-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ParensNode = freeze({\n    is(node) {\n        return node.kind === 'ParensNode';\n    },\n    create(node) {\n        return freeze({\n            kind: 'ParensNode',\n            node,\n        });\n    },\n});\n", "/// <reference types=\"./binary-operation-parser.d.ts\" />\nimport { BinaryOperationNode } from '../operation-node/binary-operation-node.js';\nimport { isBoolean, isNull, isString, isUndefined, } from '../util/object-utils.js';\nimport { isOperationNodeSource, } from '../operation-node/operation-node-source.js';\nimport { OperatorNode, OPERATORS, } from '../operation-node/operator-node.js';\nimport { parseReferenceExpression, } from './reference-parser.js';\nimport { parseValueExpression, parseValueExpressionOrList, } from './value-parser.js';\nimport { ValueNode } from '../operation-node/value-node.js';\nimport { AndNode } from '../operation-node/and-node.js';\nimport { ParensNode } from '../operation-node/parens-node.js';\nimport { OrNode } from '../operation-node/or-node.js';\nexport function parseValueBinaryOperationOrExpression(args) {\n    if (args.length === 3) {\n        return parseValueBinaryOperation(args[0], args[1], args[2]);\n    }\n    else if (args.length === 1) {\n        return parseValueExpression(args[0]);\n    }\n    throw new Error(`invalid arguments: ${JSON.stringify(args)}`);\n}\nexport function parseValueBinaryOperation(left, operator, right) {\n    if (isIsOperator(operator) && needsIsOperator(right)) {\n        return BinaryOperationNode.create(parseReferenceExpression(left), parseOperator(operator), ValueNode.createImmediate(right));\n    }\n    return BinaryOperationNode.create(parseReferenceExpression(left), parseOperator(operator), parseValueExpressionOrList(right));\n}\nexport function parseReferentialBinaryOperation(left, operator, right) {\n    return BinaryOperationNode.create(parseReferenceExpression(left), parseOperator(operator), parseReferenceExpression(right));\n}\nexport function parseFilterObject(obj, combinator) {\n    return parseFilterList(Object.entries(obj)\n        .filter(([, v]) => !isUndefined(v))\n        .map(([k, v]) => parseValueBinaryOperation(k, needsIsOperator(v) ? 'is' : '=', v)), combinator);\n}\nexport function parseFilterList(list, combinator, withParens = true) {\n    const combine = combinator === 'and' ? AndNode.create : OrNode.create;\n    if (list.length === 0) {\n        return BinaryOperationNode.create(ValueNode.createImmediate(1), OperatorNode.create('='), ValueNode.createImmediate(combinator === 'and' ? 1 : 0));\n    }\n    let node = toOperationNode(list[0]);\n    for (let i = 1; i < list.length; ++i) {\n        node = combine(node, toOperationNode(list[i]));\n    }\n    if (list.length > 1 && withParens) {\n        return ParensNode.create(node);\n    }\n    return node;\n}\nfunction isIsOperator(operator) {\n    return operator === 'is' || operator === 'is not';\n}\nfunction needsIsOperator(value) {\n    return isNull(value) || isBoolean(value);\n}\nfunction parseOperator(operator) {\n    if (isString(operator) && OPERATORS.includes(operator)) {\n        return OperatorNode.create(operator);\n    }\n    if (isOperationNodeSource(operator)) {\n        return operator.toOperationNode();\n    }\n    throw new Error(`invalid operator ${JSON.stringify(operator)}`);\n}\nfunction toOperationNode(nodeOrSource) {\n    return isOperationNodeSource(nodeOrSource)\n        ? nodeOrSource.toOperationNode()\n        : nodeOrSource;\n}\n", "/// <reference types=\"./order-by-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OrderByNode = freeze({\n    is(node) {\n        return node.kind === 'OrderByNode';\n    },\n    create(items) {\n        return freeze({\n            kind: 'OrderByNode',\n            items: freeze([...items]),\n        });\n    },\n    cloneWithItems(orderBy, items) {\n        return freeze({\n            ...orderBy,\n            items: freeze([...orderBy.items, ...items]),\n        });\n    },\n});\n", "/// <reference types=\"./partition-by-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const PartitionByNode = freeze({\n    is(node) {\n        return node.kind === 'PartitionByNode';\n    },\n    create(items) {\n        return freeze({\n            kind: 'PartitionByNode',\n            items: freeze(items),\n        });\n    },\n    cloneWithItems(partitionBy, items) {\n        return freeze({\n            ...partitionBy,\n            items: freeze([...partitionBy.items, ...items]),\n        });\n    },\n});\n", "/// <reference types=\"./over-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { OrderByNode } from './order-by-node.js';\nimport { PartitionByNode } from './partition-by-node.js';\n/**\n * @internal\n */\nexport const OverNode = freeze({\n    is(node) {\n        return node.kind === 'OverNode';\n    },\n    create() {\n        return freeze({\n            kind: 'OverNode',\n        });\n    },\n    cloneWithOrderByItems(overNode, items) {\n        return freeze({\n            ...overNode,\n            orderBy: overNode.orderBy\n                ? OrderByNode.cloneWithItems(overNode.orderBy, items)\n                : OrderByNode.create(items),\n        });\n    },\n    cloneWithPartitionByItems(overNode, items) {\n        return freeze({\n            ...overNode,\n            partitionBy: overNode.partitionBy\n                ? PartitionByNode.cloneWithItems(overNode.partitionBy, items)\n                : PartitionByNode.create(items),\n        });\n    },\n});\n", "/// <reference types=\"./from-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const FromNode = freeze({\n    is(node) {\n        return node.kind === 'FromNode';\n    },\n    create(froms) {\n        return freeze({\n            kind: 'FromNode',\n            froms: freeze(froms),\n        });\n    },\n    cloneWithFroms(from, froms) {\n        return freeze({\n            ...from,\n            froms: freeze([...from.froms, ...froms]),\n        });\n    },\n});\n", "/// <reference types=\"./group-by-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const GroupByNode = freeze({\n    is(node) {\n        return node.kind === 'GroupByNode';\n    },\n    create(items) {\n        return freeze({\n            kind: 'GroupByNode',\n            items: freeze(items),\n        });\n    },\n    cloneWithItems(groupBy, items) {\n        return freeze({\n            ...groupBy,\n            items: freeze([...groupBy.items, ...items]),\n        });\n    },\n});\n", "/// <reference types=\"./having-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { AndNode } from './and-node.js';\nimport { OrNode } from './or-node.js';\n/**\n * @internal\n */\nexport const HavingNode = freeze({\n    is(node) {\n        return node.kind === 'HavingNode';\n    },\n    create(filter) {\n        return freeze({\n            kind: 'HavingNode',\n            having: filter,\n        });\n    },\n    cloneWithOperation(havingNode, operator, operation) {\n        return freeze({\n            ...havingNode,\n            having: operator === 'And'\n                ? AndNode.create(havingNode.having, operation)\n                : OrNode.create(havingNode.having, operation),\n        });\n    },\n});\n", "/// <reference types=\"./insert-query-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const InsertQueryNode = freeze({\n    is(node) {\n        return node.kind === 'InsertQueryNode';\n    },\n    create(into, withNode, replace) {\n        return freeze({\n            kind: 'InsertQueryNode',\n            into,\n            ...(withNode && { with: withNode }),\n            replace,\n        });\n    },\n    createWithoutInto() {\n        return freeze({\n            kind: 'InsertQueryNode',\n        });\n    },\n    cloneWith(insertQuery, props) {\n        return freeze({\n            ...insertQuery,\n            ...props,\n        });\n    },\n});\n", "/// <reference types=\"./list-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ListNode = freeze({\n    is(node) {\n        return node.kind === 'ListNode';\n    },\n    create(items) {\n        return freeze({\n            kind: 'ListNode',\n            items: freeze(items),\n        });\n    },\n});\n", "/// <reference types=\"./update-query-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { FromNode } from './from-node.js';\nimport { ListNode } from './list-node.js';\n/**\n * @internal\n */\nexport const UpdateQueryNode = freeze({\n    is(node) {\n        return node.kind === 'UpdateQueryNode';\n    },\n    create(tables, withNode) {\n        return freeze({\n            kind: 'UpdateQueryNode',\n            // For backwards compatibility, use the raw table node when there's only one table\n            // and don't rename the property to something like `tables`.\n            table: tables.length === 1 ? tables[0] : ListNode.create(tables),\n            ...(withNode && { with: withNode }),\n        });\n    },\n    createWithoutTable() {\n        return freeze({\n            kind: 'UpdateQueryNode',\n        });\n    },\n    cloneWithFromItems(updateQuery, fromItems) {\n        return freeze({\n            ...updateQuery,\n            from: updateQuery.from\n                ? FromNode.cloneWithFroms(updateQuery.from, fromItems)\n                : FromNode.create(fromItems),\n        });\n    },\n    cloneWithUpdates(updateQuery, updates) {\n        return freeze({\n            ...updateQuery,\n            updates: updateQuery.updates\n                ? freeze([...updateQuery.updates, ...updates])\n                : updates,\n        });\n    },\n    cloneWithLimit(updateQuery, limit) {\n        return freeze({\n            ...updateQuery,\n            limit,\n        });\n    },\n});\n", "/// <reference types=\"./using-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const UsingNode = freeze({\n    is(node) {\n        return node.kind === 'UsingNode';\n    },\n    create(tables) {\n        return freeze({\n            kind: 'UsingNode',\n            tables: freeze(tables),\n        });\n    },\n    cloneWithTables(using, tables) {\n        return freeze({\n            ...using,\n            tables: freeze([...using.tables, ...tables]),\n        });\n    },\n});\n", "/// <reference types=\"./delete-query-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { FromNode } from './from-node.js';\nimport { UsingNode } from './using-node.js';\nimport { QueryNode } from './query-node.js';\n/**\n * @internal\n */\nexport const DeleteQueryNode = freeze({\n    is(node) {\n        return node.kind === 'DeleteQueryNode';\n    },\n    create(fromItems, withNode) {\n        return freeze({\n            kind: 'DeleteQueryNode',\n            from: FromNode.create(fromItems),\n            ...(withNode && { with: withNode }),\n        });\n    },\n    // TODO: remove in v0.29\n    /**\n     * @deprecated Use `QueryNode.cloneWithoutOrderBy` instead.\n     */\n    cloneWithOrderByItems: (node, items) => QueryNode.cloneWithOrderByItems(node, items),\n    // TODO: remove in v0.29\n    /**\n     * @deprecated Use `QueryNode.cloneWithoutOrderBy` instead.\n     */\n    cloneWithoutOrderBy: (node) => QueryNode.cloneWithoutOrderBy(node),\n    cloneWithLimit(deleteNode, limit) {\n        return freeze({\n            ...deleteNode,\n            limit,\n        });\n    },\n    cloneWithoutLimit(deleteNode) {\n        return freeze({\n            ...deleteNode,\n            limit: undefined,\n        });\n    },\n    cloneWithUsing(deleteNode, tables) {\n        return freeze({\n            ...deleteNode,\n            using: deleteNode.using !== undefined\n                ? UsingNode.cloneWithTables(deleteNode.using, tables)\n                : UsingNode.create(tables),\n        });\n    },\n});\n", "/// <reference types=\"./where-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { AndNode } from './and-node.js';\nimport { OrNode } from './or-node.js';\n/**\n * @internal\n */\nexport const WhereNode = freeze({\n    is(node) {\n        return node.kind === 'WhereNode';\n    },\n    create(filter) {\n        return freeze({\n            kind: 'WhereNode',\n            where: filter,\n        });\n    },\n    cloneWithOperation(whereNode, operator, operation) {\n        return freeze({\n            ...whereNode,\n            where: operator === 'And'\n                ? AndNode.create(whereNode.where, operation)\n                : OrNode.create(whereNode.where, operation),\n        });\n    },\n});\n", "/// <reference types=\"./returning-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ReturningNode = freeze({\n    is(node) {\n        return node.kind === 'ReturningNode';\n    },\n    create(selections) {\n        return freeze({\n            kind: 'ReturningNode',\n            selections: freeze(selections),\n        });\n    },\n    cloneWithSelections(returning, selections) {\n        return freeze({\n            ...returning,\n            selections: returning.selections\n                ? freeze([...returning.selections, ...selections])\n                : freeze(selections),\n        });\n    },\n});\n", "/// <reference types=\"./explain-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ExplainNode = freeze({\n    is(node) {\n        return node.kind === 'ExplainNode';\n    },\n    create(format, options) {\n        return freeze({\n            kind: 'ExplainNode',\n            format,\n            options,\n        });\n    },\n});\n", "/// <reference types=\"./when-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const WhenNode = freeze({\n    is(node) {\n        return node.kind === 'WhenNode';\n    },\n    create(condition) {\n        return freeze({\n            kind: 'WhenNode',\n            condition,\n        });\n    },\n    cloneWithResult(whenNode, result) {\n        return freeze({\n            ...whenNode,\n            result,\n        });\n    },\n});\n", "/// <reference types=\"./merge-query-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { WhenNode } from './when-node.js';\n/**\n * @internal\n */\nexport const MergeQueryNode = freeze({\n    is(node) {\n        return node.kind === 'MergeQueryNode';\n    },\n    create(into, withNode) {\n        return freeze({\n            kind: 'MergeQueryNode',\n            into,\n            ...(withNode && { with: withNode }),\n        });\n    },\n    cloneWithUsing(mergeNode, using) {\n        return freeze({\n            ...mergeNode,\n            using,\n        });\n    },\n    cloneWithWhen(mergeNode, when) {\n        return freeze({\n            ...mergeNode,\n            whens: mergeNode.whens\n                ? freeze([...mergeNode.whens, when])\n                : freeze([when]),\n        });\n    },\n    cloneWithThen(mergeNode, then) {\n        return freeze({\n            ...mergeNode,\n            whens: mergeNode.whens\n                ? freeze([\n                    ...mergeNode.whens.slice(0, -1),\n                    WhenNode.cloneWithResult(mergeNode.whens[mergeNode.whens.length - 1], then),\n                ])\n                : undefined,\n        });\n    },\n});\n", "/// <reference types=\"./output-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OutputNode = freeze({\n    is(node) {\n        return node.kind === 'OutputNode';\n    },\n    create(selections) {\n        return freeze({\n            kind: 'OutputNode',\n            selections: freeze(selections),\n        });\n    },\n    cloneWithSelections(output, selections) {\n        return freeze({\n            ...output,\n            selections: output.selections\n                ? freeze([...output.selections, ...selections])\n                : freeze(selections),\n        });\n    },\n});\n", "/// <reference types=\"./query-node.d.ts\" />\nimport { InsertQueryNode } from './insert-query-node.js';\nimport { SelectQueryNode } from './select-query-node.js';\nimport { UpdateQueryNode } from './update-query-node.js';\nimport { DeleteQueryNode } from './delete-query-node.js';\nimport { WhereNode } from './where-node.js';\nimport { freeze } from '../util/object-utils.js';\nimport { ReturningNode } from './returning-node.js';\nimport { ExplainNode } from './explain-node.js';\nimport { MergeQueryNode } from './merge-query-node.js';\nimport { OutputNode } from './output-node.js';\nimport { OrderByNode } from './order-by-node.js';\n/**\n * @internal\n */\nexport const QueryNode = freeze({\n    is(node) {\n        return (SelectQueryNode.is(node) ||\n            InsertQueryNode.is(node) ||\n            UpdateQueryNode.is(node) ||\n            DeleteQueryNode.is(node) ||\n            MergeQueryNode.is(node));\n    },\n    cloneWithEndModifier(node, modifier) {\n        return freeze({\n            ...node,\n            endModifiers: node.endModifiers\n                ? freeze([...node.endModifiers, modifier])\n                : freeze([modifier]),\n        });\n    },\n    cloneWithWhere(node, operation) {\n        return freeze({\n            ...node,\n            where: node.where\n                ? WhereNode.cloneWithOperation(node.where, 'And', operation)\n                : WhereNode.create(operation),\n        });\n    },\n    cloneWithJoin(node, join) {\n        return freeze({\n            ...node,\n            joins: node.joins ? freeze([...node.joins, join]) : freeze([join]),\n        });\n    },\n    cloneWithReturning(node, selections) {\n        return freeze({\n            ...node,\n            returning: node.returning\n                ? ReturningNode.cloneWithSelections(node.returning, selections)\n                : ReturningNode.create(selections),\n        });\n    },\n    cloneWithoutReturning(node) {\n        return freeze({\n            ...node,\n            returning: undefined,\n        });\n    },\n    cloneWithoutWhere(node) {\n        return freeze({\n            ...node,\n            where: undefined,\n        });\n    },\n    cloneWithExplain(node, format, options) {\n        return freeze({\n            ...node,\n            explain: ExplainNode.create(format, options?.toOperationNode()),\n        });\n    },\n    cloneWithTop(node, top) {\n        return freeze({\n            ...node,\n            top,\n        });\n    },\n    cloneWithOutput(node, selections) {\n        return freeze({\n            ...node,\n            output: node.output\n                ? OutputNode.cloneWithSelections(node.output, selections)\n                : OutputNode.create(selections),\n        });\n    },\n    cloneWithOrderByItems(node, items) {\n        return freeze({\n            ...node,\n            orderBy: node.orderBy\n                ? OrderByNode.cloneWithItems(node.orderBy, items)\n                : OrderByNode.create(items),\n        });\n    },\n    cloneWithoutOrderBy(node) {\n        return freeze({\n            ...node,\n            orderBy: undefined,\n        });\n    },\n});\n", "/// <reference types=\"./select-query-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { FromNode } from './from-node.js';\nimport { GroupByNode } from './group-by-node.js';\nimport { HavingNode } from './having-node.js';\nimport { QueryNode } from './query-node.js';\n/**\n * @internal\n */\nexport const SelectQueryNode = freeze({\n    is(node) {\n        return node.kind === 'SelectQueryNode';\n    },\n    create(withNode) {\n        return freeze({\n            kind: 'SelectQueryNode',\n            ...(withNode && { with: withNode }),\n        });\n    },\n    createFrom(fromItems, withNode) {\n        return freeze({\n            kind: 'SelectQueryNode',\n            from: FromNode.create(fromItems),\n            ...(withNode && { with: withNode }),\n        });\n    },\n    cloneWithSelections(select, selections) {\n        return freeze({\n            ...select,\n            selections: select.selections\n                ? freeze([...select.selections, ...selections])\n                : freeze(selections),\n        });\n    },\n    cloneWithDistinctOn(select, expressions) {\n        return freeze({\n            ...select,\n            distinctOn: select.distinctOn\n                ? freeze([...select.distinctOn, ...expressions])\n                : freeze(expressions),\n        });\n    },\n    cloneWithFrontModifier(select, modifier) {\n        return freeze({\n            ...select,\n            frontModifiers: select.frontModifiers\n                ? freeze([...select.frontModifiers, modifier])\n                : freeze([modifier]),\n        });\n    },\n    // TODO: remove in v0.29\n    /**\n     * @deprecated Use `QueryNode.cloneWithoutOrderBy` instead.\n     */\n    cloneWithOrderByItems: (node, items) => QueryNode.cloneWithOrderByItems(node, items),\n    cloneWithGroupByItems(selectNode, items) {\n        return freeze({\n            ...selectNode,\n            groupBy: selectNode.groupBy\n                ? GroupByNode.cloneWithItems(selectNode.groupBy, items)\n                : GroupByNode.create(items),\n        });\n    },\n    cloneWithLimit(selectNode, limit) {\n        return freeze({\n            ...selectNode,\n            limit,\n        });\n    },\n    cloneWithOffset(selectNode, offset) {\n        return freeze({\n            ...selectNode,\n            offset,\n        });\n    },\n    cloneWithFetch(selectNode, fetch) {\n        return freeze({\n            ...selectNode,\n            fetch,\n        });\n    },\n    cloneWithHaving(selectNode, operation) {\n        return freeze({\n            ...selectNode,\n            having: selectNode.having\n                ? HavingNode.cloneWithOperation(selectNode.having, 'And', operation)\n                : HavingNode.create(operation),\n        });\n    },\n    cloneWithSetOperations(selectNode, setOperations) {\n        return freeze({\n            ...selectNode,\n            setOperations: selectNode.setOperations\n                ? freeze([...selectNode.setOperations, ...setOperations])\n                : freeze([...setOperations]),\n        });\n    },\n    cloneWithoutSelections(select) {\n        return freeze({\n            ...select,\n            selections: [],\n        });\n    },\n    cloneWithoutLimit(select) {\n        return freeze({\n            ...select,\n            limit: undefined,\n        });\n    },\n    cloneWithoutOffset(select) {\n        return freeze({\n            ...select,\n            offset: undefined,\n        });\n    },\n    // TODO: remove in v0.29\n    /**\n     * @deprecated Use `QueryNode.cloneWithoutOrderBy` instead.\n     */\n    cloneWithoutOrderBy: (node) => QueryNode.cloneWithoutOrderBy(node),\n    cloneWithoutGroupBy(select) {\n        return freeze({\n            ...select,\n            groupBy: undefined,\n        });\n    },\n});\n", "/// <reference types=\"./join-builder.d.ts\" />\nimport { JoinNode } from '../operation-node/join-node.js';\nimport { RawNode } from '../operation-node/raw-node.js';\nimport { parseValueBinaryOperationOrExpression, parseReferentialBinaryOperation, } from '../parser/binary-operation-parser.js';\nimport { freeze } from '../util/object-utils.js';\nexport class JoinBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    on(...args) {\n        return new JoinBuilder({\n            ...this.#props,\n            joinNode: JoinNode.cloneWithOn(this.#props.joinNode, parseValueBinaryOperationOrExpression(args)),\n        });\n    }\n    /**\n     * Just like {@link WhereInterface.whereRef} but adds an item to the join's\n     * `on` clause instead.\n     *\n     * See {@link WhereInterface.whereRef} for documentation and examples.\n     */\n    onRef(lhs, op, rhs) {\n        return new JoinBuilder({\n            ...this.#props,\n            joinNode: JoinNode.cloneWithOn(this.#props.joinNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n        });\n    }\n    /**\n     * Adds `on true`.\n     */\n    onTrue() {\n        return new JoinBuilder({\n            ...this.#props,\n            joinNode: JoinNode.cloneWithOn(this.#props.joinNode, RawNode.createWithSql('true')),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.joinNode;\n    }\n}\n", "/// <reference types=\"./partition-by-item-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const PartitionByItemNode = freeze({\n    is(node) {\n        return node.kind === 'PartitionByItemNode';\n    },\n    create(partitionBy) {\n        return freeze({\n            kind: 'PartitionByItemNode',\n            partitionBy,\n        });\n    },\n});\n", "/// <reference types=\"./partition-by-parser.d.ts\" />\nimport { PartitionByItemNode } from '../operation-node/partition-by-item-node.js';\nimport { parseReferenceExpressionOrList, } from './reference-parser.js';\nexport function parsePartitionBy(partitionBy) {\n    return parseReferenceExpressionOrList(partitionBy).map(PartitionByItemNode.create);\n}\n", "/// <reference types=\"./over-builder.d.ts\" />\nimport { OverNode } from '../operation-node/over-node.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { parseOrderBy, } from '../parser/order-by-parser.js';\nimport { parsePartitionBy, } from '../parser/partition-by-parser.js';\nimport { freeze } from '../util/object-utils.js';\nexport class OverBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    orderBy(...args) {\n        return new OverBuilder({\n            overNode: OverNode.cloneWithOrderByItems(this.#props.overNode, parseOrderBy(args)),\n        });\n    }\n    clearOrderBy() {\n        return new OverBuilder({\n            overNode: QueryNode.cloneWithoutOrderBy(this.#props.overNode),\n        });\n    }\n    partitionBy(partitionBy) {\n        return new OverBuilder({\n            overNode: OverNode.cloneWithPartitionByItems(this.#props.overNode, parsePartitionBy(partitionBy)),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.overNode;\n    }\n}\n", "/// <reference types=\"./selection-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { ReferenceNode } from './reference-node.js';\nimport { SelectAllNode } from './select-all-node.js';\n/**\n * @internal\n */\nexport const SelectionNode = freeze({\n    is(node) {\n        return node.kind === 'SelectionNode';\n    },\n    create(selection) {\n        return freeze({\n            kind: 'SelectionNode',\n            selection: selection,\n        });\n    },\n    createSelectAll() {\n        return freeze({\n            kind: 'SelectionNode',\n            selection: SelectAllNode.create(),\n        });\n    },\n    createSelectAllFromTable(table) {\n        return freeze({\n            kind: 'SelectionNode',\n            selection: ReferenceNode.createSelectAll(table),\n        });\n    },\n});\n", "/// <reference types=\"./select-parser.d.ts\" />\nimport { isFunction, isReadonlyArray, isString } from '../util/object-utils.js';\nimport { SelectionNode } from '../operation-node/selection-node.js';\nimport { parseAliasedStringReference } from './reference-parser.js';\nimport { isDynamicReferenceBuilder, } from '../dynamic/dynamic-reference-builder.js';\nimport { parseAliasedExpression, } from './expression-parser.js';\nimport { parseTable } from './table-parser.js';\nimport { expressionBuilder, } from '../expression/expression-builder.js';\nexport function parseSelectArg(selection) {\n    if (isFunction(selection)) {\n        return parseSelectArg(selection(expressionBuilder()));\n    }\n    else if (isReadonlyArray(selection)) {\n        return selection.map((it) => parseSelectExpression(it));\n    }\n    else {\n        return [parseSelectExpression(selection)];\n    }\n}\nfunction parseSelectExpression(selection) {\n    if (isString(selection)) {\n        return SelectionNode.create(parseAliasedStringReference(selection));\n    }\n    else if (isDynamicReferenceBuilder(selection)) {\n        return SelectionNode.create(selection.toOperationNode());\n    }\n    else {\n        return SelectionNode.create(parseAliasedExpression(selection));\n    }\n}\nexport function parseSelectAll(table) {\n    if (!table) {\n        return [SelectionNode.createSelectAll()];\n    }\n    else if (Array.isArray(table)) {\n        return table.map(parseSelectAllArg);\n    }\n    else {\n        return [parseSelectAllArg(table)];\n    }\n}\nfunction parseSelectAllArg(table) {\n    if (isString(table)) {\n        return SelectionNode.createSelectAllFromTable(parseTable(table));\n    }\n    throw new Error(`invalid value selectAll expression: ${JSON.stringify(table)}`);\n}\n", "/// <reference types=\"./values-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ValuesNode = freeze({\n    is(node) {\n        return node.kind === 'ValuesNode';\n    },\n    create(values) {\n        return freeze({\n            kind: 'ValuesNode',\n            values: freeze(values),\n        });\n    },\n});\n", "/// <reference types=\"./default-insert-value-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const DefaultInsertValueNode = freeze({\n    is(node) {\n        return node.kind === 'DefaultInsertValueNode';\n    },\n    create() {\n        return freeze({\n            kind: 'DefaultInsertValueNode',\n        });\n    },\n});\n", "/// <reference types=\"./insert-values-parser.d.ts\" />\nimport { ColumnNode } from '../operation-node/column-node.js';\nimport { PrimitiveValueListNode } from '../operation-node/primitive-value-list-node.js';\nimport { ValueListNode } from '../operation-node/value-list-node.js';\nimport { freeze, isFunction, isReadonlyArray, isUndefined, } from '../util/object-utils.js';\nimport { parseValueExpression } from './value-parser.js';\nimport { ValuesNode } from '../operation-node/values-node.js';\nimport { isExpressionOrFactory } from './expression-parser.js';\nimport { DefaultInsertValueNode } from '../operation-node/default-insert-value-node.js';\nimport { expressionBuilder, } from '../expression/expression-builder.js';\nexport function parseInsertExpression(arg) {\n    const objectOrList = isFunction(arg) ? arg(expressionBuilder()) : arg;\n    const list = isReadonlyArray(objectOrList)\n        ? objectOrList\n        : freeze([objectOrList]);\n    return parseInsertColumnsAndValues(list);\n}\nfunction parseInsertColumnsAndValues(rows) {\n    const columns = parseColumnNamesAndIndexes(rows);\n    return [\n        freeze([...columns.keys()].map(ColumnNode.create)),\n        ValuesNode.create(rows.map((row) => parseRowValues(row, columns))),\n    ];\n}\nfunction parseColumnNamesAndIndexes(rows) {\n    const columns = new Map();\n    for (const row of rows) {\n        const cols = Object.keys(row);\n        for (const col of cols) {\n            if (!columns.has(col) && row[col] !== undefined) {\n                columns.set(col, columns.size);\n            }\n        }\n    }\n    return columns;\n}\nfunction parseRowValues(row, columns) {\n    const rowColumns = Object.keys(row);\n    const rowValues = Array.from({\n        length: columns.size,\n    });\n    let hasUndefinedOrComplexColumns = false;\n    let indexedRowColumns = rowColumns.length;\n    for (const col of rowColumns) {\n        const columnIdx = columns.get(col);\n        if (isUndefined(columnIdx)) {\n            indexedRowColumns--;\n            continue;\n        }\n        const value = row[col];\n        if (isUndefined(value) || isExpressionOrFactory(value)) {\n            hasUndefinedOrComplexColumns = true;\n        }\n        rowValues[columnIdx] = value;\n    }\n    const hasMissingColumns = indexedRowColumns < columns.size;\n    if (hasMissingColumns || hasUndefinedOrComplexColumns) {\n        const defaultValue = DefaultInsertValueNode.create();\n        return ValueListNode.create(rowValues.map((it) => isUndefined(it) ? defaultValue : parseValueExpression(it)));\n    }\n    return PrimitiveValueListNode.create(rowValues);\n}\n", "/// <reference types=\"./column-update-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ColumnUpdateNode = freeze({\n    is(node) {\n        return node.kind === 'ColumnUpdateNode';\n    },\n    create(column, value) {\n        return freeze({\n            kind: 'ColumnUpdateNode',\n            column,\n            value,\n        });\n    },\n});\n", "/// <reference types=\"./update-set-parser.d.ts\" />\nimport { ColumnNode } from '../operation-node/column-node.js';\nimport { ColumnUpdateNode } from '../operation-node/column-update-node.js';\nimport { expressionBuilder, } from '../expression/expression-builder.js';\nimport { isFunction } from '../util/object-utils.js';\nimport { parseValueExpression } from './value-parser.js';\nimport { parseReferenceExpression, } from './reference-parser.js';\nexport function parseUpdate(...args) {\n    if (args.length === 2) {\n        return [\n            ColumnUpdateNode.create(parseReferenceExpression(args[0]), parseValueExpression(args[1])),\n        ];\n    }\n    return parseUpdateObjectExpression(args[0]);\n}\nexport function parseUpdateObjectExpression(update) {\n    const updateObj = isFunction(update) ? update(expressionBuilder()) : update;\n    return Object.entries(updateObj)\n        .filter(([_, value]) => value !== undefined)\n        .map(([key, value]) => {\n        return ColumnUpdateNode.create(ColumnNode.create(key), parseValueExpression(value));\n    });\n}\n", "/// <reference types=\"./on-duplicate-key-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OnDuplicateKeyNode = freeze({\n    is(node) {\n        return node.kind === 'OnDuplicateKeyNode';\n    },\n    create(updates) {\n        return freeze({\n            kind: 'OnDuplicateKeyNode',\n            updates,\n        });\n    },\n});\n", "/// <reference types=\"./insert-result.d.ts\" />\n/**\n * The result of an insert query.\n *\n * If the table has an auto incrementing primary key {@link insertId} will hold\n * the generated id on dialects that support it. For example PostgreSQL doesn't\n * return the id by default and {@link insertId} is undefined. On PostgreSQL you\n * need to use {@link ReturningInterface.returning} or {@link ReturningInterface.returningAll}\n * to get out the inserted id.\n *\n * {@link numInsertedOrUpdatedRows} holds the number of (actually) inserted rows.\n * On MySQL, updated rows are counted twice when using `on duplicate key update`.\n *\n * ### Examples\n *\n * ```ts\n * import type { NewPerson } from 'type-editor' // imaginary module\n *\n * async function insertPerson(person: NewPerson) {\n *   const result = await db\n *     .insertInto('person')\n *     .values(person)\n *     .executeTakeFirstOrThrow()\n *\n *   console.log(result.insertId) // relevant on MySQL\n *   console.log(result.numInsertedOrUpdatedRows) // always relevant\n * }\n * ```\n */\nexport class InsertResult {\n    /**\n     * The auto incrementing primary key of the inserted row.\n     *\n     * This property can be undefined when the query contains an `on conflict`\n     * clause that makes the query succeed even when nothing gets inserted.\n     *\n     * This property is always undefined on dialects like PostgreSQL that\n     * don't return the inserted id by default. On those dialects you need\n     * to use the {@link ReturningInterface.returning | returning} method.\n     */\n    insertId;\n    /**\n     * Affected rows count.\n     */\n    numInsertedOrUpdatedRows;\n    constructor(insertId, numInsertedOrUpdatedRows) {\n        this.insertId = insertId;\n        this.numInsertedOrUpdatedRows = numInsertedOrUpdatedRows;\n    }\n}\n", "/// <reference types=\"./no-result-error.d.ts\" />\nexport class NoResultError extends Error {\n    /**\n     * The operation node tree of the query that was executed.\n     */\n    node;\n    constructor(node) {\n        super('no result');\n        this.node = node;\n    }\n}\nexport function isNoResultErrorConstructor(fn) {\n    return Object.prototype.hasOwnProperty.call(fn, 'prototype');\n}\n", "/// <reference types=\"./on-conflict-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { WhereNode } from './where-node.js';\n/**\n * @internal\n */\nexport const OnConflictNode = freeze({\n    is(node) {\n        return node.kind === 'OnConflictNode';\n    },\n    create() {\n        return freeze({\n            kind: 'OnConflictNode',\n        });\n    },\n    cloneWith(node, props) {\n        return freeze({\n            ...node,\n            ...props,\n        });\n    },\n    cloneWithIndexWhere(node, operation) {\n        return freeze({\n            ...node,\n            indexWhere: node.indexWhere\n                ? WhereNode.cloneWithOperation(node.indexWhere, 'And', operation)\n                : WhereNode.create(operation),\n        });\n    },\n    cloneWithIndexOrWhere(node, operation) {\n        return freeze({\n            ...node,\n            indexWhere: node.indexWhere\n                ? WhereNode.cloneWithOperation(node.indexWhere, 'Or', operation)\n                : WhereNode.create(operation),\n        });\n    },\n    cloneWithUpdateWhere(node, operation) {\n        return freeze({\n            ...node,\n            updateWhere: node.updateWhere\n                ? WhereNode.cloneWithOperation(node.updateWhere, 'And', operation)\n                : WhereNode.create(operation),\n        });\n    },\n    cloneWithUpdateOrWhere(node, operation) {\n        return freeze({\n            ...node,\n            updateWhere: node.updateWhere\n                ? WhereNode.cloneWithOperation(node.updateWhere, 'Or', operation)\n                : WhereNode.create(operation),\n        });\n    },\n    cloneWithoutIndexWhere(node) {\n        return freeze({\n            ...node,\n            indexWhere: undefined,\n        });\n    },\n    cloneWithoutUpdateWhere(node) {\n        return freeze({\n            ...node,\n            updateWhere: undefined,\n        });\n    },\n});\n", "/// <reference types=\"./on-conflict-builder.d.ts\" />\nimport { ColumnNode } from '../operation-node/column-node.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { OnConflictNode } from '../operation-node/on-conflict-node.js';\nimport { parseValueBinaryOperationOrExpression, parseReferentialBinaryOperation, } from '../parser/binary-operation-parser.js';\nimport { parseUpdateObjectExpression, } from '../parser/update-set-parser.js';\nimport { freeze } from '../util/object-utils.js';\nexport class OnConflictBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * Specify a single column as the conflict target.\n     *\n     * Also see the {@link columns}, {@link constraint} and {@link expression}\n     * methods for alternative ways to specify the conflict target.\n     */\n    column(column) {\n        const columnNode = ColumnNode.create(column);\n        return new OnConflictBuilder({\n            ...this.#props,\n            onConflictNode: OnConflictNode.cloneWith(this.#props.onConflictNode, {\n                columns: this.#props.onConflictNode.columns\n                    ? freeze([...this.#props.onConflictNode.columns, columnNode])\n                    : freeze([columnNode]),\n            }),\n        });\n    }\n    /**\n     * Specify a list of columns as the conflict target.\n     *\n     * Also see the {@link column}, {@link constraint} and {@link expression}\n     * methods for alternative ways to specify the conflict target.\n     */\n    columns(columns) {\n        const columnNodes = columns.map(ColumnNode.create);\n        return new OnConflictBuilder({\n            ...this.#props,\n            onConflictNode: OnConflictNode.cloneWith(this.#props.onConflictNode, {\n                columns: this.#props.onConflictNode.columns\n                    ? freeze([...this.#props.onConflictNode.columns, ...columnNodes])\n                    : freeze(columnNodes),\n            }),\n        });\n    }\n    /**\n     * Specify a specific constraint by name as the conflict target.\n     *\n     * Also see the {@link column}, {@link columns} and {@link expression}\n     * methods for alternative ways to specify the conflict target.\n     */\n    constraint(constraintName) {\n        return new OnConflictBuilder({\n            ...this.#props,\n            onConflictNode: OnConflictNode.cloneWith(this.#props.onConflictNode, {\n                constraint: IdentifierNode.create(constraintName),\n            }),\n        });\n    }\n    /**\n     * Specify an expression as the conflict target.\n     *\n     * This can be used if the unique index is an expression index.\n     *\n     * Also see the {@link column}, {@link columns} and {@link constraint}\n     * methods for alternative ways to specify the conflict target.\n     */\n    expression(expression) {\n        return new OnConflictBuilder({\n            ...this.#props,\n            onConflictNode: OnConflictNode.cloneWith(this.#props.onConflictNode, {\n                indexExpression: expression.toOperationNode(),\n            }),\n        });\n    }\n    where(...args) {\n        return new OnConflictBuilder({\n            ...this.#props,\n            onConflictNode: OnConflictNode.cloneWithIndexWhere(this.#props.onConflictNode, parseValueBinaryOperationOrExpression(args)),\n        });\n    }\n    whereRef(lhs, op, rhs) {\n        return new OnConflictBuilder({\n            ...this.#props,\n            onConflictNode: OnConflictNode.cloneWithIndexWhere(this.#props.onConflictNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n        });\n    }\n    clearWhere() {\n        return new OnConflictBuilder({\n            ...this.#props,\n            onConflictNode: OnConflictNode.cloneWithoutIndexWhere(this.#props.onConflictNode),\n        });\n    }\n    /**\n     * Adds the \"do nothing\" conflict action.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * const id = 1\n     * const first_name = 'John'\n     *\n     * await db\n     *   .insertInto('person')\n     *   .values({\u00A0first_name, id })\n     *   .onConflict((oc) => oc\n     *     .column('id')\n     *     .doNothing()\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"person\" (\"first_name\", \"id\")\n     * values ($1, $2)\n     * on conflict (\"id\") do nothing\n     * ```\n     */\n    doNothing() {\n        return new OnConflictDoNothingBuilder({\n            ...this.#props,\n            onConflictNode: OnConflictNode.cloneWith(this.#props.onConflictNode, {\n                doNothing: true,\n            }),\n        });\n    }\n    /**\n     * Adds the \"do update set\" conflict action.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * const id = 1\n     * const first_name = 'John'\n     *\n     * await db\n     *   .insertInto('person')\n     *   .values({\u00A0first_name, id })\n     *   .onConflict((oc) => oc\n     *     .column('id')\n     *     .doUpdateSet({ first_name })\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"person\" (\"first_name\", \"id\")\n     * values ($1, $2)\n     * on conflict (\"id\")\n     * do update set \"first_name\" = $3\n     * ```\n     *\n     * In the next example we use the `ref` method to reference\n     * columns of the virtual table `excluded` in a type-safe way\n     * to create an upsert operation:\n     *\n     * ```ts\n     * import type { NewPerson } from 'type-editor' // imaginary module\n     *\n     * async function upsertPerson(person: NewPerson): Promise<void> {\n     *   await db.insertInto('person')\n     *     .values(person)\n     *     .onConflict((oc) => oc\n     *       .column('id')\n     *       .doUpdateSet((eb) => ({\n     *         first_name: eb.ref('excluded.first_name'),\n     *         last_name: eb.ref('excluded.last_name')\n     *       })\n     *     )\n     *   )\n     *   .execute()\n     * }\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"person\" (\"first_name\", \"last_name\")\n     * values ($1, $2)\n     * on conflict (\"id\")\n     * do update set\n     *  \"first_name\" = excluded.\"first_name\",\n     *  \"last_name\" = excluded.\"last_name\"\n     * ```\n     */\n    doUpdateSet(update) {\n        return new OnConflictUpdateBuilder({\n            ...this.#props,\n            onConflictNode: OnConflictNode.cloneWith(this.#props.onConflictNode, {\n                updates: parseUpdateObjectExpression(update),\n            }),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n}\nexport class OnConflictDoNothingBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    toOperationNode() {\n        return this.#props.onConflictNode;\n    }\n}\nexport class OnConflictUpdateBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    where(...args) {\n        return new OnConflictUpdateBuilder({\n            ...this.#props,\n            onConflictNode: OnConflictNode.cloneWithUpdateWhere(this.#props.onConflictNode, parseValueBinaryOperationOrExpression(args)),\n        });\n    }\n    /**\n     * Specify a where condition for the update operation.\n     *\n     * See {@link WhereInterface.whereRef} for more info.\n     */\n    whereRef(lhs, op, rhs) {\n        return new OnConflictUpdateBuilder({\n            ...this.#props,\n            onConflictNode: OnConflictNode.cloneWithUpdateWhere(this.#props.onConflictNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n        });\n    }\n    clearWhere() {\n        return new OnConflictUpdateBuilder({\n            ...this.#props,\n            onConflictNode: OnConflictNode.cloneWithoutUpdateWhere(this.#props.onConflictNode),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.onConflictNode;\n    }\n}\n", "/// <reference types=\"./top-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const TopNode = freeze({\n    is(node) {\n        return node.kind === 'TopNode';\n    },\n    create(expression, modifiers) {\n        return freeze({\n            kind: 'TopNode',\n            expression,\n            modifiers,\n        });\n    },\n});\n", "/// <reference types=\"./top-parser.d.ts\" />\nimport { TopNode } from '../operation-node/top-node.js';\nimport { isBigInt, isNumber, isUndefined } from '../util/object-utils.js';\nexport function parseTop(expression, modifiers) {\n    if (!isNumber(expression) && !isBigInt(expression)) {\n        throw new Error(`Invalid top expression: ${expression}`);\n    }\n    if (!isUndefined(modifiers) && !isTopModifiers(modifiers)) {\n        throw new Error(`Invalid top modifiers: ${modifiers}`);\n    }\n    return TopNode.create(expression, modifiers);\n}\nfunction isTopModifiers(modifiers) {\n    return (modifiers === 'percent' ||\n        modifiers === 'with ties' ||\n        modifiers === 'percent with ties');\n}\n", "/// <reference types=\"./or-action-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OrActionNode = freeze({\n    is(node) {\n        return node.kind === 'OrActionNode';\n    },\n    create(action) {\n        return freeze({\n            kind: 'OrActionNode',\n            action,\n        });\n    },\n});\n", "/// <reference types=\"./insert-query-builder.d.ts\" />\nimport { parseSelectArg, parseSelectAll, } from '../parser/select-parser.js';\nimport { parseInsertExpression, } from '../parser/insert-values-parser.js';\nimport { InsertQueryNode } from '../operation-node/insert-query-node.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { parseUpdateObjectExpression, } from '../parser/update-set-parser.js';\nimport { freeze } from '../util/object-utils.js';\nimport { OnDuplicateKeyNode } from '../operation-node/on-duplicate-key-node.js';\nimport { InsertResult } from './insert-result.js';\nimport { isNoResultErrorConstructor, NoResultError, } from './no-result-error.js';\nimport { parseExpression, } from '../parser/expression-parser.js';\nimport { ColumnNode } from '../operation-node/column-node.js';\nimport { OnConflictBuilder, } from './on-conflict-builder.js';\nimport { OnConflictNode } from '../operation-node/on-conflict-node.js';\nimport { parseTop } from '../parser/top-parser.js';\nimport { OrActionNode } from '../operation-node/or-action-node.js';\nexport class InsertQueryBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * Sets the values to insert for an {@link Kysely.insertInto | insert} query.\n     *\n     * This method takes an object whose keys are column names and values are\n     * values to insert. In addition to the column's type, the values can be\n     * raw {@link sql} snippets or select queries.\n     *\n     * You must provide all fields you haven't explicitly marked as nullable\n     * or optional using {@link Generated} or {@link ColumnType}.\n     *\n     * The return value of an `insert` query is an instance of {@link InsertResult}. The\n     * {@link InsertResult.insertId | insertId} field holds the auto incremented primary\n     * key if the database returned one.\n     *\n     * On PostgreSQL and some other dialects, you need to call `returning` to get\n     * something out of the query.\n     *\n     * Also see the {@link expression} method for inserting the result of a select\n     * query or any other expression.\n     *\n     * ### Examples\n     *\n     * <!-- siteExample(\"insert\", \"Single row\", 10) -->\n     *\n     * Insert a single row:\n     *\n     * ```ts\n     * const result = await db\n     *   .insertInto('person')\n     *   .values({\n     *     first_name: 'Jennifer',\n     *     last_name: 'Aniston',\n     *     age: 40\n     *   })\n     *   .executeTakeFirst()\n     *\n     * // `insertId` is only available on dialects that\n     * // automatically return the id of the inserted row\n     * // such as MySQL and SQLite. On PostgreSQL, for example,\n     * // you need to add a `returning` clause to the query to\n     * // get anything out. See the \"returning data\" example.\n     * console.log(result.insertId)\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * insert into `person` (`first_name`, `last_name`, `age`) values (?, ?, ?)\n     * ```\n     *\n     * <!-- siteExample(\"insert\", \"Multiple rows\", 20) -->\n     *\n     * On dialects that support it (for example PostgreSQL) you can insert multiple\n     * rows by providing an array. Note that the return value is once again very\n     * dialect-specific. Some databases may only return the id of the *last* inserted\n     * row and some return nothing at all unless you call `returning`.\n     *\n     * ```ts\n     * await db\n     *   .insertInto('person')\n     *   .values([{\n     *     first_name: 'Jennifer',\n     *     last_name: 'Aniston',\n     *     age: 40,\n     *   }, {\n     *     first_name: 'Arnold',\n     *     last_name: 'Schwarzenegger',\n     *     age: 70,\n     *   }])\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"person\" (\"first_name\", \"last_name\", \"age\") values (($1, $2, $3), ($4, $5, $6))\n     * ```\n     *\n     * <!-- siteExample(\"insert\", \"Returning data\", 30) -->\n     *\n     * On supported dialects like PostgreSQL you need to chain `returning` to the query to get\n     * the inserted row's columns (or any other expression) as the return value. `returning`\n     * works just like `select`. Refer to `select` method's examples and documentation for\n     * more info.\n     *\n     * ```ts\n     * const result = await db\n     *   .insertInto('person')\n     *   .values({\n     *     first_name: 'Jennifer',\n     *     last_name: 'Aniston',\n     *     age: 40,\n     *   })\n     *   .returning(['id', 'first_name as name'])\n     *   .executeTakeFirstOrThrow()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"person\" (\"first_name\", \"last_name\", \"age\") values ($1, $2, $3) returning \"id\", \"first_name\" as \"name\"\n     * ```\n     *\n     * <!-- siteExample(\"insert\", \"Complex values\", 40) -->\n     *\n     * In addition to primitives, the values can also be arbitrary expressions.\n     * You can build the expressions by using a callback and calling the methods\n     * on the expression builder passed to it:\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * const ani = \"Ani\"\n     * const ston = \"ston\"\n     *\n     * const result = await db\n     *   .insertInto('person')\n     *   .values(({ ref, selectFrom, fn }) => ({\n     *     first_name: 'Jennifer',\n     *     last_name: sql<string>`concat(${ani}, ${ston})`,\n     *     middle_name: ref('first_name'),\n     *     age: selectFrom('person')\n     *       .select(fn.avg<number>('age').as('avg_age')),\n     *   }))\n     *   .executeTakeFirst()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"person\" (\n     *   \"first_name\",\n     *   \"last_name\",\n     *   \"middle_name\",\n     *   \"age\"\n     * )\n     * values (\n     *   $1,\n     *   concat($2, $3),\n     *   \"first_name\",\n     *   (select avg(\"age\") as \"avg_age\" from \"person\")\n     * )\n     * ```\n     *\n     * You can also use the callback version of subqueries or raw expressions:\n     *\n     * ```ts\n     * await db.with('jennifer', (db) => db\n     *   .selectFrom('person')\n     *   .where('first_name', '=', 'Jennifer')\n     *   .select(['id', 'first_name', 'gender'])\n     *   .limit(1)\n     * ).insertInto('pet').values((eb) => ({\n     *   owner_id: eb.selectFrom('jennifer').select('id'),\n     *   name: eb.selectFrom('jennifer').select('first_name'),\n     *   species: 'cat',\n     * }))\n     * .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * with \"jennifer\" as (\n     *   select \"id\", \"first_name\", \"gender\"\n     *   from \"person\"\n     *   where \"first_name\" = $1\n     *   limit $2\n     * )\n     * insert into \"pet\" (\"owner_id\", \"name\", \"species\")\n     * values (\n     *  (select \"id\" from \"jennifer\"),\n     *  (select \"first_name\" from \"jennifer\"),\n     *  $3\n     * )\n     * ```\n     */\n    values(insert) {\n        const [columns, values] = parseInsertExpression(insert);\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n                columns,\n                values,\n            }),\n        });\n    }\n    /**\n     * Sets the columns to insert.\n     *\n     * The {@link values} method sets both the columns and the values and this method\n     * is not needed. But if you are using the {@link expression} method, you can use\n     * this method to set the columns to insert.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.insertInto('person')\n     *   .columns(['first_name'])\n     *   .expression((eb) => eb.selectFrom('pet').select('pet.name'))\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"person\" (\"first_name\")\n     * select \"pet\".\"name\" from \"pet\"\n     * ```\n     */\n    columns(columns) {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n                columns: freeze(columns.map(ColumnNode.create)),\n            }),\n        });\n    }\n    /**\n     * Insert an arbitrary expression. For example the result of a select query.\n     *\n     * ### Examples\n     *\n     * <!-- siteExample(\"insert\", \"Insert subquery\", 50) -->\n     *\n     * You can create an `INSERT INTO SELECT FROM` query using the `expression` method.\n     * This API doesn't follow our WYSIWYG principles and might be a bit difficult to\n     * remember. The reasons for this design stem from implementation difficulties.\n     *\n     * ```ts\n     * const result = await db.insertInto('person')\n     *   .columns(['first_name', 'last_name', 'age'])\n     *   .expression((eb) => eb\n     *     .selectFrom('pet')\n     *     .select((eb) => [\n     *       'pet.name',\n     *       eb.val('Petson').as('last_name'),\n     *       eb.lit(7).as('age'),\n     *     ])\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"person\" (\"first_name\", \"last_name\", \"age\")\n     * select \"pet\".\"name\", $1 as \"last_name\", 7 as \"age from \"pet\"\n     * ```\n     */\n    expression(expression) {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n                values: parseExpression(expression),\n            }),\n        });\n    }\n    /**\n     * Creates an `insert into \"person\" default values` query.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.insertInto('person')\n     *   .defaultValues()\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"person\" default values\n     * ```\n     */\n    defaultValues() {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n                defaultValues: true,\n            }),\n        });\n    }\n    /**\n     * This can be used to add any additional SQL to the end of the query.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * await db.insertInto('person')\n     *   .values({\n     *     first_name: 'John',\n     *     last_name: 'Doe',\n     *     gender: 'male',\n     *   })\n     *   .modifyEnd(sql`-- This is a comment`)\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * insert into `person` (\"first_name\", \"last_name\", \"gender\")\n     * values (?, ?, ?) -- This is a comment\n     * ```\n     */\n    modifyEnd(modifier) {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, modifier.toOperationNode()),\n        });\n    }\n    /**\n     * Changes an `insert into` query to an `insert ignore into` query.\n     *\n     * This is only supported by some dialects like MySQL.\n     *\n     * To avoid a footgun, when invoked with the SQLite dialect, this method will\n     * be handled like {@link orIgnore}. See also, {@link orAbort}, {@link orFail},\n     * {@link orReplace}, and {@link orRollback}.\n     *\n     * If you use the ignore modifier, ignorable errors that occur while executing the\n     * insert statement are ignored. For example, without ignore, a row that duplicates\n     * an existing unique index or primary key value in the table causes a duplicate-key\n     * error and the statement is aborted. With ignore, the row is discarded and no error\n     * occurs.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.insertInto('person')\n     *   .ignore()\n     *   .values({\n     *     first_name: 'John',\n     *     last_name: 'Doe',\n     *     gender: 'female',\n     *   })\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * insert ignore into `person` (`first_name`, `last_name`, `gender`) values (?, ?, ?)\n     * ```\n     *\n     * The generated SQL (SQLite):\n     *\n     * ```sql\n     * insert or ignore into \"person\" (\"first_name\", \"last_name\", \"gender\") values (?, ?, ?)\n     * ```\n     */\n    ignore() {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n                orAction: OrActionNode.create('ignore'),\n            }),\n        });\n    }\n    /**\n     * Changes an `insert into` query to an `insert or ignore into` query.\n     *\n     * This is only supported by some dialects like SQLite.\n     *\n     * To avoid a footgun, when invoked with the MySQL dialect, this method will\n     * be handled like {@link ignore}.\n     *\n     * See also, {@link orAbort}, {@link orFail}, {@link orReplace}, and {@link orRollback}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.insertInto('person')\n     *   .orIgnore()\n     *   .values({\n     *     first_name: 'John',\n     *     last_name: 'Doe',\n     *     gender: 'female',\n     *   })\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (SQLite):\n     *\n     * ```sql\n     * insert or ignore into \"person\" (\"first_name\", \"last_name\", \"gender\") values (?, ?, ?)\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * insert ignore into `person` (`first_name`, `last_name`, `gender`) values (?, ?, ?)\n     * ```\n     */\n    orIgnore() {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n                orAction: OrActionNode.create('ignore'),\n            }),\n        });\n    }\n    /**\n     * Changes an `insert into` query to an `insert or abort into` query.\n     *\n     * This is only supported by some dialects like SQLite.\n     *\n     * See also, {@link orIgnore}, {@link orFail}, {@link orReplace}, and {@link orRollback}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.insertInto('person')\n     *   .orAbort()\n     *   .values({\n     *     first_name: 'John',\n     *     last_name: 'Doe',\n     *     gender: 'female',\n     *   })\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (SQLite):\n     *\n     * ```sql\n     * insert or abort into \"person\" (\"first_name\", \"last_name\", \"gender\") values (?, ?, ?)\n     * ```\n     */\n    orAbort() {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n                orAction: OrActionNode.create('abort'),\n            }),\n        });\n    }\n    /**\n     * Changes an `insert into` query to an `insert or fail into` query.\n     *\n     * This is only supported by some dialects like SQLite.\n     *\n     * See also, {@link orIgnore}, {@link orAbort}, {@link orReplace}, and {@link orRollback}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.insertInto('person')\n     *   .orFail()\n     *   .values({\n     *     first_name: 'John',\n     *     last_name: 'Doe',\n     *     gender: 'female',\n     *   })\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (SQLite):\n     *\n     * ```sql\n     * insert or fail into \"person\" (\"first_name\", \"last_name\", \"gender\") values (?, ?, ?)\n     * ```\n     */\n    orFail() {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n                orAction: OrActionNode.create('fail'),\n            }),\n        });\n    }\n    /**\n     * Changes an `insert into` query to an `insert or replace into` query.\n     *\n     * This is only supported by some dialects like SQLite.\n     *\n     * You can also use {@link Kysely.replaceInto} to achieve the same result.\n     *\n     * See also, {@link orIgnore}, {@link orAbort}, {@link orFail}, and {@link orRollback}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.insertInto('person')\n     *   .orReplace()\n     *   .values({\n     *     first_name: 'John',\n     *     last_name: 'Doe',\n     *     gender: 'female',\n     *   })\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (SQLite):\n     *\n     * ```sql\n     * insert or replace into \"person\" (\"first_name\", \"last_name\", \"gender\") values (?, ?, ?)\n     * ```\n     */\n    orReplace() {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n                orAction: OrActionNode.create('replace'),\n            }),\n        });\n    }\n    /**\n     * Changes an `insert into` query to an `insert or rollback into` query.\n     *\n     * This is only supported by some dialects like SQLite.\n     *\n     * See also, {@link orIgnore}, {@link orAbort}, {@link orFail}, and {@link orReplace}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.insertInto('person')\n     *   .orRollback()\n     *   .values({\n     *     first_name: 'John',\n     *     last_name: 'Doe',\n     *     gender: 'female',\n     *   })\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (SQLite):\n     *\n     * ```sql\n     * insert or rollback into \"person\" (\"first_name\", \"last_name\", \"gender\") values (?, ?, ?)\n     * ```\n     */\n    orRollback() {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n                orAction: OrActionNode.create('rollback'),\n            }),\n        });\n    }\n    /**\n     * Changes an `insert into` query to an `insert top into` query.\n     *\n     * `top` clause is only supported by some dialects like MS SQL Server.\n     *\n     * ### Examples\n     *\n     * Insert the first 5 rows:\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * await db.insertInto('person')\n     *   .top(5)\n     *   .columns(['first_name', 'gender'])\n     *   .expression(\n     *     (eb) => eb.selectFrom('pet').select(['name', sql.lit('other').as('gender')])\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MS SQL Server):\n     *\n     * ```sql\n     * insert top(5) into \"person\" (\"first_name\", \"gender\") select \"name\", 'other' as \"gender\" from \"pet\"\n     * ```\n     *\n     * Insert the first 50 percent of rows:\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * await db.insertInto('person')\n     *   .top(50, 'percent')\n     *   .columns(['first_name', 'gender'])\n     *   .expression(\n     *     (eb) => eb.selectFrom('pet').select(['name', sql.lit('other').as('gender')])\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MS SQL Server):\n     *\n     * ```sql\n     * insert top(50) percent into \"person\" (\"first_name\", \"gender\") select \"name\", 'other' as \"gender\" from \"pet\"\n     * ```\n     */\n    top(expression, modifiers) {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithTop(this.#props.queryNode, parseTop(expression, modifiers)),\n        });\n    }\n    /**\n     * Adds an `on conflict` clause to the query.\n     *\n     * `on conflict` is only supported by some dialects like PostgreSQL and SQLite. On MySQL\n     * you can use {@link ignore} and {@link onDuplicateKeyUpdate} to achieve similar results.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db\n     *   .insertInto('pet')\n     *   .values({\n     *     name: 'Catto',\n     *     species: 'cat',\n     *     owner_id: 3,\n     *   })\n     *   .onConflict((oc) => oc\n     *     .column('name')\n     *     .doUpdateSet({ species: 'hamster' })\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"pet\" (\"name\", \"species\", \"owner_id\")\n     * values ($1, $2, $3)\n     * on conflict (\"name\")\n     * do update set \"species\" = $4\n     * ```\n     *\n     * You can provide the name of the constraint instead of a column name:\n     *\n     * ```ts\n     * await db\n     *   .insertInto('pet')\n     *   .values({\n     *     name: 'Catto',\n     *     species: 'cat',\n     *     owner_id: 3,\n     *   })\n     *   .onConflict((oc) => oc\n     *     .constraint('pet_name_key')\n     *     .doUpdateSet({ species: 'hamster' })\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"pet\" (\"name\", \"species\", \"owner_id\")\n     * values ($1, $2, $3)\n     * on conflict on constraint \"pet_name_key\"\n     * do update set \"species\" = $4\n     * ```\n     *\n     * You can also specify an expression as the conflict target in case\n     * the unique index is an expression index:\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * await db\n     *   .insertInto('pet')\n     *   .values({\n     *     name: 'Catto',\n     *     species: 'cat',\n     *     owner_id: 3,\n     *   })\n     *   .onConflict((oc) => oc\n     *     .expression(sql<string>`lower(name)`)\n     *     .doUpdateSet({ species: 'hamster' })\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"pet\" (\"name\", \"species\", \"owner_id\")\n     * values ($1, $2, $3)\n     * on conflict (lower(name))\n     * do update set \"species\" = $4\n     * ```\n     *\n     * You can add a filter for the update statement like this:\n     *\n     * ```ts\n     * await db\n     *   .insertInto('pet')\n     *   .values({\n     *     name: 'Catto',\n     *     species: 'cat',\n     *     owner_id: 3,\n     *   })\n     *   .onConflict((oc) => oc\n     *     .column('name')\n     *     .doUpdateSet({ species: 'hamster' })\n     *     .where('excluded.name', '!=', 'Catto')\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"pet\" (\"name\", \"species\", \"owner_id\")\n     * values ($1, $2, $3)\n     * on conflict (\"name\")\n     * do update set \"species\" = $4\n     * where \"excluded\".\"name\" != $5\n     * ```\n     *\n     * You can create an `on conflict do nothing` clauses like this:\n     *\n     * ```ts\n     * await db\n     *   .insertInto('pet')\n     *   .values({\n     *     name: 'Catto',\n     *     species: 'cat',\n     *     owner_id: 3,\n     *   })\n     *   .onConflict((oc) => oc\n     *     .column('name')\n     *     .doNothing()\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"pet\" (\"name\", \"species\", \"owner_id\")\n     * values ($1, $2, $3)\n     * on conflict (\"name\") do nothing\n     * ```\n     *\n     * You can refer to the columns of the virtual `excluded` table\n     * in a type-safe way using a callback and the `ref` method of\n     * `ExpressionBuilder`:\n     *\n     * ```ts\n     * await db.insertInto('person')\n     *   .values({\n     *     id: 1,\n     *     first_name: 'John',\n     *     last_name: 'Doe',\n     *     gender: 'male',\n     *   })\n     *   .onConflict(oc => oc\n     *     .column('id')\n     *     .doUpdateSet({\n     *       first_name: (eb) => eb.ref('excluded.first_name'),\n     *       last_name: (eb) => eb.ref('excluded.last_name')\n     *     })\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * insert into \"person\" (\"id\", \"first_name\", \"last_name\", \"gender\")\n     * values ($1, $2, $3, $4)\n     * on conflict (\"id\")\n     * do update set\n     *  \"first_name\" = \"excluded\".\"first_name\",\n     *  \"last_name\" = \"excluded\".\"last_name\"\n     * ```\n     */\n    onConflict(callback) {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n                onConflict: callback(new OnConflictBuilder({\n                    onConflictNode: OnConflictNode.create(),\n                })).toOperationNode(),\n            }),\n        });\n    }\n    /**\n     * Adds `on duplicate key update` to the query.\n     *\n     * If you specify `on duplicate key update`, and a row is inserted that would cause\n     * a duplicate value in a unique index or primary key, an update of the old row occurs.\n     *\n     * This is only implemented by some dialects like MySQL. On most dialects you should\n     * use {@link onConflict} instead.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db\n     *   .insertInto('person')\n     *   .values({\n     *     id: 1,\n     *     first_name: 'John',\n     *     last_name: 'Doe',\n     *     gender: 'male',\n     *   })\n     *   .onDuplicateKeyUpdate({ updated_at: new Date().toISOString() })\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * insert into `person` (`id`, `first_name`, `last_name`, `gender`)\n     * values (?, ?, ?, ?)\n     * on duplicate key update `updated_at` = ?\n     * ```\n     */\n    onDuplicateKeyUpdate(update) {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n                onDuplicateKey: OnDuplicateKeyNode.create(parseUpdateObjectExpression(update)),\n            }),\n        });\n    }\n    returning(selection) {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectArg(selection)),\n        });\n    }\n    returningAll() {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectAll()),\n        });\n    }\n    output(args) {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectArg(args)),\n        });\n    }\n    outputAll(table) {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectAll(table)),\n        });\n    }\n    /**\n     * Clears all `returning` clauses from the query.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.insertInto('person')\n     *   .values({ first_name: 'James', last_name: 'Smith', gender: 'male' })\n     *   .returning(['first_name'])\n     *   .clearReturning()\n     *   .execute()\n     * ```\n     *\n     * The generated SQL(PostgreSQL):\n     *\n     * ```sql\n     * insert into \"person\" (\"first_name\", \"last_name\", \"gender\") values ($1, $2, $3)\n     * ```\n     */\n    clearReturning() {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithoutReturning(this.#props.queryNode),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     *\n     * If you want to conditionally call a method on `this`, see\n     * the {@link $if} method.\n     *\n     * ### Examples\n     *\n     * The next example uses a helper function `log` to log a query:\n     *\n     * ```ts\n     * import type { Compilable } from 'kysely'\n     *\n     * function log<T extends Compilable>(qb: T): T {\n     *   console.log(qb.compile())\n     *   return qb\n     * }\n     *\n     * await db.insertInto('person')\n     *   .values({ first_name: 'John', last_name: 'Doe', gender: 'male' })\n     *   .$call(log)\n     *   .execute()\n     * ```\n     */\n    $call(func) {\n        return func(this);\n    }\n    /**\n     * Call `func(this)` if `condition` is true.\n     *\n     * This method is especially handy with optional selects. Any `returning` or `returningAll`\n     * method calls add columns as optional fields to the output type when called inside\n     * the `func` callback. This is because we can't know if those selections were actually\n     * made before running the code.\n     *\n     * You can also call any other methods inside the callback.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import type { NewPerson } from 'type-editor' // imaginary module\n     *\n     * async function insertPerson(values: NewPerson, returnLastName: boolean) {\n     *   return await db\n     *     .insertInto('person')\n     *     .values(values)\n     *     .returning(['id', 'first_name'])\n     *     .$if(returnLastName, (qb) => qb.returning('last_name'))\n     *     .executeTakeFirstOrThrow()\n     * }\n     * ```\n     *\n     * Any selections added inside the `if` callback will be added as optional fields to the\n     * output type since we can't know if the selections were actually made before running\n     * the code. In the example above the return type of the `insertPerson` function is:\n     *\n     * ```ts\n     * Promise<{\n     *   id: number\n     *   first_name: string\n     *   last_name?: string\n     * }>\n     * ```\n     */\n    $if(condition, func) {\n        if (condition) {\n            return func(this);\n        }\n        return new InsertQueryBuilder({\n            ...this.#props,\n        });\n    }\n    /**\n     * Change the output type of the query.\n     *\n     * This method call doesn't change the SQL in any way. This methods simply\n     * returns a copy of this `InsertQueryBuilder` with a new output type.\n     */\n    $castTo() {\n        return new InsertQueryBuilder(this.#props);\n    }\n    /**\n     * Narrows (parts of) the output type of the query.\n     *\n     * Kysely tries to be as type-safe as possible, but in some cases we have to make\n     * compromises for better maintainability and compilation performance. At present,\n     * Kysely doesn't narrow the output type of the query based on {@link values} input\n     * when using {@link returning} or {@link returningAll}.\n     *\n     * This utility method is very useful for these situations, as it removes unncessary\n     * runtime assertion/guard code. Its input type is limited to the output type\n     * of the query, so you can't add a column that doesn't exist, or change a column's\n     * type to something that doesn't exist in its union type.\n     *\n     * ### Examples\n     *\n     * Turn this code:\n     *\n     * ```ts\n     * import type { Person } from 'type-editor' // imaginary module\n     *\n     * const person = await db.insertInto('person')\n     *   .values({\n     *     first_name: 'John',\n     *     last_name: 'Doe',\n     *     gender: 'male',\n     *     nullable_column: 'hell yeah!'\n     *   })\n     *   .returningAll()\n     *   .executeTakeFirstOrThrow()\n     *\n     * if (isWithNoNullValue(person)) {\n     *   functionThatExpectsPersonWithNonNullValue(person)\n     * }\n     *\n     * function isWithNoNullValue(person: Person): person is Person & { nullable_column: string } {\n     *   return person.nullable_column != null\n     * }\n     * ```\n     *\n     * Into this:\n     *\n     * ```ts\n     * import type { NotNull } from 'kysely'\n     *\n     * const person = await db.insertInto('person')\n     *   .values({\n     *     first_name: 'John',\n     *     last_name: 'Doe',\n     *     gender: 'male',\n     *     nullable_column: 'hell yeah!'\n     *   })\n     *   .returningAll()\n     *   .$narrowType<{ nullable_column: NotNull }>()\n     *   .executeTakeFirstOrThrow()\n     *\n     * functionThatExpectsPersonWithNonNullValue(person)\n     * ```\n     */\n    $narrowType() {\n        return new InsertQueryBuilder(this.#props);\n    }\n    /**\n     * Asserts that query's output row type equals the given type `T`.\n     *\n     * This method can be used to simplify excessively complex types to make TypeScript happy\n     * and much faster.\n     *\n     * Kysely uses complex type magic to achieve its type safety. This complexity is sometimes too much\n     * for TypeScript and you get errors like this:\n     *\n     * ```\n     * error TS2589: Type instantiation is excessively deep and possibly infinite.\n     * ```\n     *\n     * In these case you can often use this method to help TypeScript a little bit. When you use this\n     * method to assert the output type of a query, Kysely can drop the complex output type that\n     * consists of multiple nested helper types and replace it with the simple asserted type.\n     *\n     * Using this method doesn't reduce type safety at all. You have to pass in a type that is\n     * structurally equal to the current type.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import type { NewPerson, NewPet, Species } from 'type-editor' // imaginary module\n     *\n     * async function insertPersonAndPet(person: NewPerson, pet: Omit<NewPet, 'owner_id'>) {\n     *   return await db\n     *     .with('new_person', (qb) => qb\n     *       .insertInto('person')\n     *       .values(person)\n     *       .returning('id')\n     *       .$assertType<{ id: number }>()\n     *     )\n     *     .with('new_pet', (qb) => qb\n     *       .insertInto('pet')\n     *       .values((eb) => ({\n     *         owner_id: eb.selectFrom('new_person').select('id'),\n     *         ...pet\n     *       }))\n     *       .returning(['name as pet_name', 'species'])\n     *       .$assertType<{ pet_name: string, species: Species }>()\n     *     )\n     *     .selectFrom(['new_person', 'new_pet'])\n     *     .selectAll()\n     *     .executeTakeFirstOrThrow()\n     * }\n     * ```\n     */\n    $assertType() {\n        return new InsertQueryBuilder(this.#props);\n    }\n    /**\n     * Returns a copy of this InsertQueryBuilder instance with the given plugin installed.\n     */\n    withPlugin(plugin) {\n        return new InsertQueryBuilder({\n            ...this.#props,\n            executor: this.#props.executor.withPlugin(plugin),\n        });\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.queryNode, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    /**\n     * Executes the query and returns an array of rows.\n     *\n     * Also see the {@link executeTakeFirst} and {@link executeTakeFirstOrThrow} methods.\n     */\n    async execute() {\n        const compiledQuery = this.compile();\n        const result = await this.#props.executor.executeQuery(compiledQuery, this.#props.queryId);\n        const { adapter } = this.#props.executor;\n        const query = compiledQuery.query;\n        if ((query.returning && adapter.supportsReturning) ||\n            (query.output && adapter.supportsOutput)) {\n            return result.rows;\n        }\n        return [\n            new InsertResult(result.insertId, result.numAffectedRows ?? BigInt(0)),\n        ];\n    }\n    /**\n     * Executes the query and returns the first result or undefined if\n     * the query returned no result.\n     */\n    async executeTakeFirst() {\n        const [result] = await this.execute();\n        return result;\n    }\n    /**\n     * Executes the query and returns the first result or throws if\n     * the query returned no result.\n     *\n     * By default an instance of {@link NoResultError} is thrown, but you can\n     * provide a custom error class, or callback as the only argument to throw a different\n     * error.\n     */\n    async executeTakeFirstOrThrow(errorConstructor = NoResultError) {\n        const result = await this.executeTakeFirst();\n        if (result === undefined) {\n            const error = isNoResultErrorConstructor(errorConstructor)\n                ? new errorConstructor(this.toOperationNode())\n                : errorConstructor(this.toOperationNode());\n            throw error;\n        }\n        return result;\n    }\n    async *stream(chunkSize = 100) {\n        const compiledQuery = this.compile();\n        const stream = this.#props.executor.stream(compiledQuery, chunkSize, this.#props.queryId);\n        for await (const item of stream) {\n            yield* item.rows;\n        }\n    }\n    async explain(format, options) {\n        const builder = new InsertQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithExplain(this.#props.queryNode, format, options),\n        });\n        return await builder.execute();\n    }\n}\n", "/// <reference types=\"./delete-result.d.ts\" />\nexport class DeleteResult {\n    numDeletedRows;\n    constructor(numDeletedRows) {\n        this.numDeletedRows = numDeletedRows;\n    }\n}\n", "/// <reference types=\"./limit-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const LimitNode = freeze({\n    is(node) {\n        return node.kind === 'LimitNode';\n    },\n    create(limit) {\n        return freeze({\n            kind: 'LimitNode',\n            limit,\n        });\n    },\n});\n", "/// <reference types=\"./delete-query-builder.d.ts\" />\nimport { parseJoin, } from '../parser/join-parser.js';\nimport { parseTableExpressionOrList, } from '../parser/table-parser.js';\nimport { parseSelectArg, parseSelectAll, } from '../parser/select-parser.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { freeze } from '../util/object-utils.js';\nimport { isNoResultErrorConstructor, NoResultError, } from './no-result-error.js';\nimport { DeleteResult } from './delete-result.js';\nimport { DeleteQueryNode } from '../operation-node/delete-query-node.js';\nimport { LimitNode } from '../operation-node/limit-node.js';\nimport { parseOrderBy, } from '../parser/order-by-parser.js';\nimport { parseValueBinaryOperationOrExpression, parseReferentialBinaryOperation, } from '../parser/binary-operation-parser.js';\nimport { parseValueExpression, } from '../parser/value-parser.js';\nimport { parseTop } from '../parser/top-parser.js';\nexport class DeleteQueryBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    where(...args) {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithWhere(this.#props.queryNode, parseValueBinaryOperationOrExpression(args)),\n        });\n    }\n    whereRef(lhs, op, rhs) {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithWhere(this.#props.queryNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n        });\n    }\n    clearWhere() {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithoutWhere(this.#props.queryNode),\n        });\n    }\n    /**\n     * Changes a `delete from` query into a `delete top from` query.\n     *\n     * `top` clause is only supported by some dialects like MS SQL Server.\n     *\n     * ### Examples\n     *\n     * Delete the first 5 rows:\n     *\n     * ```ts\n     * await db\n     *   .deleteFrom('person')\n     *   .top(5)\n     *   .where('age', '>', 18)\n     *   .executeTakeFirstOrThrow()\n     * ```\n     *\n     * The generated SQL (MS SQL Server):\n     *\n     * ```sql\n     * delete top(5) from \"person\" where \"age\" > @1\n     * ```\n     *\n     * Delete the first 50% of rows:\n     *\n     * ```ts\n     * await db\n     *   .deleteFrom('person')\n     *   .top(50, 'percent')\n     *   .where('age', '>', 18)\n     *   .executeTakeFirstOrThrow()\n     * ```\n     *\n     * The generated SQL (MS SQL Server):\n     *\n     * ```sql\n     * delete top(50) percent from \"person\" where \"age\" > @1\n     * ```\n     */\n    top(expression, modifiers) {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithTop(this.#props.queryNode, parseTop(expression, modifiers)),\n        });\n    }\n    using(tables) {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: DeleteQueryNode.cloneWithUsing(this.#props.queryNode, parseTableExpressionOrList(tables)),\n        });\n    }\n    innerJoin(...args) {\n        return this.#join('InnerJoin', args);\n    }\n    leftJoin(...args) {\n        return this.#join('LeftJoin', args);\n    }\n    rightJoin(...args) {\n        return this.#join('RightJoin', args);\n    }\n    fullJoin(...args) {\n        return this.#join('FullJoin', args);\n    }\n    #join(joinType, args) {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithJoin(this.#props.queryNode, parseJoin(joinType, args)),\n        });\n    }\n    returning(selection) {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectArg(selection)),\n        });\n    }\n    returningAll(table) {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectAll(table)),\n        });\n    }\n    output(args) {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectArg(args)),\n        });\n    }\n    outputAll(table) {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectAll(table)),\n        });\n    }\n    /**\n     * Clears all `returning` clauses from the query.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.deleteFrom('pet')\n     *   .returningAll()\n     *   .where('name', '=', 'Max')\n     *   .clearReturning()\n     *   .execute()\n     * ```\n     *\n     * The generated SQL(PostgreSQL):\n     *\n     * ```sql\n     * delete from \"pet\" where \"name\" = \"Max\"\n     * ```\n     */\n    clearReturning() {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithoutReturning(this.#props.queryNode),\n        });\n    }\n    /**\n     * Clears the `limit` clause from the query.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.deleteFrom('pet')\n     *   .returningAll()\n     *   .where('name', '=', 'Max')\n     *   .limit(5)\n     *   .clearLimit()\n     *   .execute()\n     * ```\n     *\n     * The generated SQL(PostgreSQL):\n     *\n     * ```sql\n     * delete from \"pet\" where \"name\" = \"Max\" returning *\n     * ```\n     */\n    clearLimit() {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: DeleteQueryNode.cloneWithoutLimit(this.#props.queryNode),\n        });\n    }\n    orderBy(...args) {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithOrderByItems(this.#props.queryNode, parseOrderBy(args)),\n        });\n    }\n    clearOrderBy() {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithoutOrderBy(this.#props.queryNode),\n        });\n    }\n    /**\n     * Adds a limit clause to the query.\n     *\n     * A limit clause in a delete query is only supported by some dialects\n     * like MySQL.\n     *\n     * ### Examples\n     *\n     * Delete 5 oldest items in a table:\n     *\n     * ```ts\n     * await db\n     *   .deleteFrom('pet')\n     *   .orderBy('created_at')\n     *   .limit(5)\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * delete from `pet` order by `created_at` limit ?\n     * ```\n     */\n    limit(limit) {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: DeleteQueryNode.cloneWithLimit(this.#props.queryNode, LimitNode.create(parseValueExpression(limit))),\n        });\n    }\n    /**\n     * This can be used to add any additional SQL to the end of the query.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * await db.deleteFrom('person')\n     *   .where('first_name', '=', 'John')\n     *   .modifyEnd(sql`-- This is a comment`)\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * delete from `person`\n     * where `first_name` = \"John\" -- This is a comment\n     * ```\n     */\n    modifyEnd(modifier) {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, modifier.toOperationNode()),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     *\n     * If you want to conditionally call a method on `this`, see\n     * the {@link $if} method.\n     *\n     * ### Examples\n     *\n     * The next example uses a helper function `log` to log a query:\n     *\n     * ```ts\n     * import type { Compilable } from 'kysely'\n     *\n     * function log<T extends Compilable>(qb: T): T {\n     *   console.log(qb.compile())\n     *   return qb\n     * }\n     *\n     * await db.deleteFrom('person')\n     *   .$call(log)\n     *   .execute()\n     * ```\n     */\n    $call(func) {\n        return func(this);\n    }\n    /**\n     * Call `func(this)` if `condition` is true.\n     *\n     * This method is especially handy with optional selects. Any `returning` or `returningAll`\n     * method calls add columns as optional fields to the output type when called inside\n     * the `func` callback. This is because we can't know if those selections were actually\n     * made before running the code.\n     *\n     * You can also call any other methods inside the callback.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * async function deletePerson(id: number, returnLastName: boolean) {\n     *   return await db\n     *     .deleteFrom('person')\n     *     .where('id', '=', id)\n     *     .returning(['id', 'first_name'])\n     *     .$if(returnLastName, (qb) => qb.returning('last_name'))\n     *     .executeTakeFirstOrThrow()\n     * }\n     * ```\n     *\n     * Any selections added inside the `if` callback will be added as optional fields to the\n     * output type since we can't know if the selections were actually made before running\n     * the code. In the example above the return type of the `deletePerson` function is:\n     *\n     * ```ts\n     * Promise<{\n     *   id: number\n     *   first_name: string\n     *   last_name?: string\n     * }>\n     * ```\n     */\n    $if(condition, func) {\n        if (condition) {\n            return func(this);\n        }\n        return new DeleteQueryBuilder({\n            ...this.#props,\n        });\n    }\n    /**\n     * Change the output type of the query.\n     *\n     * This method call doesn't change the SQL in any way. This methods simply\n     * returns a copy of this `DeleteQueryBuilder` with a new output type.\n     */\n    $castTo() {\n        return new DeleteQueryBuilder(this.#props);\n    }\n    /**\n     * Narrows (parts of) the output type of the query.\n     *\n     * Kysely tries to be as type-safe as possible, but in some cases we have to make\n     * compromises for better maintainability and compilation performance. At present,\n     * Kysely doesn't narrow the output type of the query when using {@link where} and {@link returning} or {@link returningAll}.\n     *\n     * This utility method is very useful for these situations, as it removes unncessary\n     * runtime assertion/guard code. Its input type is limited to the output type\n     * of the query, so you can't add a column that doesn't exist, or change a column's\n     * type to something that doesn't exist in its union type.\n     *\n     * ### Examples\n     *\n     * Turn this code:\n     *\n     * ```ts\n     * import type { Person } from 'type-editor' // imaginary module\n     *\n     * const person = await db.deleteFrom('person')\n     *   .where('id', '=', 3)\n     *   .where('nullable_column', 'is not', null)\n     *   .returningAll()\n     *   .executeTakeFirstOrThrow()\n     *\n     * if (isWithNoNullValue(person)) {\n     *   functionThatExpectsPersonWithNonNullValue(person)\n     * }\n     *\n     * function isWithNoNullValue(person: Person): person is Person & { nullable_column: string } {\n     *   return person.nullable_column != null\n     * }\n     * ```\n     *\n     * Into this:\n     *\n     * ```ts\n     * import type { NotNull } from 'kysely'\n     *\n     * const person = await db.deleteFrom('person')\n     *   .where('id', '=', 3)\n     *   .where('nullable_column', 'is not', null)\n     *   .returningAll()\n     *   .$narrowType<{ nullable_column: NotNull }>()\n     *   .executeTakeFirstOrThrow()\n     *\n     * functionThatExpectsPersonWithNonNullValue(person)\n     * ```\n     */\n    $narrowType() {\n        return new DeleteQueryBuilder(this.#props);\n    }\n    /**\n     * Asserts that query's output row type equals the given type `T`.\n     *\n     * This method can be used to simplify excessively complex types to make TypeScript happy\n     * and much faster.\n     *\n     * Kysely uses complex type magic to achieve its type safety. This complexity is sometimes too much\n     * for TypeScript and you get errors like this:\n     *\n     * ```\n     * error TS2589: Type instantiation is excessively deep and possibly infinite.\n     * ```\n     *\n     * In these case you can often use this method to help TypeScript a little bit. When you use this\n     * method to assert the output type of a query, Kysely can drop the complex output type that\n     * consists of multiple nested helper types and replace it with the simple asserted type.\n     *\n     * Using this method doesn't reduce type safety at all. You have to pass in a type that is\n     * structurally equal to the current type.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import type { Species } from 'type-editor' // imaginary module\n     *\n     * async function deletePersonAndPets(personId: number) {\n     *   return await db\n     *     .with('deleted_person', (qb) => qb\n     *        .deleteFrom('person')\n     *        .where('id', '=', personId)\n     *        .returning('first_name')\n     *        .$assertType<{ first_name: string }>()\n     *     )\n     *     .with('deleted_pets', (qb) => qb\n     *       .deleteFrom('pet')\n     *       .where('owner_id', '=', personId)\n     *       .returning(['name as pet_name', 'species'])\n     *       .$assertType<{ pet_name: string, species: Species }>()\n     *     )\n     *     .selectFrom(['deleted_person', 'deleted_pets'])\n     *     .selectAll()\n     *     .execute()\n     * }\n     * ```\n     */\n    $assertType() {\n        return new DeleteQueryBuilder(this.#props);\n    }\n    /**\n     * Returns a copy of this DeleteQueryBuilder instance with the given plugin installed.\n     */\n    withPlugin(plugin) {\n        return new DeleteQueryBuilder({\n            ...this.#props,\n            executor: this.#props.executor.withPlugin(plugin),\n        });\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.queryNode, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    /**\n     * Executes the query and returns an array of rows.\n     *\n     * Also see the {@link executeTakeFirst} and {@link executeTakeFirstOrThrow} methods.\n     */\n    async execute() {\n        const compiledQuery = this.compile();\n        const result = await this.#props.executor.executeQuery(compiledQuery, this.#props.queryId);\n        const { adapter } = this.#props.executor;\n        const query = compiledQuery.query;\n        if ((query.returning && adapter.supportsReturning) ||\n            (query.output && adapter.supportsOutput)) {\n            return result.rows;\n        }\n        return [new DeleteResult(result.numAffectedRows ?? BigInt(0))];\n    }\n    /**\n     * Executes the query and returns the first result or undefined if\n     * the query returned no result.\n     */\n    async executeTakeFirst() {\n        const [result] = await this.execute();\n        return result;\n    }\n    /**\n     * Executes the query and returns the first result or throws if\n     * the query returned no result.\n     *\n     * By default an instance of {@link NoResultError} is thrown, but you can\n     * provide a custom error class, or callback as the only argument to throw a different\n     * error.\n     */\n    async executeTakeFirstOrThrow(errorConstructor = NoResultError) {\n        const result = await this.executeTakeFirst();\n        if (result === undefined) {\n            const error = isNoResultErrorConstructor(errorConstructor)\n                ? new errorConstructor(this.toOperationNode())\n                : errorConstructor(this.toOperationNode());\n            throw error;\n        }\n        return result;\n    }\n    async *stream(chunkSize = 100) {\n        const compiledQuery = this.compile();\n        const stream = this.#props.executor.stream(compiledQuery, chunkSize, this.#props.queryId);\n        for await (const item of stream) {\n            yield* item.rows;\n        }\n    }\n    async explain(format, options) {\n        const builder = new DeleteQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithExplain(this.#props.queryNode, format, options),\n        });\n        return await builder.execute();\n    }\n}\n", "/// <reference types=\"./update-result.d.ts\" />\nexport class UpdateResult {\n    /**\n     * The number of rows the update query updated (even if not changed).\n     */\n    numUpdatedRows;\n    /**\n     * The number of rows the update query changed.\n     *\n     * This is **optional** and only supported in dialects such as MySQL.\n     * You would probably use {@link numUpdatedRows} in most cases.\n     */\n    numChangedRows;\n    constructor(numUpdatedRows, numChangedRows) {\n        this.numUpdatedRows = numUpdatedRows;\n        this.numChangedRows = numChangedRows;\n    }\n}\n", "/// <reference types=\"./update-query-builder.d.ts\" />\nimport { parseJoin, } from '../parser/join-parser.js';\nimport { parseTableExpressionOrList, } from '../parser/table-parser.js';\nimport { parseSelectArg, parseSelectAll, } from '../parser/select-parser.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { UpdateQueryNode } from '../operation-node/update-query-node.js';\nimport { parseUpdate, } from '../parser/update-set-parser.js';\nimport { freeze } from '../util/object-utils.js';\nimport { UpdateResult } from './update-result.js';\nimport { isNoResultErrorConstructor, NoResultError, } from './no-result-error.js';\nimport { parseReferentialBinaryOperation, parseValueBinaryOperationOrExpression, } from '../parser/binary-operation-parser.js';\nimport { parseValueExpression, } from '../parser/value-parser.js';\nimport { LimitNode } from '../operation-node/limit-node.js';\nimport { parseTop } from '../parser/top-parser.js';\nimport { parseOrderBy, } from '../parser/order-by-parser.js';\nexport class UpdateQueryBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    where(...args) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithWhere(this.#props.queryNode, parseValueBinaryOperationOrExpression(args)),\n        });\n    }\n    whereRef(lhs, op, rhs) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithWhere(this.#props.queryNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n        });\n    }\n    clearWhere() {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithoutWhere(this.#props.queryNode),\n        });\n    }\n    /**\n     * Changes an `update` query into a `update top` query.\n     *\n     * `top` clause is only supported by some dialects like MS SQL Server.\n     *\n     * ### Examples\n     *\n     * Update the first row:\n     *\n     * ```ts\n     * await db.updateTable('person')\n     *   .top(1)\n     *   .set({ first_name: 'Foo' })\n     *   .where('age', '>', 18)\n     *   .executeTakeFirstOrThrow()\n     * ```\n     *\n     * The generated SQL (MS SQL Server):\n     *\n     * ```sql\n     * update top(1) \"person\" set \"first_name\" = @1 where \"age\" > @2\n     * ```\n     *\n     * Update the 50% first rows:\n     *\n     * ```ts\n     * await db.updateTable('person')\n     *   .top(50, 'percent')\n     *   .set({ first_name: 'Foo' })\n     *   .where('age', '>', 18)\n     *   .executeTakeFirstOrThrow()\n     * ```\n     *\n     * The generated SQL (MS SQL Server):\n     *\n     * ```sql\n     * update top(50) percent \"person\" set \"first_name\" = @1 where \"age\" > @2\n     * ```\n     */\n    top(expression, modifiers) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithTop(this.#props.queryNode, parseTop(expression, modifiers)),\n        });\n    }\n    from(from) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: UpdateQueryNode.cloneWithFromItems(this.#props.queryNode, parseTableExpressionOrList(from)),\n        });\n    }\n    innerJoin(...args) {\n        return this.#join('InnerJoin', args);\n    }\n    leftJoin(...args) {\n        return this.#join('LeftJoin', args);\n    }\n    rightJoin(...args) {\n        return this.#join('RightJoin', args);\n    }\n    fullJoin(...args) {\n        return this.#join('FullJoin', args);\n    }\n    #join(joinType, args) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithJoin(this.#props.queryNode, parseJoin(joinType, args)),\n        });\n    }\n    orderBy(...args) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithOrderByItems(this.#props.queryNode, parseOrderBy(args)),\n        });\n    }\n    clearOrderBy() {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithoutOrderBy(this.#props.queryNode),\n        });\n    }\n    /**\n     * Adds a limit clause to the update query for supported databases, such as MySQL.\n     *\n     * ### Examples\n     *\n     * Update the first 2 rows in the 'person' table:\n     *\n     * ```ts\n     * await db\n     *   .updateTable('person')\n     *   .set({ first_name: 'Foo' })\n     *   .limit(2)\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * update `person` set `first_name` = ? limit ?\n     * ```\n     */\n    limit(limit) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: UpdateQueryNode.cloneWithLimit(this.#props.queryNode, LimitNode.create(parseValueExpression(limit))),\n        });\n    }\n    set(...args) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: UpdateQueryNode.cloneWithUpdates(this.#props.queryNode, parseUpdate(...args)),\n        });\n    }\n    returning(selection) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectArg(selection)),\n        });\n    }\n    returningAll(table) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectAll(table)),\n        });\n    }\n    output(args) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectArg(args)),\n        });\n    }\n    outputAll(table) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectAll(table)),\n        });\n    }\n    /**\n     * This can be used to add any additional SQL to the end of the query.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * await db.updateTable('person')\n     *   .set({ age: 39 })\n     *   .where('first_name', '=', 'John')\n     *   .modifyEnd(sql.raw('-- This is a comment'))\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * update `person`\n     * set `age` = 39\n     * where `first_name` = \"John\" -- This is a comment\n     * ```\n     */\n    modifyEnd(modifier) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, modifier.toOperationNode()),\n        });\n    }\n    /**\n     * Clears all `returning` clauses from the query.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * db.updateTable('person')\n     *   .returningAll()\n     *   .set({ age: 39 })\n     *   .where('first_name', '=', 'John')\n     *   .clearReturning()\n     * ```\n     *\n     * The generated SQL(PostgreSQL):\n     *\n     * ```sql\n     * update \"person\" set \"age\" = 39 where \"first_name\" = \"John\"\n     * ```\n     */\n    clearReturning() {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithoutReturning(this.#props.queryNode),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     *\n     * If you want to conditionally call a method on `this`, see\n     * the {@link $if} method.\n     *\n     * ### Examples\n     *\n     * The next example uses a helper function `log` to log a query:\n     *\n     * ```ts\n     * import type { Compilable } from 'kysely'\n     * import type { PersonUpdate } from 'type-editor' // imaginary module\n     *\n     * function log<T extends Compilable>(qb: T): T {\n     *   console.log(qb.compile())\n     *   return qb\n     * }\n     *\n     * const values = {\n     *   first_name: 'John',\n     * } satisfies PersonUpdate\n     *\n     * db.updateTable('person')\n     *   .set(values)\n     *   .$call(log)\n     *   .execute()\n     * ```\n     */\n    $call(func) {\n        return func(this);\n    }\n    /**\n     * Call `func(this)` if `condition` is true.\n     *\n     * This method is especially handy with optional selects. Any `returning` or `returningAll`\n     * method calls add columns as optional fields to the output type when called inside\n     * the `func` callback. This is because we can't know if those selections were actually\n     * made before running the code.\n     *\n     * You can also call any other methods inside the callback.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import type { PersonUpdate } from 'type-editor' // imaginary module\n     *\n     * async function updatePerson(id: number, updates: PersonUpdate, returnLastName: boolean) {\n     *   return await db\n     *     .updateTable('person')\n     *     .set(updates)\n     *     .where('id', '=', id)\n     *     .returning(['id', 'first_name'])\n     *     .$if(returnLastName, (qb) => qb.returning('last_name'))\n     *     .executeTakeFirstOrThrow()\n     * }\n     * ```\n     *\n     * Any selections added inside the `if` callback will be added as optional fields to the\n     * output type since we can't know if the selections were actually made before running\n     * the code. In the example above the return type of the `updatePerson` function is:\n     *\n     * ```ts\n     * Promise<{\n     *   id: number\n     *   first_name: string\n     *   last_name?: string\n     * }>\n     * ```\n     */\n    $if(condition, func) {\n        if (condition) {\n            return func(this);\n        }\n        return new UpdateQueryBuilder({\n            ...this.#props,\n        });\n    }\n    /**\n     * Change the output type of the query.\n     *\n     * This method call doesn't change the SQL in any way. This methods simply\n     * returns a copy of this `UpdateQueryBuilder` with a new output type.\n     */\n    $castTo() {\n        return new UpdateQueryBuilder(this.#props);\n    }\n    /**\n     * Narrows (parts of) the output type of the query.\n     *\n     * Kysely tries to be as type-safe as possible, but in some cases we have to make\n     * compromises for better maintainability and compilation performance. At present,\n     * Kysely doesn't narrow the output type of the query based on {@link set} input\n     * when using {@link where} and/or {@link returning} or {@link returningAll}.\n     *\n     * This utility method is very useful for these situations, as it removes unncessary\n     * runtime assertion/guard code. Its input type is limited to the output type\n     * of the query, so you can't add a column that doesn't exist, or change a column's\n     * type to something that doesn't exist in its union type.\n     *\n     * ### Examples\n     *\n     * Turn this code:\n     *\n     * ```ts\n     * import type { Person } from 'type-editor' // imaginary module\n     *\n     * const id = 1\n     * const now = new Date().toISOString()\n     *\n     * const person = await db.updateTable('person')\n     *   .set({ deleted_at: now })\n     *   .where('id', '=', id)\n     *   .where('nullable_column', 'is not', null)\n     *   .returningAll()\n     *   .executeTakeFirstOrThrow()\n     *\n     * if (isWithNoNullValue(person)) {\n     *   functionThatExpectsPersonWithNonNullValue(person)\n     * }\n     *\n     * function isWithNoNullValue(person: Person): person is Person & { nullable_column: string } {\n     *   return person.nullable_column != null\n     * }\n     * ```\n     *\n     * Into this:\n     *\n     * ```ts\n     * import type { NotNull } from 'kysely'\n     *\n     * const id = 1\n     * const now = new Date().toISOString()\n     *\n     * const person = await db.updateTable('person')\n     *   .set({ deleted_at: now })\n     *   .where('id', '=', id)\n     *   .where('nullable_column', 'is not', null)\n     *   .returningAll()\n     *   .$narrowType<{ deleted_at: Date; nullable_column: NotNull }>()\n     *   .executeTakeFirstOrThrow()\n     *\n     * functionThatExpectsPersonWithNonNullValue(person)\n     * ```\n     */\n    $narrowType() {\n        return new UpdateQueryBuilder(this.#props);\n    }\n    /**\n     * Asserts that query's output row type equals the given type `T`.\n     *\n     * This method can be used to simplify excessively complex types to make TypeScript happy\n     * and much faster.\n     *\n     * Kysely uses complex type magic to achieve its type safety. This complexity is sometimes too much\n     * for TypeScript and you get errors like this:\n     *\n     * ```\n     * error TS2589: Type instantiation is excessively deep and possibly infinite.\n     * ```\n     *\n     * In these case you can often use this method to help TypeScript a little bit. When you use this\n     * method to assert the output type of a query, Kysely can drop the complex output type that\n     * consists of multiple nested helper types and replace it with the simple asserted type.\n     *\n     * Using this method doesn't reduce type safety at all. You have to pass in a type that is\n     * structurally equal to the current type.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import type { PersonUpdate, PetUpdate, Species } from 'type-editor' // imaginary module\n     *\n     * const person = {\n     *   id: 1,\n     *   gender: 'other',\n     * } satisfies PersonUpdate\n     *\n     * const pet = {\n     *   name: 'Fluffy',\n     * } satisfies PetUpdate\n     *\n     * const result = await db\n     *   .with('updated_person', (qb) => qb\n     *     .updateTable('person')\n     *     .set(person)\n     *     .where('id', '=', person.id)\n     *     .returning('first_name')\n     *     .$assertType<{ first_name: string }>()\n     *   )\n     *   .with('updated_pet', (qb) => qb\n     *     .updateTable('pet')\n     *     .set(pet)\n     *     .where('owner_id', '=', person.id)\n     *     .returning(['name as pet_name', 'species'])\n     *     .$assertType<{ pet_name: string, species: Species }>()\n     *   )\n     *   .selectFrom(['updated_person', 'updated_pet'])\n     *   .selectAll()\n     *   .executeTakeFirstOrThrow()\n     * ```\n     */\n    $assertType() {\n        return new UpdateQueryBuilder(this.#props);\n    }\n    /**\n     * Returns a copy of this UpdateQueryBuilder instance with the given plugin installed.\n     */\n    withPlugin(plugin) {\n        return new UpdateQueryBuilder({\n            ...this.#props,\n            executor: this.#props.executor.withPlugin(plugin),\n        });\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.queryNode, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    /**\n     * Executes the query and returns an array of rows.\n     *\n     * Also see the {@link executeTakeFirst} and {@link executeTakeFirstOrThrow} methods.\n     */\n    async execute() {\n        const compiledQuery = this.compile();\n        const result = await this.#props.executor.executeQuery(compiledQuery, this.#props.queryId);\n        const { adapter } = this.#props.executor;\n        const query = compiledQuery.query;\n        if ((query.returning && adapter.supportsReturning) ||\n            (query.output && adapter.supportsOutput)) {\n            return result.rows;\n        }\n        return [\n            new UpdateResult(result.numAffectedRows ?? BigInt(0), result.numChangedRows),\n        ];\n    }\n    /**\n     * Executes the query and returns the first result or undefined if\n     * the query returned no result.\n     */\n    async executeTakeFirst() {\n        const [result] = await this.execute();\n        return result;\n    }\n    /**\n     * Executes the query and returns the first result or throws if\n     * the query returned no result.\n     *\n     * By default an instance of {@link NoResultError} is thrown, but you can\n     * provide a custom error class, or callback as the only argument to throw a different\n     * error.\n     */\n    async executeTakeFirstOrThrow(errorConstructor = NoResultError) {\n        const result = await this.executeTakeFirst();\n        if (result === undefined) {\n            const error = isNoResultErrorConstructor(errorConstructor)\n                ? new errorConstructor(this.toOperationNode())\n                : errorConstructor(this.toOperationNode());\n            throw error;\n        }\n        return result;\n    }\n    async *stream(chunkSize = 100) {\n        const compiledQuery = this.compile();\n        const stream = this.#props.executor.stream(compiledQuery, chunkSize, this.#props.queryId);\n        for await (const item of stream) {\n            yield* item.rows;\n        }\n    }\n    async explain(format, options) {\n        const builder = new UpdateQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithExplain(this.#props.queryNode, format, options),\n        });\n        return await builder.execute();\n    }\n}\n", "/// <reference types=\"./common-table-expression-name-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { ColumnNode } from './column-node.js';\nimport { TableNode } from './table-node.js';\n/**\n * @internal\n */\nexport const CommonTableExpressionNameNode = freeze({\n    is(node) {\n        return node.kind === 'CommonTableExpressionNameNode';\n    },\n    create(tableName, columnNames) {\n        return freeze({\n            kind: 'CommonTableExpressionNameNode',\n            table: TableNode.create(tableName),\n            columns: columnNames\n                ? freeze(columnNames.map(ColumnNode.create))\n                : undefined,\n        });\n    },\n});\n", "/// <reference types=\"./common-table-expression-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const CommonTableExpressionNode = freeze({\n    is(node) {\n        return node.kind === 'CommonTableExpressionNode';\n    },\n    create(name, expression) {\n        return freeze({\n            kind: 'CommonTableExpressionNode',\n            name,\n            expression,\n        });\n    },\n    cloneWith(node, props) {\n        return freeze({\n            ...node,\n            ...props,\n        });\n    },\n});\n", "/// <reference types=\"./cte-builder.d.ts\" />\nimport { CommonTableExpressionNode } from '../operation-node/common-table-expression-node.js';\nimport { freeze } from '../util/object-utils.js';\nexport class CTEBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * Makes the common table expression materialized.\n     */\n    materialized() {\n        return new CTEBuilder({\n            ...this.#props,\n            node: CommonTableExpressionNode.cloneWith(this.#props.node, {\n                materialized: true,\n            }),\n        });\n    }\n    /**\n     * Makes the common table expression not materialized.\n     */\n    notMaterialized() {\n        return new CTEBuilder({\n            ...this.#props,\n            node: CommonTableExpressionNode.cloneWith(this.#props.node, {\n                materialized: false,\n            }),\n        });\n    }\n    toOperationNode() {\n        return this.#props.node;\n    }\n}\n", "/// <reference types=\"./with-parser.d.ts\" />\nimport { CommonTableExpressionNameNode } from '../operation-node/common-table-expression-name-node.js';\nimport { createQueryCreator } from './parse-utils.js';\nimport { isFunction } from '../util/object-utils.js';\nimport { CTEBuilder } from '../query-builder/cte-builder.js';\nimport { CommonTableExpressionNode } from '../operation-node/common-table-expression-node.js';\nexport function parseCommonTableExpression(nameOrBuilderCallback, expression) {\n    const expressionNode = expression(createQueryCreator()).toOperationNode();\n    if (isFunction(nameOrBuilderCallback)) {\n        return nameOrBuilderCallback(cteBuilderFactory(expressionNode)).toOperationNode();\n    }\n    return CommonTableExpressionNode.create(parseCommonTableExpressionName(nameOrBuilderCallback), expressionNode);\n}\nfunction cteBuilderFactory(expressionNode) {\n    return (name) => {\n        return new CTEBuilder({\n            node: CommonTableExpressionNode.create(parseCommonTableExpressionName(name), expressionNode),\n        });\n    };\n}\nfunction parseCommonTableExpressionName(name) {\n    if (name.includes('(')) {\n        const parts = name.split(/[\\(\\)]/);\n        const table = parts[0];\n        const columns = parts[1].split(',').map((it) => it.trim());\n        return CommonTableExpressionNameNode.create(table, columns);\n    }\n    else {\n        return CommonTableExpressionNameNode.create(name);\n    }\n}\n", "/// <reference types=\"./with-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const WithNode = freeze({\n    is(node) {\n        return node.kind === 'WithNode';\n    },\n    create(expression, params) {\n        return freeze({\n            kind: 'WithNode',\n            expressions: freeze([expression]),\n            ...params,\n        });\n    },\n    cloneWithExpression(withNode, expression) {\n        return freeze({\n            ...withNode,\n            expressions: freeze([...withNode.expressions, expression]),\n        });\n    },\n});\n", "/// <reference types=\"./random-string.d.ts\" />\nconst CHARS = [\n    'A',\n    'B',\n    'C',\n    'D',\n    'E',\n    'F',\n    'G',\n    'H',\n    'I',\n    'J',\n    'K',\n    'L',\n    'M',\n    'N',\n    'O',\n    'P',\n    'Q',\n    'R',\n    'S',\n    'T',\n    'U',\n    'V',\n    'W',\n    'X',\n    'Y',\n    'Z',\n    'a',\n    'b',\n    'c',\n    'd',\n    'e',\n    'f',\n    'g',\n    'h',\n    'i',\n    'j',\n    'k',\n    'l',\n    'm',\n    'n',\n    'o',\n    'p',\n    'q',\n    'r',\n    's',\n    't',\n    'u',\n    'v',\n    'w',\n    'x',\n    'y',\n    'z',\n    '0',\n    '1',\n    '2',\n    '3',\n    '4',\n    '5',\n    '6',\n    '7',\n    '8',\n    '9',\n];\nexport function randomString(length) {\n    let chars = '';\n    for (let i = 0; i < length; ++i) {\n        chars += randomChar();\n    }\n    return chars;\n}\nfunction randomChar() {\n    return CHARS[~~(Math.random() * CHARS.length)];\n}\n", "/// <reference types=\"./query-id.d.ts\" />\nimport { randomString } from './random-string.js';\nexport function createQueryId() {\n    return new LazyQueryId();\n}\nclass LazyQueryId {\n    #queryId;\n    get queryId() {\n        if (this.#queryId === undefined) {\n            this.#queryId = randomString(8);\n        }\n        return this.#queryId;\n    }\n}\n", "/// <reference types=\"./operation-node-transformer.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { requireAllProps } from '../util/require-all-props.js';\n/**\n * Transforms an operation node tree into another one.\n *\n * Kysely queries are expressed internally as a tree of objects (operation nodes).\n * `OperationNodeTransformer` takes such a tree as its input and returns a\n * transformed deep copy of it. By default the `OperationNodeTransformer`\n * does nothing. You need to override one or more methods to make it do\n * something.\n *\n * There's a method for each node type. For example if you'd like to convert\n * each identifier (table name, column name, alias etc.) from camelCase to\n * snake_case, you'd do something like this:\n *\n * ```ts\n * import { type IdentifierNode, OperationNodeTransformer } from 'kysely'\n * import snakeCase from 'lodash/snakeCase'\n *\n * class CamelCaseTransformer extends OperationNodeTransformer {\n *   override transformIdentifier(node: IdentifierNode): IdentifierNode {\n *     node = super.transformIdentifier(node)\n *\n *     return {\n *       ...node,\n *       name: snakeCase(node.name),\n *     }\n *   }\n * }\n *\n * const transformer = new CamelCaseTransformer()\n *\n * const query = db.selectFrom('person').select(['first_name', 'last_name'])\n *\n * const tree = transformer.transformNode(query.toOperationNode())\n * ```\n */\nexport class OperationNodeTransformer {\n    nodeStack = [];\n    #transformers = freeze({\n        AliasNode: this.transformAlias.bind(this),\n        ColumnNode: this.transformColumn.bind(this),\n        IdentifierNode: this.transformIdentifier.bind(this),\n        SchemableIdentifierNode: this.transformSchemableIdentifier.bind(this),\n        RawNode: this.transformRaw.bind(this),\n        ReferenceNode: this.transformReference.bind(this),\n        SelectQueryNode: this.transformSelectQuery.bind(this),\n        SelectionNode: this.transformSelection.bind(this),\n        TableNode: this.transformTable.bind(this),\n        FromNode: this.transformFrom.bind(this),\n        SelectAllNode: this.transformSelectAll.bind(this),\n        AndNode: this.transformAnd.bind(this),\n        OrNode: this.transformOr.bind(this),\n        ValueNode: this.transformValue.bind(this),\n        ValueListNode: this.transformValueList.bind(this),\n        PrimitiveValueListNode: this.transformPrimitiveValueList.bind(this),\n        ParensNode: this.transformParens.bind(this),\n        JoinNode: this.transformJoin.bind(this),\n        OperatorNode: this.transformOperator.bind(this),\n        WhereNode: this.transformWhere.bind(this),\n        InsertQueryNode: this.transformInsertQuery.bind(this),\n        DeleteQueryNode: this.transformDeleteQuery.bind(this),\n        ReturningNode: this.transformReturning.bind(this),\n        CreateTableNode: this.transformCreateTable.bind(this),\n        AddColumnNode: this.transformAddColumn.bind(this),\n        ColumnDefinitionNode: this.transformColumnDefinition.bind(this),\n        DropTableNode: this.transformDropTable.bind(this),\n        DataTypeNode: this.transformDataType.bind(this),\n        OrderByNode: this.transformOrderBy.bind(this),\n        OrderByItemNode: this.transformOrderByItem.bind(this),\n        GroupByNode: this.transformGroupBy.bind(this),\n        GroupByItemNode: this.transformGroupByItem.bind(this),\n        UpdateQueryNode: this.transformUpdateQuery.bind(this),\n        ColumnUpdateNode: this.transformColumnUpdate.bind(this),\n        LimitNode: this.transformLimit.bind(this),\n        OffsetNode: this.transformOffset.bind(this),\n        OnConflictNode: this.transformOnConflict.bind(this),\n        OnDuplicateKeyNode: this.transformOnDuplicateKey.bind(this),\n        CreateIndexNode: this.transformCreateIndex.bind(this),\n        DropIndexNode: this.transformDropIndex.bind(this),\n        ListNode: this.transformList.bind(this),\n        PrimaryKeyConstraintNode: this.transformPrimaryKeyConstraint.bind(this),\n        UniqueConstraintNode: this.transformUniqueConstraint.bind(this),\n        ReferencesNode: this.transformReferences.bind(this),\n        CheckConstraintNode: this.transformCheckConstraint.bind(this),\n        WithNode: this.transformWith.bind(this),\n        CommonTableExpressionNode: this.transformCommonTableExpression.bind(this),\n        CommonTableExpressionNameNode: this.transformCommonTableExpressionName.bind(this),\n        HavingNode: this.transformHaving.bind(this),\n        CreateSchemaNode: this.transformCreateSchema.bind(this),\n        DropSchemaNode: this.transformDropSchema.bind(this),\n        AlterTableNode: this.transformAlterTable.bind(this),\n        DropColumnNode: this.transformDropColumn.bind(this),\n        RenameColumnNode: this.transformRenameColumn.bind(this),\n        AlterColumnNode: this.transformAlterColumn.bind(this),\n        ModifyColumnNode: this.transformModifyColumn.bind(this),\n        AddConstraintNode: this.transformAddConstraint.bind(this),\n        DropConstraintNode: this.transformDropConstraint.bind(this),\n        RenameConstraintNode: this.transformRenameConstraint.bind(this),\n        ForeignKeyConstraintNode: this.transformForeignKeyConstraint.bind(this),\n        CreateViewNode: this.transformCreateView.bind(this),\n        RefreshMaterializedViewNode: this.transformRefreshMaterializedView.bind(this),\n        DropViewNode: this.transformDropView.bind(this),\n        GeneratedNode: this.transformGenerated.bind(this),\n        DefaultValueNode: this.transformDefaultValue.bind(this),\n        OnNode: this.transformOn.bind(this),\n        ValuesNode: this.transformValues.bind(this),\n        SelectModifierNode: this.transformSelectModifier.bind(this),\n        CreateTypeNode: this.transformCreateType.bind(this),\n        DropTypeNode: this.transformDropType.bind(this),\n        ExplainNode: this.transformExplain.bind(this),\n        DefaultInsertValueNode: this.transformDefaultInsertValue.bind(this),\n        AggregateFunctionNode: this.transformAggregateFunction.bind(this),\n        OverNode: this.transformOver.bind(this),\n        PartitionByNode: this.transformPartitionBy.bind(this),\n        PartitionByItemNode: this.transformPartitionByItem.bind(this),\n        SetOperationNode: this.transformSetOperation.bind(this),\n        BinaryOperationNode: this.transformBinaryOperation.bind(this),\n        UnaryOperationNode: this.transformUnaryOperation.bind(this),\n        UsingNode: this.transformUsing.bind(this),\n        FunctionNode: this.transformFunction.bind(this),\n        CaseNode: this.transformCase.bind(this),\n        WhenNode: this.transformWhen.bind(this),\n        JSONReferenceNode: this.transformJSONReference.bind(this),\n        JSONPathNode: this.transformJSONPath.bind(this),\n        JSONPathLegNode: this.transformJSONPathLeg.bind(this),\n        JSONOperatorChainNode: this.transformJSONOperatorChain.bind(this),\n        TupleNode: this.transformTuple.bind(this),\n        MergeQueryNode: this.transformMergeQuery.bind(this),\n        MatchedNode: this.transformMatched.bind(this),\n        AddIndexNode: this.transformAddIndex.bind(this),\n        CastNode: this.transformCast.bind(this),\n        FetchNode: this.transformFetch.bind(this),\n        TopNode: this.transformTop.bind(this),\n        OutputNode: this.transformOutput.bind(this),\n        OrActionNode: this.transformOrAction.bind(this),\n        CollateNode: this.transformCollate.bind(this),\n    });\n    transformNode(node, queryId) {\n        if (!node) {\n            return node;\n        }\n        this.nodeStack.push(node);\n        const out = this.transformNodeImpl(node, queryId);\n        this.nodeStack.pop();\n        return freeze(out);\n    }\n    transformNodeImpl(node, queryId) {\n        return this.#transformers[node.kind](node, queryId);\n    }\n    transformNodeList(list, queryId) {\n        if (!list) {\n            return list;\n        }\n        return freeze(list.map((node) => this.transformNode(node, queryId)));\n    }\n    transformSelectQuery(node, queryId) {\n        return requireAllProps({\n            kind: 'SelectQueryNode',\n            from: this.transformNode(node.from, queryId),\n            selections: this.transformNodeList(node.selections, queryId),\n            distinctOn: this.transformNodeList(node.distinctOn, queryId),\n            joins: this.transformNodeList(node.joins, queryId),\n            groupBy: this.transformNode(node.groupBy, queryId),\n            orderBy: this.transformNode(node.orderBy, queryId),\n            where: this.transformNode(node.where, queryId),\n            frontModifiers: this.transformNodeList(node.frontModifiers, queryId),\n            endModifiers: this.transformNodeList(node.endModifiers, queryId),\n            limit: this.transformNode(node.limit, queryId),\n            offset: this.transformNode(node.offset, queryId),\n            with: this.transformNode(node.with, queryId),\n            having: this.transformNode(node.having, queryId),\n            explain: this.transformNode(node.explain, queryId),\n            setOperations: this.transformNodeList(node.setOperations, queryId),\n            fetch: this.transformNode(node.fetch, queryId),\n            top: this.transformNode(node.top, queryId),\n        });\n    }\n    transformSelection(node, queryId) {\n        return requireAllProps({\n            kind: 'SelectionNode',\n            selection: this.transformNode(node.selection, queryId),\n        });\n    }\n    transformColumn(node, queryId) {\n        return requireAllProps({\n            kind: 'ColumnNode',\n            column: this.transformNode(node.column, queryId),\n        });\n    }\n    transformAlias(node, queryId) {\n        return requireAllProps({\n            kind: 'AliasNode',\n            node: this.transformNode(node.node, queryId),\n            alias: this.transformNode(node.alias, queryId),\n        });\n    }\n    transformTable(node, queryId) {\n        return requireAllProps({\n            kind: 'TableNode',\n            table: this.transformNode(node.table, queryId),\n        });\n    }\n    transformFrom(node, queryId) {\n        return requireAllProps({\n            kind: 'FromNode',\n            froms: this.transformNodeList(node.froms, queryId),\n        });\n    }\n    transformReference(node, queryId) {\n        return requireAllProps({\n            kind: 'ReferenceNode',\n            column: this.transformNode(node.column, queryId),\n            table: this.transformNode(node.table, queryId),\n        });\n    }\n    transformAnd(node, queryId) {\n        return requireAllProps({\n            kind: 'AndNode',\n            left: this.transformNode(node.left, queryId),\n            right: this.transformNode(node.right, queryId),\n        });\n    }\n    transformOr(node, queryId) {\n        return requireAllProps({\n            kind: 'OrNode',\n            left: this.transformNode(node.left, queryId),\n            right: this.transformNode(node.right, queryId),\n        });\n    }\n    transformValueList(node, queryId) {\n        return requireAllProps({\n            kind: 'ValueListNode',\n            values: this.transformNodeList(node.values, queryId),\n        });\n    }\n    transformParens(node, queryId) {\n        return requireAllProps({\n            kind: 'ParensNode',\n            node: this.transformNode(node.node, queryId),\n        });\n    }\n    transformJoin(node, queryId) {\n        return requireAllProps({\n            kind: 'JoinNode',\n            joinType: node.joinType,\n            table: this.transformNode(node.table, queryId),\n            on: this.transformNode(node.on, queryId),\n        });\n    }\n    transformRaw(node, queryId) {\n        return requireAllProps({\n            kind: 'RawNode',\n            sqlFragments: freeze([...node.sqlFragments]),\n            parameters: this.transformNodeList(node.parameters, queryId),\n        });\n    }\n    transformWhere(node, queryId) {\n        return requireAllProps({\n            kind: 'WhereNode',\n            where: this.transformNode(node.where, queryId),\n        });\n    }\n    transformInsertQuery(node, queryId) {\n        return requireAllProps({\n            kind: 'InsertQueryNode',\n            into: this.transformNode(node.into, queryId),\n            columns: this.transformNodeList(node.columns, queryId),\n            values: this.transformNode(node.values, queryId),\n            returning: this.transformNode(node.returning, queryId),\n            onConflict: this.transformNode(node.onConflict, queryId),\n            onDuplicateKey: this.transformNode(node.onDuplicateKey, queryId),\n            endModifiers: this.transformNodeList(node.endModifiers, queryId),\n            with: this.transformNode(node.with, queryId),\n            ignore: node.ignore,\n            orAction: this.transformNode(node.orAction, queryId),\n            replace: node.replace,\n            explain: this.transformNode(node.explain, queryId),\n            defaultValues: node.defaultValues,\n            top: this.transformNode(node.top, queryId),\n            output: this.transformNode(node.output, queryId),\n        });\n    }\n    transformValues(node, queryId) {\n        return requireAllProps({\n            kind: 'ValuesNode',\n            values: this.transformNodeList(node.values, queryId),\n        });\n    }\n    transformDeleteQuery(node, queryId) {\n        return requireAllProps({\n            kind: 'DeleteQueryNode',\n            from: this.transformNode(node.from, queryId),\n            using: this.transformNode(node.using, queryId),\n            joins: this.transformNodeList(node.joins, queryId),\n            where: this.transformNode(node.where, queryId),\n            returning: this.transformNode(node.returning, queryId),\n            endModifiers: this.transformNodeList(node.endModifiers, queryId),\n            with: this.transformNode(node.with, queryId),\n            orderBy: this.transformNode(node.orderBy, queryId),\n            limit: this.transformNode(node.limit, queryId),\n            explain: this.transformNode(node.explain, queryId),\n            top: this.transformNode(node.top, queryId),\n            output: this.transformNode(node.output, queryId),\n        });\n    }\n    transformReturning(node, queryId) {\n        return requireAllProps({\n            kind: 'ReturningNode',\n            selections: this.transformNodeList(node.selections, queryId),\n        });\n    }\n    transformCreateTable(node, queryId) {\n        return requireAllProps({\n            kind: 'CreateTableNode',\n            table: this.transformNode(node.table, queryId),\n            columns: this.transformNodeList(node.columns, queryId),\n            constraints: this.transformNodeList(node.constraints, queryId),\n            temporary: node.temporary,\n            ifNotExists: node.ifNotExists,\n            onCommit: node.onCommit,\n            frontModifiers: this.transformNodeList(node.frontModifiers, queryId),\n            endModifiers: this.transformNodeList(node.endModifiers, queryId),\n            selectQuery: this.transformNode(node.selectQuery, queryId),\n        });\n    }\n    transformColumnDefinition(node, queryId) {\n        return requireAllProps({\n            kind: 'ColumnDefinitionNode',\n            column: this.transformNode(node.column, queryId),\n            dataType: this.transformNode(node.dataType, queryId),\n            references: this.transformNode(node.references, queryId),\n            primaryKey: node.primaryKey,\n            autoIncrement: node.autoIncrement,\n            unique: node.unique,\n            notNull: node.notNull,\n            unsigned: node.unsigned,\n            defaultTo: this.transformNode(node.defaultTo, queryId),\n            check: this.transformNode(node.check, queryId),\n            generated: this.transformNode(node.generated, queryId),\n            frontModifiers: this.transformNodeList(node.frontModifiers, queryId),\n            endModifiers: this.transformNodeList(node.endModifiers, queryId),\n            nullsNotDistinct: node.nullsNotDistinct,\n            identity: node.identity,\n            ifNotExists: node.ifNotExists,\n        });\n    }\n    transformAddColumn(node, queryId) {\n        return requireAllProps({\n            kind: 'AddColumnNode',\n            column: this.transformNode(node.column, queryId),\n        });\n    }\n    transformDropTable(node, queryId) {\n        return requireAllProps({\n            kind: 'DropTableNode',\n            table: this.transformNode(node.table, queryId),\n            ifExists: node.ifExists,\n            cascade: node.cascade,\n        });\n    }\n    transformOrderBy(node, queryId) {\n        return requireAllProps({\n            kind: 'OrderByNode',\n            items: this.transformNodeList(node.items, queryId),\n        });\n    }\n    transformOrderByItem(node, queryId) {\n        return requireAllProps({\n            kind: 'OrderByItemNode',\n            orderBy: this.transformNode(node.orderBy, queryId),\n            direction: this.transformNode(node.direction, queryId),\n            collation: this.transformNode(node.collation, queryId),\n            nulls: node.nulls,\n        });\n    }\n    transformGroupBy(node, queryId) {\n        return requireAllProps({\n            kind: 'GroupByNode',\n            items: this.transformNodeList(node.items, queryId),\n        });\n    }\n    transformGroupByItem(node, queryId) {\n        return requireAllProps({\n            kind: 'GroupByItemNode',\n            groupBy: this.transformNode(node.groupBy, queryId),\n        });\n    }\n    transformUpdateQuery(node, queryId) {\n        return requireAllProps({\n            kind: 'UpdateQueryNode',\n            table: this.transformNode(node.table, queryId),\n            from: this.transformNode(node.from, queryId),\n            joins: this.transformNodeList(node.joins, queryId),\n            where: this.transformNode(node.where, queryId),\n            updates: this.transformNodeList(node.updates, queryId),\n            returning: this.transformNode(node.returning, queryId),\n            endModifiers: this.transformNodeList(node.endModifiers, queryId),\n            with: this.transformNode(node.with, queryId),\n            explain: this.transformNode(node.explain, queryId),\n            limit: this.transformNode(node.limit, queryId),\n            top: this.transformNode(node.top, queryId),\n            output: this.transformNode(node.output, queryId),\n            orderBy: this.transformNode(node.orderBy, queryId),\n        });\n    }\n    transformColumnUpdate(node, queryId) {\n        return requireAllProps({\n            kind: 'ColumnUpdateNode',\n            column: this.transformNode(node.column, queryId),\n            value: this.transformNode(node.value, queryId),\n        });\n    }\n    transformLimit(node, queryId) {\n        return requireAllProps({\n            kind: 'LimitNode',\n            limit: this.transformNode(node.limit, queryId),\n        });\n    }\n    transformOffset(node, queryId) {\n        return requireAllProps({\n            kind: 'OffsetNode',\n            offset: this.transformNode(node.offset, queryId),\n        });\n    }\n    transformOnConflict(node, queryId) {\n        return requireAllProps({\n            kind: 'OnConflictNode',\n            columns: this.transformNodeList(node.columns, queryId),\n            constraint: this.transformNode(node.constraint, queryId),\n            indexExpression: this.transformNode(node.indexExpression, queryId),\n            indexWhere: this.transformNode(node.indexWhere, queryId),\n            updates: this.transformNodeList(node.updates, queryId),\n            updateWhere: this.transformNode(node.updateWhere, queryId),\n            doNothing: node.doNothing,\n        });\n    }\n    transformOnDuplicateKey(node, queryId) {\n        return requireAllProps({\n            kind: 'OnDuplicateKeyNode',\n            updates: this.transformNodeList(node.updates, queryId),\n        });\n    }\n    transformCreateIndex(node, queryId) {\n        return requireAllProps({\n            kind: 'CreateIndexNode',\n            name: this.transformNode(node.name, queryId),\n            table: this.transformNode(node.table, queryId),\n            columns: this.transformNodeList(node.columns, queryId),\n            unique: node.unique,\n            using: this.transformNode(node.using, queryId),\n            ifNotExists: node.ifNotExists,\n            where: this.transformNode(node.where, queryId),\n            nullsNotDistinct: node.nullsNotDistinct,\n        });\n    }\n    transformList(node, queryId) {\n        return requireAllProps({\n            kind: 'ListNode',\n            items: this.transformNodeList(node.items, queryId),\n        });\n    }\n    transformDropIndex(node, queryId) {\n        return requireAllProps({\n            kind: 'DropIndexNode',\n            name: this.transformNode(node.name, queryId),\n            table: this.transformNode(node.table, queryId),\n            ifExists: node.ifExists,\n            cascade: node.cascade,\n        });\n    }\n    transformPrimaryKeyConstraint(node, queryId) {\n        return requireAllProps({\n            kind: 'PrimaryKeyConstraintNode',\n            columns: this.transformNodeList(node.columns, queryId),\n            name: this.transformNode(node.name, queryId),\n            deferrable: node.deferrable,\n            initiallyDeferred: node.initiallyDeferred,\n        });\n    }\n    transformUniqueConstraint(node, queryId) {\n        return requireAllProps({\n            kind: 'UniqueConstraintNode',\n            columns: this.transformNodeList(node.columns, queryId),\n            name: this.transformNode(node.name, queryId),\n            nullsNotDistinct: node.nullsNotDistinct,\n            deferrable: node.deferrable,\n            initiallyDeferred: node.initiallyDeferred,\n        });\n    }\n    transformForeignKeyConstraint(node, queryId) {\n        return requireAllProps({\n            kind: 'ForeignKeyConstraintNode',\n            columns: this.transformNodeList(node.columns, queryId),\n            references: this.transformNode(node.references, queryId),\n            name: this.transformNode(node.name, queryId),\n            onDelete: node.onDelete,\n            onUpdate: node.onUpdate,\n            deferrable: node.deferrable,\n            initiallyDeferred: node.initiallyDeferred,\n        });\n    }\n    transformSetOperation(node, queryId) {\n        return requireAllProps({\n            kind: 'SetOperationNode',\n            operator: node.operator,\n            expression: this.transformNode(node.expression, queryId),\n            all: node.all,\n        });\n    }\n    transformReferences(node, queryId) {\n        return requireAllProps({\n            kind: 'ReferencesNode',\n            table: this.transformNode(node.table, queryId),\n            columns: this.transformNodeList(node.columns, queryId),\n            onDelete: node.onDelete,\n            onUpdate: node.onUpdate,\n        });\n    }\n    transformCheckConstraint(node, queryId) {\n        return requireAllProps({\n            kind: 'CheckConstraintNode',\n            expression: this.transformNode(node.expression, queryId),\n            name: this.transformNode(node.name, queryId),\n        });\n    }\n    transformWith(node, queryId) {\n        return requireAllProps({\n            kind: 'WithNode',\n            expressions: this.transformNodeList(node.expressions, queryId),\n            recursive: node.recursive,\n        });\n    }\n    transformCommonTableExpression(node, queryId) {\n        return requireAllProps({\n            kind: 'CommonTableExpressionNode',\n            name: this.transformNode(node.name, queryId),\n            materialized: node.materialized,\n            expression: this.transformNode(node.expression, queryId),\n        });\n    }\n    transformCommonTableExpressionName(node, queryId) {\n        return requireAllProps({\n            kind: 'CommonTableExpressionNameNode',\n            table: this.transformNode(node.table, queryId),\n            columns: this.transformNodeList(node.columns, queryId),\n        });\n    }\n    transformHaving(node, queryId) {\n        return requireAllProps({\n            kind: 'HavingNode',\n            having: this.transformNode(node.having, queryId),\n        });\n    }\n    transformCreateSchema(node, queryId) {\n        return requireAllProps({\n            kind: 'CreateSchemaNode',\n            schema: this.transformNode(node.schema, queryId),\n            ifNotExists: node.ifNotExists,\n        });\n    }\n    transformDropSchema(node, queryId) {\n        return requireAllProps({\n            kind: 'DropSchemaNode',\n            schema: this.transformNode(node.schema, queryId),\n            ifExists: node.ifExists,\n            cascade: node.cascade,\n        });\n    }\n    transformAlterTable(node, queryId) {\n        return requireAllProps({\n            kind: 'AlterTableNode',\n            table: this.transformNode(node.table, queryId),\n            renameTo: this.transformNode(node.renameTo, queryId),\n            setSchema: this.transformNode(node.setSchema, queryId),\n            columnAlterations: this.transformNodeList(node.columnAlterations, queryId),\n            addConstraint: this.transformNode(node.addConstraint, queryId),\n            dropConstraint: this.transformNode(node.dropConstraint, queryId),\n            renameConstraint: this.transformNode(node.renameConstraint, queryId),\n            addIndex: this.transformNode(node.addIndex, queryId),\n            dropIndex: this.transformNode(node.dropIndex, queryId),\n        });\n    }\n    transformDropColumn(node, queryId) {\n        return requireAllProps({\n            kind: 'DropColumnNode',\n            column: this.transformNode(node.column, queryId),\n        });\n    }\n    transformRenameColumn(node, queryId) {\n        return requireAllProps({\n            kind: 'RenameColumnNode',\n            column: this.transformNode(node.column, queryId),\n            renameTo: this.transformNode(node.renameTo, queryId),\n        });\n    }\n    transformAlterColumn(node, queryId) {\n        return requireAllProps({\n            kind: 'AlterColumnNode',\n            column: this.transformNode(node.column, queryId),\n            dataType: this.transformNode(node.dataType, queryId),\n            dataTypeExpression: this.transformNode(node.dataTypeExpression, queryId),\n            setDefault: this.transformNode(node.setDefault, queryId),\n            dropDefault: node.dropDefault,\n            setNotNull: node.setNotNull,\n            dropNotNull: node.dropNotNull,\n        });\n    }\n    transformModifyColumn(node, queryId) {\n        return requireAllProps({\n            kind: 'ModifyColumnNode',\n            column: this.transformNode(node.column, queryId),\n        });\n    }\n    transformAddConstraint(node, queryId) {\n        return requireAllProps({\n            kind: 'AddConstraintNode',\n            constraint: this.transformNode(node.constraint, queryId),\n        });\n    }\n    transformDropConstraint(node, queryId) {\n        return requireAllProps({\n            kind: 'DropConstraintNode',\n            constraintName: this.transformNode(node.constraintName, queryId),\n            ifExists: node.ifExists,\n            modifier: node.modifier,\n        });\n    }\n    transformRenameConstraint(node, queryId) {\n        return requireAllProps({\n            kind: 'RenameConstraintNode',\n            oldName: this.transformNode(node.oldName, queryId),\n            newName: this.transformNode(node.newName, queryId),\n        });\n    }\n    transformCreateView(node, queryId) {\n        return requireAllProps({\n            kind: 'CreateViewNode',\n            name: this.transformNode(node.name, queryId),\n            temporary: node.temporary,\n            orReplace: node.orReplace,\n            ifNotExists: node.ifNotExists,\n            materialized: node.materialized,\n            columns: this.transformNodeList(node.columns, queryId),\n            as: this.transformNode(node.as, queryId),\n        });\n    }\n    transformRefreshMaterializedView(node, queryId) {\n        return requireAllProps({\n            kind: 'RefreshMaterializedViewNode',\n            name: this.transformNode(node.name, queryId),\n            concurrently: node.concurrently,\n            withNoData: node.withNoData,\n        });\n    }\n    transformDropView(node, queryId) {\n        return requireAllProps({\n            kind: 'DropViewNode',\n            name: this.transformNode(node.name, queryId),\n            ifExists: node.ifExists,\n            materialized: node.materialized,\n            cascade: node.cascade,\n        });\n    }\n    transformGenerated(node, queryId) {\n        return requireAllProps({\n            kind: 'GeneratedNode',\n            byDefault: node.byDefault,\n            always: node.always,\n            identity: node.identity,\n            stored: node.stored,\n            expression: this.transformNode(node.expression, queryId),\n        });\n    }\n    transformDefaultValue(node, queryId) {\n        return requireAllProps({\n            kind: 'DefaultValueNode',\n            defaultValue: this.transformNode(node.defaultValue, queryId),\n        });\n    }\n    transformOn(node, queryId) {\n        return requireAllProps({\n            kind: 'OnNode',\n            on: this.transformNode(node.on, queryId),\n        });\n    }\n    transformSelectModifier(node, queryId) {\n        return requireAllProps({\n            kind: 'SelectModifierNode',\n            modifier: node.modifier,\n            rawModifier: this.transformNode(node.rawModifier, queryId),\n            of: this.transformNodeList(node.of, queryId),\n        });\n    }\n    transformCreateType(node, queryId) {\n        return requireAllProps({\n            kind: 'CreateTypeNode',\n            name: this.transformNode(node.name, queryId),\n            enum: this.transformNode(node.enum, queryId),\n        });\n    }\n    transformDropType(node, queryId) {\n        return requireAllProps({\n            kind: 'DropTypeNode',\n            name: this.transformNode(node.name, queryId),\n            ifExists: node.ifExists,\n        });\n    }\n    transformExplain(node, queryId) {\n        return requireAllProps({\n            kind: 'ExplainNode',\n            format: node.format,\n            options: this.transformNode(node.options, queryId),\n        });\n    }\n    transformSchemableIdentifier(node, queryId) {\n        return requireAllProps({\n            kind: 'SchemableIdentifierNode',\n            schema: this.transformNode(node.schema, queryId),\n            identifier: this.transformNode(node.identifier, queryId),\n        });\n    }\n    transformAggregateFunction(node, queryId) {\n        return requireAllProps({\n            kind: 'AggregateFunctionNode',\n            func: node.func,\n            aggregated: this.transformNodeList(node.aggregated, queryId),\n            distinct: node.distinct,\n            orderBy: this.transformNode(node.orderBy, queryId),\n            withinGroup: this.transformNode(node.withinGroup, queryId),\n            filter: this.transformNode(node.filter, queryId),\n            over: this.transformNode(node.over, queryId),\n        });\n    }\n    transformOver(node, queryId) {\n        return requireAllProps({\n            kind: 'OverNode',\n            orderBy: this.transformNode(node.orderBy, queryId),\n            partitionBy: this.transformNode(node.partitionBy, queryId),\n        });\n    }\n    transformPartitionBy(node, queryId) {\n        return requireAllProps({\n            kind: 'PartitionByNode',\n            items: this.transformNodeList(node.items, queryId),\n        });\n    }\n    transformPartitionByItem(node, queryId) {\n        return requireAllProps({\n            kind: 'PartitionByItemNode',\n            partitionBy: this.transformNode(node.partitionBy, queryId),\n        });\n    }\n    transformBinaryOperation(node, queryId) {\n        return requireAllProps({\n            kind: 'BinaryOperationNode',\n            leftOperand: this.transformNode(node.leftOperand, queryId),\n            operator: this.transformNode(node.operator, queryId),\n            rightOperand: this.transformNode(node.rightOperand, queryId),\n        });\n    }\n    transformUnaryOperation(node, queryId) {\n        return requireAllProps({\n            kind: 'UnaryOperationNode',\n            operator: this.transformNode(node.operator, queryId),\n            operand: this.transformNode(node.operand, queryId),\n        });\n    }\n    transformUsing(node, queryId) {\n        return requireAllProps({\n            kind: 'UsingNode',\n            tables: this.transformNodeList(node.tables, queryId),\n        });\n    }\n    transformFunction(node, queryId) {\n        return requireAllProps({\n            kind: 'FunctionNode',\n            func: node.func,\n            arguments: this.transformNodeList(node.arguments, queryId),\n        });\n    }\n    transformCase(node, queryId) {\n        return requireAllProps({\n            kind: 'CaseNode',\n            value: this.transformNode(node.value, queryId),\n            when: this.transformNodeList(node.when, queryId),\n            else: this.transformNode(node.else, queryId),\n            isStatement: node.isStatement,\n        });\n    }\n    transformWhen(node, queryId) {\n        return requireAllProps({\n            kind: 'WhenNode',\n            condition: this.transformNode(node.condition, queryId),\n            result: this.transformNode(node.result, queryId),\n        });\n    }\n    transformJSONReference(node, queryId) {\n        return requireAllProps({\n            kind: 'JSONReferenceNode',\n            reference: this.transformNode(node.reference, queryId),\n            traversal: this.transformNode(node.traversal, queryId),\n        });\n    }\n    transformJSONPath(node, queryId) {\n        return requireAllProps({\n            kind: 'JSONPathNode',\n            inOperator: this.transformNode(node.inOperator, queryId),\n            pathLegs: this.transformNodeList(node.pathLegs, queryId),\n        });\n    }\n    transformJSONPathLeg(node, _queryId) {\n        return requireAllProps({\n            kind: 'JSONPathLegNode',\n            type: node.type,\n            value: node.value,\n        });\n    }\n    transformJSONOperatorChain(node, queryId) {\n        return requireAllProps({\n            kind: 'JSONOperatorChainNode',\n            operator: this.transformNode(node.operator, queryId),\n            values: this.transformNodeList(node.values, queryId),\n        });\n    }\n    transformTuple(node, queryId) {\n        return requireAllProps({\n            kind: 'TupleNode',\n            values: this.transformNodeList(node.values, queryId),\n        });\n    }\n    transformMergeQuery(node, queryId) {\n        return requireAllProps({\n            kind: 'MergeQueryNode',\n            into: this.transformNode(node.into, queryId),\n            using: this.transformNode(node.using, queryId),\n            whens: this.transformNodeList(node.whens, queryId),\n            with: this.transformNode(node.with, queryId),\n            top: this.transformNode(node.top, queryId),\n            endModifiers: this.transformNodeList(node.endModifiers, queryId),\n            output: this.transformNode(node.output, queryId),\n            returning: this.transformNode(node.returning, queryId),\n        });\n    }\n    transformMatched(node, _queryId) {\n        return requireAllProps({\n            kind: 'MatchedNode',\n            not: node.not,\n            bySource: node.bySource,\n        });\n    }\n    transformAddIndex(node, queryId) {\n        return requireAllProps({\n            kind: 'AddIndexNode',\n            name: this.transformNode(node.name, queryId),\n            columns: this.transformNodeList(node.columns, queryId),\n            unique: node.unique,\n            using: this.transformNode(node.using, queryId),\n            ifNotExists: node.ifNotExists,\n        });\n    }\n    transformCast(node, queryId) {\n        return requireAllProps({\n            kind: 'CastNode',\n            expression: this.transformNode(node.expression, queryId),\n            dataType: this.transformNode(node.dataType, queryId),\n        });\n    }\n    transformFetch(node, queryId) {\n        return requireAllProps({\n            kind: 'FetchNode',\n            rowCount: this.transformNode(node.rowCount, queryId),\n            modifier: node.modifier,\n        });\n    }\n    transformTop(node, _queryId) {\n        return requireAllProps({\n            kind: 'TopNode',\n            expression: node.expression,\n            modifiers: node.modifiers,\n        });\n    }\n    transformOutput(node, queryId) {\n        return requireAllProps({\n            kind: 'OutputNode',\n            selections: this.transformNodeList(node.selections, queryId),\n        });\n    }\n    transformDataType(node, _queryId) {\n        // An Object.freezed leaf node. No need to clone.\n        return node;\n    }\n    transformSelectAll(node, _queryId) {\n        // An Object.freezed leaf node. No need to clone.\n        return node;\n    }\n    transformIdentifier(node, _queryId) {\n        // An Object.freezed leaf node. No need to clone.\n        return node;\n    }\n    transformValue(node, _queryId) {\n        // An Object.freezed leaf node. No need to clone.\n        return node;\n    }\n    transformPrimitiveValueList(node, _queryId) {\n        // An Object.freezed leaf node. No need to clone.\n        return node;\n    }\n    transformOperator(node, _queryId) {\n        // An Object.freezed leaf node. No need to clone.\n        return node;\n    }\n    transformDefaultInsertValue(node, _queryId) {\n        // An Object.freezed leaf node. No need to clone.\n        return node;\n    }\n    transformOrAction(node, _queryId) {\n        // An Object.freezed leaf node. No need to clone.\n        return node;\n    }\n    transformCollate(node, _queryId) {\n        // An Object.freezed leaf node. No need to clone.\n        return node;\n    }\n}\n", "/// <reference types=\"./with-schema-transformer.d.ts\" />\nimport { AliasNode } from '../../operation-node/alias-node.js';\nimport { IdentifierNode } from '../../operation-node/identifier-node.js';\nimport { ListNode } from '../../operation-node/list-node.js';\nimport { OperationNodeTransformer } from '../../operation-node/operation-node-transformer.js';\nimport { SchemableIdentifierNode } from '../../operation-node/schemable-identifier-node.js';\nimport { TableNode } from '../../operation-node/table-node.js';\nimport { freeze } from '../../util/object-utils.js';\n// This object exist only so that we get a type error when a new RootOperationNode\n// is added. If you get a type error here, make sure to add the new root node and\n// handle it correctly in the transformer.\n//\n// DO NOT REFACTOR THIS EVEN IF IT SEEMS USELESS TO YOU!\nconst ROOT_OPERATION_NODES = freeze({\n    AlterTableNode: true,\n    CreateIndexNode: true,\n    CreateSchemaNode: true,\n    CreateTableNode: true,\n    CreateTypeNode: true,\n    CreateViewNode: true,\n    RefreshMaterializedViewNode: true,\n    DeleteQueryNode: true,\n    DropIndexNode: true,\n    DropSchemaNode: true,\n    DropTableNode: true,\n    DropTypeNode: true,\n    DropViewNode: true,\n    InsertQueryNode: true,\n    RawNode: true,\n    SelectQueryNode: true,\n    UpdateQueryNode: true,\n    MergeQueryNode: true,\n});\nconst SCHEMALESS_FUNCTIONS = {\n    json_agg: true,\n    to_json: true,\n};\nexport class WithSchemaTransformer extends OperationNodeTransformer {\n    #schema;\n    #schemableIds = new Set();\n    #ctes = new Set();\n    constructor(schema) {\n        super();\n        this.#schema = schema;\n    }\n    transformNodeImpl(node, queryId) {\n        if (!this.#isRootOperationNode(node)) {\n            return super.transformNodeImpl(node, queryId);\n        }\n        const ctes = this.#collectCTEs(node);\n        for (const cte of ctes) {\n            this.#ctes.add(cte);\n        }\n        const tables = this.#collectSchemableIds(node);\n        for (const table of tables) {\n            this.#schemableIds.add(table);\n        }\n        const transformed = super.transformNodeImpl(node, queryId);\n        for (const table of tables) {\n            this.#schemableIds.delete(table);\n        }\n        for (const cte of ctes) {\n            this.#ctes.delete(cte);\n        }\n        return transformed;\n    }\n    transformSchemableIdentifier(node, queryId) {\n        const transformed = super.transformSchemableIdentifier(node, queryId);\n        if (transformed.schema || !this.#schemableIds.has(node.identifier.name)) {\n            return transformed;\n        }\n        return {\n            ...transformed,\n            schema: IdentifierNode.create(this.#schema),\n        };\n    }\n    transformReferences(node, queryId) {\n        const transformed = super.transformReferences(node, queryId);\n        if (transformed.table.table.schema) {\n            return transformed;\n        }\n        return {\n            ...transformed,\n            table: TableNode.createWithSchema(this.#schema, transformed.table.table.identifier.name),\n        };\n    }\n    transformAggregateFunction(node, queryId) {\n        return {\n            ...super.transformAggregateFunction({ ...node, aggregated: [] }, queryId),\n            aggregated: this.#transformTableArgsWithoutSchemas(node, queryId, 'aggregated'),\n        };\n    }\n    transformFunction(node, queryId) {\n        return {\n            ...super.transformFunction({ ...node, arguments: [] }, queryId),\n            arguments: this.#transformTableArgsWithoutSchemas(node, queryId, 'arguments'),\n        };\n    }\n    #transformTableArgsWithoutSchemas(node, queryId, argsKey) {\n        return SCHEMALESS_FUNCTIONS[node.func]\n            ? node[argsKey].map((arg) => !TableNode.is(arg) || arg.table.schema\n                ? this.transformNode(arg, queryId)\n                : {\n                    ...arg,\n                    table: this.transformIdentifier(arg.table.identifier, queryId),\n                })\n            : this.transformNodeList(node[argsKey], queryId);\n    }\n    #isRootOperationNode(node) {\n        return node.kind in ROOT_OPERATION_NODES;\n    }\n    #collectSchemableIds(node) {\n        const schemableIds = new Set();\n        if ('name' in node && node.name && SchemableIdentifierNode.is(node.name)) {\n            this.#collectSchemableId(node.name, schemableIds);\n        }\n        if ('from' in node && node.from) {\n            for (const from of node.from.froms) {\n                this.#collectSchemableIdsFromTableExpr(from, schemableIds);\n            }\n        }\n        if ('into' in node && node.into) {\n            this.#collectSchemableIdsFromTableExpr(node.into, schemableIds);\n        }\n        if ('table' in node && node.table) {\n            this.#collectSchemableIdsFromTableExpr(node.table, schemableIds);\n        }\n        if ('joins' in node && node.joins) {\n            for (const join of node.joins) {\n                this.#collectSchemableIdsFromTableExpr(join.table, schemableIds);\n            }\n        }\n        if ('using' in node && node.using) {\n            this.#collectSchemableIdsFromTableExpr(node.using, schemableIds);\n        }\n        return schemableIds;\n    }\n    #collectCTEs(node) {\n        const ctes = new Set();\n        if ('with' in node && node.with) {\n            this.#collectCTEIds(node.with, ctes);\n        }\n        return ctes;\n    }\n    #collectSchemableIdsFromTableExpr(node, schemableIds) {\n        if (TableNode.is(node)) {\n            this.#collectSchemableId(node.table, schemableIds);\n        }\n        else if (AliasNode.is(node) && TableNode.is(node.node)) {\n            this.#collectSchemableId(node.node.table, schemableIds);\n        }\n        else if (ListNode.is(node)) {\n            for (const table of node.items) {\n                this.#collectSchemableIdsFromTableExpr(table, schemableIds);\n            }\n        }\n    }\n    #collectSchemableId(node, schemableIds) {\n        const id = node.identifier.name;\n        if (!this.#schemableIds.has(id) && !this.#ctes.has(id)) {\n            schemableIds.add(id);\n        }\n    }\n    #collectCTEIds(node, ctes) {\n        for (const expr of node.expressions) {\n            const cteId = expr.name.table.table.identifier.name;\n            if (!this.#ctes.has(cteId)) {\n                ctes.add(cteId);\n            }\n        }\n    }\n}\n", "/// <reference types=\"./with-schema-plugin.d.ts\" />\nimport { WithSchemaTransformer } from './with-schema-transformer.js';\nexport class WithSchemaPlugin {\n    #transformer;\n    constructor(schema) {\n        this.#transformer = new WithSchemaTransformer(schema);\n    }\n    transformQuery(args) {\n        return this.#transformer.transformNode(args.node, args.queryId);\n    }\n    async transformResult(args) {\n        return args.result;\n    }\n}\n", "/// <reference types=\"./matched-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const MatchedNode = freeze({\n    is(node) {\n        return node.kind === 'MatchedNode';\n    },\n    create(not, bySource = false) {\n        return freeze({\n            kind: 'MatchedNode',\n            not,\n            bySource,\n        });\n    },\n});\n", "/// <reference types=\"./merge-parser.d.ts\" />\nimport { MatchedNode } from '../operation-node/matched-node.js';\nimport { isOperationNodeSource, } from '../operation-node/operation-node-source.js';\nimport { RawNode } from '../operation-node/raw-node.js';\nimport { WhenNode } from '../operation-node/when-node.js';\nimport { isString } from '../util/object-utils.js';\nimport { parseFilterList, parseReferentialBinaryOperation, parseValueBinaryOperationOrExpression, } from './binary-operation-parser.js';\nexport function parseMergeWhen(type, args, refRight) {\n    return WhenNode.create(parseFilterList([\n        MatchedNode.create(!type.isMatched, type.bySource),\n        ...(args && args.length > 0\n            ? [\n                args.length === 3 && refRight\n                    ? parseReferentialBinaryOperation(args[0], args[1], args[2])\n                    : parseValueBinaryOperationOrExpression(args),\n            ]\n            : []),\n    ], 'and', false));\n}\nexport function parseMergeThen(result) {\n    if (isString(result)) {\n        return RawNode.create([result], []);\n    }\n    if (isOperationNodeSource(result)) {\n        return result.toOperationNode();\n    }\n    return result;\n}\n", "/// <reference types=\"./deferred.d.ts\" />\nexport class Deferred {\n    #promise;\n    #resolve;\n    #reject;\n    constructor() {\n        this.#promise = new Promise((resolve, reject) => {\n            this.#reject = reject;\n            this.#resolve = resolve;\n        });\n    }\n    get promise() {\n        return this.#promise;\n    }\n    resolve = (value) => {\n        if (this.#resolve) {\n            this.#resolve(value);\n        }\n    };\n    reject = (reason) => {\n        if (this.#reject) {\n            this.#reject(reason);\n        }\n    };\n}\n", "/// <reference types=\"./provide-controlled-connection.d.ts\" />\nimport { Deferred } from './deferred.js';\nimport { freeze } from './object-utils.js';\nexport async function provideControlledConnection(connectionProvider) {\n    const connectionDefer = new Deferred();\n    const connectionReleaseDefer = new Deferred();\n    connectionProvider\n        .provideConnection(async (connection) => {\n        connectionDefer.resolve(connection);\n        return await connectionReleaseDefer.promise;\n    })\n        .catch((ex) => connectionDefer.reject(ex));\n    // Create composite of the connection and the release method instead of\n    // modifying the connection or creating a new nesting `DatabaseConnection`.\n    // This way we don't accidentally override any methods of 3rd party\n    // connections and don't return wrapped connections to drivers that\n    // expect a certain specific connection class.\n    return freeze({\n        connection: await connectionDefer.promise,\n        release: connectionReleaseDefer.resolve,\n    });\n}\n", "/// <reference types=\"./query-executor-base.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { provideControlledConnection } from '../util/provide-controlled-connection.js';\nimport { logOnce } from '../util/log-once.js';\nconst NO_PLUGINS = freeze([]);\nexport class QueryExecutorBase {\n    #plugins;\n    constructor(plugins = NO_PLUGINS) {\n        this.#plugins = plugins;\n    }\n    get plugins() {\n        return this.#plugins;\n    }\n    transformQuery(node, queryId) {\n        for (const plugin of this.#plugins) {\n            const transformedNode = plugin.transformQuery({ node, queryId });\n            // We need to do a runtime check here. There is no good way\n            // to write types that enforce this constraint.\n            if (transformedNode.kind === node.kind) {\n                node = transformedNode;\n            }\n            else {\n                throw new Error([\n                    `KyselyPlugin.transformQuery must return a node`,\n                    `of the same kind that was given to it.`,\n                    `The plugin was given a ${node.kind}`,\n                    `but it returned a ${transformedNode.kind}`,\n                ].join(' '));\n            }\n        }\n        return node;\n    }\n    async executeQuery(compiledQuery, queryId) {\n        return await this.provideConnection(async (connection) => {\n            const result = await connection.executeQuery(compiledQuery);\n            if ('numUpdatedOrDeletedRows' in result) {\n                logOnce('kysely:warning: outdated driver/plugin detected! `QueryResult.numUpdatedOrDeletedRows` has been replaced with `QueryResult.numAffectedRows`.');\n            }\n            return await this.#transformResult(result, queryId);\n        });\n    }\n    async *stream(compiledQuery, chunkSize, queryId) {\n        const { connection, release } = await provideControlledConnection(this);\n        try {\n            for await (const result of connection.streamQuery(compiledQuery, chunkSize)) {\n                yield await this.#transformResult(result, queryId);\n            }\n        }\n        finally {\n            release();\n        }\n    }\n    async #transformResult(result, queryId) {\n        for (const plugin of this.#plugins) {\n            result = await plugin.transformResult({ result, queryId });\n        }\n        return result;\n    }\n}\n", "/// <reference types=\"./noop-query-executor.d.ts\" />\nimport { QueryExecutorBase } from './query-executor-base.js';\n/**\n * A {@link QueryExecutor} subclass that can be used when you don't\n * have a {@link QueryCompiler}, {@link ConnectionProvider} or any\n * other needed things to actually execute queries.\n */\nexport class NoopQueryExecutor extends QueryExecutorBase {\n    get adapter() {\n        throw new Error('this query cannot be compiled to SQL');\n    }\n    compileQuery() {\n        throw new Error('this query cannot be compiled to SQL');\n    }\n    provideConnection() {\n        throw new Error('this query cannot be executed');\n    }\n    withConnectionProvider() {\n        throw new Error('this query cannot have a connection provider');\n    }\n    withPlugin(plugin) {\n        return new NoopQueryExecutor([...this.plugins, plugin]);\n    }\n    withPlugins(plugins) {\n        return new NoopQueryExecutor([...this.plugins, ...plugins]);\n    }\n    withPluginAtFront(plugin) {\n        return new NoopQueryExecutor([plugin, ...this.plugins]);\n    }\n    withoutPlugins() {\n        return new NoopQueryExecutor([]);\n    }\n}\nexport const NOOP_QUERY_EXECUTOR = new NoopQueryExecutor();\n", "/// <reference types=\"./merge-result.d.ts\" />\nexport class MergeResult {\n    numChangedRows;\n    constructor(numChangedRows) {\n        this.numChangedRows = numChangedRows;\n    }\n}\n", "/// <reference types=\"./merge-query-builder.d.ts\" />\nimport { InsertQueryNode } from '../operation-node/insert-query-node.js';\nimport { MergeQueryNode } from '../operation-node/merge-query-node.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { UpdateQueryNode } from '../operation-node/update-query-node.js';\nimport { parseInsertExpression, } from '../parser/insert-values-parser.js';\nimport { parseJoin, } from '../parser/join-parser.js';\nimport { parseMergeThen, parseMergeWhen } from '../parser/merge-parser.js';\nimport { parseSelectAll, parseSelectArg, } from '../parser/select-parser.js';\nimport { parseTop } from '../parser/top-parser.js';\nimport { NOOP_QUERY_EXECUTOR } from '../query-executor/noop-query-executor.js';\nimport { freeze } from '../util/object-utils.js';\nimport { MergeResult } from './merge-result.js';\nimport { NoResultError, isNoResultErrorConstructor, } from './no-result-error.js';\nimport { UpdateQueryBuilder } from './update-query-builder.js';\nexport class MergeQueryBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * This can be used to add any additional SQL to the end of the query.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * await db\n     *   .mergeInto('person')\n     *   .using('pet', 'pet.owner_id', 'person.id')\n     *   .whenMatched()\n     *   .thenDelete()\n     *   .modifyEnd(sql.raw('-- this is a comment'))\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * merge into \"person\" using \"pet\" on \"pet\".\"owner_id\" = \"person\".\"id\" when matched then delete -- this is a comment\n     * ```\n     */\n    modifyEnd(modifier) {\n        return new MergeQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, modifier.toOperationNode()),\n        });\n    }\n    /**\n     * Changes a `merge into` query to an `merge top into` query.\n     *\n     * `top` clause is only supported by some dialects like MS SQL Server.\n     *\n     * ### Examples\n     *\n     * Affect 5 matched rows at most:\n     *\n     * ```ts\n     * await db.mergeInto('person')\n     *   .top(5)\n     *   .using('pet', 'person.id', 'pet.owner_id')\n     *   .whenMatched()\n     *   .thenDelete()\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MS SQL Server):\n     *\n     * ```sql\n     * merge top(5) into \"person\"\n     * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n     * when matched then\n     *   delete\n     * ```\n     *\n     * Affect 50% of matched rows:\n     *\n     * ```ts\n     * await db.mergeInto('person')\n     *   .top(50, 'percent')\n     *   .using('pet', 'person.id', 'pet.owner_id')\n     *   .whenMatched()\n     *   .thenDelete()\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MS SQL Server):\n     *\n     * ```sql\n     * merge top(50) percent into \"person\"\n     * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n     * when matched then\n     *   delete\n     * ```\n     */\n    top(expression, modifiers) {\n        return new MergeQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithTop(this.#props.queryNode, parseTop(expression, modifiers)),\n        });\n    }\n    using(...args) {\n        return new WheneableMergeQueryBuilder({\n            ...this.#props,\n            queryNode: MergeQueryNode.cloneWithUsing(this.#props.queryNode, parseJoin('Using', args)),\n        });\n    }\n    returning(args) {\n        return new MergeQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectArg(args)),\n        });\n    }\n    returningAll(table) {\n        return new MergeQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectAll(table)),\n        });\n    }\n    output(args) {\n        return new MergeQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectArg(args)),\n        });\n    }\n    outputAll(table) {\n        return new MergeQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectAll(table)),\n        });\n    }\n}\nexport class WheneableMergeQueryBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * This can be used to add any additional SQL to the end of the query.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * await db\n     *   .mergeInto('person')\n     *   .using('pet', 'pet.owner_id', 'person.id')\n     *   .whenMatched()\n     *   .thenDelete()\n     *   .modifyEnd(sql.raw('-- this is a comment'))\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * merge into \"person\" using \"pet\" on \"pet\".\"owner_id\" = \"person\".\"id\" when matched then delete -- this is a comment\n     * ```\n     */\n    modifyEnd(modifier) {\n        return new WheneableMergeQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, modifier.toOperationNode()),\n        });\n    }\n    /**\n     * See {@link MergeQueryBuilder.top}.\n     */\n    top(expression, modifiers) {\n        return new WheneableMergeQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithTop(this.#props.queryNode, parseTop(expression, modifiers)),\n        });\n    }\n    /**\n     * Adds a simple `when matched` clause to the query.\n     *\n     * For a `when matched` clause with an `and` condition, see {@link whenMatchedAnd}.\n     *\n     * For a simple `when not matched` clause, see {@link whenNotMatched}.\n     *\n     * For a `when not matched` clause with an `and` condition, see {@link whenNotMatchedAnd}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * const result = await db.mergeInto('person')\n     *   .using('pet', 'person.id', 'pet.owner_id')\n     *   .whenMatched()\n     *   .thenDelete()\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * merge into \"person\"\n     * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n     * when matched then\n     *   delete\n     * ```\n     */\n    whenMatched() {\n        return this.#whenMatched([]);\n    }\n    whenMatchedAnd(...args) {\n        return this.#whenMatched(args);\n    }\n    /**\n     * Adds the `when matched` clause to the query with an `and` condition. But unlike\n     * {@link whenMatchedAnd}, this method accepts a column reference as the 3rd argument.\n     *\n     * This method is similar to {@link SelectQueryBuilder.whereRef}, so see the documentation\n     * for that method for more examples.\n     */\n    whenMatchedAndRef(lhs, op, rhs) {\n        return this.#whenMatched([lhs, op, rhs], true);\n    }\n    #whenMatched(args, refRight) {\n        return new MatchedThenableMergeQueryBuilder({\n            ...this.#props,\n            queryNode: MergeQueryNode.cloneWithWhen(this.#props.queryNode, parseMergeWhen({ isMatched: true }, args, refRight)),\n        });\n    }\n    /**\n     * Adds a simple `when not matched` clause to the query.\n     *\n     * For a `when not matched` clause with an `and` condition, see {@link whenNotMatchedAnd}.\n     *\n     * For a simple `when matched` clause, see {@link whenMatched}.\n     *\n     * For a `when matched` clause with an `and` condition, see {@link whenMatchedAnd}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * const result = await db.mergeInto('person')\n     *   .using('pet', 'person.id', 'pet.owner_id')\n     *   .whenNotMatched()\n     *   .thenInsertValues({\n     *     first_name: 'John',\n     *     last_name: 'Doe',\n     *   })\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * merge into \"person\"\n     * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n     * when not matched then\n     *   insert (\"first_name\", \"last_name\") values ($1, $2)\n     * ```\n     */\n    whenNotMatched() {\n        return this.#whenNotMatched([]);\n    }\n    whenNotMatchedAnd(...args) {\n        return this.#whenNotMatched(args);\n    }\n    /**\n     * Adds the `when not matched` clause to the query with an `and` condition. But unlike\n     * {@link whenNotMatchedAnd}, this method accepts a column reference as the 3rd argument.\n     *\n     * Unlike {@link whenMatchedAndRef}, you cannot reference columns from the target table.\n     *\n     * This method is similar to {@link SelectQueryBuilder.whereRef}, so see the documentation\n     * for that method for more examples.\n     */\n    whenNotMatchedAndRef(lhs, op, rhs) {\n        return this.#whenNotMatched([lhs, op, rhs], true);\n    }\n    /**\n     * Adds a simple `when not matched by source` clause to the query.\n     *\n     * Supported in MS SQL Server.\n     *\n     * Similar to {@link whenNotMatched}, but returns a {@link MatchedThenableMergeQueryBuilder}.\n     */\n    whenNotMatchedBySource() {\n        return this.#whenNotMatched([], false, true);\n    }\n    whenNotMatchedBySourceAnd(...args) {\n        return this.#whenNotMatched(args, false, true);\n    }\n    /**\n     * Adds the `when not matched by source` clause to the query with an `and` condition.\n     *\n     * Similar to {@link whenNotMatchedAndRef}, but you can reference columns from\n     * the target table, and not from source table and returns a {@link MatchedThenableMergeQueryBuilder}.\n     */\n    whenNotMatchedBySourceAndRef(lhs, op, rhs) {\n        return this.#whenNotMatched([lhs, op, rhs], true, true);\n    }\n    returning(args) {\n        return new WheneableMergeQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectArg(args)),\n        });\n    }\n    returningAll(table) {\n        return new WheneableMergeQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectAll(table)),\n        });\n    }\n    output(args) {\n        return new WheneableMergeQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectArg(args)),\n        });\n    }\n    outputAll(table) {\n        return new WheneableMergeQueryBuilder({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectAll(table)),\n        });\n    }\n    #whenNotMatched(args, refRight = false, bySource = false) {\n        const props = {\n            ...this.#props,\n            queryNode: MergeQueryNode.cloneWithWhen(this.#props.queryNode, parseMergeWhen({ isMatched: false, bySource }, args, refRight)),\n        };\n        const Builder = bySource\n            ? MatchedThenableMergeQueryBuilder\n            : NotMatchedThenableMergeQueryBuilder;\n        return new Builder(props);\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     *\n     * If you want to conditionally call a method on `this`, see\n     * the {@link $if} method.\n     *\n     * ### Examples\n     *\n     * The next example uses a helper function `log` to log a query:\n     *\n     * ```ts\n     * import type { Compilable } from 'kysely'\n     *\n     * function log<T extends Compilable>(qb: T): T {\n     *   console.log(qb.compile())\n     *   return qb\n     * }\n     *\n     * await db.updateTable('person')\n     *   .set({ first_name: 'John' })\n     *   .$call(log)\n     *   .execute()\n     * ```\n     */\n    $call(func) {\n        return func(this);\n    }\n    /**\n     * Call `func(this)` if `condition` is true.\n     *\n     * This method is especially handy with optional selects. Any `returning` or `returningAll`\n     * method calls add columns as optional fields to the output type when called inside\n     * the `func` callback. This is because we can't know if those selections were actually\n     * made before running the code.\n     *\n     * You can also call any other methods inside the callback.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import type { PersonUpdate } from 'type-editor' // imaginary module\n     *\n     * async function updatePerson(id: number, updates: PersonUpdate, returnLastName: boolean) {\n     *   return await db\n     *     .updateTable('person')\n     *     .set(updates)\n     *     .where('id', '=', id)\n     *     .returning(['id', 'first_name'])\n     *     .$if(returnLastName, (qb) => qb.returning('last_name'))\n     *     .executeTakeFirstOrThrow()\n     * }\n     * ```\n     *\n     * Any selections added inside the `if` callback will be added as optional fields to the\n     * output type since we can't know if the selections were actually made before running\n     * the code. In the example above the return type of the `updatePerson` function is:\n     *\n     * ```ts\n     * Promise<{\n     *   id: number\n     *   first_name: string\n     *   last_name?: string\n     * }>\n     * ```\n     */\n    $if(condition, func) {\n        if (condition) {\n            return func(this);\n        }\n        return new WheneableMergeQueryBuilder({\n            ...this.#props,\n        });\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.queryNode, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    /**\n     * Executes the query and returns an array of rows.\n     *\n     * Also see the {@link executeTakeFirst} and {@link executeTakeFirstOrThrow} methods.\n     */\n    async execute() {\n        const compiledQuery = this.compile();\n        const result = await this.#props.executor.executeQuery(compiledQuery, this.#props.queryId);\n        const { adapter } = this.#props.executor;\n        const query = compiledQuery.query;\n        if ((query.returning && adapter.supportsReturning) ||\n            (query.output && adapter.supportsOutput)) {\n            return result.rows;\n        }\n        return [new MergeResult(result.numAffectedRows)];\n    }\n    /**\n     * Executes the query and returns the first result or undefined if\n     * the query returned no result.\n     */\n    async executeTakeFirst() {\n        const [result] = await this.execute();\n        return result;\n    }\n    /**\n     * Executes the query and returns the first result or throws if\n     * the query returned no result.\n     *\n     * By default an instance of {@link NoResultError} is thrown, but you can\n     * provide a custom error class, or callback as the only argument to throw a different\n     * error.\n     */\n    async executeTakeFirstOrThrow(errorConstructor = NoResultError) {\n        const result = await this.executeTakeFirst();\n        if (result === undefined) {\n            const error = isNoResultErrorConstructor(errorConstructor)\n                ? new errorConstructor(this.toOperationNode())\n                : errorConstructor(this.toOperationNode());\n            throw error;\n        }\n        return result;\n    }\n}\nexport class MatchedThenableMergeQueryBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * Performs the `delete` action.\n     *\n     * To perform the `do nothing` action, see {@link thenDoNothing}.\n     *\n     * To perform the `update` action, see {@link thenUpdate} or {@link thenUpdateSet}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * const result = await db.mergeInto('person')\n     *   .using('pet', 'person.id', 'pet.owner_id')\n     *   .whenMatched()\n     *   .thenDelete()\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * merge into \"person\"\n     * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n     * when matched then\n     *   delete\n     * ```\n     */\n    thenDelete() {\n        return new WheneableMergeQueryBuilder({\n            ...this.#props,\n            queryNode: MergeQueryNode.cloneWithThen(this.#props.queryNode, parseMergeThen('delete')),\n        });\n    }\n    /**\n     * Performs the `do nothing` action.\n     *\n     * This is supported in PostgreSQL.\n     *\n     * To perform the `delete` action, see {@link thenDelete}.\n     *\n     * To perform the `update` action, see {@link thenUpdate} or {@link thenUpdateSet}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * const result = await db.mergeInto('person')\n     *   .using('pet', 'person.id', 'pet.owner_id')\n     *   .whenMatched()\n     *   .thenDoNothing()\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * merge into \"person\"\n     * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n     * when matched then\n     *   do nothing\n     * ```\n     */\n    thenDoNothing() {\n        return new WheneableMergeQueryBuilder({\n            ...this.#props,\n            queryNode: MergeQueryNode.cloneWithThen(this.#props.queryNode, parseMergeThen('do nothing')),\n        });\n    }\n    /**\n     * Perform an `update` operation with a full-fledged {@link UpdateQueryBuilder}.\n     * This is handy when multiple `set` invocations are needed.\n     *\n     * For a shorthand version of this method, see {@link thenUpdateSet}.\n     *\n     * To perform the `delete` action, see {@link thenDelete}.\n     *\n     * To perform the `do nothing` action, see {@link thenDoNothing}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * const result = await db.mergeInto('person')\n     *   .using('pet', 'person.id', 'pet.owner_id')\n     *   .whenMatched()\n     *   .thenUpdate((ub) => ub\n     *     .set(sql`metadata['has_pets']`, 'Y')\n     *     .set({\n     *       updated_at: new Date().toISOString(),\n     *     })\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * merge into \"person\"\n     * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n     * when matched then\n     *   update set metadata['has_pets'] = $1, \"updated_at\" = $2\n     * ```\n     */\n    thenUpdate(set) {\n        return new WheneableMergeQueryBuilder({\n            ...this.#props,\n            queryNode: MergeQueryNode.cloneWithThen(this.#props.queryNode, parseMergeThen(set(new UpdateQueryBuilder({\n                queryId: this.#props.queryId,\n                executor: NOOP_QUERY_EXECUTOR,\n                queryNode: UpdateQueryNode.createWithoutTable(),\n            })))),\n        });\n    }\n    thenUpdateSet(...args) {\n        // @ts-ignore not sure how to type this so it won't complain about set(...args).\n        return this.thenUpdate((ub) => ub.set(...args));\n    }\n}\nexport class NotMatchedThenableMergeQueryBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * Performs the `do nothing` action.\n     *\n     * This is supported in PostgreSQL.\n     *\n     * To perform the `insert` action, see {@link thenInsertValues}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * const result = await db.mergeInto('person')\n     *   .using('pet', 'person.id', 'pet.owner_id')\n     *   .whenNotMatched()\n     *   .thenDoNothing()\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * merge into \"person\"\n     * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n     * when not matched then\n     *   do nothing\n     * ```\n     */\n    thenDoNothing() {\n        return new WheneableMergeQueryBuilder({\n            ...this.#props,\n            queryNode: MergeQueryNode.cloneWithThen(this.#props.queryNode, parseMergeThen('do nothing')),\n        });\n    }\n    thenInsertValues(insert) {\n        const [columns, values] = parseInsertExpression(insert);\n        return new WheneableMergeQueryBuilder({\n            ...this.#props,\n            queryNode: MergeQueryNode.cloneWithThen(this.#props.queryNode, parseMergeThen(InsertQueryNode.cloneWith(InsertQueryNode.createWithoutInto(), {\n                columns,\n                values,\n            }))),\n        });\n    }\n}\n", "/// <reference types=\"./query-creator.d.ts\" />\nimport { createSelectQueryBuilder, } from './query-builder/select-query-builder.js';\nimport { InsertQueryBuilder } from './query-builder/insert-query-builder.js';\nimport { DeleteQueryBuilder } from './query-builder/delete-query-builder.js';\nimport { UpdateQueryBuilder } from './query-builder/update-query-builder.js';\nimport { DeleteQueryNode } from './operation-node/delete-query-node.js';\nimport { InsertQueryNode } from './operation-node/insert-query-node.js';\nimport { SelectQueryNode } from './operation-node/select-query-node.js';\nimport { UpdateQueryNode } from './operation-node/update-query-node.js';\nimport { parseTable, parseTableExpressionOrList, parseAliasedTable, } from './parser/table-parser.js';\nimport { parseCommonTableExpression, } from './parser/with-parser.js';\nimport { WithNode } from './operation-node/with-node.js';\nimport { createQueryId } from './util/query-id.js';\nimport { WithSchemaPlugin } from './plugin/with-schema/with-schema-plugin.js';\nimport { freeze } from './util/object-utils.js';\nimport { parseSelectArg, } from './parser/select-parser.js';\nimport { MergeQueryBuilder } from './query-builder/merge-query-builder.js';\nimport { MergeQueryNode } from './operation-node/merge-query-node.js';\nexport class QueryCreator {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * Creates a `select` query builder for the given table or tables.\n     *\n     * The tables passed to this method are built as the query's `from` clause.\n     *\n     * ### Examples\n     *\n     * Create a select query for one table:\n     *\n     * ```ts\n     * db.selectFrom('person').selectAll()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select * from \"person\"\n     * ```\n     *\n     * Create a select query for one table with an alias:\n     *\n     * ```ts\n     * const persons = await db.selectFrom('person as p')\n     *   .select(['p.id', 'first_name'])\n     *   .execute()\n     *\n     * console.log(persons[0].id)\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select \"p\".\"id\", \"first_name\" from \"person\" as \"p\"\n     * ```\n     *\n     * Create a select query from a subquery:\n     *\n     * ```ts\n     * const persons = await db.selectFrom(\n     *     (eb) => eb.selectFrom('person').select('person.id as identifier').as('p')\n     *   )\n     *   .select('p.identifier')\n     *   .execute()\n     *\n     * console.log(persons[0].identifier)\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select \"p\".\"identifier\",\n     * from (\n     *   select \"person\".\"id\" as \"identifier\" from \"person\"\n     * ) as p\n     * ```\n     *\n     * Create a select query from raw sql:\n     *\n     * ```ts\n     * import {\u00A0sql } from 'kysely'\n     *\n     * const items = await db\n     *   .selectFrom(sql<{ one: number }>`(select 1 as one)`.as('q'))\n     *   .select('q.one')\n     *   .execute()\n     *\n     * console.log(items[0].one)\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select \"q\".\"one\",\n     * from (\n     *   select 1 as one\n     * ) as q\n     * ```\n     *\n     * When you use the `sql` tag you need to also provide the result type of the\n     * raw snippet / query so that Kysely can figure out what columns are\n     * available for the rest of the query.\n     *\n     * The `selectFrom` method also accepts an array for multiple tables. All\n     * the above examples can also be used in an array.\n     *\n     * ```ts\n     * import {\u00A0sql } from 'kysely'\n     *\n     * const items = await db.selectFrom([\n     *     'person as p',\n     *     db.selectFrom('pet').select('pet.species').as('a'),\n     *     sql<{ one: number }>`(select 1 as one)`.as('q')\n     *   ])\n     *   .select(['p.id', 'a.species', 'q.one'])\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select \"p\".id, \"a\".\"species\", \"q\".\"one\"\n     * from\n     *   \"person\" as \"p\",\n     *   (select \"pet\".\"species\" from \"pet\") as a,\n     *   (select 1 as one) as \"q\"\n     * ```\n     */\n    selectFrom(from) {\n        return createSelectQueryBuilder({\n            queryId: createQueryId(),\n            executor: this.#props.executor,\n            queryNode: SelectQueryNode.createFrom(parseTableExpressionOrList(from), this.#props.withNode),\n        });\n    }\n    selectNoFrom(selection) {\n        return createSelectQueryBuilder({\n            queryId: createQueryId(),\n            executor: this.#props.executor,\n            queryNode: SelectQueryNode.cloneWithSelections(SelectQueryNode.create(this.#props.withNode), parseSelectArg(selection)),\n        });\n    }\n    /**\n     * Creates an insert query.\n     *\n     * The return value of this query is an instance of {@link InsertResult}. {@link InsertResult}\n     * has the {@link InsertResult.insertId | insertId} field that holds the auto incremented id of\n     * the inserted row if the db returned one.\n     *\n     * See the {@link InsertQueryBuilder.values | values} method for more info and examples. Also see\n     * the {@link ReturningInterface.returning | returning} method for a way to return columns\n     * on supported databases like PostgreSQL.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * const result = await db\n     *   .insertInto('person')\n     *   .values({\n     *     first_name: 'Jennifer',\n     *     last_name: 'Aniston'\n     *   })\n     *   .executeTakeFirst()\n     *\n     * console.log(result.insertId)\n     * ```\n     *\n     * Some databases like PostgreSQL support the `returning` method:\n     *\n     * ```ts\n     * const { id } = await db\n     *   .insertInto('person')\n     *   .values({\n     *     first_name: 'Jennifer',\n     *     last_name: 'Aniston'\n     *   })\n     *   .returning('id')\n     *   .executeTakeFirstOrThrow()\n     * ```\n     */\n    insertInto(table) {\n        return new InsertQueryBuilder({\n            queryId: createQueryId(),\n            executor: this.#props.executor,\n            queryNode: InsertQueryNode.create(parseTable(table), this.#props.withNode),\n        });\n    }\n    /**\n     * Creates a \"replace into\" query.\n     *\n     * This is only supported by some dialects like MySQL or SQLite.\n     *\n     * Similar to MySQL's {@link InsertQueryBuilder.onDuplicateKeyUpdate} that deletes\n     * and inserts values on collision instead of updating existing rows.\n     *\n     * An alias of SQLite's {@link InsertQueryBuilder.orReplace}.\n     *\n     * The return value of this query is an instance of {@link InsertResult}. {@link InsertResult}\n     * has the {@link InsertResult.insertId | insertId} field that holds the auto incremented id of\n     * the inserted row if the db returned one.\n     *\n     * See the {@link InsertQueryBuilder.values | values} method for more info and examples.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * const result = await db\n     *   .replaceInto('person')\n     *   .values({\n     *     first_name: 'Jennifer',\n     *     last_name: 'Aniston'\n     *   })\n     *   .executeTakeFirstOrThrow()\n     *\n     * console.log(result.insertId)\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * replace into `person` (`first_name`, `last_name`) values (?, ?)\n     * ```\n     */\n    replaceInto(table) {\n        return new InsertQueryBuilder({\n            queryId: createQueryId(),\n            executor: this.#props.executor,\n            queryNode: InsertQueryNode.create(parseTable(table), this.#props.withNode, true),\n        });\n    }\n    /**\n     * Creates a delete query.\n     *\n     * See the {@link DeleteQueryBuilder.where} method for examples on how to specify\n     * a where clause for the delete operation.\n     *\n     * The return value of the query is an instance of {@link DeleteResult}.\n     *\n     * ### Examples\n     *\n     * <!-- siteExample(\"delete\", \"Single row\", 10) -->\n     *\n     * Delete a single row:\n     *\n     * ```ts\n     * const result = await db\n     *   .deleteFrom('person')\n     *   .where('person.id', '=', 1)\n     *   .executeTakeFirst()\n     *\n     * console.log(result.numDeletedRows)\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * delete from \"person\" where \"person\".\"id\" = $1\n     * ```\n     *\n     * Some databases such as MySQL support deleting from multiple tables:\n     *\n     * ```ts\n     * const result = await db\n     *   .deleteFrom(['person', 'pet'])\n     *   .using('person')\n     *   .innerJoin('pet', 'pet.owner_id', 'person.id')\n     *   .where('person.id', '=', 1)\n     *   .executeTakeFirst()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * delete from `person`, `pet`\n     * using `person`\n     * inner join `pet` on `pet`.`owner_id` = `person`.`id`\n     * where `person`.`id` = ?\n     * ```\n     */\n    deleteFrom(from) {\n        return new DeleteQueryBuilder({\n            queryId: createQueryId(),\n            executor: this.#props.executor,\n            queryNode: DeleteQueryNode.create(parseTableExpressionOrList(from), this.#props.withNode),\n        });\n    }\n    /**\n     * Creates an update query.\n     *\n     * See the {@link UpdateQueryBuilder.where} method for examples on how to specify\n     * a where clause for the update operation.\n     *\n     * See the {@link UpdateQueryBuilder.set} method for examples on how to\n     * specify the updates.\n     *\n     * The return value of the query is an {@link UpdateResult}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * const result = await db\n     *   .updateTable('person')\n     *   .set({ first_name: 'Jennifer' })\n     *   .where('person.id', '=', 1)\n     *   .executeTakeFirst()\n     *\n     * console.log(result.numUpdatedRows)\n     * ```\n     */\n    updateTable(tables) {\n        return new UpdateQueryBuilder({\n            queryId: createQueryId(),\n            executor: this.#props.executor,\n            queryNode: UpdateQueryNode.create(parseTableExpressionOrList(tables), this.#props.withNode),\n        });\n    }\n    /**\n     * Creates a merge query.\n     *\n     * The return value of the query is a {@link MergeResult}.\n     *\n     * See the {@link MergeQueryBuilder.using} method for examples on how to specify\n     * the other table.\n     *\n     * ### Examples\n     *\n     * <!-- siteExample(\"merge\", \"Source row existence\", 10) -->\n     *\n     * Update a target column based on the existence of a source row:\n     *\n     * ```ts\n     * const result = await db\n     *   .mergeInto('person as target')\n     *   .using('pet as source', 'source.owner_id', 'target.id')\n     *   .whenMatchedAnd('target.has_pets', '!=', 'Y')\n     *   .thenUpdateSet({ has_pets: 'Y' })\n     *   .whenNotMatchedBySourceAnd('target.has_pets', '=', 'Y')\n     *   .thenUpdateSet({ has_pets: 'N' })\n     *   .executeTakeFirstOrThrow()\n     *\n     * console.log(result.numChangedRows)\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * merge into \"person\"\n     * using \"pet\"\n     * on \"pet\".\"owner_id\" = \"person\".\"id\"\n     * when matched and \"has_pets\" != $1\n     * then update set \"has_pets\" = $2\n     * when not matched by source and \"has_pets\" = $3\n     * then update set \"has_pets\" = $4\n     * ```\n     *\n     * <!-- siteExample(\"merge\", \"Temporary changes table\", 20) -->\n     *\n     * Merge new entries from a temporary changes table:\n     *\n     * ```ts\n     * const result = await db\n     *   .mergeInto('wine as target')\n     *   .using(\n     *     'wine_stock_change as source',\n     *     'source.wine_name',\n     *     'target.name',\n     *   )\n     *   .whenNotMatchedAnd('source.stock_delta', '>', 0)\n     *   .thenInsertValues(({ ref }) => ({\n     *     name: ref('source.wine_name'),\n     *     stock: ref('source.stock_delta'),\n     *   }))\n     *   .whenMatchedAnd(\n     *     (eb) => eb('target.stock', '+', eb.ref('source.stock_delta')),\n     *     '>',\n     *     0,\n     *   )\n     *   .thenUpdateSet('stock', (eb) =>\n     *     eb('target.stock', '+', eb.ref('source.stock_delta')),\n     *   )\n     *   .whenMatched()\n     *   .thenDelete()\n     *   .executeTakeFirstOrThrow()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * merge into \"wine\" as \"target\"\n     * using \"wine_stock_change\" as \"source\"\n     * on \"source\".\"wine_name\" = \"target\".\"name\"\n     * when not matched and \"source\".\"stock_delta\" > $1\n     * then insert (\"name\", \"stock\") values (\"source\".\"wine_name\", \"source\".\"stock_delta\")\n     * when matched and \"target\".\"stock\" + \"source\".\"stock_delta\" > $2\n     * then update set \"stock\" = \"target\".\"stock\" + \"source\".\"stock_delta\"\n     * when matched\n     * then delete\n     * ```\n     */\n    mergeInto(targetTable) {\n        return new MergeQueryBuilder({\n            queryId: createQueryId(),\n            executor: this.#props.executor,\n            queryNode: MergeQueryNode.create(parseAliasedTable(targetTable), this.#props.withNode),\n        });\n    }\n    /**\n     * Creates a `with` query (Common Table Expression).\n     *\n     * ### Examples\n     *\n     * <!-- siteExample(\"cte\", \"Simple selects\", 10) -->\n     *\n     * Common table expressions (CTE) are a great way to modularize complex queries.\n     * Essentially they allow you to run multiple separate queries within a\n     * single roundtrip to the DB.\n     *\n     * Since CTEs are a part of the main query, query optimizers inside DB\n     * engines are able to optimize the overall query. For example, postgres\n     * is able to inline the CTEs inside the using queries if it decides it's\n     * faster.\n     *\n     * ```ts\n     * const result = await db\n     *   // Create a CTE called `jennifers` that selects all\n     *   // persons named 'Jennifer'.\n     *   .with('jennifers', (db) => db\n     *     .selectFrom('person')\n     *     .where('first_name', '=', 'Jennifer')\n     *     .select(['id', 'age'])\n     *   )\n     *   // Select all rows from the `jennifers` CTE and\n     *   // further filter it.\n     *   .with('adult_jennifers', (db) => db\n     *     .selectFrom('jennifers')\n     *     .where('age', '>', 18)\n     *     .select(['id', 'age'])\n     *   )\n     *   // Finally select all adult jennifers that are\n     *   // also younger than 60.\n     *   .selectFrom('adult_jennifers')\n     *   .where('age', '<', 60)\n     *   .selectAll()\n     *   .execute()\n     * ```\n     *\n     * <!-- siteExample(\"cte\", \"Inserts, updates and deletions\", 20) -->\n     *\n     * Some databases like postgres also allow you to run other queries than selects\n     * in CTEs. On these databases CTEs are extremely powerful:\n     *\n     * ```ts\n     * const result = await db\n     *   .with('new_person', (db) => db\n     *     .insertInto('person')\n     *     .values({\n     *       first_name: 'Jennifer',\n     *       age: 35,\n     *     })\n     *     .returning('id')\n     *   )\n     *   .with('new_pet', (db) => db\n     *     .insertInto('pet')\n     *     .values({\n     *       name: 'Doggo',\n     *       species: 'dog',\n     *       is_favorite: true,\n     *       // Use the id of the person we just inserted.\n     *       owner_id: db\n     *         .selectFrom('new_person')\n     *         .select('id')\n     *     })\n     *     .returning('id')\n     *   )\n     *   .selectFrom(['new_person', 'new_pet'])\n     *   .select([\n     *     'new_person.id as person_id',\n     *     'new_pet.id as pet_id'\n     *   ])\n     *   .execute()\n     * ```\n     *\n     * The CTE name can optionally specify column names in addition to\n     * a name. In that case Kysely requires the expression to retun\n     * rows with the same columns.\n     *\n     * ```ts\n     * await db\n     *   .with('jennifers(id, age)', (db) => db\n     *     .selectFrom('person')\n     *     .where('first_name', '=', 'Jennifer')\n     *     // This is ok since we return columns with the same\n     *     // names as specified by `jennifers(id, age)`.\n     *     .select(['id', 'age'])\n     *   )\n     *   .selectFrom('jennifers')\n     *   .selectAll()\n     *   .execute()\n     * ```\n     *\n     * The first argument can also be a callback. The callback is passed\n     * a `CTEBuilder` instance that can be used to configure the CTE:\n     *\n     * ```ts\n     * await db\n     *   .with(\n     *     (cte) => cte('jennifers').materialized(),\n     *     (db) => db\n     *       .selectFrom('person')\n     *       .where('first_name', '=', 'Jennifer')\n     *       .select(['id', 'age'])\n     *   )\n     *   .selectFrom('jennifers')\n     *   .selectAll()\n     *   .execute()\n     * ```\n     */\n    with(nameOrBuilder, expression) {\n        const cte = parseCommonTableExpression(nameOrBuilder, expression);\n        return new QueryCreator({\n            ...this.#props,\n            withNode: this.#props.withNode\n                ? WithNode.cloneWithExpression(this.#props.withNode, cte)\n                : WithNode.create(cte),\n        });\n    }\n    /**\n     * Creates a recursive `with` query (Common Table Expression).\n     *\n     * Note that recursiveness is a property of the whole `with` statement.\n     * You cannot have recursive and non-recursive CTEs in a same `with` statement.\n     * Therefore the recursiveness is determined by the **first** `with` or\n     * `withRecusive` call you make.\n     *\n     * See the {@link with} method for examples and more documentation.\n     */\n    withRecursive(nameOrBuilder, expression) {\n        const cte = parseCommonTableExpression(nameOrBuilder, expression);\n        return new QueryCreator({\n            ...this.#props,\n            withNode: this.#props.withNode\n                ? WithNode.cloneWithExpression(this.#props.withNode, cte)\n                : WithNode.create(cte, { recursive: true }),\n        });\n    }\n    /**\n     * Returns a copy of this query creator instance with the given plugin installed.\n     */\n    withPlugin(plugin) {\n        return new QueryCreator({\n            ...this.#props,\n            executor: this.#props.executor.withPlugin(plugin),\n        });\n    }\n    /**\n     * Returns a copy of this query creator instance without any plugins.\n     */\n    withoutPlugins() {\n        return new QueryCreator({\n            ...this.#props,\n            executor: this.#props.executor.withoutPlugins(),\n        });\n    }\n    /**\n     * Sets the schema to be used for all table references that don't explicitly\n     * specify a schema.\n     *\n     * This only affects the query created through the builder returned from\n     * this method and doesn't modify the `db` instance.\n     *\n     * See [this recipe](https://github.com/kysely-org/kysely/blob/master/site/docs/recipes/0007-schemas.md)\n     * for a more detailed explanation.\n     *\n     * ### Examples\n     *\n     * ```\n     * await db\n     *   .withSchema('mammals')\n     *   .selectFrom('pet')\n     *   .selectAll()\n     *   .innerJoin('public.person', 'public.person.id', 'pet.owner_id')\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select * from \"mammals\".\"pet\"\n     * inner join \"public\".\"person\"\n     * on \"public\".\"person\".\"id\" = \"mammals\".\"pet\".\"owner_id\"\n     * ```\n     *\n     * `withSchema` is smart enough to not add schema for aliases,\n     * common table expressions or other places where the schema\n     * doesn't belong to:\n     *\n     * ```\n     * await db\n     *   .withSchema('mammals')\n     *   .selectFrom('pet as p')\n     *   .select('p.name')\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select \"p\".\"name\" from \"mammals\".\"pet\" as \"p\"\n     * ```\n     */\n    withSchema(schema) {\n        return new QueryCreator({\n            ...this.#props,\n            executor: this.#props.executor.withPluginAtFront(new WithSchemaPlugin(schema)),\n        });\n    }\n}\n", "/// <reference types=\"./parse-utils.d.ts\" />\nimport { JoinNode } from '../operation-node/join-node.js';\nimport { OverNode } from '../operation-node/over-node.js';\nimport { SelectQueryNode } from '../operation-node/select-query-node.js';\nimport { JoinBuilder } from '../query-builder/join-builder.js';\nimport { OverBuilder } from '../query-builder/over-builder.js';\nimport { createSelectQueryBuilder as newSelectQueryBuilder, } from '../query-builder/select-query-builder.js';\nimport { QueryCreator } from '../query-creator.js';\nimport { NOOP_QUERY_EXECUTOR } from '../query-executor/noop-query-executor.js';\nimport { createQueryId } from '../util/query-id.js';\nimport { parseTableExpression, parseTableExpressionOrList, } from './table-parser.js';\nexport function createSelectQueryBuilder() {\n    return newSelectQueryBuilder({\n        queryId: createQueryId(),\n        executor: NOOP_QUERY_EXECUTOR,\n        queryNode: SelectQueryNode.createFrom(parseTableExpressionOrList([])),\n    });\n}\nexport function createQueryCreator() {\n    return new QueryCreator({\n        executor: NOOP_QUERY_EXECUTOR,\n    });\n}\nexport function createJoinBuilder(joinType, table) {\n    return new JoinBuilder({\n        joinNode: JoinNode.create(joinType, parseTableExpression(table)),\n    });\n}\nexport function createOverBuilder() {\n    return new OverBuilder({\n        overNode: OverNode.create(),\n    });\n}\n", "/// <reference types=\"./join-parser.d.ts\" />\nimport { JoinNode } from '../operation-node/join-node.js';\nimport { parseReferentialBinaryOperation } from './binary-operation-parser.js';\nimport { createJoinBuilder } from './parse-utils.js';\nimport { parseTableExpression, } from './table-parser.js';\nexport function parseJoin(joinType, args) {\n    if (args.length === 3) {\n        return parseSingleOnJoin(joinType, args[0], args[1], args[2]);\n    }\n    else if (args.length === 2) {\n        return parseCallbackJoin(joinType, args[0], args[1]);\n    }\n    else if (args.length === 1) {\n        return parseOnlessJoin(joinType, args[0]);\n    }\n    else {\n        throw new Error('not implemented');\n    }\n}\nfunction parseCallbackJoin(joinType, from, callback) {\n    return callback(createJoinBuilder(joinType, from)).toOperationNode();\n}\nfunction parseSingleOnJoin(joinType, from, lhsColumn, rhsColumn) {\n    return JoinNode.createWithOn(joinType, parseTableExpression(from), parseReferentialBinaryOperation(lhsColumn, '=', rhsColumn));\n}\nfunction parseOnlessJoin(joinType, from) {\n    return JoinNode.create(joinType, parseTableExpression(from));\n}\n", "/// <reference types=\"./offset-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OffsetNode = freeze({\n    is(node) {\n        return node.kind === 'OffsetNode';\n    },\n    create(offset) {\n        return freeze({\n            kind: 'OffsetNode',\n            offset,\n        });\n    },\n});\n", "/// <reference types=\"./group-by-item-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const GroupByItemNode = freeze({\n    is(node) {\n        return node.kind === 'GroupByItemNode';\n    },\n    create(groupBy) {\n        return freeze({\n            kind: 'GroupByItemNode',\n            groupBy,\n        });\n    },\n});\n", "/// <reference types=\"./group-by-parser.d.ts\" />\nimport { GroupByItemNode } from '../operation-node/group-by-item-node.js';\nimport { expressionBuilder, } from '../expression/expression-builder.js';\nimport { isFunction } from '../util/object-utils.js';\nimport { parseReferenceExpressionOrList, } from './reference-parser.js';\nexport function parseGroupBy(groupBy) {\n    groupBy = isFunction(groupBy) ? groupBy(expressionBuilder()) : groupBy;\n    return parseReferenceExpressionOrList(groupBy).map(GroupByItemNode.create);\n}\n", "/// <reference types=\"./set-operation-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const SetOperationNode = freeze({\n    is(node) {\n        return node.kind === 'SetOperationNode';\n    },\n    create(operator, expression, all) {\n        return freeze({\n            kind: 'SetOperationNode',\n            operator,\n            expression,\n            all,\n        });\n    },\n});\n", "/// <reference types=\"./set-operation-parser.d.ts\" />\nimport { createExpressionBuilder, } from '../expression/expression-builder.js';\nimport { SetOperationNode, } from '../operation-node/set-operation-node.js';\nimport { isFunction, isReadonlyArray } from '../util/object-utils.js';\nimport { parseExpression } from './expression-parser.js';\nexport function parseSetOperations(operator, expression, all) {\n    if (isFunction(expression)) {\n        expression = expression(createExpressionBuilder());\n    }\n    if (!isReadonlyArray(expression)) {\n        expression = [expression];\n    }\n    return expression.map((expr) => SetOperationNode.create(operator, parseExpression(expr), all));\n}\n", "/// <reference types=\"./expression-wrapper.d.ts\" />\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { AndNode } from '../operation-node/and-node.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { isOperationNodeSource } from '../operation-node/operation-node-source.js';\nimport { OrNode } from '../operation-node/or-node.js';\nimport { ParensNode } from '../operation-node/parens-node.js';\nimport { parseValueBinaryOperationOrExpression, } from '../parser/binary-operation-parser.js';\nexport class ExpressionWrapper {\n    #node;\n    constructor(node) {\n        this.#node = node;\n    }\n    /** @private */\n    get expressionType() {\n        return undefined;\n    }\n    as(alias) {\n        return new AliasedExpressionWrapper(this, alias);\n    }\n    or(...args) {\n        return new OrWrapper(OrNode.create(this.#node, parseValueBinaryOperationOrExpression(args)));\n    }\n    and(...args) {\n        return new AndWrapper(AndNode.create(this.#node, parseValueBinaryOperationOrExpression(args)));\n    }\n    /**\n     * Change the output type of the expression.\n     *\n     * This method call doesn't change the SQL in any way. This methods simply\n     * returns a copy of this `ExpressionWrapper` with a new output type.\n     */\n    $castTo() {\n        return new ExpressionWrapper(this.#node);\n    }\n    /**\n     * Omit null from the expression's type.\n     *\n     * This function can be useful in cases where you know an expression can't be\n     * null, but Kysely is unable to infer it.\n     *\n     * This method call doesn't change the SQL in any way. This methods simply\n     * returns a copy of `this` with a new output type.\n     */\n    $notNull() {\n        return new ExpressionWrapper(this.#node);\n    }\n    toOperationNode() {\n        return this.#node;\n    }\n}\nexport class AliasedExpressionWrapper {\n    #expr;\n    #alias;\n    constructor(expr, alias) {\n        this.#expr = expr;\n        this.#alias = alias;\n    }\n    /** @private */\n    get expression() {\n        return this.#expr;\n    }\n    /** @private */\n    get alias() {\n        return this.#alias;\n    }\n    toOperationNode() {\n        return AliasNode.create(this.#expr.toOperationNode(), isOperationNodeSource(this.#alias)\n            ? this.#alias.toOperationNode()\n            : IdentifierNode.create(this.#alias));\n    }\n}\nexport class OrWrapper {\n    #node;\n    constructor(node) {\n        this.#node = node;\n    }\n    /** @private */\n    get expressionType() {\n        return undefined;\n    }\n    as(alias) {\n        return new AliasedExpressionWrapper(this, alias);\n    }\n    or(...args) {\n        return new OrWrapper(OrNode.create(this.#node, parseValueBinaryOperationOrExpression(args)));\n    }\n    /**\n     * Change the output type of the expression.\n     *\n     * This method call doesn't change the SQL in any way. This methods simply\n     * returns a copy of this `OrWrapper` with a new output type.\n     */\n    $castTo() {\n        return new OrWrapper(this.#node);\n    }\n    toOperationNode() {\n        return ParensNode.create(this.#node);\n    }\n}\nexport class AndWrapper {\n    #node;\n    constructor(node) {\n        this.#node = node;\n    }\n    /** @private */\n    get expressionType() {\n        return undefined;\n    }\n    as(alias) {\n        return new AliasedExpressionWrapper(this, alias);\n    }\n    and(...args) {\n        return new AndWrapper(AndNode.create(this.#node, parseValueBinaryOperationOrExpression(args)));\n    }\n    /**\n     * Change the output type of the expression.\n     *\n     * This method call doesn't change the SQL in any way. This methods simply\n     * returns a copy of this `AndWrapper` with a new output type.\n     */\n    $castTo() {\n        return new AndWrapper(this.#node);\n    }\n    toOperationNode() {\n        return ParensNode.create(this.#node);\n    }\n}\n", "/// <reference types=\"./fetch-node.d.ts\" />\nimport { ValueNode } from './value-node.js';\n/**\n * @internal\n */\nexport const FetchNode = {\n    is(node) {\n        return node.kind === 'FetchNode';\n    },\n    create(rowCount, modifier) {\n        return {\n            kind: 'FetchNode',\n            rowCount: ValueNode.create(rowCount),\n            modifier,\n        };\n    },\n};\n", "/// <reference types=\"./fetch-parser.d.ts\" />\nimport { FetchNode } from '../operation-node/fetch-node.js';\nimport { isBigInt, isNumber } from '../util/object-utils.js';\nexport function parseFetch(rowCount, modifier) {\n    if (!isNumber(rowCount) && !isBigInt(rowCount)) {\n        throw new Error(`Invalid fetch row count: ${rowCount}`);\n    }\n    if (!isFetchModifier(modifier)) {\n        throw new Error(`Invalid fetch modifier: ${modifier}`);\n    }\n    return FetchNode.create(rowCount, modifier);\n}\nfunction isFetchModifier(value) {\n    return value === 'only' || value === 'with ties';\n}\n", "/// <reference types=\"./select-query-builder.d.ts\" />\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { SelectModifierNode } from '../operation-node/select-modifier-node.js';\nimport { parseJoin, } from '../parser/join-parser.js';\nimport { parseTable } from '../parser/table-parser.js';\nimport { parseSelectArg, parseSelectAll, } from '../parser/select-parser.js';\nimport { parseReferenceExpressionOrList, } from '../parser/reference-parser.js';\nimport { SelectQueryNode } from '../operation-node/select-query-node.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { parseOrderBy, } from '../parser/order-by-parser.js';\nimport { LimitNode } from '../operation-node/limit-node.js';\nimport { OffsetNode } from '../operation-node/offset-node.js';\nimport { asArray, freeze } from '../util/object-utils.js';\nimport { parseGroupBy } from '../parser/group-by-parser.js';\nimport { isNoResultErrorConstructor, NoResultError, } from './no-result-error.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { parseSetOperations, } from '../parser/set-operation-parser.js';\nimport { parseValueBinaryOperationOrExpression, parseReferentialBinaryOperation, } from '../parser/binary-operation-parser.js';\nimport { ExpressionWrapper } from '../expression/expression-wrapper.js';\nimport { parseValueExpression, } from '../parser/value-parser.js';\nimport { parseFetch } from '../parser/fetch-parser.js';\nimport { parseTop } from '../parser/top-parser.js';\nclass SelectQueryBuilderImpl {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    get expressionType() {\n        return undefined;\n    }\n    get isSelectQueryBuilder() {\n        return true;\n    }\n    where(...args) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithWhere(this.#props.queryNode, parseValueBinaryOperationOrExpression(args)),\n        });\n    }\n    whereRef(lhs, op, rhs) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithWhere(this.#props.queryNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n        });\n    }\n    having(...args) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithHaving(this.#props.queryNode, parseValueBinaryOperationOrExpression(args)),\n        });\n    }\n    havingRef(lhs, op, rhs) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithHaving(this.#props.queryNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n        });\n    }\n    select(selection) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithSelections(this.#props.queryNode, parseSelectArg(selection)),\n        });\n    }\n    distinctOn(selection) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithDistinctOn(this.#props.queryNode, parseReferenceExpressionOrList(selection)),\n        });\n    }\n    modifyFront(modifier) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithFrontModifier(this.#props.queryNode, SelectModifierNode.createWithExpression(modifier.toOperationNode())),\n        });\n    }\n    modifyEnd(modifier) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.createWithExpression(modifier.toOperationNode())),\n        });\n    }\n    distinct() {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithFrontModifier(this.#props.queryNode, SelectModifierNode.create('Distinct')),\n        });\n    }\n    forUpdate(of) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.create('ForUpdate', of ? asArray(of).map(parseTable) : undefined)),\n        });\n    }\n    forShare(of) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.create('ForShare', of ? asArray(of).map(parseTable) : undefined)),\n        });\n    }\n    forKeyShare(of) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.create('ForKeyShare', of ? asArray(of).map(parseTable) : undefined)),\n        });\n    }\n    forNoKeyUpdate(of) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.create('ForNoKeyUpdate', of ? asArray(of).map(parseTable) : undefined)),\n        });\n    }\n    skipLocked() {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.create('SkipLocked')),\n        });\n    }\n    noWait() {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.create('NoWait')),\n        });\n    }\n    selectAll(table) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithSelections(this.#props.queryNode, parseSelectAll(table)),\n        });\n    }\n    innerJoin(...args) {\n        return this.#join('InnerJoin', args);\n    }\n    leftJoin(...args) {\n        return this.#join('LeftJoin', args);\n    }\n    rightJoin(...args) {\n        return this.#join('RightJoin', args);\n    }\n    fullJoin(...args) {\n        return this.#join('FullJoin', args);\n    }\n    crossJoin(...args) {\n        return this.#join('CrossJoin', args);\n    }\n    innerJoinLateral(...args) {\n        return this.#join('LateralInnerJoin', args);\n    }\n    leftJoinLateral(...args) {\n        return this.#join('LateralLeftJoin', args);\n    }\n    crossJoinLateral(...args) {\n        return this.#join('LateralCrossJoin', args);\n    }\n    crossApply(...args) {\n        return this.#join('CrossApply', args);\n    }\n    outerApply(...args) {\n        return this.#join('OuterApply', args);\n    }\n    #join(joinType, args) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithJoin(this.#props.queryNode, parseJoin(joinType, args)),\n        });\n    }\n    orderBy(...args) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithOrderByItems(this.#props.queryNode, parseOrderBy(args)),\n        });\n    }\n    groupBy(groupBy) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithGroupByItems(this.#props.queryNode, parseGroupBy(groupBy)),\n        });\n    }\n    limit(limit) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithLimit(this.#props.queryNode, LimitNode.create(parseValueExpression(limit))),\n        });\n    }\n    offset(offset) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithOffset(this.#props.queryNode, OffsetNode.create(parseValueExpression(offset))),\n        });\n    }\n    fetch(rowCount, modifier = 'only') {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithFetch(this.#props.queryNode, parseFetch(rowCount, modifier)),\n        });\n    }\n    top(expression, modifiers) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithTop(this.#props.queryNode, parseTop(expression, modifiers)),\n        });\n    }\n    union(expression) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithSetOperations(this.#props.queryNode, parseSetOperations('union', expression, false)),\n        });\n    }\n    unionAll(expression) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithSetOperations(this.#props.queryNode, parseSetOperations('union', expression, true)),\n        });\n    }\n    intersect(expression) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithSetOperations(this.#props.queryNode, parseSetOperations('intersect', expression, false)),\n        });\n    }\n    intersectAll(expression) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithSetOperations(this.#props.queryNode, parseSetOperations('intersect', expression, true)),\n        });\n    }\n    except(expression) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithSetOperations(this.#props.queryNode, parseSetOperations('except', expression, false)),\n        });\n    }\n    exceptAll(expression) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithSetOperations(this.#props.queryNode, parseSetOperations('except', expression, true)),\n        });\n    }\n    as(alias) {\n        return new AliasedSelectQueryBuilderImpl(this, alias);\n    }\n    clearSelect() {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithoutSelections(this.#props.queryNode),\n        });\n    }\n    clearWhere() {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithoutWhere(this.#props.queryNode),\n        });\n    }\n    clearLimit() {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithoutLimit(this.#props.queryNode),\n        });\n    }\n    clearOffset() {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithoutOffset(this.#props.queryNode),\n        });\n    }\n    clearOrderBy() {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithoutOrderBy(this.#props.queryNode),\n        });\n    }\n    clearGroupBy() {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: SelectQueryNode.cloneWithoutGroupBy(this.#props.queryNode),\n        });\n    }\n    $call(func) {\n        return func(this);\n    }\n    $if(condition, func) {\n        if (condition) {\n            return func(this);\n        }\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n        });\n    }\n    $castTo() {\n        return new SelectQueryBuilderImpl(this.#props);\n    }\n    $narrowType() {\n        return new SelectQueryBuilderImpl(this.#props);\n    }\n    $assertType() {\n        return new SelectQueryBuilderImpl(this.#props);\n    }\n    $asTuple() {\n        return new ExpressionWrapper(this.toOperationNode());\n    }\n    $asScalar() {\n        return new ExpressionWrapper(this.toOperationNode());\n    }\n    withPlugin(plugin) {\n        return new SelectQueryBuilderImpl({\n            ...this.#props,\n            executor: this.#props.executor.withPlugin(plugin),\n        });\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.queryNode, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        const compiledQuery = this.compile();\n        const result = await this.#props.executor.executeQuery(compiledQuery, this.#props.queryId);\n        return result.rows;\n    }\n    async executeTakeFirst() {\n        const [result] = await this.execute();\n        return result;\n    }\n    async executeTakeFirstOrThrow(errorConstructor = NoResultError) {\n        const result = await this.executeTakeFirst();\n        if (result === undefined) {\n            const error = isNoResultErrorConstructor(errorConstructor)\n                ? new errorConstructor(this.toOperationNode())\n                : errorConstructor(this.toOperationNode());\n            throw error;\n        }\n        return result;\n    }\n    async *stream(chunkSize = 100) {\n        const compiledQuery = this.compile();\n        const stream = this.#props.executor.stream(compiledQuery, chunkSize, this.#props.queryId);\n        for await (const item of stream) {\n            yield* item.rows;\n        }\n    }\n    async explain(format, options) {\n        const builder = new SelectQueryBuilderImpl({\n            ...this.#props,\n            queryNode: QueryNode.cloneWithExplain(this.#props.queryNode, format, options),\n        });\n        return await builder.execute();\n    }\n}\nexport function createSelectQueryBuilder(props) {\n    return new SelectQueryBuilderImpl(props);\n}\n/**\n * {@link SelectQueryBuilder} with an alias. The result of calling {@link SelectQueryBuilder.as}.\n */\nclass AliasedSelectQueryBuilderImpl {\n    #queryBuilder;\n    #alias;\n    constructor(queryBuilder, alias) {\n        this.#queryBuilder = queryBuilder;\n        this.#alias = alias;\n    }\n    get expression() {\n        return this.#queryBuilder;\n    }\n    get alias() {\n        return this.#alias;\n    }\n    get isAliasedSelectQueryBuilder() {\n        return true;\n    }\n    toOperationNode() {\n        return AliasNode.create(this.#queryBuilder.toOperationNode(), IdentifierNode.create(this.#alias));\n    }\n}\n", "/// <reference types=\"./aggregate-function-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { WhereNode } from './where-node.js';\nimport { OrderByNode } from './order-by-node.js';\n/**\n * @internal\n */\nexport const AggregateFunctionNode = freeze({\n    is(node) {\n        return node.kind === 'AggregateFunctionNode';\n    },\n    create(aggregateFunction, aggregated = []) {\n        return freeze({\n            kind: 'AggregateFunctionNode',\n            func: aggregateFunction,\n            aggregated,\n        });\n    },\n    cloneWithDistinct(aggregateFunctionNode) {\n        return freeze({\n            ...aggregateFunctionNode,\n            distinct: true,\n        });\n    },\n    cloneWithOrderBy(aggregateFunctionNode, orderItems, withinGroup = false) {\n        const prop = withinGroup ? 'withinGroup' : 'orderBy';\n        return freeze({\n            ...aggregateFunctionNode,\n            [prop]: aggregateFunctionNode[prop]\n                ? OrderByNode.cloneWithItems(aggregateFunctionNode[prop], orderItems)\n                : OrderByNode.create(orderItems),\n        });\n    },\n    cloneWithFilter(aggregateFunctionNode, filter) {\n        return freeze({\n            ...aggregateFunctionNode,\n            filter: aggregateFunctionNode.filter\n                ? WhereNode.cloneWithOperation(aggregateFunctionNode.filter, 'And', filter)\n                : WhereNode.create(filter),\n        });\n    },\n    cloneWithOrFilter(aggregateFunctionNode, filter) {\n        return freeze({\n            ...aggregateFunctionNode,\n            filter: aggregateFunctionNode.filter\n                ? WhereNode.cloneWithOperation(aggregateFunctionNode.filter, 'Or', filter)\n                : WhereNode.create(filter),\n        });\n    },\n    cloneWithOver(aggregateFunctionNode, over) {\n        return freeze({\n            ...aggregateFunctionNode,\n            over,\n        });\n    },\n});\n", "/// <reference types=\"./function-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const FunctionNode = freeze({\n    is(node) {\n        return node.kind === 'FunctionNode';\n    },\n    create(func, args) {\n        return freeze({\n            kind: 'FunctionNode',\n            func,\n            arguments: args,\n        });\n    },\n});\n", "/// <reference types=\"./aggregate-function-builder.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { AggregateFunctionNode } from '../operation-node/aggregate-function-node.js';\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { createOverBuilder } from '../parser/parse-utils.js';\nimport { parseReferentialBinaryOperation, parseValueBinaryOperationOrExpression, } from '../parser/binary-operation-parser.js';\nimport { parseOrderBy, } from '../parser/order-by-parser.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nexport class AggregateFunctionBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /** @private */\n    get expressionType() {\n        return undefined;\n    }\n    /**\n     * Returns an aliased version of the function.\n     *\n     * In addition to slapping `as \"the_alias\"` to the end of the SQL,\n     * this method also provides strict typing:\n     *\n     * ```ts\n     * const result = await db\n     *   .selectFrom('person')\n     *   .select(\n     *     (eb) => eb.fn.count<number>('id').as('person_count')\n     *   )\n     *   .executeTakeFirstOrThrow()\n     *\n     * // `person_count: number` field exists in the result type.\n     * console.log(result.person_count)\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select count(\"id\") as \"person_count\"\n     * from \"person\"\n     * ```\n     */\n    as(alias) {\n        return new AliasedAggregateFunctionBuilder(this, alias);\n    }\n    /**\n     * Adds a `distinct` clause inside the function.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * const result = await db\n     *   .selectFrom('person')\n     *   .select((eb) =>\n     *     eb.fn.count<number>('first_name').distinct().as('first_name_count')\n     *   )\n     *   .executeTakeFirstOrThrow()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select count(distinct \"first_name\") as \"first_name_count\"\n     * from \"person\"\n     * ```\n     */\n    distinct() {\n        return new AggregateFunctionBuilder({\n            ...this.#props,\n            aggregateFunctionNode: AggregateFunctionNode.cloneWithDistinct(this.#props.aggregateFunctionNode),\n        });\n    }\n    orderBy(...args) {\n        return new AggregateFunctionBuilder({\n            ...this.#props,\n            aggregateFunctionNode: QueryNode.cloneWithOrderByItems(this.#props.aggregateFunctionNode, parseOrderBy(args)),\n        });\n    }\n    clearOrderBy() {\n        return new AggregateFunctionBuilder({\n            ...this.#props,\n            aggregateFunctionNode: QueryNode.cloneWithoutOrderBy(this.#props.aggregateFunctionNode),\n        });\n    }\n    withinGroupOrderBy(...args) {\n        return new AggregateFunctionBuilder({\n            ...this.#props,\n            aggregateFunctionNode: AggregateFunctionNode.cloneWithOrderBy(this.#props.aggregateFunctionNode, parseOrderBy(args), true),\n        });\n    }\n    filterWhere(...args) {\n        return new AggregateFunctionBuilder({\n            ...this.#props,\n            aggregateFunctionNode: AggregateFunctionNode.cloneWithFilter(this.#props.aggregateFunctionNode, parseValueBinaryOperationOrExpression(args)),\n        });\n    }\n    /**\n     * Adds a `filter` clause with a nested `where` clause after the function, where\n     * both sides of the operator are references to columns.\n     *\n     * Similar to {@link WhereInterface}'s `whereRef` method.\n     *\n     * ### Examples\n     *\n     * Count people with same first and last names versus general public:\n     *\n     * ```ts\n     * const result = await db\n     *   .selectFrom('person')\n     *   .select((eb) => [\n     *     eb.fn\n     *       .count<number>('id')\n     *       .filterWhereRef('first_name', '=', 'last_name')\n     *       .as('repeat_name_count'),\n     *     eb.fn.count<number>('id').as('total_count'),\n     *   ])\n     *   .executeTakeFirstOrThrow()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select\n     *   count(\"id\") filter(where \"first_name\" = \"last_name\") as \"repeat_name_count\",\n     *   count(\"id\") as \"total_count\"\n     * from \"person\"\n     * ```\n     */\n    filterWhereRef(lhs, op, rhs) {\n        return new AggregateFunctionBuilder({\n            ...this.#props,\n            aggregateFunctionNode: AggregateFunctionNode.cloneWithFilter(this.#props.aggregateFunctionNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n        });\n    }\n    /**\n     * Adds an `over` clause (window functions) after the function.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * const result = await db\n     *   .selectFrom('person')\n     *   .select(\n     *     (eb) => eb.fn.avg<number>('age').over().as('average_age')\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select avg(\"age\") over() as \"average_age\"\n     * from \"person\"\n     * ```\n     *\n     * Also supports passing a callback that returns an over builder,\n     * allowing to add partition by and sort by clauses inside over.\n     *\n     * ```ts\n     * const result = await db\n     *   .selectFrom('person')\n     *   .select(\n     *     (eb) => eb.fn.avg<number>('age').over(\n     *       ob => ob.partitionBy('last_name').orderBy('first_name', 'asc')\n     *     ).as('average_age')\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select avg(\"age\") over(partition by \"last_name\" order by \"first_name\" asc) as \"average_age\"\n     * from \"person\"\n     * ```\n     */\n    over(over) {\n        const builder = createOverBuilder();\n        return new AggregateFunctionBuilder({\n            ...this.#props,\n            aggregateFunctionNode: AggregateFunctionNode.cloneWithOver(this.#props.aggregateFunctionNode, (over ? over(builder) : builder).toOperationNode()),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    /**\n     * Casts the expression to the given type.\n     *\n     * This method call doesn't change the SQL in any way. This methods simply\n     * returns a copy of this `AggregateFunctionBuilder` with a new output type.\n     */\n    $castTo() {\n        return new AggregateFunctionBuilder(this.#props);\n    }\n    /**\n     * Omit null from the expression's type.\n     *\n     * This function can be useful in cases where you know an expression can't be\n     * null, but Kysely is unable to infer it.\n     *\n     * This method call doesn't change the SQL in any way. This methods simply\n     * returns a copy of `this` with a new output type.\n     */\n    $notNull() {\n        return new AggregateFunctionBuilder(this.#props);\n    }\n    toOperationNode() {\n        return this.#props.aggregateFunctionNode;\n    }\n}\n/**\n * {@link AggregateFunctionBuilder} with an alias. The result of calling {@link AggregateFunctionBuilder.as}.\n */\nexport class AliasedAggregateFunctionBuilder {\n    #aggregateFunctionBuilder;\n    #alias;\n    constructor(aggregateFunctionBuilder, alias) {\n        this.#aggregateFunctionBuilder = aggregateFunctionBuilder;\n        this.#alias = alias;\n    }\n    /** @private */\n    get expression() {\n        return this.#aggregateFunctionBuilder;\n    }\n    /** @private */\n    get alias() {\n        return this.#alias;\n    }\n    toOperationNode() {\n        return AliasNode.create(this.#aggregateFunctionBuilder.toOperationNode(), IdentifierNode.create(this.#alias));\n    }\n}\n", "/// <reference types=\"./function-module.d.ts\" />\nimport { ExpressionWrapper } from '../expression/expression-wrapper.js';\nimport { AggregateFunctionNode } from '../operation-node/aggregate-function-node.js';\nimport { FunctionNode } from '../operation-node/function-node.js';\nimport { parseReferenceExpressionOrList, } from '../parser/reference-parser.js';\nimport { parseSelectAll } from '../parser/select-parser.js';\nimport { AggregateFunctionBuilder } from './aggregate-function-builder.js';\nimport { isString } from '../util/object-utils.js';\nimport { parseTable } from '../parser/table-parser.js';\nexport function createFunctionModule() {\n    const fn = (name, args) => {\n        return new ExpressionWrapper(FunctionNode.create(name, parseReferenceExpressionOrList(args ?? [])));\n    };\n    const agg = (name, args) => {\n        return new AggregateFunctionBuilder({\n            aggregateFunctionNode: AggregateFunctionNode.create(name, args ? parseReferenceExpressionOrList(args) : undefined),\n        });\n    };\n    return Object.assign(fn, {\n        agg,\n        avg(column) {\n            return agg('avg', [column]);\n        },\n        coalesce(...values) {\n            return fn('coalesce', values);\n        },\n        count(column) {\n            return agg('count', [column]);\n        },\n        countAll(table) {\n            return new AggregateFunctionBuilder({\n                aggregateFunctionNode: AggregateFunctionNode.create('count', parseSelectAll(table)),\n            });\n        },\n        max(column) {\n            return agg('max', [column]);\n        },\n        min(column) {\n            return agg('min', [column]);\n        },\n        sum(column) {\n            return agg('sum', [column]);\n        },\n        any(column) {\n            return fn('any', [column]);\n        },\n        jsonAgg(table) {\n            return new AggregateFunctionBuilder({\n                aggregateFunctionNode: AggregateFunctionNode.create('json_agg', [\n                    isString(table) ? parseTable(table) : table.toOperationNode(),\n                ]),\n            });\n        },\n        toJson(table) {\n            return new ExpressionWrapper(FunctionNode.create('to_json', [\n                isString(table) ? parseTable(table) : table.toOperationNode(),\n            ]));\n        },\n    });\n}\n", "/// <reference types=\"./unary-operation-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const UnaryOperationNode = freeze({\n    is(node) {\n        return node.kind === 'UnaryOperationNode';\n    },\n    create(operator, operand) {\n        return freeze({\n            kind: 'UnaryOperationNode',\n            operator,\n            operand,\n        });\n    },\n});\n", "/// <reference types=\"./unary-operation-parser.d.ts\" />\nimport { OperatorNode } from '../operation-node/operator-node.js';\nimport { UnaryOperationNode } from '../operation-node/unary-operation-node.js';\nimport { parseReferenceExpression, } from './reference-parser.js';\nexport function parseExists(operand) {\n    return parseUnaryOperation('exists', operand);\n}\nexport function parseNotExists(operand) {\n    return parseUnaryOperation('not exists', operand);\n}\nexport function parseUnaryOperation(operator, operand) {\n    return UnaryOperationNode.create(OperatorNode.create(operator), parseReferenceExpression(operand));\n}\n", "/// <reference types=\"./case-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { WhenNode } from './when-node.js';\n/**\n * @internal\n */\nexport const CaseNode = freeze({\n    is(node) {\n        return node.kind === 'CaseNode';\n    },\n    create(value) {\n        return freeze({\n            kind: 'CaseNode',\n            value,\n        });\n    },\n    cloneWithWhen(caseNode, when) {\n        return freeze({\n            ...caseNode,\n            when: freeze(caseNode.when ? [...caseNode.when, when] : [when]),\n        });\n    },\n    cloneWithThen(caseNode, then) {\n        return freeze({\n            ...caseNode,\n            when: caseNode.when\n                ? freeze([\n                    ...caseNode.when.slice(0, -1),\n                    WhenNode.cloneWithResult(caseNode.when[caseNode.when.length - 1], then),\n                ])\n                : undefined,\n        });\n    },\n    cloneWith(caseNode, props) {\n        return freeze({\n            ...caseNode,\n            ...props,\n        });\n    },\n});\n", "/// <reference types=\"./case-builder.d.ts\" />\nimport { ExpressionWrapper } from '../expression/expression-wrapper.js';\nimport { freeze } from '../util/object-utils.js';\nimport { CaseNode } from '../operation-node/case-node.js';\nimport { WhenNode } from '../operation-node/when-node.js';\nimport { parseValueBinaryOperationOrExpression, } from '../parser/binary-operation-parser.js';\nimport { isSafeImmediateValue, parseSafeImmediateValue, parseValueExpression, } from '../parser/value-parser.js';\nexport class CaseBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    when(...args) {\n        return new CaseThenBuilder({\n            ...this.#props,\n            node: CaseNode.cloneWithWhen(this.#props.node, WhenNode.create(parseValueBinaryOperationOrExpression(args))),\n        });\n    }\n}\nexport class CaseThenBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    then(valueExpression) {\n        return new CaseWhenBuilder({\n            ...this.#props,\n            node: CaseNode.cloneWithThen(this.#props.node, isSafeImmediateValue(valueExpression)\n                ? parseSafeImmediateValue(valueExpression)\n                : parseValueExpression(valueExpression)),\n        });\n    }\n}\nexport class CaseWhenBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    when(...args) {\n        return new CaseThenBuilder({\n            ...this.#props,\n            node: CaseNode.cloneWithWhen(this.#props.node, WhenNode.create(parseValueBinaryOperationOrExpression(args))),\n        });\n    }\n    else(valueExpression) {\n        return new CaseEndBuilder({\n            ...this.#props,\n            node: CaseNode.cloneWith(this.#props.node, {\n                else: isSafeImmediateValue(valueExpression)\n                    ? parseSafeImmediateValue(valueExpression)\n                    : parseValueExpression(valueExpression),\n            }),\n        });\n    }\n    end() {\n        return new ExpressionWrapper(CaseNode.cloneWith(this.#props.node, { isStatement: false }));\n    }\n    endCase() {\n        return new ExpressionWrapper(CaseNode.cloneWith(this.#props.node, { isStatement: true }));\n    }\n}\nexport class CaseEndBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    end() {\n        return new ExpressionWrapper(CaseNode.cloneWith(this.#props.node, { isStatement: false }));\n    }\n    endCase() {\n        return new ExpressionWrapper(CaseNode.cloneWith(this.#props.node, { isStatement: true }));\n    }\n}\n", "/// <reference types=\"./json-path-leg-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const JSONPathLegNode = freeze({\n    is(node) {\n        return node.kind === 'JSONPathLegNode';\n    },\n    create(type, value) {\n        return freeze({\n            kind: 'JSONPathLegNode',\n            type,\n            value,\n        });\n    },\n});\n", "/// <reference types=\"./json-path-builder.d.ts\" />\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { JSONOperatorChainNode } from '../operation-node/json-operator-chain-node.js';\nimport { JSONPathLegNode, } from '../operation-node/json-path-leg-node.js';\nimport { JSONPathNode } from '../operation-node/json-path-node.js';\nimport { JSONReferenceNode } from '../operation-node/json-reference-node.js';\nimport { isOperationNodeSource } from '../operation-node/operation-node-source.js';\nimport { ValueNode } from '../operation-node/value-node.js';\nexport class JSONPathBuilder {\n    #node;\n    constructor(node) {\n        this.#node = node;\n    }\n    /**\n     * Access an element of a JSON array in a specific location.\n     *\n     * Since there's no guarantee an element exists in the given array location, the\n     * resulting type is always nullable. If you're sure the element exists, you\n     * should use {@link SelectQueryBuilder.$assertType} to narrow the type safely.\n     *\n     * See also {@link key} to access properties of JSON objects.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.selectFrom('person')\n     *   .select(eb =>\n     *     eb.ref('nicknames', '->').at(0).as('primary_nickname')\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select \"nicknames\"->0 as \"primary_nickname\" from \"person\"\n     *```\n     *\n     * Combined with {@link key}:\n     *\n     * ```ts\n     * db.selectFrom('person').select(eb =>\n     *   eb.ref('experience', '->').at(0).key('role').as('first_role')\n     * )\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select \"experience\"->0->'role' as \"first_role\" from \"person\"\n     * ```\n     *\n     * You can use `'last'` to access the last element of the array in MySQL:\n     *\n     * ```ts\n     * db.selectFrom('person').select(eb =>\n     *   eb.ref('nicknames', '->$').at('last').as('last_nickname')\n     * )\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * select `nicknames`->'$[last]' as `last_nickname` from `person`\n     * ```\n     *\n     * Or `'#-1'` in SQLite:\n     *\n     * ```ts\n     * db.selectFrom('person').select(eb =>\n     *   eb.ref('nicknames', '->>$').at('#-1').as('last_nickname')\n     * )\n     * ```\n     *\n     * The generated SQL (SQLite):\n     *\n     * ```sql\n     * select \"nicknames\"->>'$[#-1]' as `last_nickname` from `person`\n     * ```\n     */\n    at(index) {\n        return this.#createBuilderWithPathLeg('ArrayLocation', index);\n    }\n    /**\n     * Access a property of a JSON object.\n     *\n     * If a field is optional, the resulting type will be nullable.\n     *\n     * See also {@link at} to access elements of JSON arrays.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * db.selectFrom('person').select(eb =>\n     *   eb.ref('address', '->').key('city').as('city')\n     * )\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select \"address\"->'city' as \"city\" from \"person\"\n     * ```\n     *\n     * Going deeper:\n     *\n     * ```ts\n     * db.selectFrom('person').select(eb =>\n     *   eb.ref('profile', '->$').key('website').key('url').as('website_url')\n     * )\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * select `profile`->'$.website.url' as `website_url` from `person`\n     * ```\n     *\n     * Combined with {@link at}:\n     *\n     * ```ts\n     * db.selectFrom('person').select(eb =>\n     *   eb.ref('profile', '->').key('addresses').at(0).key('city').as('city')\n     * )\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select \"profile\"->'addresses'->0->'city' as \"city\" from \"person\"\n     * ```\n     */\n    key(key) {\n        return this.#createBuilderWithPathLeg('Member', key);\n    }\n    #createBuilderWithPathLeg(legType, value) {\n        if (JSONReferenceNode.is(this.#node)) {\n            return new TraversedJSONPathBuilder(JSONReferenceNode.cloneWithTraversal(this.#node, JSONPathNode.is(this.#node.traversal)\n                ? JSONPathNode.cloneWithLeg(this.#node.traversal, JSONPathLegNode.create(legType, value))\n                : JSONOperatorChainNode.cloneWithValue(this.#node.traversal, ValueNode.createImmediate(value))));\n        }\n        return new TraversedJSONPathBuilder(JSONPathNode.cloneWithLeg(this.#node, JSONPathLegNode.create(legType, value)));\n    }\n}\nexport class TraversedJSONPathBuilder extends JSONPathBuilder {\n    #node;\n    constructor(node) {\n        super(node);\n        this.#node = node;\n    }\n    /** @private */\n    get expressionType() {\n        return undefined;\n    }\n    as(alias) {\n        return new AliasedJSONPathBuilder(this, alias);\n    }\n    /**\n     * Change the output type of the json path.\n     *\n     * This method call doesn't change the SQL in any way. This methods simply\n     * returns a copy of this `JSONPathBuilder` with a new output type.\n     */\n    $castTo() {\n        return new TraversedJSONPathBuilder(this.#node);\n    }\n    $notNull() {\n        return new TraversedJSONPathBuilder(this.#node);\n    }\n    toOperationNode() {\n        return this.#node;\n    }\n}\nexport class AliasedJSONPathBuilder {\n    #jsonPath;\n    #alias;\n    constructor(jsonPath, alias) {\n        this.#jsonPath = jsonPath;\n        this.#alias = alias;\n    }\n    /** @private */\n    get expression() {\n        return this.#jsonPath;\n    }\n    /** @private */\n    get alias() {\n        return this.#alias;\n    }\n    toOperationNode() {\n        return AliasNode.create(this.#jsonPath.toOperationNode(), isOperationNodeSource(this.#alias)\n            ? this.#alias.toOperationNode()\n            : IdentifierNode.create(this.#alias));\n    }\n}\n", "/// <reference types=\"./tuple-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const TupleNode = freeze({\n    is(node) {\n        return node.kind === 'TupleNode';\n    },\n    create(values) {\n        return freeze({\n            kind: 'TupleNode',\n            values: freeze(values),\n        });\n    },\n});\n", "/// <reference types=\"./data-type-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nconst SIMPLE_COLUMN_DATA_TYPES = [\n    'varchar',\n    'char',\n    'text',\n    'integer',\n    'int2',\n    'int4',\n    'int8',\n    'smallint',\n    'bigint',\n    'boolean',\n    'real',\n    'double precision',\n    'float4',\n    'float8',\n    'decimal',\n    'numeric',\n    'binary',\n    'bytea',\n    'date',\n    'datetime',\n    'time',\n    'timetz',\n    'timestamp',\n    'timestamptz',\n    'serial',\n    'bigserial',\n    'uuid',\n    'json',\n    'jsonb',\n    'blob',\n    'varbinary',\n    'int4range',\n    'int4multirange',\n    'int8range',\n    'int8multirange',\n    'numrange',\n    'nummultirange',\n    'tsrange',\n    'tsmultirange',\n    'tstzrange',\n    'tstzmultirange',\n    'daterange',\n    'datemultirange',\n];\nconst COLUMN_DATA_TYPE_REGEX = [\n    /^varchar\\(\\d+\\)$/,\n    /^char\\(\\d+\\)$/,\n    /^decimal\\(\\d+, \\d+\\)$/,\n    /^numeric\\(\\d+, \\d+\\)$/,\n    /^binary\\(\\d+\\)$/,\n    /^datetime\\(\\d+\\)$/,\n    /^time\\(\\d+\\)$/,\n    /^timetz\\(\\d+\\)$/,\n    /^timestamp\\(\\d+\\)$/,\n    /^timestamptz\\(\\d+\\)$/,\n    /^varbinary\\(\\d+\\)$/,\n];\n/**\n * @internal\n */\nexport const DataTypeNode = freeze({\n    is(node) {\n        return node.kind === 'DataTypeNode';\n    },\n    create(dataType) {\n        return freeze({\n            kind: 'DataTypeNode',\n            dataType,\n        });\n    },\n});\nexport function isColumnDataType(dataType) {\n    if (SIMPLE_COLUMN_DATA_TYPES.includes(dataType)) {\n        return true;\n    }\n    if (COLUMN_DATA_TYPE_REGEX.some((r) => r.test(dataType))) {\n        return true;\n    }\n    return false;\n}\n", "/// <reference types=\"./data-type-parser.d.ts\" />\nimport { DataTypeNode, isColumnDataType, } from '../operation-node/data-type-node.js';\nimport { isOperationNodeSource } from '../operation-node/operation-node-source.js';\nexport function parseDataTypeExpression(dataType) {\n    if (isOperationNodeSource(dataType)) {\n        return dataType.toOperationNode();\n    }\n    if (isColumnDataType(dataType)) {\n        return DataTypeNode.create(dataType);\n    }\n    throw new Error(`invalid column data type ${JSON.stringify(dataType)}`);\n}\n", "/// <reference types=\"./cast-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const CastNode = freeze({\n    is(node) {\n        return node.kind === 'CastNode';\n    },\n    create(expression, dataType) {\n        return freeze({\n            kind: 'CastNode',\n            expression,\n            dataType,\n        });\n    },\n});\n", "/// <reference types=\"./expression-builder.d.ts\" />\nimport { createSelectQueryBuilder, } from '../query-builder/select-query-builder.js';\nimport { SelectQueryNode } from '../operation-node/select-query-node.js';\nimport { parseTableExpressionOrList, parseTable, } from '../parser/table-parser.js';\nimport { WithSchemaPlugin } from '../plugin/with-schema/with-schema-plugin.js';\nimport { createQueryId } from '../util/query-id.js';\nimport { createFunctionModule, } from '../query-builder/function-module.js';\nimport { parseJSONReference, parseReferenceExpression, parseStringReference, } from '../parser/reference-parser.js';\nimport { parseFilterList, parseFilterObject, parseValueBinaryOperation, parseValueBinaryOperationOrExpression, } from '../parser/binary-operation-parser.js';\nimport { ParensNode } from '../operation-node/parens-node.js';\nimport { ExpressionWrapper } from './expression-wrapper.js';\nimport { OperatorNode, } from '../operation-node/operator-node.js';\nimport { parseUnaryOperation } from '../parser/unary-operation-parser.js';\nimport { parseSafeImmediateValue, parseValueExpression, } from '../parser/value-parser.js';\nimport { NOOP_QUERY_EXECUTOR } from '../query-executor/noop-query-executor.js';\nimport { CaseBuilder } from '../query-builder/case-builder.js';\nimport { CaseNode } from '../operation-node/case-node.js';\nimport { isReadonlyArray, isUndefined } from '../util/object-utils.js';\nimport { JSONPathBuilder } from '../query-builder/json-path-builder.js';\nimport { BinaryOperationNode } from '../operation-node/binary-operation-node.js';\nimport { AndNode } from '../operation-node/and-node.js';\nimport { TupleNode } from '../operation-node/tuple-node.js';\nimport { JSONPathNode } from '../operation-node/json-path-node.js';\nimport { parseDataTypeExpression, } from '../parser/data-type-parser.js';\nimport { CastNode } from '../operation-node/cast-node.js';\nexport function createExpressionBuilder(executor = NOOP_QUERY_EXECUTOR) {\n    function binary(lhs, op, rhs) {\n        return new ExpressionWrapper(parseValueBinaryOperation(lhs, op, rhs));\n    }\n    function unary(op, expr) {\n        return new ExpressionWrapper(parseUnaryOperation(op, expr));\n    }\n    const eb = Object.assign(binary, {\n        fn: undefined,\n        eb: undefined,\n        selectFrom(table) {\n            return createSelectQueryBuilder({\n                queryId: createQueryId(),\n                executor,\n                queryNode: SelectQueryNode.createFrom(parseTableExpressionOrList(table)),\n            });\n        },\n        case(reference) {\n            return new CaseBuilder({\n                node: CaseNode.create(isUndefined(reference)\n                    ? undefined\n                    : parseReferenceExpression(reference)),\n            });\n        },\n        ref(reference, op) {\n            if (isUndefined(op)) {\n                return new ExpressionWrapper(parseStringReference(reference));\n            }\n            return new JSONPathBuilder(parseJSONReference(reference, op));\n        },\n        jsonPath() {\n            return new JSONPathBuilder(JSONPathNode.create());\n        },\n        table(table) {\n            return new ExpressionWrapper(parseTable(table));\n        },\n        val(value) {\n            return new ExpressionWrapper(parseValueExpression(value));\n        },\n        refTuple(...values) {\n            return new ExpressionWrapper(TupleNode.create(values.map(parseReferenceExpression)));\n        },\n        tuple(...values) {\n            return new ExpressionWrapper(TupleNode.create(values.map(parseValueExpression)));\n        },\n        lit(value) {\n            return new ExpressionWrapper(parseSafeImmediateValue(value));\n        },\n        unary,\n        not(expr) {\n            return unary('not', expr);\n        },\n        exists(expr) {\n            return unary('exists', expr);\n        },\n        neg(expr) {\n            return unary('-', expr);\n        },\n        between(expr, start, end) {\n            return new ExpressionWrapper(BinaryOperationNode.create(parseReferenceExpression(expr), OperatorNode.create('between'), AndNode.create(parseValueExpression(start), parseValueExpression(end))));\n        },\n        betweenSymmetric(expr, start, end) {\n            return new ExpressionWrapper(BinaryOperationNode.create(parseReferenceExpression(expr), OperatorNode.create('between symmetric'), AndNode.create(parseValueExpression(start), parseValueExpression(end))));\n        },\n        and(exprs) {\n            if (isReadonlyArray(exprs)) {\n                return new ExpressionWrapper(parseFilterList(exprs, 'and'));\n            }\n            return new ExpressionWrapper(parseFilterObject(exprs, 'and'));\n        },\n        or(exprs) {\n            if (isReadonlyArray(exprs)) {\n                return new ExpressionWrapper(parseFilterList(exprs, 'or'));\n            }\n            return new ExpressionWrapper(parseFilterObject(exprs, 'or'));\n        },\n        parens(...args) {\n            const node = parseValueBinaryOperationOrExpression(args);\n            if (ParensNode.is(node)) {\n                // No double wrapping.\n                return new ExpressionWrapper(node);\n            }\n            else {\n                return new ExpressionWrapper(ParensNode.create(node));\n            }\n        },\n        cast(expr, dataType) {\n            return new ExpressionWrapper(CastNode.create(parseReferenceExpression(expr), parseDataTypeExpression(dataType)));\n        },\n        withSchema(schema) {\n            return createExpressionBuilder(executor.withPluginAtFront(new WithSchemaPlugin(schema)));\n        },\n    });\n    eb.fn = createFunctionModule();\n    eb.eb = eb;\n    return eb;\n}\nexport function expressionBuilder(_) {\n    return createExpressionBuilder();\n}\n", "/// <reference types=\"./expression-parser.d.ts\" />\nimport { isAliasedExpression, isExpression, } from '../expression/expression.js';\nimport { isOperationNodeSource } from '../operation-node/operation-node-source.js';\nimport { expressionBuilder, } from '../expression/expression-builder.js';\nimport { isFunction } from '../util/object-utils.js';\nexport function parseExpression(exp) {\n    if (isOperationNodeSource(exp)) {\n        return exp.toOperationNode();\n    }\n    else if (isFunction(exp)) {\n        return exp(expressionBuilder()).toOperationNode();\n    }\n    throw new Error(`invalid expression: ${JSON.stringify(exp)}`);\n}\nexport function parseAliasedExpression(exp) {\n    if (isOperationNodeSource(exp)) {\n        return exp.toOperationNode();\n    }\n    else if (isFunction(exp)) {\n        return exp(expressionBuilder()).toOperationNode();\n    }\n    throw new Error(`invalid aliased expression: ${JSON.stringify(exp)}`);\n}\nexport function isExpressionOrFactory(obj) {\n    return isExpression(obj) || isAliasedExpression(obj) || isFunction(obj);\n}\n", "/// <reference types=\"./dynamic-table-builder.d.ts\" />\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { isOperationNodeSource, } from '../operation-node/operation-node-source.js';\nimport { parseTable } from '../parser/table-parser.js';\nimport { isObject, isString } from '../util/object-utils.js';\nexport class DynamicTableBuilder {\n    #table;\n    get table() {\n        return this.#table;\n    }\n    constructor(table) {\n        this.#table = table;\n    }\n    as(alias) {\n        return new AliasedDynamicTableBuilder(this.#table, alias);\n    }\n}\nexport class AliasedDynamicTableBuilder {\n    #table;\n    #alias;\n    get table() {\n        return this.#table;\n    }\n    get alias() {\n        return this.#alias;\n    }\n    constructor(table, alias) {\n        this.#table = table;\n        this.#alias = alias;\n    }\n    toOperationNode() {\n        return AliasNode.create(parseTable(this.#table), IdentifierNode.create(this.#alias));\n    }\n}\nexport function isAliasedDynamicTableBuilder(obj) {\n    return (isObject(obj) &&\n        isOperationNodeSource(obj) &&\n        isString(obj.table) &&\n        isString(obj.alias));\n}\n", "/// <reference types=\"./table-parser.d.ts\" />\nimport { isReadonlyArray, isString } from '../util/object-utils.js';\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { TableNode } from '../operation-node/table-node.js';\nimport { parseAliasedExpression, } from './expression-parser.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { isAliasedDynamicTableBuilder, } from '../dynamic/dynamic-table-builder.js';\nexport function parseTableExpressionOrList(table) {\n    if (isReadonlyArray(table)) {\n        return table.map((it) => parseTableExpression(it));\n    }\n    else {\n        return [parseTableExpression(table)];\n    }\n}\nexport function parseTableExpression(table) {\n    if (isString(table)) {\n        return parseAliasedTable(table);\n    }\n    else if (isAliasedDynamicTableBuilder(table)) {\n        return table.toOperationNode();\n    }\n    else {\n        return parseAliasedExpression(table);\n    }\n}\nexport function parseAliasedTable(from) {\n    const ALIAS_SEPARATOR = ' as ';\n    if (from.includes(ALIAS_SEPARATOR)) {\n        const [table, alias] = from.split(ALIAS_SEPARATOR).map(trim);\n        return AliasNode.create(parseTable(table), IdentifierNode.create(alias));\n    }\n    else {\n        return parseTable(from);\n    }\n}\nexport function parseTable(from) {\n    const SCHEMA_SEPARATOR = '.';\n    if (from.includes(SCHEMA_SEPARATOR)) {\n        const [schema, table] = from.split(SCHEMA_SEPARATOR).map(trim);\n        return TableNode.createWithSchema(schema, table);\n    }\n    else {\n        return TableNode.create(from);\n    }\n}\nfunction trim(str) {\n    return str.trim();\n}\n", "/// <reference types=\"./add-column-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const AddColumnNode = freeze({\n    is(node) {\n        return node.kind === 'AddColumnNode';\n    },\n    create(column) {\n        return freeze({\n            kind: 'AddColumnNode',\n            column,\n        });\n    },\n});\n", "/// <reference types=\"./column-definition-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { ColumnNode } from './column-node.js';\n/**\n * @internal\n */\nexport const ColumnDefinitionNode = freeze({\n    is(node) {\n        return node.kind === 'ColumnDefinitionNode';\n    },\n    create(column, dataType) {\n        return freeze({\n            kind: 'ColumnDefinitionNode',\n            column: ColumnNode.create(column),\n            dataType,\n        });\n    },\n    cloneWithFrontModifier(node, modifier) {\n        return freeze({\n            ...node,\n            frontModifiers: node.frontModifiers\n                ? freeze([...node.frontModifiers, modifier])\n                : [modifier],\n        });\n    },\n    cloneWithEndModifier(node, modifier) {\n        return freeze({\n            ...node,\n            endModifiers: node.endModifiers\n                ? freeze([...node.endModifiers, modifier])\n                : [modifier],\n        });\n    },\n    cloneWith(node, props) {\n        return freeze({\n            ...node,\n            ...props,\n        });\n    },\n});\n", "/// <reference types=\"./drop-column-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { ColumnNode } from './column-node.js';\n/**\n * @internal\n */\nexport const DropColumnNode = freeze({\n    is(node) {\n        return node.kind === 'DropColumnNode';\n    },\n    create(column) {\n        return freeze({\n            kind: 'DropColumnNode',\n            column: ColumnNode.create(column),\n        });\n    },\n});\n", "/// <reference types=\"./rename-column-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { ColumnNode } from './column-node.js';\n/**\n * @internal\n */\nexport const RenameColumnNode = freeze({\n    is(node) {\n        return node.kind === 'RenameColumnNode';\n    },\n    create(column, newColumn) {\n        return freeze({\n            kind: 'RenameColumnNode',\n            column: ColumnNode.create(column),\n            renameTo: ColumnNode.create(newColumn),\n        });\n    },\n});\n", "/// <reference types=\"./check-constraint-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const CheckConstraintNode = freeze({\n    is(node) {\n        return node.kind === 'CheckConstraintNode';\n    },\n    create(expression, constraintName) {\n        return freeze({\n            kind: 'CheckConstraintNode',\n            expression,\n            name: constraintName ? IdentifierNode.create(constraintName) : undefined,\n        });\n    },\n});\n", "/// <reference types=\"./references-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nexport const ON_MODIFY_FOREIGN_ACTIONS = [\n    'no action',\n    'restrict',\n    'cascade',\n    'set null',\n    'set default',\n];\n/**\n * @internal\n */\nexport const ReferencesNode = freeze({\n    is(node) {\n        return node.kind === 'ReferencesNode';\n    },\n    create(table, columns) {\n        return freeze({\n            kind: 'ReferencesNode',\n            table,\n            columns: freeze([...columns]),\n        });\n    },\n    cloneWithOnDelete(references, onDelete) {\n        return freeze({\n            ...references,\n            onDelete,\n        });\n    },\n    cloneWithOnUpdate(references, onUpdate) {\n        return freeze({\n            ...references,\n            onUpdate,\n        });\n    },\n});\n", "/// <reference types=\"./default-value-parser.d.ts\" />\nimport { isOperationNodeSource } from '../operation-node/operation-node-source.js';\nimport { ValueNode } from '../operation-node/value-node.js';\nexport function parseDefaultValueExpression(value) {\n    return isOperationNodeSource(value)\n        ? value.toOperationNode()\n        : ValueNode.createImmediate(value);\n}\n", "/// <reference types=\"./generated-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const GeneratedNode = freeze({\n    is(node) {\n        return node.kind === 'GeneratedNode';\n    },\n    create(params) {\n        return freeze({\n            kind: 'GeneratedNode',\n            ...params,\n        });\n    },\n    createWithExpression(expression) {\n        return freeze({\n            kind: 'GeneratedNode',\n            always: true,\n            expression,\n        });\n    },\n    cloneWith(node, params) {\n        return freeze({\n            ...node,\n            ...params,\n        });\n    },\n});\n", "/// <reference types=\"./default-value-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const DefaultValueNode = freeze({\n    is(node) {\n        return node.kind === 'DefaultValueNode';\n    },\n    create(defaultValue) {\n        return freeze({\n            kind: 'DefaultValueNode',\n            defaultValue,\n        });\n    },\n});\n", "/// <reference types=\"./on-modify-action-parser.d.ts\" />\nimport { ON_MODIFY_FOREIGN_ACTIONS, } from '../operation-node/references-node.js';\nexport function parseOnModifyForeignAction(action) {\n    if (ON_MODIFY_FOREIGN_ACTIONS.includes(action)) {\n        return action;\n    }\n    throw new Error(`invalid OnModifyForeignAction ${action}`);\n}\n", "/// <reference types=\"./column-definition-builder.d.ts\" />\nimport { CheckConstraintNode } from '../operation-node/check-constraint-node.js';\nimport { ReferencesNode, } from '../operation-node/references-node.js';\nimport { SelectAllNode } from '../operation-node/select-all-node.js';\nimport { parseStringReference } from '../parser/reference-parser.js';\nimport { ColumnDefinitionNode } from '../operation-node/column-definition-node.js';\nimport { parseDefaultValueExpression, } from '../parser/default-value-parser.js';\nimport { GeneratedNode } from '../operation-node/generated-node.js';\nimport { DefaultValueNode } from '../operation-node/default-value-node.js';\nimport { parseOnModifyForeignAction } from '../parser/on-modify-action-parser.js';\nexport class ColumnDefinitionBuilder {\n    #node;\n    constructor(node) {\n        this.#node = node;\n    }\n    /**\n     * Adds `auto_increment` or `autoincrement` to the column definition\n     * depending on the dialect.\n     *\n     * Some dialects like PostgreSQL don't support this. On PostgreSQL\n     * you can use the `serial` or `bigserial` data type instead.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('id', 'integer', col => col.autoIncrement().primaryKey())\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * create table `person` (\n     *   `id` integer primary key auto_increment\n     * )\n     * ```\n     */\n    autoIncrement() {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, { autoIncrement: true }));\n    }\n    /**\n     * Makes the column an identity column.\n     *\n     * This only works on some dialects like MS SQL Server (MSSQL).\n     *\n     * For PostgreSQL's `generated always as identity` use {@link generatedAlwaysAsIdentity}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('id', 'integer', col => col.identity().primaryKey())\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MSSQL):\n     *\n     * ```sql\n     * create table \"person\" (\n     *   \"id\" integer identity primary key\n     * )\n     * ```\n     */\n    identity() {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, { identity: true }));\n    }\n    /**\n     * Makes the column the primary key.\n     *\n     * If you want to specify a composite primary key use the\n     * {@link CreateTableBuilder.addPrimaryKeyConstraint} method.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('id', 'integer', col => col.primaryKey())\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * create table `person` (\n     *   `id` integer primary key\n     * )\n     */\n    primaryKey() {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, { primaryKey: true }));\n    }\n    /**\n     * Adds a foreign key constraint for the column.\n     *\n     * If your database engine doesn't support foreign key constraints in the\n     * column definition (like MySQL 5) you need to call the table level\n     * {@link CreateTableBuilder.addForeignKeyConstraint} method instead.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('pet')\n     *   .addColumn('owner_id', 'integer', (col) => col.references('person.id'))\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * create table \"pet\" (\n     *   \"owner_id\" integer references \"person\" (\"id\")\n     * )\n     * ```\n     */\n    references(ref) {\n        const references = parseStringReference(ref);\n        if (!references.table || SelectAllNode.is(references.column)) {\n            throw new Error(`invalid call references('${ref}'). The reference must have format table.column or schema.table.column`);\n        }\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, {\n            references: ReferencesNode.create(references.table, [\n                references.column,\n            ]),\n        }));\n    }\n    /**\n     * Adds an `on delete` constraint for the foreign key column.\n     *\n     * If your database engine doesn't support foreign key constraints in the\n     * column definition (like MySQL 5) you need to call the table level\n     * {@link CreateTableBuilder.addForeignKeyConstraint} method instead.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('pet')\n     *   .addColumn(\n     *     'owner_id',\n     *     'integer',\n     *     (col) => col.references('person.id').onDelete('cascade')\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * create table \"pet\" (\n     *   \"owner_id\" integer references \"person\" (\"id\") on delete cascade\n     * )\n     * ```\n     */\n    onDelete(onDelete) {\n        if (!this.#node.references) {\n            throw new Error('on delete constraint can only be added for foreign keys');\n        }\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, {\n            references: ReferencesNode.cloneWithOnDelete(this.#node.references, parseOnModifyForeignAction(onDelete)),\n        }));\n    }\n    /**\n     * Adds an `on update` constraint for the foreign key column.\n     *\n     * If your database engine doesn't support foreign key constraints in the\n     * column definition (like MySQL 5) you need to call the table level\n     * {@link CreateTableBuilder.addForeignKeyConstraint} method instead.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('pet')\n     *   .addColumn(\n     *     'owner_id',\n     *     'integer',\n     *     (col) => col.references('person.id').onUpdate('cascade')\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * create table \"pet\" (\n     *   \"owner_id\" integer references \"person\" (\"id\") on update cascade\n     * )\n     * ```\n     */\n    onUpdate(onUpdate) {\n        if (!this.#node.references) {\n            throw new Error('on update constraint can only be added for foreign keys');\n        }\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, {\n            references: ReferencesNode.cloneWithOnUpdate(this.#node.references, parseOnModifyForeignAction(onUpdate)),\n        }));\n    }\n    /**\n     * Adds a unique constraint for the column.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('email', 'varchar(255)', col => col.unique())\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * create table `person` (\n     *   `email` varchar(255) unique\n     * )\n     * ```\n     */\n    unique() {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, { unique: true }));\n    }\n    /**\n     * Adds a `not null` constraint for the column.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('first_name', 'varchar(255)', col => col.notNull())\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * create table `person` (\n     *   `first_name` varchar(255) not null\n     * )\n     * ```\n     */\n    notNull() {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, { notNull: true }));\n    }\n    /**\n     * Adds a `unsigned` modifier for the column.\n     *\n     * This only works on some dialects like MySQL.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('age', 'integer', col => col.unsigned())\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * create table `person` (\n     *   `age` integer unsigned\n     * )\n     * ```\n     */\n    unsigned() {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, { unsigned: true }));\n    }\n    /**\n     * Adds a default value constraint for the column.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('pet')\n     *   .addColumn('number_of_legs', 'integer', (col) => col.defaultTo(4))\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * create table `pet` (\n     *   `number_of_legs` integer default 4\n     * )\n     * ```\n     *\n     * Values passed to `defaultTo` are interpreted as value literals by default. You can define\n     * an arbitrary SQL expression using the {@link sql} template tag:\n     *\n     * ```ts\n     * import {\u00A0sql } from 'kysely'\n     *\n     * await db.schema\n     *   .createTable('pet')\n     *   .addColumn(\n     *     'created_at',\n     *     'timestamp',\n     *     (col) => col.defaultTo(sql`CURRENT_TIMESTAMP`)\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * create table `pet` (\n     *   `created_at` timestamp default CURRENT_TIMESTAMP\n     * )\n     * ```\n     */\n    defaultTo(value) {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, {\n            defaultTo: DefaultValueNode.create(parseDefaultValueExpression(value)),\n        }));\n    }\n    /**\n     * Adds a check constraint for the column.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import {\u00A0sql } from 'kysely'\n     *\n     * await db.schema\n     *   .createTable('pet')\n     *   .addColumn('number_of_legs', 'integer', (col) =>\n     *     col.check(sql`number_of_legs < 5`)\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * create table `pet` (\n     *   `number_of_legs` integer check (number_of_legs < 5)\n     * )\n     * ```\n     */\n    check(expression) {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, {\n            check: CheckConstraintNode.create(expression.toOperationNode()),\n        }));\n    }\n    /**\n     * Makes the column a generated column using a `generated always as` statement.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import {\u00A0sql } from 'kysely'\n     *\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('full_name', 'varchar(255)',\n     *     (col) => col.generatedAlwaysAs(sql`concat(first_name, ' ', last_name)`)\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * create table `person` (\n     *   `full_name` varchar(255) generated always as (concat(first_name, ' ', last_name))\n     * )\n     * ```\n     */\n    generatedAlwaysAs(expression) {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, {\n            generated: GeneratedNode.createWithExpression(expression.toOperationNode()),\n        }));\n    }\n    /**\n     * Adds the `generated always as identity` specifier.\n     *\n     * This only works on some dialects like PostgreSQL.\n     *\n     * For MS SQL Server (MSSQL)'s identity column use {@link identity}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('id', 'integer', col => col.generatedAlwaysAsIdentity().primaryKey())\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * create table \"person\" (\n     *   \"id\" integer generated always as identity primary key\n     * )\n     * ```\n     */\n    generatedAlwaysAsIdentity() {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, {\n            generated: GeneratedNode.create({ identity: true, always: true }),\n        }));\n    }\n    /**\n     * Adds the `generated by default as identity` specifier on supported dialects.\n     *\n     * This only works on some dialects like PostgreSQL.\n     *\n     * For MS SQL Server (MSSQL)'s identity column use {@link identity}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('id', 'integer', col => col.generatedByDefaultAsIdentity().primaryKey())\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * create table \"person\" (\n     *   \"id\" integer generated by default as identity primary key\n     * )\n     * ```\n     */\n    generatedByDefaultAsIdentity() {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, {\n            generated: GeneratedNode.create({ identity: true, byDefault: true }),\n        }));\n    }\n    /**\n     * Makes a generated column stored instead of virtual. This method can only\n     * be used with {@link generatedAlwaysAs}\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('full_name', 'varchar(255)', (col) => col\n     *     .generatedAlwaysAs(sql`concat(first_name, ' ', last_name)`)\n     *     .stored()\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * create table `person` (\n     *   `full_name` varchar(255) generated always as (concat(first_name, ' ', last_name)) stored\n     * )\n     * ```\n     */\n    stored() {\n        if (!this.#node.generated) {\n            throw new Error('stored() can only be called after generatedAlwaysAs');\n        }\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, {\n            generated: GeneratedNode.cloneWith(this.#node.generated, {\n                stored: true,\n            }),\n        }));\n    }\n    /**\n     * This can be used to add any additional SQL right after the column's data type.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('id', 'integer', col => col.primaryKey())\n     *   .addColumn(\n     *     'first_name',\n     *     'varchar(36)',\n     *     (col) => col.modifyFront(sql`collate utf8mb4_general_ci`).notNull()\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * create table `person` (\n     *   `id` integer primary key,\n     *   `first_name` varchar(36) collate utf8mb4_general_ci not null\n     * )\n     * ```\n     */\n    modifyFront(modifier) {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWithFrontModifier(this.#node, modifier.toOperationNode()));\n    }\n    /**\n     * Adds `nulls not distinct` specifier.\n     * Should be used with `unique` constraint.\n     *\n     * This only works on some dialects like PostgreSQL.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * db.schema\n     *   .createTable('person')\n     *   .addColumn('id', 'integer', col => col.primaryKey())\n     *   .addColumn('first_name', 'varchar(30)', col => col.unique().nullsNotDistinct())\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * create table \"person\" (\n     *   \"id\" integer primary key,\n     *   \"first_name\" varchar(30) unique nulls not distinct\n     * )\n     * ```\n     */\n    nullsNotDistinct() {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, { nullsNotDistinct: true }));\n    }\n    /**\n     * Adds `if not exists` specifier. This only works for PostgreSQL.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .alterTable('person')\n     *   .addColumn('email', 'varchar(255)', col => col.unique().ifNotExists())\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * alter table \"person\" add column if not exists \"email\" varchar(255) unique\n     * ```\n     */\n    ifNotExists() {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWith(this.#node, { ifNotExists: true }));\n    }\n    /**\n     * This can be used to add any additional SQL to the end of the column definition.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('id', 'integer', col => col.primaryKey())\n     *   .addColumn(\n     *     'age',\n     *     'integer',\n     *     col => col.unsigned()\n     *       .notNull()\n     *       .modifyEnd(sql`comment ${sql.lit('it is not polite to ask a woman her age')}`)\n     *   )\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * create table `person` (\n     *   `id` integer primary key,\n     *   `age` integer unsigned not null comment 'it is not polite to ask a woman her age'\n     * )\n     * ```\n     */\n    modifyEnd(modifier) {\n        return new ColumnDefinitionBuilder(ColumnDefinitionNode.cloneWithEndModifier(this.#node, modifier.toOperationNode()));\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#node;\n    }\n}\n", "/// <reference types=\"./modify-column-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ModifyColumnNode = freeze({\n    is(node) {\n        return node.kind === 'ModifyColumnNode';\n    },\n    create(column) {\n        return freeze({\n            kind: 'ModifyColumnNode',\n            column,\n        });\n    },\n});\n", "/// <reference types=\"./foreign-key-constraint-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\nimport { ReferencesNode } from './references-node.js';\n/**\n * @internal\n */\nexport const ForeignKeyConstraintNode = freeze({\n    is(node) {\n        return node.kind === 'ForeignKeyConstraintNode';\n    },\n    create(sourceColumns, targetTable, targetColumns, constraintName) {\n        return freeze({\n            kind: 'ForeignKeyConstraintNode',\n            columns: sourceColumns,\n            references: ReferencesNode.create(targetTable, targetColumns),\n            name: constraintName ? IdentifierNode.create(constraintName) : undefined,\n        });\n    },\n    cloneWith(node, props) {\n        return freeze({\n            ...node,\n            ...props,\n        });\n    },\n});\n", "/// <reference types=\"./foreign-key-constraint-builder.d.ts\" />\nimport { ForeignKeyConstraintNode } from '../operation-node/foreign-key-constraint-node.js';\nimport { parseOnModifyForeignAction } from '../parser/on-modify-action-parser.js';\nexport class ForeignKeyConstraintBuilder {\n    #node;\n    constructor(node) {\n        this.#node = node;\n    }\n    onDelete(onDelete) {\n        return new ForeignKeyConstraintBuilder(ForeignKeyConstraintNode.cloneWith(this.#node, {\n            onDelete: parseOnModifyForeignAction(onDelete),\n        }));\n    }\n    onUpdate(onUpdate) {\n        return new ForeignKeyConstraintBuilder(ForeignKeyConstraintNode.cloneWith(this.#node, {\n            onUpdate: parseOnModifyForeignAction(onUpdate),\n        }));\n    }\n    deferrable() {\n        return new ForeignKeyConstraintBuilder(ForeignKeyConstraintNode.cloneWith(this.#node, { deferrable: true }));\n    }\n    notDeferrable() {\n        return new ForeignKeyConstraintBuilder(ForeignKeyConstraintNode.cloneWith(this.#node, { deferrable: false }));\n    }\n    initiallyDeferred() {\n        return new ForeignKeyConstraintBuilder(ForeignKeyConstraintNode.cloneWith(this.#node, {\n            initiallyDeferred: true,\n        }));\n    }\n    initiallyImmediate() {\n        return new ForeignKeyConstraintBuilder(ForeignKeyConstraintNode.cloneWith(this.#node, {\n            initiallyDeferred: false,\n        }));\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#node;\n    }\n}\n", "/// <reference types=\"./add-constraint-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const AddConstraintNode = freeze({\n    is(node) {\n        return node.kind === 'AddConstraintNode';\n    },\n    create(constraint) {\n        return freeze({\n            kind: 'AddConstraintNode',\n            constraint,\n        });\n    },\n});\n", "/// <reference types=\"./unique-constraint-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { ColumnNode } from './column-node.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const UniqueConstraintNode = freeze({\n    is(node) {\n        return node.kind === 'UniqueConstraintNode';\n    },\n    create(columns, constraintName, nullsNotDistinct) {\n        return freeze({\n            kind: 'UniqueConstraintNode',\n            columns: freeze(columns.map(ColumnNode.create)),\n            name: constraintName ? IdentifierNode.create(constraintName) : undefined,\n            nullsNotDistinct,\n        });\n    },\n    cloneWith(node, props) {\n        return freeze({\n            ...node,\n            ...props,\n        });\n    },\n});\n", "/// <reference types=\"./drop-constraint-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const DropConstraintNode = freeze({\n    is(node) {\n        return node.kind === 'DropConstraintNode';\n    },\n    create(constraintName) {\n        return freeze({\n            kind: 'DropConstraintNode',\n            constraintName: IdentifierNode.create(constraintName),\n        });\n    },\n    cloneWith(dropConstraint, props) {\n        return freeze({\n            ...dropConstraint,\n            ...props,\n        });\n    },\n});\n", "/// <reference types=\"./alter-column-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { ColumnNode } from './column-node.js';\n/**\n * @internal\n */\nexport const AlterColumnNode = freeze({\n    is(node) {\n        return node.kind === 'AlterColumnNode';\n    },\n    create(column, prop, value) {\n        return freeze({\n            kind: 'AlterColumnNode',\n            column: ColumnNode.create(column),\n            [prop]: value,\n        });\n    },\n});\n", "/// <reference types=\"./alter-column-builder.d.ts\" />\nimport { AlterColumnNode } from '../operation-node/alter-column-node.js';\nimport { parseDataTypeExpression, } from '../parser/data-type-parser.js';\nimport { parseDefaultValueExpression, } from '../parser/default-value-parser.js';\nexport class AlterColumnBuilder {\n    #column;\n    constructor(column) {\n        this.#column = column;\n    }\n    setDataType(dataType) {\n        return new AlteredColumnBuilder(AlterColumnNode.create(this.#column, 'dataType', parseDataTypeExpression(dataType)));\n    }\n    setDefault(value) {\n        return new AlteredColumnBuilder(AlterColumnNode.create(this.#column, 'setDefault', parseDefaultValueExpression(value)));\n    }\n    dropDefault() {\n        return new AlteredColumnBuilder(AlterColumnNode.create(this.#column, 'dropDefault', true));\n    }\n    setNotNull() {\n        return new AlteredColumnBuilder(AlterColumnNode.create(this.#column, 'setNotNull', true));\n    }\n    dropNotNull() {\n        return new AlteredColumnBuilder(AlterColumnNode.create(this.#column, 'dropNotNull', true));\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n}\n/**\n * Allows us to force consumers to do exactly one alteration to a column.\n *\n * One cannot do no alterations:\n *\n * ```ts\n * await db.schema\n *   .alterTable('person')\n * //  .execute() // Property 'execute' does not exist on type 'AlteredColumnBuilder'.\n * ```\n *\n * ```ts\n * await db.schema\n *   .alterTable('person')\n * //  .alterColumn('age', (ac) => ac) // Type 'AlterColumnBuilder' is not assignable to type 'AlteredColumnBuilder'.\n * //  .execute()\n * ```\n *\n * One cannot do multiple alterations:\n *\n * ```ts\n * await db.schema\n *   .alterTable('person')\n * //  .alterColumn('age', (ac) => ac.dropNotNull().setNotNull()) // Property 'setNotNull' does not exist on type 'AlteredColumnBuilder'.\n * //  .execute()\n * ```\n *\n * Which would now throw a compilation error, instead of a runtime error.\n */\nexport class AlteredColumnBuilder {\n    #alterColumnNode;\n    constructor(alterColumnNode) {\n        this.#alterColumnNode = alterColumnNode;\n    }\n    toOperationNode() {\n        return this.#alterColumnNode;\n    }\n}\n", "/// <reference types=\"./alter-table-executor.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nexport class AlterTableExecutor {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./alter-table-add-foreign-key-constraint-builder.d.ts\" />\nimport { AddConstraintNode } from '../operation-node/add-constraint-node.js';\nimport { AlterTableNode } from '../operation-node/alter-table-node.js';\nimport { freeze } from '../util/object-utils.js';\nexport class AlterTableAddForeignKeyConstraintBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    onDelete(onDelete) {\n        return new AlterTableAddForeignKeyConstraintBuilder({\n            ...this.#props,\n            constraintBuilder: this.#props.constraintBuilder.onDelete(onDelete),\n        });\n    }\n    onUpdate(onUpdate) {\n        return new AlterTableAddForeignKeyConstraintBuilder({\n            ...this.#props,\n            constraintBuilder: this.#props.constraintBuilder.onUpdate(onUpdate),\n        });\n    }\n    deferrable() {\n        return new AlterTableAddForeignKeyConstraintBuilder({\n            ...this.#props,\n            constraintBuilder: this.#props.constraintBuilder.deferrable(),\n        });\n    }\n    notDeferrable() {\n        return new AlterTableAddForeignKeyConstraintBuilder({\n            ...this.#props,\n            constraintBuilder: this.#props.constraintBuilder.notDeferrable(),\n        });\n    }\n    initiallyDeferred() {\n        return new AlterTableAddForeignKeyConstraintBuilder({\n            ...this.#props,\n            constraintBuilder: this.#props.constraintBuilder.initiallyDeferred(),\n        });\n    }\n    initiallyImmediate() {\n        return new AlterTableAddForeignKeyConstraintBuilder({\n            ...this.#props,\n            constraintBuilder: this.#props.constraintBuilder.initiallyImmediate(),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(AlterTableNode.cloneWithTableProps(this.#props.node, {\n            addConstraint: AddConstraintNode.create(this.#props.constraintBuilder.toOperationNode()),\n        }), this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./alter-table-drop-constraint-builder.d.ts\" />\nimport { AlterTableNode } from '../operation-node/alter-table-node.js';\nimport { DropConstraintNode } from '../operation-node/drop-constraint-node.js';\nimport { freeze } from '../util/object-utils.js';\nexport class AlterTableDropConstraintBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    ifExists() {\n        return new AlterTableDropConstraintBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                dropConstraint: DropConstraintNode.cloneWith(this.#props.node.dropConstraint, {\n                    ifExists: true,\n                }),\n            }),\n        });\n    }\n    cascade() {\n        return new AlterTableDropConstraintBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                dropConstraint: DropConstraintNode.cloneWith(this.#props.node.dropConstraint, {\n                    modifier: 'cascade',\n                }),\n            }),\n        });\n    }\n    restrict() {\n        return new AlterTableDropConstraintBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                dropConstraint: DropConstraintNode.cloneWith(this.#props.node.dropConstraint, {\n                    modifier: 'restrict',\n                }),\n            }),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./primary-key-constraint-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { ColumnNode } from './column-node.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const PrimaryKeyConstraintNode = freeze({\n    is(node) {\n        return node.kind === 'PrimaryKeyConstraintNode';\n    },\n    create(columns, constraintName) {\n        return freeze({\n            kind: 'PrimaryKeyConstraintNode',\n            columns: freeze(columns.map(ColumnNode.create)),\n            name: constraintName ? IdentifierNode.create(constraintName) : undefined,\n        });\n    },\n    cloneWith(node, props) {\n        return freeze({ ...node, ...props });\n    },\n});\n/**\n * Backwards compatibility for a typo in the codebase.\n *\n * @deprecated Use {@link PrimaryKeyConstraintNode} instead.\n */\nexport const PrimaryConstraintNode = PrimaryKeyConstraintNode;\n", "/// <reference types=\"./add-index-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const AddIndexNode = freeze({\n    is(node) {\n        return node.kind === 'AddIndexNode';\n    },\n    create(name) {\n        return freeze({\n            kind: 'AddIndexNode',\n            name: IdentifierNode.create(name),\n        });\n    },\n    cloneWith(node, props) {\n        return freeze({\n            ...node,\n            ...props,\n        });\n    },\n    cloneWithColumns(node, columns) {\n        return freeze({\n            ...node,\n            columns: [...(node.columns || []), ...columns],\n        });\n    },\n});\n", "/// <reference types=\"./alter-table-add-index-builder.d.ts\" />\nimport { AddIndexNode } from '../operation-node/add-index-node.js';\nimport { AlterTableNode } from '../operation-node/alter-table-node.js';\nimport { RawNode } from '../operation-node/raw-node.js';\nimport { parseOrderedColumnName, } from '../parser/reference-parser.js';\nimport { freeze } from '../util/object-utils.js';\nexport class AlterTableAddIndexBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * Makes the index unique.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .alterTable('person')\n     *   .addIndex('person_first_name_index')\n     *   .unique()\n     *   .column('email')\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * alter table `person` add unique index `person_first_name_index` (`email`)\n     * ```\n     */\n    unique() {\n        return new AlterTableAddIndexBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                addIndex: AddIndexNode.cloneWith(this.#props.node.addIndex, {\n                    unique: true,\n                }),\n            }),\n        });\n    }\n    /**\n     * Adds a column to the index.\n     *\n     * Also see {@link columns} for adding multiple columns at once or {@link expression}\n     * for specifying an arbitrary expression.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .alterTable('person')\n     *   .addIndex('person_first_name_and_age_index')\n     *   .column('first_name')\n     *   .column('age desc')\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * alter table `person` add index `person_first_name_and_age_index` (`first_name`, `age` desc)\n     * ```\n     */\n    column(column) {\n        return new AlterTableAddIndexBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                addIndex: AddIndexNode.cloneWithColumns(this.#props.node.addIndex, [\n                    parseOrderedColumnName(column),\n                ]),\n            }),\n        });\n    }\n    /**\n     * Specifies a list of columns for the index.\n     *\n     * Also see {@link column} for adding a single column or {@link expression} for\n     * specifying an arbitrary expression.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .alterTable('person')\n     *   .addIndex('person_first_name_and_age_index')\n     *   .columns(['first_name', 'age desc'])\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * alter table `person` add index `person_first_name_and_age_index` (`first_name`, `age` desc)\n     * ```\n     */\n    columns(columns) {\n        return new AlterTableAddIndexBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                addIndex: AddIndexNode.cloneWithColumns(this.#props.node.addIndex, columns.map(parseOrderedColumnName)),\n            }),\n        });\n    }\n    /**\n     * Specifies an arbitrary expression for the index.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import {\u00A0sql } from 'kysely'\n     *\n     * await db.schema\n     *   .alterTable('person')\n     *   .addIndex('person_first_name_index')\n     *   .expression(sql<boolean>`(first_name < 'Sami')`)\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * alter table `person` add index `person_first_name_index` ((first_name < 'Sami'))\n     * ```\n     */\n    expression(expression) {\n        return new AlterTableAddIndexBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                addIndex: AddIndexNode.cloneWithColumns(this.#props.node.addIndex, [\n                    expression.toOperationNode(),\n                ]),\n            }),\n        });\n    }\n    using(indexType) {\n        return new AlterTableAddIndexBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                addIndex: AddIndexNode.cloneWith(this.#props.node.addIndex, {\n                    using: RawNode.createWithSql(indexType),\n                }),\n            }),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./unique-constraint-builder.d.ts\" />\nimport { UniqueConstraintNode } from '../operation-node/unique-constraint-node.js';\nexport class UniqueConstraintNodeBuilder {\n    #node;\n    constructor(node) {\n        this.#node = node;\n    }\n    /**\n     * Adds `nulls not distinct` to the unique constraint definition\n     *\n     * Supported by PostgreSQL dialect only\n     */\n    nullsNotDistinct() {\n        return new UniqueConstraintNodeBuilder(UniqueConstraintNode.cloneWith(this.#node, { nullsNotDistinct: true }));\n    }\n    deferrable() {\n        return new UniqueConstraintNodeBuilder(UniqueConstraintNode.cloneWith(this.#node, { deferrable: true }));\n    }\n    notDeferrable() {\n        return new UniqueConstraintNodeBuilder(UniqueConstraintNode.cloneWith(this.#node, { deferrable: false }));\n    }\n    initiallyDeferred() {\n        return new UniqueConstraintNodeBuilder(UniqueConstraintNode.cloneWith(this.#node, {\n            initiallyDeferred: true,\n        }));\n    }\n    initiallyImmediate() {\n        return new UniqueConstraintNodeBuilder(UniqueConstraintNode.cloneWith(this.#node, {\n            initiallyDeferred: false,\n        }));\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#node;\n    }\n}\n", "/// <reference types=\"./primary-key-constraint-builder.d.ts\" />\nimport { PrimaryKeyConstraintNode } from '../operation-node/primary-key-constraint-node.js';\nexport class PrimaryKeyConstraintBuilder {\n    #node;\n    constructor(node) {\n        this.#node = node;\n    }\n    deferrable() {\n        return new PrimaryKeyConstraintBuilder(PrimaryKeyConstraintNode.cloneWith(this.#node, { deferrable: true }));\n    }\n    notDeferrable() {\n        return new PrimaryKeyConstraintBuilder(PrimaryKeyConstraintNode.cloneWith(this.#node, { deferrable: false }));\n    }\n    initiallyDeferred() {\n        return new PrimaryKeyConstraintBuilder(PrimaryKeyConstraintNode.cloneWith(this.#node, {\n            initiallyDeferred: true,\n        }));\n    }\n    initiallyImmediate() {\n        return new PrimaryKeyConstraintBuilder(PrimaryKeyConstraintNode.cloneWith(this.#node, {\n            initiallyDeferred: false,\n        }));\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#node;\n    }\n}\n", "/// <reference types=\"./check-constraint-builder.d.ts\" />\nexport class CheckConstraintBuilder {\n    #node;\n    constructor(node) {\n        this.#node = node;\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#node;\n    }\n}\n", "/// <reference types=\"./rename-constraint-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const RenameConstraintNode = freeze({\n    is(node) {\n        return node.kind === 'RenameConstraintNode';\n    },\n    create(oldName, newName) {\n        return freeze({\n            kind: 'RenameConstraintNode',\n            oldName: IdentifierNode.create(oldName),\n            newName: IdentifierNode.create(newName),\n        });\n    },\n});\n", "/// <reference types=\"./alter-table-builder.d.ts\" />\nimport { AddColumnNode } from '../operation-node/add-column-node.js';\nimport { AlterTableNode } from '../operation-node/alter-table-node.js';\nimport { ColumnDefinitionNode } from '../operation-node/column-definition-node.js';\nimport { DropColumnNode } from '../operation-node/drop-column-node.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { RenameColumnNode } from '../operation-node/rename-column-node.js';\nimport { freeze, noop } from '../util/object-utils.js';\nimport { ColumnDefinitionBuilder, } from './column-definition-builder.js';\nimport { ModifyColumnNode } from '../operation-node/modify-column-node.js';\nimport { parseDataTypeExpression, } from '../parser/data-type-parser.js';\nimport { ForeignKeyConstraintBuilder, } from './foreign-key-constraint-builder.js';\nimport { AddConstraintNode } from '../operation-node/add-constraint-node.js';\nimport { UniqueConstraintNode } from '../operation-node/unique-constraint-node.js';\nimport { CheckConstraintNode } from '../operation-node/check-constraint-node.js';\nimport { ForeignKeyConstraintNode } from '../operation-node/foreign-key-constraint-node.js';\nimport { ColumnNode } from '../operation-node/column-node.js';\nimport { parseTable } from '../parser/table-parser.js';\nimport { DropConstraintNode } from '../operation-node/drop-constraint-node.js';\nimport { AlterColumnBuilder, } from './alter-column-builder.js';\nimport { AlterTableExecutor } from './alter-table-executor.js';\nimport { AlterTableAddForeignKeyConstraintBuilder } from './alter-table-add-foreign-key-constraint-builder.js';\nimport { AlterTableDropConstraintBuilder } from './alter-table-drop-constraint-builder.js';\nimport { PrimaryKeyConstraintNode } from '../operation-node/primary-key-constraint-node.js';\nimport { DropIndexNode } from '../operation-node/drop-index-node.js';\nimport { AddIndexNode } from '../operation-node/add-index-node.js';\nimport { AlterTableAddIndexBuilder } from './alter-table-add-index-builder.js';\nimport { UniqueConstraintNodeBuilder, } from './unique-constraint-builder.js';\nimport { PrimaryKeyConstraintBuilder, } from './primary-key-constraint-builder.js';\nimport { CheckConstraintBuilder, } from './check-constraint-builder.js';\nimport { RenameConstraintNode } from '../operation-node/rename-constraint-node.js';\n/**\n * This builder can be used to create a `alter table` query.\n */\nexport class AlterTableBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    renameTo(newTableName) {\n        return new AlterTableExecutor({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                renameTo: parseTable(newTableName),\n            }),\n        });\n    }\n    setSchema(newSchema) {\n        return new AlterTableExecutor({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                setSchema: IdentifierNode.create(newSchema),\n            }),\n        });\n    }\n    alterColumn(column, alteration) {\n        const builder = alteration(new AlterColumnBuilder(column));\n        return new AlterTableColumnAlteringBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithColumnAlteration(this.#props.node, builder.toOperationNode()),\n        });\n    }\n    dropColumn(column) {\n        return new AlterTableColumnAlteringBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithColumnAlteration(this.#props.node, DropColumnNode.create(column)),\n        });\n    }\n    renameColumn(column, newColumn) {\n        return new AlterTableColumnAlteringBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithColumnAlteration(this.#props.node, RenameColumnNode.create(column, newColumn)),\n        });\n    }\n    addColumn(columnName, dataType, build = noop) {\n        const builder = build(new ColumnDefinitionBuilder(ColumnDefinitionNode.create(columnName, parseDataTypeExpression(dataType))));\n        return new AlterTableColumnAlteringBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithColumnAlteration(this.#props.node, AddColumnNode.create(builder.toOperationNode())),\n        });\n    }\n    modifyColumn(columnName, dataType, build = noop) {\n        const builder = build(new ColumnDefinitionBuilder(ColumnDefinitionNode.create(columnName, parseDataTypeExpression(dataType))));\n        return new AlterTableColumnAlteringBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithColumnAlteration(this.#props.node, ModifyColumnNode.create(builder.toOperationNode())),\n        });\n    }\n    /**\n     * See {@link CreateTableBuilder.addUniqueConstraint}\n     */\n    addUniqueConstraint(constraintName, columns, build = noop) {\n        const uniqueConstraintBuilder = build(new UniqueConstraintNodeBuilder(UniqueConstraintNode.create(columns, constraintName)));\n        return new AlterTableExecutor({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                addConstraint: AddConstraintNode.create(uniqueConstraintBuilder.toOperationNode()),\n            }),\n        });\n    }\n    /**\n     * See {@link CreateTableBuilder.addCheckConstraint}\n     */\n    addCheckConstraint(constraintName, checkExpression, build = noop) {\n        const constraintBuilder = build(new CheckConstraintBuilder(CheckConstraintNode.create(checkExpression.toOperationNode(), constraintName)));\n        return new AlterTableExecutor({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                addConstraint: AddConstraintNode.create(constraintBuilder.toOperationNode()),\n            }),\n        });\n    }\n    /**\n     * See {@link CreateTableBuilder.addForeignKeyConstraint}\n     *\n     * Unlike {@link CreateTableBuilder.addForeignKeyConstraint} this method returns\n     * the constraint builder and doesn't take a callback as the last argument. This\n     * is because you can only add one column per `ALTER TABLE` query.\n     */\n    addForeignKeyConstraint(constraintName, columns, targetTable, targetColumns, build = noop) {\n        const constraintBuilder = build(new ForeignKeyConstraintBuilder(ForeignKeyConstraintNode.create(columns.map(ColumnNode.create), parseTable(targetTable), targetColumns.map(ColumnNode.create), constraintName)));\n        return new AlterTableAddForeignKeyConstraintBuilder({\n            ...this.#props,\n            constraintBuilder,\n        });\n    }\n    /**\n     * See {@link CreateTableBuilder.addPrimaryKeyConstraint}\n     */\n    addPrimaryKeyConstraint(constraintName, columns, build = noop) {\n        const constraintBuilder = build(new PrimaryKeyConstraintBuilder(PrimaryKeyConstraintNode.create(columns, constraintName)));\n        return new AlterTableExecutor({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                addConstraint: AddConstraintNode.create(constraintBuilder.toOperationNode()),\n            }),\n        });\n    }\n    dropConstraint(constraintName) {\n        return new AlterTableDropConstraintBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                dropConstraint: DropConstraintNode.create(constraintName),\n            }),\n        });\n    }\n    renameConstraint(oldName, newName) {\n        return new AlterTableDropConstraintBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                renameConstraint: RenameConstraintNode.create(oldName, newName),\n            }),\n        });\n    }\n    /**\n     * This can be used to add index to table.\n     *\n     *  ### Examples\n     *\n     * ```ts\n     * db.schema.alterTable('person')\n     *   .addIndex('person_email_index')\n     *   .column('email')\n     *   .unique()\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * alter table `person` add unique index `person_email_index` (`email`)\n     * ```\n     */\n    addIndex(indexName) {\n        return new AlterTableAddIndexBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                addIndex: AddIndexNode.create(indexName),\n            }),\n        });\n    }\n    /**\n     * This can be used to drop index from table.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * db.schema.alterTable('person')\n     *   .dropIndex('person_email_index')\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * alter table `person` drop index `test_first_name_index`\n     * ```\n     */\n    dropIndex(indexName) {\n        return new AlterTableExecutor({\n            ...this.#props,\n            node: AlterTableNode.cloneWithTableProps(this.#props.node, {\n                dropIndex: DropIndexNode.create(indexName),\n            }),\n        });\n    }\n    /**\n     * Calls the given function passing `this` as the only argument.\n     *\n     * See {@link CreateTableBuilder.$call}\n     */\n    $call(func) {\n        return func(this);\n    }\n}\nexport class AlterTableColumnAlteringBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    alterColumn(column, alteration) {\n        const builder = alteration(new AlterColumnBuilder(column));\n        return new AlterTableColumnAlteringBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithColumnAlteration(this.#props.node, builder.toOperationNode()),\n        });\n    }\n    dropColumn(column) {\n        return new AlterTableColumnAlteringBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithColumnAlteration(this.#props.node, DropColumnNode.create(column)),\n        });\n    }\n    renameColumn(column, newColumn) {\n        return new AlterTableColumnAlteringBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithColumnAlteration(this.#props.node, RenameColumnNode.create(column, newColumn)),\n        });\n    }\n    addColumn(columnName, dataType, build = noop) {\n        const builder = build(new ColumnDefinitionBuilder(ColumnDefinitionNode.create(columnName, parseDataTypeExpression(dataType))));\n        return new AlterTableColumnAlteringBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithColumnAlteration(this.#props.node, AddColumnNode.create(builder.toOperationNode())),\n        });\n    }\n    modifyColumn(columnName, dataType, build = noop) {\n        const builder = build(new ColumnDefinitionBuilder(ColumnDefinitionNode.create(columnName, parseDataTypeExpression(dataType))));\n        return new AlterTableColumnAlteringBuilder({\n            ...this.#props,\n            node: AlterTableNode.cloneWithColumnAlteration(this.#props.node, ModifyColumnNode.create(builder.toOperationNode())),\n        });\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./immediate-value-transformer.d.ts\" />\nimport { OperationNodeTransformer } from '../../operation-node/operation-node-transformer.js';\nimport { ValueListNode } from '../../operation-node/value-list-node.js';\nimport { ValueNode } from '../../operation-node/value-node.js';\n/**\n * Transforms all ValueNodes to immediate.\n *\n * WARNING! This should never be part of the public API. Users should never use this.\n * This is an internal helper.\n *\n * @internal\n */\nexport class ImmediateValueTransformer extends OperationNodeTransformer {\n    transformPrimitiveValueList(node) {\n        return ValueListNode.create(node.values.map(ValueNode.createImmediate));\n    }\n    transformValue(node) {\n        return ValueNode.createImmediate(node.value);\n    }\n}\n", "/// <reference types=\"./create-index-builder.d.ts\" />\nimport { CreateIndexNode, } from '../operation-node/create-index-node.js';\nimport { RawNode } from '../operation-node/raw-node.js';\nimport { parseOrderedColumnName, } from '../parser/reference-parser.js';\nimport { parseTable } from '../parser/table-parser.js';\nimport { freeze } from '../util/object-utils.js';\nimport { parseValueBinaryOperationOrExpression, } from '../parser/binary-operation-parser.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { ImmediateValueTransformer } from '../plugin/immediate-value/immediate-value-transformer.js';\nexport class CreateIndexBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * Adds the \"if not exists\" modifier.\n     *\n     * If the index already exists, no error is thrown if this method has been called.\n     */\n    ifNotExists() {\n        return new CreateIndexBuilder({\n            ...this.#props,\n            node: CreateIndexNode.cloneWith(this.#props.node, {\n                ifNotExists: true,\n            }),\n        });\n    }\n    /**\n     * Makes the index unique.\n     */\n    unique() {\n        return new CreateIndexBuilder({\n            ...this.#props,\n            node: CreateIndexNode.cloneWith(this.#props.node, {\n                unique: true,\n            }),\n        });\n    }\n    /**\n     * Adds `nulls not distinct` specifier to index.\n     * This only works on some dialects like PostgreSQL.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * db.schema.createIndex('person_first_name_index')\n     *  .on('person')\n     *  .column('first_name')\n     *  .nullsNotDistinct()\n     *  .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * create index \"person_first_name_index\"\n     * on \"test\" (\"first_name\")\n     * nulls not distinct;\n     * ```\n     */\n    nullsNotDistinct() {\n        return new CreateIndexBuilder({\n            ...this.#props,\n            node: CreateIndexNode.cloneWith(this.#props.node, {\n                nullsNotDistinct: true,\n            }),\n        });\n    }\n    /**\n     * Specifies the table for the index.\n     */\n    on(table) {\n        return new CreateIndexBuilder({\n            ...this.#props,\n            node: CreateIndexNode.cloneWith(this.#props.node, {\n                table: parseTable(table),\n            }),\n        });\n    }\n    /**\n     * Adds a column to the index.\n     *\n     * Also see {@link columns} for adding multiple columns at once or {@link expression}\n     * for specifying an arbitrary expression.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *         .createIndex('person_first_name_and_age_index')\n     *         .on('person')\n     *         .column('first_name')\n     *         .column('age desc')\n     *         .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * create index \"person_first_name_and_age_index\" on \"person\" (\"first_name\", \"age\" desc)\n     * ```\n     */\n    column(column) {\n        return new CreateIndexBuilder({\n            ...this.#props,\n            node: CreateIndexNode.cloneWithColumns(this.#props.node, [\n                parseOrderedColumnName(column),\n            ]),\n        });\n    }\n    /**\n     * Specifies a list of columns for the index.\n     *\n     * Also see {@link column} for adding a single column or {@link expression} for\n     * specifying an arbitrary expression.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *         .createIndex('person_first_name_and_age_index')\n     *         .on('person')\n     *         .columns(['first_name', 'age desc'])\n     *         .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * create index \"person_first_name_and_age_index\" on \"person\" (\"first_name\", \"age\" desc)\n     * ```\n     */\n    columns(columns) {\n        return new CreateIndexBuilder({\n            ...this.#props,\n            node: CreateIndexNode.cloneWithColumns(this.#props.node, columns.map(parseOrderedColumnName)),\n        });\n    }\n    /**\n     * Specifies an arbitrary expression for the index.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import {\u00A0sql } from 'kysely'\n     *\n     * await db.schema\n     *   .createIndex('person_first_name_index')\n     *   .on('person')\n     *   .expression(sql`first_name COLLATE \"fi_FI\"`)\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * create index \"person_first_name_index\" on \"person\" (first_name COLLATE \"fi_FI\")\n     * ```\n     */\n    expression(expression) {\n        return new CreateIndexBuilder({\n            ...this.#props,\n            node: CreateIndexNode.cloneWithColumns(this.#props.node, [\n                expression.toOperationNode(),\n            ]),\n        });\n    }\n    using(indexType) {\n        return new CreateIndexBuilder({\n            ...this.#props,\n            node: CreateIndexNode.cloneWith(this.#props.node, {\n                using: RawNode.createWithSql(indexType),\n            }),\n        });\n    }\n    where(...args) {\n        const transformer = new ImmediateValueTransformer();\n        return new CreateIndexBuilder({\n            ...this.#props,\n            node: QueryNode.cloneWithWhere(this.#props.node, transformer.transformNode(parseValueBinaryOperationOrExpression(args), this.#props.queryId)),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./create-schema-builder.d.ts\" />\nimport { CreateSchemaNode } from '../operation-node/create-schema-node.js';\nimport { freeze } from '../util/object-utils.js';\nexport class CreateSchemaBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    ifNotExists() {\n        return new CreateSchemaBuilder({\n            ...this.#props,\n            node: CreateSchemaNode.cloneWith(this.#props.node, { ifNotExists: true }),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./on-commit-action-parse.d.ts\" />\nimport { ON_COMMIT_ACTIONS, } from '../operation-node/create-table-node.js';\nexport function parseOnCommitAction(action) {\n    if (ON_COMMIT_ACTIONS.includes(action)) {\n        return action;\n    }\n    throw new Error(`invalid OnCommitAction ${action}`);\n}\n", "/// <reference types=\"./create-table-builder.d.ts\" />\nimport { ColumnDefinitionNode } from '../operation-node/column-definition-node.js';\nimport { CreateTableNode, } from '../operation-node/create-table-node.js';\nimport { ColumnDefinitionBuilder } from './column-definition-builder.js';\nimport { freeze, noop } from '../util/object-utils.js';\nimport { ForeignKeyConstraintNode } from '../operation-node/foreign-key-constraint-node.js';\nimport { ColumnNode } from '../operation-node/column-node.js';\nimport { ForeignKeyConstraintBuilder, } from './foreign-key-constraint-builder.js';\nimport { parseDataTypeExpression, } from '../parser/data-type-parser.js';\nimport { PrimaryKeyConstraintNode } from '../operation-node/primary-key-constraint-node.js';\nimport { UniqueConstraintNode } from '../operation-node/unique-constraint-node.js';\nimport { CheckConstraintNode } from '../operation-node/check-constraint-node.js';\nimport { parseTable } from '../parser/table-parser.js';\nimport { parseOnCommitAction } from '../parser/on-commit-action-parse.js';\nimport { UniqueConstraintNodeBuilder, } from './unique-constraint-builder.js';\nimport { parseExpression } from '../parser/expression-parser.js';\nimport { PrimaryKeyConstraintBuilder, } from './primary-key-constraint-builder.js';\nimport { CheckConstraintBuilder, } from './check-constraint-builder.js';\n/**\n * This builder can be used to create a `create table` query.\n */\nexport class CreateTableBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * Adds the \"temporary\" modifier.\n     *\n     * Use this to create a temporary table.\n     */\n    temporary() {\n        return new CreateTableBuilder({\n            ...this.#props,\n            node: CreateTableNode.cloneWith(this.#props.node, {\n                temporary: true,\n            }),\n        });\n    }\n    /**\n     * Adds an \"on commit\" statement.\n     *\n     * This can be used in conjunction with temporary tables on supported databases\n     * like PostgreSQL.\n     */\n    onCommit(onCommit) {\n        return new CreateTableBuilder({\n            ...this.#props,\n            node: CreateTableNode.cloneWith(this.#props.node, {\n                onCommit: parseOnCommitAction(onCommit),\n            }),\n        });\n    }\n    /**\n     * Adds the \"if not exists\" modifier.\n     *\n     * If the table already exists, no error is thrown if this method has been called.\n     */\n    ifNotExists() {\n        return new CreateTableBuilder({\n            ...this.#props,\n            node: CreateTableNode.cloneWith(this.#props.node, {\n                ifNotExists: true,\n            }),\n        });\n    }\n    /**\n     * Adds a column to the table.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import {\u00A0sql } from 'kysely'\n     *\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('id', 'integer', (col) => col.autoIncrement().primaryKey())\n     *   .addColumn('first_name', 'varchar(50)', (col) => col.notNull())\n     *   .addColumn('last_name', 'varchar(255)')\n     *   .addColumn('bank_balance', 'numeric(8, 2)')\n     *   // You can specify any data type using the `sql` tag if the types\n     *   // don't include it.\n     *   .addColumn('data', sql`any_type_here`)\n     *   .addColumn('parent_id', 'integer', (col) =>\n     *     col.references('person.id').onDelete('cascade')\n     *   )\n     * ```\n     *\n     * With this method, it's once again good to remember that Kysely just builds the\n     * query and doesn't provide the same API for all databases. For example, some\n     * databases like older MySQL don't support the `references` statement in the\n     * column definition. Instead foreign key constraints need to be defined in the\n     * `create table` query. See the next example:\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('id', 'integer', (col) => col.primaryKey())\n     *   .addColumn('parent_id', 'integer')\n     *   .addForeignKeyConstraint(\n     *     'person_parent_id_fk',\n     *     ['parent_id'],\n     *     'person',\n     *     ['id'],\n     *     (cb) => cb.onDelete('cascade')\n     *   )\n     *   .execute()\n     * ```\n     *\n     * Another good example is that PostgreSQL doesn't support the `auto_increment`\n     * keyword and you need to define an autoincrementing column for example using\n     * `serial`:\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('id', 'serial', (col) => col.primaryKey())\n     *   .execute()\n     * ```\n     */\n    addColumn(columnName, dataType, build = noop) {\n        const columnBuilder = build(new ColumnDefinitionBuilder(ColumnDefinitionNode.create(columnName, parseDataTypeExpression(dataType))));\n        return new CreateTableBuilder({\n            ...this.#props,\n            node: CreateTableNode.cloneWithColumn(this.#props.node, columnBuilder.toOperationNode()),\n        });\n    }\n    /**\n     * Adds a primary key constraint for one or more columns.\n     *\n     * The constraint name can be anything you want, but it must be unique\n     * across the whole database.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('first_name', 'varchar(64)')\n     *   .addColumn('last_name', 'varchar(64)')\n     *   .addPrimaryKeyConstraint('primary_key', ['first_name', 'last_name'])\n     *   .execute()\n     * ```\n     */\n    addPrimaryKeyConstraint(constraintName, columns, build = noop) {\n        const constraintBuilder = build(new PrimaryKeyConstraintBuilder(PrimaryKeyConstraintNode.create(columns, constraintName)));\n        return new CreateTableBuilder({\n            ...this.#props,\n            node: CreateTableNode.cloneWithConstraint(this.#props.node, constraintBuilder.toOperationNode()),\n        });\n    }\n    /**\n     * Adds a unique constraint for one or more columns.\n     *\n     * The constraint name can be anything you want, but it must be unique\n     * across the whole database.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('first_name', 'varchar(64)')\n     *   .addColumn('last_name', 'varchar(64)')\n     *   .addUniqueConstraint(\n     *     'first_name_last_name_unique',\n     *     ['first_name', 'last_name']\n     *   )\n     *   .execute()\n     * ```\n     *\n     * In dialects such as PostgreSQL you can specify `nulls not distinct` as follows:\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('first_name', 'varchar(64)')\n     *   .addColumn('last_name', 'varchar(64)')\n     *   .addUniqueConstraint(\n     *     'first_name_last_name_unique',\n     *     ['first_name', 'last_name'],\n     *     (cb) => cb.nullsNotDistinct()\n     *   )\n     *   .execute()\n     * ```\n     */\n    addUniqueConstraint(constraintName, columns, build = noop) {\n        const uniqueConstraintBuilder = build(new UniqueConstraintNodeBuilder(UniqueConstraintNode.create(columns, constraintName)));\n        return new CreateTableBuilder({\n            ...this.#props,\n            node: CreateTableNode.cloneWithConstraint(this.#props.node, uniqueConstraintBuilder.toOperationNode()),\n        });\n    }\n    /**\n     * Adds a check constraint.\n     *\n     * The constraint name can be anything you want, but it must be unique\n     * across the whole database.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import {\u00A0sql } from 'kysely'\n     *\n     * await db.schema\n     *   .createTable('animal')\n     *   .addColumn('number_of_legs', 'integer')\n     *   .addCheckConstraint('check_legs', sql`number_of_legs < 5`)\n     *   .execute()\n     * ```\n     */\n    addCheckConstraint(constraintName, checkExpression, build = noop) {\n        const constraintBuilder = build(new CheckConstraintBuilder(CheckConstraintNode.create(checkExpression.toOperationNode(), constraintName)));\n        return new CreateTableBuilder({\n            ...this.#props,\n            node: CreateTableNode.cloneWithConstraint(this.#props.node, constraintBuilder.toOperationNode()),\n        });\n    }\n    /**\n     * Adds a foreign key constraint.\n     *\n     * The constraint name can be anything you want, but it must be unique\n     * across the whole database.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('pet')\n     *   .addColumn('owner_id', 'integer')\n     *   .addForeignKeyConstraint(\n     *     'owner_id_foreign',\n     *     ['owner_id'],\n     *     'person',\n     *     ['id'],\n     *   )\n     *   .execute()\n     * ```\n     *\n     * Add constraint for multiple columns:\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('pet')\n     *   .addColumn('owner_id1', 'integer')\n     *   .addColumn('owner_id2', 'integer')\n     *   .addForeignKeyConstraint(\n     *     'owner_id_foreign',\n     *     ['owner_id1', 'owner_id2'],\n     *     'person',\n     *     ['id1', 'id2'],\n     *     (cb) => cb.onDelete('cascade')\n     *   )\n     *   .execute()\n     * ```\n     */\n    addForeignKeyConstraint(constraintName, columns, targetTable, targetColumns, build = noop) {\n        const builder = build(new ForeignKeyConstraintBuilder(ForeignKeyConstraintNode.create(columns.map(ColumnNode.create), parseTable(targetTable), targetColumns.map(ColumnNode.create), constraintName)));\n        return new CreateTableBuilder({\n            ...this.#props,\n            node: CreateTableNode.cloneWithConstraint(this.#props.node, builder.toOperationNode()),\n        });\n    }\n    /**\n     * This can be used to add any additional SQL to the front of the query __after__ the `create` keyword.\n     *\n     * Also see {@link temporary}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * await db.schema\n     *   .createTable('person')\n     *   .modifyFront(sql`global temporary`)\n     *   .addColumn('id', 'integer', col => col.primaryKey())\n     *   .addColumn('first_name', 'varchar(64)', col => col.notNull())\n     *   .addColumn('last_name', 'varchar(64)', col => col.notNull())\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (Postgres):\n     *\n     * ```sql\n     * create global temporary table \"person\" (\n     *   \"id\" integer primary key,\n     *   \"first_name\" varchar(64) not null,\n     *   \"last_name\" varchar(64) not null\n     * )\n     * ```\n     */\n    modifyFront(modifier) {\n        return new CreateTableBuilder({\n            ...this.#props,\n            node: CreateTableNode.cloneWithFrontModifier(this.#props.node, modifier.toOperationNode()),\n        });\n    }\n    /**\n     * This can be used to add any additional SQL to the end of the query.\n     *\n     * Also see {@link onCommit}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import { sql } from 'kysely'\n     *\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('id', 'integer', col => col.primaryKey())\n     *   .addColumn('first_name', 'varchar(64)', col => col.notNull())\n     *   .addColumn('last_name', 'varchar(64)', col => col.notNull())\n     *   .modifyEnd(sql`collate utf8_unicode_ci`)\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (MySQL):\n     *\n     * ```sql\n     * create table `person` (\n     *   `id` integer primary key,\n     *   `first_name` varchar(64) not null,\n     *   `last_name` varchar(64) not null\n     * ) collate utf8_unicode_ci\n     * ```\n     */\n    modifyEnd(modifier) {\n        return new CreateTableBuilder({\n            ...this.#props,\n            node: CreateTableNode.cloneWithEndModifier(this.#props.node, modifier.toOperationNode()),\n        });\n    }\n    /**\n     * Allows to create table from `select` query.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('copy')\n     *   .temporary()\n     *   .as(db.selectFrom('person').select(['first_name', 'last_name']))\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * create temporary table \"copy\" as\n     * select \"first_name\", \"last_name\" from \"person\"\n     * ```\n     */\n    as(expression) {\n        return new CreateTableBuilder({\n            ...this.#props,\n            node: CreateTableNode.cloneWith(this.#props.node, {\n                selectQuery: parseExpression(expression),\n            }),\n        });\n    }\n    /**\n     * Calls the given function passing `this` as the only argument.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('test')\n     *   .$call((builder) => builder.addColumn('id', 'integer'))\n     *   .execute()\n     * ```\n     *\n     * This is useful for creating reusable functions that can be called with a builder.\n     *\n     * ```ts\n     * import { type CreateTableBuilder, sql } from 'kysely'\n     *\n     * const addDefaultColumns = (ctb: CreateTableBuilder<any, any>) => {\n     *   return ctb\n     *     .addColumn('id', 'integer', (col) => col.notNull())\n     *     .addColumn('created_at', 'date', (col) =>\n     *       col.notNull().defaultTo(sql`now()`)\n     *     )\n     *     .addColumn('updated_at', 'date', (col) =>\n     *       col.notNull().defaultTo(sql`now()`)\n     *     )\n     * }\n     *\n     * await db.schema\n     *   .createTable('test')\n     *   .$call(addDefaultColumns)\n     *   .execute()\n     * ```\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./drop-index-builder.d.ts\" />\nimport { DropIndexNode } from '../operation-node/drop-index-node.js';\nimport { parseTable } from '../parser/table-parser.js';\nimport { freeze } from '../util/object-utils.js';\nexport class DropIndexBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * Specifies the table the index was created for. This is not needed\n     * in all dialects.\n     */\n    on(table) {\n        return new DropIndexBuilder({\n            ...this.#props,\n            node: DropIndexNode.cloneWith(this.#props.node, {\n                table: parseTable(table),\n            }),\n        });\n    }\n    ifExists() {\n        return new DropIndexBuilder({\n            ...this.#props,\n            node: DropIndexNode.cloneWith(this.#props.node, {\n                ifExists: true,\n            }),\n        });\n    }\n    cascade() {\n        return new DropIndexBuilder({\n            ...this.#props,\n            node: DropIndexNode.cloneWith(this.#props.node, {\n                cascade: true,\n            }),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./drop-schema-builder.d.ts\" />\nimport { DropSchemaNode } from '../operation-node/drop-schema-node.js';\nimport { freeze } from '../util/object-utils.js';\nexport class DropSchemaBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    ifExists() {\n        return new DropSchemaBuilder({\n            ...this.#props,\n            node: DropSchemaNode.cloneWith(this.#props.node, {\n                ifExists: true,\n            }),\n        });\n    }\n    cascade() {\n        return new DropSchemaBuilder({\n            ...this.#props,\n            node: DropSchemaNode.cloneWith(this.#props.node, {\n                cascade: true,\n            }),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./drop-table-builder.d.ts\" />\nimport { DropTableNode } from '../operation-node/drop-table-node.js';\nimport { freeze } from '../util/object-utils.js';\nexport class DropTableBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    ifExists() {\n        return new DropTableBuilder({\n            ...this.#props,\n            node: DropTableNode.cloneWith(this.#props.node, {\n                ifExists: true,\n            }),\n        });\n    }\n    cascade() {\n        return new DropTableBuilder({\n            ...this.#props,\n            node: DropTableNode.cloneWith(this.#props.node, {\n                cascade: true,\n            }),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./create-view-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { SchemableIdentifierNode } from './schemable-identifier-node.js';\n/**\n * @internal\n */\nexport const CreateViewNode = freeze({\n    is(node) {\n        return node.kind === 'CreateViewNode';\n    },\n    create(name) {\n        return freeze({\n            kind: 'CreateViewNode',\n            name: SchemableIdentifierNode.create(name),\n        });\n    },\n    cloneWith(createView, params) {\n        return freeze({\n            ...createView,\n            ...params,\n        });\n    },\n});\n", "/// <reference types=\"./immediate-value-plugin.d.ts\" />\nimport { ImmediateValueTransformer } from './immediate-value-transformer.js';\n/**\n * Transforms all ValueNodes to immediate.\n *\n * WARNING! This should never be part of the public API. Users should never use this.\n * This is an internal helper.\n *\n * @internal\n */\nexport class ImmediateValuePlugin {\n    #transformer = new ImmediateValueTransformer();\n    transformQuery(args) {\n        return this.#transformer.transformNode(args.node, args.queryId);\n    }\n    transformResult(args) {\n        return Promise.resolve(args.result);\n    }\n}\n", "/// <reference types=\"./create-view-builder.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { CreateViewNode } from '../operation-node/create-view-node.js';\nimport { parseColumnName } from '../parser/reference-parser.js';\nimport { ImmediateValuePlugin } from '../plugin/immediate-value/immediate-value-plugin.js';\nexport class CreateViewBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * Adds the \"temporary\" modifier.\n     *\n     * Use this to create a temporary view.\n     */\n    temporary() {\n        return new CreateViewBuilder({\n            ...this.#props,\n            node: CreateViewNode.cloneWith(this.#props.node, {\n                temporary: true,\n            }),\n        });\n    }\n    materialized() {\n        return new CreateViewBuilder({\n            ...this.#props,\n            node: CreateViewNode.cloneWith(this.#props.node, {\n                materialized: true,\n            }),\n        });\n    }\n    /**\n     * Only implemented on some dialects like SQLite. On most dialects, use {@link orReplace}.\n     */\n    ifNotExists() {\n        return new CreateViewBuilder({\n            ...this.#props,\n            node: CreateViewNode.cloneWith(this.#props.node, {\n                ifNotExists: true,\n            }),\n        });\n    }\n    orReplace() {\n        return new CreateViewBuilder({\n            ...this.#props,\n            node: CreateViewNode.cloneWith(this.#props.node, {\n                orReplace: true,\n            }),\n        });\n    }\n    columns(columns) {\n        return new CreateViewBuilder({\n            ...this.#props,\n            node: CreateViewNode.cloneWith(this.#props.node, {\n                columns: columns.map(parseColumnName),\n            }),\n        });\n    }\n    /**\n     * Sets the select query or a `values` statement that creates the view.\n     *\n     * WARNING!\n     * Some dialects don't support parameterized queries in DDL statements and therefore\n     * the query or raw {@link sql } expression passed here is interpolated into a single\n     * string opening an SQL injection vulnerability. DO NOT pass unchecked user input\n     * into the query or raw expression passed to this method!\n     */\n    as(query) {\n        const queryNode = query\n            .withPlugin(new ImmediateValuePlugin())\n            .toOperationNode();\n        return new CreateViewBuilder({\n            ...this.#props,\n            node: CreateViewNode.cloneWith(this.#props.node, {\n                as: queryNode,\n            }),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./drop-view-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { SchemableIdentifierNode } from './schemable-identifier-node.js';\n/**\n * @internal\n */\nexport const DropViewNode = freeze({\n    is(node) {\n        return node.kind === 'DropViewNode';\n    },\n    create(name) {\n        return freeze({\n            kind: 'DropViewNode',\n            name: SchemableIdentifierNode.create(name),\n        });\n    },\n    cloneWith(dropView, params) {\n        return freeze({\n            ...dropView,\n            ...params,\n        });\n    },\n});\n", "/// <reference types=\"./drop-view-builder.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { DropViewNode } from '../operation-node/drop-view-node.js';\nexport class DropViewBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    materialized() {\n        return new DropViewBuilder({\n            ...this.#props,\n            node: DropViewNode.cloneWith(this.#props.node, {\n                materialized: true,\n            }),\n        });\n    }\n    ifExists() {\n        return new DropViewBuilder({\n            ...this.#props,\n            node: DropViewNode.cloneWith(this.#props.node, {\n                ifExists: true,\n            }),\n        });\n    }\n    cascade() {\n        return new DropViewBuilder({\n            ...this.#props,\n            node: DropViewNode.cloneWith(this.#props.node, {\n                cascade: true,\n            }),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./create-type-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { ValueListNode } from './value-list-node.js';\nimport { ValueNode } from './value-node.js';\n/**\n * @internal\n */\nexport const CreateTypeNode = freeze({\n    is(node) {\n        return node.kind === 'CreateTypeNode';\n    },\n    create(name) {\n        return freeze({\n            kind: 'CreateTypeNode',\n            name,\n        });\n    },\n    cloneWithEnum(createType, values) {\n        return freeze({\n            ...createType,\n            enum: ValueListNode.create(values.map(ValueNode.createImmediate)),\n        });\n    },\n});\n", "/// <reference types=\"./create-type-builder.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { CreateTypeNode } from '../operation-node/create-type-node.js';\nexport class CreateTypeBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    /**\n     * Creates an anum type.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * db.schema.createType('species').asEnum(['cat', 'dog', 'frog'])\n     * ```\n     */\n    asEnum(values) {\n        return new CreateTypeBuilder({\n            ...this.#props,\n            node: CreateTypeNode.cloneWithEnum(this.#props.node, values),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./drop-type-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const DropTypeNode = freeze({\n    is(node) {\n        return node.kind === 'DropTypeNode';\n    },\n    create(name) {\n        return freeze({\n            kind: 'DropTypeNode',\n            name,\n        });\n    },\n    cloneWith(dropType, params) {\n        return freeze({\n            ...dropType,\n            ...params,\n        });\n    },\n});\n", "/// <reference types=\"./drop-type-builder.d.ts\" />\nimport { DropTypeNode } from '../operation-node/drop-type-node.js';\nimport { freeze } from '../util/object-utils.js';\nexport class DropTypeBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    ifExists() {\n        return new DropTypeBuilder({\n            ...this.#props,\n            node: DropTypeNode.cloneWith(this.#props.node, {\n                ifExists: true,\n            }),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./identifier-parser.d.ts\" />\nimport { SchemableIdentifierNode } from '../operation-node/schemable-identifier-node.js';\nexport function parseSchemableIdentifier(id) {\n    const SCHEMA_SEPARATOR = '.';\n    if (id.includes(SCHEMA_SEPARATOR)) {\n        const parts = id.split(SCHEMA_SEPARATOR).map(trim);\n        if (parts.length === 2) {\n            return SchemableIdentifierNode.createWithSchema(parts[0], parts[1]);\n        }\n        else {\n            throw new Error(`invalid schemable identifier ${id}`);\n        }\n    }\n    else {\n        return SchemableIdentifierNode.create(id);\n    }\n}\nfunction trim(str) {\n    return str.trim();\n}\n", "/// <reference types=\"./refresh-materialized-view-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { SchemableIdentifierNode } from './schemable-identifier-node.js';\n/**\n * @internal\n */\nexport const RefreshMaterializedViewNode = freeze({\n    is(node) {\n        return node.kind === 'RefreshMaterializedViewNode';\n    },\n    create(name) {\n        return freeze({\n            kind: 'RefreshMaterializedViewNode',\n            name: SchemableIdentifierNode.create(name),\n        });\n    },\n    cloneWith(createView, params) {\n        return freeze({\n            ...createView,\n            ...params,\n        });\n    },\n});\n", "/// <reference types=\"./refresh-materialized-view-builder.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { RefreshMaterializedViewNode } from '../operation-node/refresh-materialized-view-node.js';\nexport class RefreshMaterializedViewBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    /**\n     * Adds the \"concurrently\" modifier.\n     *\n     * Use this to refresh the view without locking out concurrent selects on the materialized view.\n     *\n     * WARNING!\n     * This cannot be used with the \"with no data\" modifier.\n     */\n    concurrently() {\n        return new RefreshMaterializedViewBuilder({\n            ...this.#props,\n            node: RefreshMaterializedViewNode.cloneWith(this.#props.node, {\n                concurrently: true,\n                withNoData: false,\n            }),\n        });\n    }\n    /**\n     * Adds the \"with data\" modifier.\n     *\n     * If specified (or defaults) the backing query is executed to provide the new data, and the materialized view is left in a scannable state\n     */\n    withData() {\n        return new RefreshMaterializedViewBuilder({\n            ...this.#props,\n            node: RefreshMaterializedViewNode.cloneWith(this.#props.node, {\n                withNoData: false,\n            }),\n        });\n    }\n    /**\n     * Adds the \"with no data\" modifier.\n     *\n     * If specified, no new data is generated and the materialized view is left in an unscannable state.\n     *\n     * WARNING!\n     * This cannot be used with the \"concurrently\" modifier.\n     */\n    withNoData() {\n        return new RefreshMaterializedViewBuilder({\n            ...this.#props,\n            node: RefreshMaterializedViewNode.cloneWith(this.#props.node, {\n                withNoData: true,\n                concurrently: false,\n            }),\n        });\n    }\n    /**\n     * Simply calls the provided function passing `this` as the only argument. `$call` returns\n     * what the provided function returns.\n     */\n    $call(func) {\n        return func(this);\n    }\n    toOperationNode() {\n        return this.#props.executor.transformQuery(this.#props.node, this.#props.queryId);\n    }\n    compile() {\n        return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n    }\n    async execute() {\n        await this.#props.executor.executeQuery(this.compile(), this.#props.queryId);\n    }\n}\n", "/// <reference types=\"./schema.d.ts\" />\nimport { AlterTableNode } from '../operation-node/alter-table-node.js';\nimport { CreateIndexNode } from '../operation-node/create-index-node.js';\nimport { CreateSchemaNode } from '../operation-node/create-schema-node.js';\nimport { CreateTableNode } from '../operation-node/create-table-node.js';\nimport { DropIndexNode } from '../operation-node/drop-index-node.js';\nimport { DropSchemaNode } from '../operation-node/drop-schema-node.js';\nimport { DropTableNode } from '../operation-node/drop-table-node.js';\nimport { parseTable } from '../parser/table-parser.js';\nimport { AlterTableBuilder } from './alter-table-builder.js';\nimport { CreateIndexBuilder } from './create-index-builder.js';\nimport { CreateSchemaBuilder } from './create-schema-builder.js';\nimport { CreateTableBuilder } from './create-table-builder.js';\nimport { DropIndexBuilder } from './drop-index-builder.js';\nimport { DropSchemaBuilder } from './drop-schema-builder.js';\nimport { DropTableBuilder } from './drop-table-builder.js';\nimport { createQueryId } from '../util/query-id.js';\nimport { WithSchemaPlugin } from '../plugin/with-schema/with-schema-plugin.js';\nimport { CreateViewBuilder } from './create-view-builder.js';\nimport { CreateViewNode } from '../operation-node/create-view-node.js';\nimport { DropViewBuilder } from './drop-view-builder.js';\nimport { DropViewNode } from '../operation-node/drop-view-node.js';\nimport { CreateTypeBuilder } from './create-type-builder.js';\nimport { DropTypeBuilder } from './drop-type-builder.js';\nimport { CreateTypeNode } from '../operation-node/create-type-node.js';\nimport { DropTypeNode } from '../operation-node/drop-type-node.js';\nimport { parseSchemableIdentifier } from '../parser/identifier-parser.js';\nimport { RefreshMaterializedViewBuilder } from './refresh-materialized-view-builder.js';\nimport { RefreshMaterializedViewNode } from '../operation-node/refresh-materialized-view-node.js';\n/**\n * Provides methods for building database schema.\n */\nexport class SchemaModule {\n    #executor;\n    constructor(executor) {\n        this.#executor = executor;\n    }\n    /**\n     * Create a new table.\n     *\n     * ### Examples\n     *\n     * This example creates a new table with columns `id`, `first_name`,\n     * `last_name` and `gender`:\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('person')\n     *   .addColumn('id', 'integer', col => col.primaryKey().autoIncrement())\n     *   .addColumn('first_name', 'varchar', col => col.notNull())\n     *   .addColumn('last_name', 'varchar', col => col.notNull())\n     *   .addColumn('gender', 'varchar')\n     *   .execute()\n     * ```\n     *\n     * This example creates a table with a foreign key. Not all database\n     * engines support column-level foreign key constraint definitions.\n     * For example if you are using MySQL 5.X see the next example after\n     * this one.\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('pet')\n     *   .addColumn('id', 'integer', col => col.primaryKey().autoIncrement())\n     *   .addColumn('owner_id', 'integer', col => col\n     *     .references('person.id')\n     *     .onDelete('cascade')\n     *   )\n     *   .execute()\n     * ```\n     *\n     * This example adds a foreign key constraint for a columns just\n     * like the previous example, but using a table-level statement.\n     * On MySQL 5.X you need to define foreign key constraints like\n     * this:\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('pet')\n     *   .addColumn('id', 'integer', col => col.primaryKey().autoIncrement())\n     *   .addColumn('owner_id', 'integer')\n     *   .addForeignKeyConstraint(\n     *     'pet_owner_id_foreign', ['owner_id'], 'person', ['id'],\n     *     (constraint) => constraint.onDelete('cascade')\n     *   )\n     *   .execute()\n     * ```\n     */\n    createTable(table) {\n        return new CreateTableBuilder({\n            queryId: createQueryId(),\n            executor: this.#executor,\n            node: CreateTableNode.create(parseTable(table)),\n        });\n    }\n    /**\n     * Drop a table.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .dropTable('person')\n     *   .execute()\n     * ```\n     */\n    dropTable(table) {\n        return new DropTableBuilder({\n            queryId: createQueryId(),\n            executor: this.#executor,\n            node: DropTableNode.create(parseTable(table)),\n        });\n    }\n    /**\n     * Create a new index.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createIndex('person_full_name_unique_index')\n     *   .on('person')\n     *   .columns(['first_name', 'last_name'])\n     *   .execute()\n     * ```\n     */\n    createIndex(indexName) {\n        return new CreateIndexBuilder({\n            queryId: createQueryId(),\n            executor: this.#executor,\n            node: CreateIndexNode.create(indexName),\n        });\n    }\n    /**\n     * Drop an index.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .dropIndex('person_full_name_unique_index')\n     *   .execute()\n     * ```\n     */\n    dropIndex(indexName) {\n        return new DropIndexBuilder({\n            queryId: createQueryId(),\n            executor: this.#executor,\n            node: DropIndexNode.create(indexName),\n        });\n    }\n    /**\n     * Create a new schema.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createSchema('some_schema')\n     *   .execute()\n     * ```\n     */\n    createSchema(schema) {\n        return new CreateSchemaBuilder({\n            queryId: createQueryId(),\n            executor: this.#executor,\n            node: CreateSchemaNode.create(schema),\n        });\n    }\n    /**\n     * Drop a schema.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .dropSchema('some_schema')\n     *   .execute()\n     * ```\n     */\n    dropSchema(schema) {\n        return new DropSchemaBuilder({\n            queryId: createQueryId(),\n            executor: this.#executor,\n            node: DropSchemaNode.create(schema),\n        });\n    }\n    /**\n     * Alter a table.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .alterTable('person')\n     *   .alterColumn('first_name', (ac) => ac.setDataType('text'))\n     *   .execute()\n     * ```\n     */\n    alterTable(table) {\n        return new AlterTableBuilder({\n            queryId: createQueryId(),\n            executor: this.#executor,\n            node: AlterTableNode.create(parseTable(table)),\n        });\n    }\n    /**\n     * Create a new view.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createView('dogs')\n     *   .orReplace()\n     *   .as(db.selectFrom('pet').selectAll().where('species', '=', 'dog'))\n     *   .execute()\n     * ```\n     */\n    createView(viewName) {\n        return new CreateViewBuilder({\n            queryId: createQueryId(),\n            executor: this.#executor,\n            node: CreateViewNode.create(viewName),\n        });\n    }\n    /**\n     * Refresh a materialized view.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .refreshMaterializedView('my_view')\n     *   .concurrently()\n     *   .execute()\n     * ```\n     */\n    refreshMaterializedView(viewName) {\n        return new RefreshMaterializedViewBuilder({\n            queryId: createQueryId(),\n            executor: this.#executor,\n            node: RefreshMaterializedViewNode.create(viewName),\n        });\n    }\n    /**\n     * Drop a view.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .dropView('dogs')\n     *   .ifExists()\n     *   .execute()\n     * ```\n     */\n    dropView(viewName) {\n        return new DropViewBuilder({\n            queryId: createQueryId(),\n            executor: this.#executor,\n            node: DropViewNode.create(viewName),\n        });\n    }\n    /**\n     * Create a new type.\n     *\n     * Only some dialects like PostgreSQL have user-defined types.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .createType('species')\n     *   .asEnum(['dog', 'cat', 'frog'])\n     *   .execute()\n     * ```\n     */\n    createType(typeName) {\n        return new CreateTypeBuilder({\n            queryId: createQueryId(),\n            executor: this.#executor,\n            node: CreateTypeNode.create(parseSchemableIdentifier(typeName)),\n        });\n    }\n    /**\n     * Drop a type.\n     *\n     * Only some dialects like PostgreSQL have user-defined types.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db.schema\n     *   .dropType('species')\n     *   .ifExists()\n     *   .execute()\n     * ```\n     */\n    dropType(typeName) {\n        return new DropTypeBuilder({\n            queryId: createQueryId(),\n            executor: this.#executor,\n            node: DropTypeNode.create(parseSchemableIdentifier(typeName)),\n        });\n    }\n    /**\n     * Returns a copy of this schema module with the given plugin installed.\n     */\n    withPlugin(plugin) {\n        return new SchemaModule(this.#executor.withPlugin(plugin));\n    }\n    /**\n     * Returns a copy of this schema module  without any plugins.\n     */\n    withoutPlugins() {\n        return new SchemaModule(this.#executor.withoutPlugins());\n    }\n    /**\n     * See {@link QueryCreator.withSchema}\n     */\n    withSchema(schema) {\n        return new SchemaModule(this.#executor.withPluginAtFront(new WithSchemaPlugin(schema)));\n    }\n}\n", "/// <reference types=\"./dynamic.d.ts\" />\nimport { DynamicReferenceBuilder } from './dynamic-reference-builder.js';\nimport { DynamicTableBuilder } from './dynamic-table-builder.js';\nexport class DynamicModule {\n    /**\n     * Creates a dynamic reference to a column that is not know at compile time.\n     *\n     * Kysely is built in a way that by default you can't refer to tables or columns\n     * that are not actually visible in the current query and context. This is all\n     * done by TypeScript at compile time, which means that you need to know the\n     * columns and tables at compile time. This is not always the case of course.\n     *\n     * This method is meant to be used in those cases where the column names\n     * come from the user input or are not otherwise known at compile time.\n     *\n     * WARNING! Unlike values, column names are not escaped by the database engine\n     * or Kysely and if you pass in unchecked column names using this method, you\n     * create an SQL injection vulnerability. Always __always__ validate the user\n     * input before passing it to this method.\n     *\n     * There are couple of examples below for some use cases, but you can pass\n     * `ref` to other methods as well. If the types allow you to pass a `ref`\n     * value to some place, it should work.\n     *\n     * ### Examples\n     *\n     * Filter by a column not know at compile time:\n     *\n     * ```ts\n     * async function someQuery(filterColumn: string, filterValue: string) {\n     *   const { ref } = db.dynamic\n     *\n     *   return await db\n     *     .selectFrom('person')\n     *     .selectAll()\n     *     .where(ref(filterColumn), '=', filterValue)\n     *     .execute()\n     * }\n     *\n     * someQuery('first_name', 'Arnold')\n     * someQuery('person.last_name', 'Aniston')\n     * ```\n     *\n     * Order by a column not know at compile time:\n     *\n     * ```ts\n     * async function someQuery(orderBy: string) {\n     *   const { ref } = db.dynamic\n     *\n     *   return await db\n     *     .selectFrom('person')\n     *     .select('person.first_name as fn')\n     *     .orderBy(ref(orderBy))\n     *     .execute()\n     * }\n     *\n     * someQuery('fn')\n     * ```\n     *\n     * In this example we add selections dynamically:\n     *\n     * ```ts\n     * const { ref } = db.dynamic\n     *\n     * // Some column name provided by the user. Value not known at compile time.\n     * const columnFromUserInput: PossibleColumns = 'birthdate';\n     *\n     * // A type that lists all possible values `columnFromUserInput` can have.\n     * // You can use `keyof Person` if any column of an interface is allowed.\n     * type PossibleColumns = 'last_name' | 'first_name' | 'birthdate'\n     *\n     * const [person] = await db.selectFrom('person')\n     *   .select([\n     *     ref<PossibleColumns>(columnFromUserInput),\n     *     'id'\n     *   ])\n     *   .execute()\n     *\n     * // The resulting type contains all `PossibleColumns` as optional fields\n     * // because we cannot know which field was actually selected before\n     * // running the code.\n     * const lastName: string | null | undefined = person?.last_name\n     * const firstName: string | undefined = person?.first_name\n     * const birthDate: Date | null | undefined = person?.birthdate\n     *\n     * // The result type also contains the compile time selection `id`.\n     * person?.id\n     * ```\n     */\n    ref(reference) {\n        return new DynamicReferenceBuilder(reference);\n    }\n    /**\n     * Creates a table reference to a table that's not fully known at compile time.\n     *\n     * The type `T` is allowed to be a union of multiple tables.\n     *\n     * <!-- siteExample(\"select\", \"Generic find query\", 130) -->\n     *\n     * A generic type-safe helper function for finding a row by a column value:\n     *\n     * ```ts\n     * import { SelectType } from 'kysely'\n     * import { Database } from 'type-editor'\n     *\n     * async function getRowByColumn<\n     *   T extends keyof Database,\n     *   C extends keyof Database[T] & string,\n     *   V extends SelectType<Database[T][C]>,\n     * >(t: T, c: C, v: V) {\n     *   // We need to use the dynamic module since the table name\n     *   // is not known at compile time.\n     *   const { table, ref } = db.dynamic\n     *\n     *   return await db\n     *     .selectFrom(table(t).as('t'))\n     *     .selectAll()\n     *     .where(ref(c), '=', v)\n     *     .orderBy('t.id')\n     *     .executeTakeFirstOrThrow()\n     * }\n     *\n     * const person = await getRowByColumn('person', 'first_name', 'Arnold')\n     * ```\n     */\n    table(table) {\n        return new DynamicTableBuilder(table);\n    }\n}\n", "/// <reference types=\"./default-connection-provider.d.ts\" />\nexport class DefaultConnectionProvider {\n    #driver;\n    constructor(driver) {\n        this.#driver = driver;\n    }\n    async provideConnection(consumer) {\n        const connection = await this.#driver.acquireConnection();\n        try {\n            return await consumer(connection);\n        }\n        finally {\n            await this.#driver.releaseConnection(connection);\n        }\n    }\n}\n", "/// <reference types=\"./default-query-executor.d.ts\" />\nimport { QueryExecutorBase } from './query-executor-base.js';\nexport class DefaultQueryExecutor extends QueryExecutorBase {\n    #compiler;\n    #adapter;\n    #connectionProvider;\n    constructor(compiler, adapter, connectionProvider, plugins = []) {\n        super(plugins);\n        this.#compiler = compiler;\n        this.#adapter = adapter;\n        this.#connectionProvider = connectionProvider;\n    }\n    get adapter() {\n        return this.#adapter;\n    }\n    compileQuery(node, queryId) {\n        return this.#compiler.compileQuery(node, queryId);\n    }\n    provideConnection(consumer) {\n        return this.#connectionProvider.provideConnection(consumer);\n    }\n    withPlugins(plugins) {\n        return new DefaultQueryExecutor(this.#compiler, this.#adapter, this.#connectionProvider, [...this.plugins, ...plugins]);\n    }\n    withPlugin(plugin) {\n        return new DefaultQueryExecutor(this.#compiler, this.#adapter, this.#connectionProvider, [...this.plugins, plugin]);\n    }\n    withPluginAtFront(plugin) {\n        return new DefaultQueryExecutor(this.#compiler, this.#adapter, this.#connectionProvider, [plugin, ...this.plugins]);\n    }\n    withConnectionProvider(connectionProvider) {\n        return new DefaultQueryExecutor(this.#compiler, this.#adapter, connectionProvider, [...this.plugins]);\n    }\n    withoutPlugins() {\n        return new DefaultQueryExecutor(this.#compiler, this.#adapter, this.#connectionProvider, []);\n    }\n}\n", "/// <reference types=\"./performance-now.d.ts\" />\nimport { isFunction } from './object-utils.js';\nexport function performanceNow() {\n    if (typeof performance !== 'undefined' && isFunction(performance.now)) {\n        return performance.now();\n    }\n    else {\n        return Date.now();\n    }\n}\n", "/// <reference types=\"./runtime-driver.d.ts\" />\nimport { performanceNow } from '../util/performance-now.js';\n/**\n * A small wrapper around {@link Driver} that makes sure the driver is\n * initialized before it is used, only initialized and destroyed\n * once etc.\n */\nexport class RuntimeDriver {\n    #driver;\n    #log;\n    #initPromise;\n    #initDone;\n    #destroyPromise;\n    #connections = new WeakSet();\n    constructor(driver, log) {\n        this.#initDone = false;\n        this.#driver = driver;\n        this.#log = log;\n    }\n    async init() {\n        if (this.#destroyPromise) {\n            throw new Error('driver has already been destroyed');\n        }\n        if (!this.#initPromise) {\n            this.#initPromise = this.#driver\n                .init()\n                .then(() => {\n                this.#initDone = true;\n            })\n                .catch((err) => {\n                this.#initPromise = undefined;\n                return Promise.reject(err);\n            });\n        }\n        await this.#initPromise;\n    }\n    async acquireConnection() {\n        if (this.#destroyPromise) {\n            throw new Error('driver has already been destroyed');\n        }\n        if (!this.#initDone) {\n            await this.init();\n        }\n        const connection = await this.#driver.acquireConnection();\n        if (!this.#connections.has(connection)) {\n            if (this.#needsLogging()) {\n                this.#addLogging(connection);\n            }\n            this.#connections.add(connection);\n        }\n        return connection;\n    }\n    async releaseConnection(connection) {\n        await this.#driver.releaseConnection(connection);\n    }\n    beginTransaction(connection, settings) {\n        return this.#driver.beginTransaction(connection, settings);\n    }\n    commitTransaction(connection) {\n        return this.#driver.commitTransaction(connection);\n    }\n    rollbackTransaction(connection) {\n        return this.#driver.rollbackTransaction(connection);\n    }\n    savepoint(connection, savepointName, compileQuery) {\n        if (this.#driver.savepoint) {\n            return this.#driver.savepoint(connection, savepointName, compileQuery);\n        }\n        throw new Error('The `savepoint` method is not supported by this driver');\n    }\n    rollbackToSavepoint(connection, savepointName, compileQuery) {\n        if (this.#driver.rollbackToSavepoint) {\n            return this.#driver.rollbackToSavepoint(connection, savepointName, compileQuery);\n        }\n        throw new Error('The `rollbackToSavepoint` method is not supported by this driver');\n    }\n    releaseSavepoint(connection, savepointName, compileQuery) {\n        if (this.#driver.releaseSavepoint) {\n            return this.#driver.releaseSavepoint(connection, savepointName, compileQuery);\n        }\n        throw new Error('The `releaseSavepoint` method is not supported by this driver');\n    }\n    async destroy() {\n        if (!this.#initPromise) {\n            return;\n        }\n        await this.#initPromise;\n        if (!this.#destroyPromise) {\n            this.#destroyPromise = this.#driver.destroy().catch((err) => {\n                this.#destroyPromise = undefined;\n                return Promise.reject(err);\n            });\n        }\n        await this.#destroyPromise;\n    }\n    #needsLogging() {\n        return (this.#log.isLevelEnabled('query') || this.#log.isLevelEnabled('error'));\n    }\n    // This method monkey patches the database connection's executeQuery method\n    // by adding logging code around it. Monkey patching is not pretty, but it's\n    // the best option in this case.\n    #addLogging(connection) {\n        const executeQuery = connection.executeQuery;\n        const streamQuery = connection.streamQuery;\n        const dis = this;\n        connection.executeQuery = async (compiledQuery) => {\n            let caughtError;\n            const startTime = performanceNow();\n            try {\n                return await executeQuery.call(connection, compiledQuery);\n            }\n            catch (error) {\n                caughtError = error;\n                await dis.#logError(error, compiledQuery, startTime);\n                throw error;\n            }\n            finally {\n                if (!caughtError) {\n                    await dis.#logQuery(compiledQuery, startTime);\n                }\n            }\n        };\n        connection.streamQuery = async function* (compiledQuery, chunkSize) {\n            let caughtError;\n            const startTime = performanceNow();\n            try {\n                for await (const result of streamQuery.call(connection, compiledQuery, chunkSize)) {\n                    yield result;\n                }\n            }\n            catch (error) {\n                caughtError = error;\n                await dis.#logError(error, compiledQuery, startTime);\n                throw error;\n            }\n            finally {\n                if (!caughtError) {\n                    await dis.#logQuery(compiledQuery, startTime, true);\n                }\n            }\n        };\n    }\n    async #logError(error, compiledQuery, startTime) {\n        await this.#log.error(() => ({\n            level: 'error',\n            error,\n            query: compiledQuery,\n            queryDurationMillis: this.#calculateDurationMillis(startTime),\n        }));\n    }\n    async #logQuery(compiledQuery, startTime, isStream = false) {\n        await this.#log.query(() => ({\n            level: 'query',\n            isStream,\n            query: compiledQuery,\n            queryDurationMillis: this.#calculateDurationMillis(startTime),\n        }));\n    }\n    #calculateDurationMillis(startTime) {\n        return performanceNow() - startTime;\n    }\n}\n", "/// <reference types=\"./single-connection-provider.d.ts\" />\nconst ignoreError = () => { };\nexport class SingleConnectionProvider {\n    #connection;\n    #runningPromise;\n    constructor(connection) {\n        this.#connection = connection;\n    }\n    async provideConnection(consumer) {\n        while (this.#runningPromise) {\n            await this.#runningPromise.catch(ignoreError);\n        }\n        // `#runningPromise` must be set to undefined before it's\n        // resolved or rejected. Otherwise the while loop above\n        // will misbehave.\n        this.#runningPromise = this.#run(consumer).finally(() => {\n            this.#runningPromise = undefined;\n        });\n        return this.#runningPromise;\n    }\n    // Run the runner in an async function to make sure it doesn't\n    // throw synchronous errors.\n    async #run(runner) {\n        return await runner(this.#connection);\n    }\n}\n", "/// <reference types=\"./driver.d.ts\" />\nexport const TRANSACTION_ACCESS_MODES = ['read only', 'read write'];\nexport const TRANSACTION_ISOLATION_LEVELS = [\n    'read uncommitted',\n    'read committed',\n    'repeatable read',\n    'serializable',\n    'snapshot',\n];\nexport function validateTransactionSettings(settings) {\n    if (settings.accessMode &&\n        !TRANSACTION_ACCESS_MODES.includes(settings.accessMode)) {\n        throw new Error(`invalid transaction access mode ${settings.accessMode}`);\n    }\n    if (settings.isolationLevel &&\n        !TRANSACTION_ISOLATION_LEVELS.includes(settings.isolationLevel)) {\n        throw new Error(`invalid transaction isolation level ${settings.isolationLevel}`);\n    }\n}\n", "/// <reference types=\"./log.d.ts\" />\nimport { freeze, isFunction } from './object-utils.js';\nexport const LOG_LEVELS = freeze(['query', 'error']);\nexport class Log {\n    #levels;\n    #logger;\n    constructor(config) {\n        if (isFunction(config)) {\n            this.#logger = config;\n            this.#levels = freeze({\n                query: true,\n                error: true,\n            });\n        }\n        else {\n            this.#logger = defaultLogger;\n            this.#levels = freeze({\n                query: config.includes('query'),\n                error: config.includes('error'),\n            });\n        }\n    }\n    isLevelEnabled(level) {\n        return this.#levels[level];\n    }\n    async query(getEvent) {\n        if (this.#levels.query) {\n            await this.#logger(getEvent());\n        }\n    }\n    async error(getEvent) {\n        if (this.#levels.error) {\n            await this.#logger(getEvent());\n        }\n    }\n}\nfunction defaultLogger(event) {\n    if (event.level === 'query') {\n        const prefix = `kysely:query:${event.isStream ? 'stream:' : ''}`;\n        console.log(`${prefix} ${event.query.sql}`);\n        console.log(`${prefix} duration: ${event.queryDurationMillis.toFixed(1)}ms`);\n    }\n    else if (event.level === 'error') {\n        if (event.error instanceof Error) {\n            console.error(`kysely:error: ${event.error.stack ?? event.error.message}`);\n        }\n        else {\n            console.error(`kysely:error: ${JSON.stringify({\n                error: event.error,\n                query: event.query.sql,\n                queryDurationMillis: event.queryDurationMillis,\n            })}`);\n        }\n    }\n}\n", "/// <reference types=\"./compilable.d.ts\" />\nimport { isFunction, isObject } from './object-utils.js';\nexport function isCompilable(value) {\n    return isObject(value) && isFunction(value.compile);\n}\n", "/// <reference types=\"./kysely.d.ts\" />\nimport { SchemaModule } from './schema/schema.js';\nimport { DynamicModule } from './dynamic/dynamic.js';\nimport { DefaultConnectionProvider } from './driver/default-connection-provider.js';\nimport { QueryCreator } from './query-creator.js';\nimport { DefaultQueryExecutor } from './query-executor/default-query-executor.js';\nimport { freeze, isObject, isUndefined } from './util/object-utils.js';\nimport { RuntimeDriver } from './driver/runtime-driver.js';\nimport { SingleConnectionProvider } from './driver/single-connection-provider.js';\nimport { validateTransactionSettings, } from './driver/driver.js';\nimport { createFunctionModule, } from './query-builder/function-module.js';\nimport { Log } from './util/log.js';\nimport { createQueryId } from './util/query-id.js';\nimport { isCompilable } from './util/compilable.js';\nimport { CaseBuilder } from './query-builder/case-builder.js';\nimport { CaseNode } from './operation-node/case-node.js';\nimport { parseExpression } from './parser/expression-parser.js';\nimport { WithSchemaPlugin } from './plugin/with-schema/with-schema-plugin.js';\nimport { provideControlledConnection, } from './util/provide-controlled-connection.js';\n// @ts-ignore\nSymbol.asyncDispose ??= Symbol('Symbol.asyncDispose');\n/**\n * The main Kysely class.\n *\n * You should create one instance of `Kysely` per database using the {@link Kysely}\n * constructor. Each `Kysely` instance maintains its own connection pool.\n *\n * ### Examples\n *\n * This example assumes your database has a \"person\" table:\n *\n * ```ts\n * import * as Sqlite from 'better-sqlite3'\n * import {\u00A0type Generated, Kysely, SqliteDialect } from 'kysely'\n *\n * interface Database {\n *   person: {\n *     id: Generated<number>\n *     first_name: string\n *     last_name: string | null\n *   }\n * }\n *\n * const db = new Kysely<Database>({\n *   dialect: new SqliteDialect({\n *     database: new Sqlite(':memory:'),\n *   })\n * })\n * ```\n *\n * @typeParam DB - The database interface type. Keys of this type must be table names\n *    in the database and values must be interfaces that describe the rows in those\n *    tables. See the examples above.\n */\nexport class Kysely extends QueryCreator {\n    #props;\n    constructor(args) {\n        let superProps;\n        let props;\n        if (isKyselyProps(args)) {\n            superProps = { executor: args.executor };\n            props = { ...args };\n        }\n        else {\n            const dialect = args.dialect;\n            const driver = dialect.createDriver();\n            const compiler = dialect.createQueryCompiler();\n            const adapter = dialect.createAdapter();\n            const log = new Log(args.log ?? []);\n            const runtimeDriver = new RuntimeDriver(driver, log);\n            const connectionProvider = new DefaultConnectionProvider(runtimeDriver);\n            const executor = new DefaultQueryExecutor(compiler, adapter, connectionProvider, args.plugins ?? []);\n            superProps = { executor };\n            props = {\n                config: args,\n                executor,\n                dialect,\n                driver: runtimeDriver,\n            };\n        }\n        super(superProps);\n        this.#props = freeze(props);\n    }\n    /**\n     * Returns the {@link SchemaModule} module for building database schema.\n     */\n    get schema() {\n        return new SchemaModule(this.#props.executor);\n    }\n    /**\n     * Returns a the {@link DynamicModule} module.\n     *\n     * The {@link DynamicModule} module can be used to bypass strict typing and\n     * passing in dynamic values for the queries.\n     */\n    get dynamic() {\n        return new DynamicModule();\n    }\n    /**\n     * Returns a {@link DatabaseIntrospector | database introspector}.\n     */\n    get introspection() {\n        return this.#props.dialect.createIntrospector(this.withoutPlugins());\n    }\n    case(value) {\n        return new CaseBuilder({\n            node: CaseNode.create(isUndefined(value) ? undefined : parseExpression(value)),\n        });\n    }\n    /**\n     * Returns a {@link FunctionModule} that can be used to write somewhat type-safe function\n     * calls.\n     *\n     * ```ts\n     * const { count } = db.fn\n     *\n     * await db.selectFrom('person')\n     *   .innerJoin('pet', 'pet.owner_id', 'person.id')\n     *   .select([\n     *     'id',\n     *     count('pet.id').as('person_count'),\n     *   ])\n     *   .groupBy('person.id')\n     *   .having(count('pet.id'), '>', 10)\n     *   .execute()\n     * ```\n     *\n     * The generated SQL (PostgreSQL):\n     *\n     * ```sql\n     * select \"person\".\"id\", count(\"pet\".\"id\") as \"person_count\"\n     * from \"person\"\n     * inner join \"pet\" on \"pet\".\"owner_id\" = \"person\".\"id\"\n     * group by \"person\".\"id\"\n     * having count(\"pet\".\"id\") > $1\n     * ```\n     *\n     * Why \"somewhat\" type-safe? Because the function calls are not bound to the\n     * current query context. They allow you to reference columns and tables that\n     * are not in the current query. E.g. remove the `innerJoin` from the previous\n     * query and TypeScript won't even complain.\n     *\n     * If you want to make the function calls fully type-safe, you can use the\n     * {@link ExpressionBuilder.fn} getter for a query context-aware, stricter {@link FunctionModule}.\n     *\n     * ```ts\n     * await db.selectFrom('person')\n     *   .innerJoin('pet', 'pet.owner_id', 'person.id')\n     *   .select((eb) => [\n     *     'person.id',\n     *     eb.fn.count('pet.id').as('pet_count')\n     *   ])\n     *   .groupBy('person.id')\n     *   .having((eb) => eb.fn.count('pet.id'), '>', 10)\n     *   .execute()\n     * ```\n     */\n    get fn() {\n        return createFunctionModule();\n    }\n    /**\n     * Creates a {@link TransactionBuilder} that can be used to run queries inside a transaction.\n     *\n     * The returned {@link TransactionBuilder} can be used to configure the transaction. The\n     * {@link TransactionBuilder.execute} method can then be called to run the transaction.\n     * {@link TransactionBuilder.execute} takes a function that is run inside the\n     * transaction. If the function throws an exception,\n     * 1. the exception is caught,\n     * 2. the transaction is rolled back, and\n     * 3. the exception is thrown again.\n     * Otherwise the transaction is committed.\n     *\n     * The callback function passed to the {@link TransactionBuilder.execute | execute}\n     * method gets the transaction object as its only argument. The transaction is\n     * of type {@link Transaction} which inherits {@link Kysely}. Any query\n     * started through the transaction object is executed inside the transaction.\n     *\n     * To run a controlled transaction, allowing you to commit and rollback manually,\n     * use {@link startTransaction} instead.\n     *\n     * ### Examples\n     *\n     * <!-- siteExample(\"transactions\", \"Simple transaction\", 10) -->\n     *\n     * This example inserts two rows in a transaction. If an exception is thrown inside\n     * the callback passed to the `execute` method,\n     * 1. the exception is caught,\n     * 2. the transaction is rolled back, and\n     * 3. the exception is thrown again.\n     * Otherwise the transaction is committed.\n     *\n     * ```ts\n     * const catto = await db.transaction().execute(async (trx) => {\n     *   const jennifer = await trx.insertInto('person')\n     *     .values({\n     *       first_name: 'Jennifer',\n     *       last_name: 'Aniston',\n     *       age: 40,\n     *     })\n     *     .returning('id')\n     *     .executeTakeFirstOrThrow()\n     *\n     *   return await trx.insertInto('pet')\n     *     .values({\n     *       owner_id: jennifer.id,\n     *       name: 'Catto',\n     *       species: 'cat',\n     *       is_favorite: false,\n     *     })\n     *     .returningAll()\n     *     .executeTakeFirst()\n     * })\n     * ```\n     *\n     * Setting the isolation level:\n     *\n     * ```ts\n     * import type { Kysely } from 'kysely'\n     *\n     * await db\n     *   .transaction()\n     *   .setIsolationLevel('serializable')\n     *   .execute(async (trx) => {\n     *     await doStuff(trx)\n     *   })\n     *\n     * async function doStuff(kysely: typeof db) {\n     *   // ...\n     * }\n     * ```\n     */\n    transaction() {\n        return new TransactionBuilder({ ...this.#props });\n    }\n    /**\n     * Creates a {@link ControlledTransactionBuilder} that can be used to run queries inside a controlled transaction.\n     *\n     * The returned {@link ControlledTransactionBuilder} can be used to configure the transaction.\n     * The {@link ControlledTransactionBuilder.execute} method can then be called\n     * to start the transaction and return a {@link ControlledTransaction}.\n     *\n     * A {@link ControlledTransaction} allows you to commit and rollback manually,\n     * execute savepoint commands. It extends {@link Transaction} which extends {@link Kysely},\n     * so you can run queries inside the transaction. Once the transaction is committed,\n     * or rolled back, it can't be used anymore - all queries will throw an error.\n     * This is to prevent accidentally running queries outside the transaction - where\n     * atomicity is not guaranteed anymore.\n     *\n     * ### Examples\n     *\n     * <!-- siteExample(\"transactions\", \"Controlled transaction\", 11) -->\n     *\n     * A controlled transaction allows you to commit and rollback manually, execute\n     * savepoint commands, and queries in general.\n     *\n     * In this example we start a transaction, use it to insert two rows and then commit\n     * the transaction. If an error is thrown, we catch it and rollback the transaction.\n     *\n     * ```ts\n     * const trx = await db.startTransaction().execute()\n     *\n     * try {\n     *   const jennifer = await trx.insertInto('person')\n     *     .values({\n     *       first_name: 'Jennifer',\n     *       last_name: 'Aniston',\n     *       age: 40,\n     *     })\n     *     .returning('id')\n     *     .executeTakeFirstOrThrow()\n     *\n     *   const catto = await trx.insertInto('pet')\n     *     .values({\n     *       owner_id: jennifer.id,\n     *       name: 'Catto',\n     *       species: 'cat',\n     *       is_favorite: false,\n     *     })\n     *     .returningAll()\n     *     .executeTakeFirstOrThrow()\n     *\n     *   await trx.commit().execute()\n     *\n     *   // ...\n     * } catch (error) {\n     *   await trx.rollback().execute()\n     * }\n     * ```\n     *\n     * <!-- siteExample(\"transactions\", \"Controlled transaction /w savepoints\", 12) -->\n     *\n     * A controlled transaction allows you to commit and rollback manually, execute\n     * savepoint commands, and queries in general.\n     *\n     * In this example we start a transaction, insert a person, create a savepoint,\n     * try inserting a toy and a pet, and if an error is thrown, we rollback to the\n     * savepoint. Eventually we release the savepoint, insert an audit record and\n     * commit the transaction. If an error is thrown, we catch it and rollback the\n     * transaction.\n     *\n     * ```ts\n     * const trx = await db.startTransaction().execute()\n     *\n     * try {\n     *   const jennifer = await trx\n     *     .insertInto('person')\n     *     .values({\n     *       first_name: 'Jennifer',\n     *       last_name: 'Aniston',\n     *       age: 40,\n     *     })\n     *     .returning('id')\n     *     .executeTakeFirstOrThrow()\n     *\n     *   const trxAfterJennifer = await trx.savepoint('after_jennifer').execute()\n     *\n     *   try {\n     *     const catto = await trxAfterJennifer\n     *       .insertInto('pet')\n     *       .values({\n     *         owner_id: jennifer.id,\n     *         name: 'Catto',\n     *         species: 'cat',\n     *       })\n     *       .returning('id')\n     *       .executeTakeFirstOrThrow()\n     *\n     *     await trxAfterJennifer\n     *       .insertInto('toy')\n     *       .values({ name: 'Bone', price: 1.99, pet_id: catto.id })\n     *       .execute()\n     *   } catch (error) {\n     *     await trxAfterJennifer.rollbackToSavepoint('after_jennifer').execute()\n     *   }\n     *\n     *   await trxAfterJennifer.releaseSavepoint('after_jennifer').execute()\n     *\n     *   await trx.insertInto('audit').values({ action: 'added Jennifer' }).execute()\n     *\n     *   await trx.commit().execute()\n     * } catch (error) {\n     *   await trx.rollback().execute()\n     * }\n     * ```\n     */\n    startTransaction() {\n        return new ControlledTransactionBuilder({ ...this.#props });\n    }\n    /**\n     * Provides a kysely instance bound to a single database connection.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * await db\n     *   .connection()\n     *   .execute(async (db) => {\n     *     // `db` is an instance of `Kysely` that's bound to a single\n     *     // database connection. All queries executed through `db` use\n     *     // the same connection.\n     *     await doStuff(db)\n     *   })\n     *\n     * async function doStuff(kysely: typeof db) {\n     *   // ...\n     * }\n     * ```\n     */\n    connection() {\n        return new ConnectionBuilder({ ...this.#props });\n    }\n    /**\n     * Returns a copy of this Kysely instance with the given plugin installed.\n     */\n    withPlugin(plugin) {\n        return new Kysely({\n            ...this.#props,\n            executor: this.#props.executor.withPlugin(plugin),\n        });\n    }\n    /**\n     * Returns a copy of this Kysely instance without any plugins.\n     */\n    withoutPlugins() {\n        return new Kysely({\n            ...this.#props,\n            executor: this.#props.executor.withoutPlugins(),\n        });\n    }\n    /**\n     * @override\n     */\n    withSchema(schema) {\n        return new Kysely({\n            ...this.#props,\n            executor: this.#props.executor.withPluginAtFront(new WithSchemaPlugin(schema)),\n        });\n    }\n    /**\n     * Returns a copy of this Kysely instance with tables added to its\n     * database type.\n     *\n     * This method only modifies the types and doesn't affect any of the\n     * executed queries in any way.\n     *\n     * ### Examples\n     *\n     * The following example adds and uses a temporary table:\n     *\n     * ```ts\n     * await db.schema\n     *   .createTable('temp_table')\n     *   .temporary()\n     *   .addColumn('some_column', 'integer')\n     *   .execute()\n     *\n     * const tempDb = db.withTables<{\n     *   temp_table: {\n     *     some_column: number\n     *   }\n     * }>()\n     *\n     * await tempDb\n     *   .insertInto('temp_table')\n     *   .values({ some_column: 100 })\n     *   .execute()\n     * ```\n     */\n    withTables() {\n        return new Kysely({ ...this.#props });\n    }\n    /**\n     * Releases all resources and disconnects from the database.\n     *\n     * You need to call this when you are done using the `Kysely` instance.\n     */\n    async destroy() {\n        await this.#props.driver.destroy();\n    }\n    /**\n     * Returns true if this `Kysely` instance is a transaction.\n     *\n     * You can also use `db instanceof Transaction`.\n     */\n    get isTransaction() {\n        return false;\n    }\n    /**\n     * @internal\n     * @private\n     */\n    getExecutor() {\n        return this.#props.executor;\n    }\n    /**\n     * Executes a given compiled query or query builder.\n     *\n     * See {@link https://github.com/kysely-org/kysely/blob/master/site/docs/recipes/0004-splitting-query-building-and-execution.md#execute-compiled-queries splitting build, compile and execute code recipe} for more information.\n     */\n    executeQuery(query, queryId = createQueryId()) {\n        const compiledQuery = isCompilable(query) ? query.compile() : query;\n        return this.getExecutor().executeQuery(compiledQuery, queryId);\n    }\n    async [Symbol.asyncDispose]() {\n        await this.destroy();\n    }\n}\nexport class Transaction extends Kysely {\n    #props;\n    constructor(props) {\n        super(props);\n        this.#props = props;\n    }\n    // The return type is `true` instead of `boolean` to make Kysely<DB>\n    // unassignable to Transaction<DB> while allowing assignment the\n    // other way around.\n    get isTransaction() {\n        return true;\n    }\n    transaction() {\n        throw new Error('calling the transaction method for a Transaction is not supported');\n    }\n    connection() {\n        throw new Error('calling the connection method for a Transaction is not supported');\n    }\n    async destroy() {\n        throw new Error('calling the destroy method for a Transaction is not supported');\n    }\n    withPlugin(plugin) {\n        return new Transaction({\n            ...this.#props,\n            executor: this.#props.executor.withPlugin(plugin),\n        });\n    }\n    withoutPlugins() {\n        return new Transaction({\n            ...this.#props,\n            executor: this.#props.executor.withoutPlugins(),\n        });\n    }\n    withSchema(schema) {\n        return new Transaction({\n            ...this.#props,\n            executor: this.#props.executor.withPluginAtFront(new WithSchemaPlugin(schema)),\n        });\n    }\n    withTables() {\n        return new Transaction({ ...this.#props });\n    }\n}\nexport function isKyselyProps(obj) {\n    return (isObject(obj) &&\n        isObject(obj.config) &&\n        isObject(obj.driver) &&\n        isObject(obj.executor) &&\n        isObject(obj.dialect));\n}\nexport class ConnectionBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    async execute(callback) {\n        return this.#props.executor.provideConnection(async (connection) => {\n            const executor = this.#props.executor.withConnectionProvider(new SingleConnectionProvider(connection));\n            const db = new Kysely({\n                ...this.#props,\n                executor,\n            });\n            return await callback(db);\n        });\n    }\n}\nexport class TransactionBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    setAccessMode(accessMode) {\n        return new TransactionBuilder({\n            ...this.#props,\n            accessMode,\n        });\n    }\n    setIsolationLevel(isolationLevel) {\n        return new TransactionBuilder({\n            ...this.#props,\n            isolationLevel,\n        });\n    }\n    async execute(callback) {\n        const { isolationLevel, accessMode, ...kyselyProps } = this.#props;\n        const settings = { isolationLevel, accessMode };\n        validateTransactionSettings(settings);\n        return this.#props.executor.provideConnection(async (connection) => {\n            const executor = this.#props.executor.withConnectionProvider(new SingleConnectionProvider(connection));\n            const transaction = new Transaction({\n                ...kyselyProps,\n                executor,\n            });\n            try {\n                await this.#props.driver.beginTransaction(connection, settings);\n                const result = await callback(transaction);\n                await this.#props.driver.commitTransaction(connection);\n                return result;\n            }\n            catch (error) {\n                await this.#props.driver.rollbackTransaction(connection);\n                throw error;\n            }\n        });\n    }\n}\nexport class ControlledTransactionBuilder {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    setAccessMode(accessMode) {\n        return new ControlledTransactionBuilder({\n            ...this.#props,\n            accessMode,\n        });\n    }\n    setIsolationLevel(isolationLevel) {\n        return new ControlledTransactionBuilder({\n            ...this.#props,\n            isolationLevel,\n        });\n    }\n    async execute() {\n        const { isolationLevel, accessMode, ...props } = this.#props;\n        const settings = { isolationLevel, accessMode };\n        validateTransactionSettings(settings);\n        const connection = await provideControlledConnection(this.#props.executor);\n        await this.#props.driver.beginTransaction(connection.connection, settings);\n        return new ControlledTransaction({\n            ...props,\n            connection,\n            executor: this.#props.executor.withConnectionProvider(new SingleConnectionProvider(connection.connection)),\n        });\n    }\n}\nexport class ControlledTransaction extends Transaction {\n    #props;\n    #compileQuery;\n    #state;\n    constructor(props) {\n        const state = { isCommitted: false, isRolledBack: false };\n        props = {\n            ...props,\n            executor: new NotCommittedOrRolledBackAssertingExecutor(props.executor, state),\n        };\n        const { connection, ...transactionProps } = props;\n        super(transactionProps);\n        this.#props = freeze(props);\n        this.#state = state;\n        const queryId = createQueryId();\n        this.#compileQuery = (node) => props.executor.compileQuery(node, queryId);\n    }\n    get isCommitted() {\n        return this.#state.isCommitted;\n    }\n    get isRolledBack() {\n        return this.#state.isRolledBack;\n    }\n    /**\n     * Commits the transaction.\n     *\n     * See {@link rollback}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import type { Kysely } from 'kysely'\n     * import type { Database } from 'type-editor' // imaginary module\n     *\n     * const trx = await db.startTransaction().execute()\n     *\n     * try {\n     *   await doSomething(trx)\n     *\n     *   await trx.commit().execute()\n     * } catch (error) {\n     *   await trx.rollback().execute()\n     * }\n     *\n     * async function doSomething(kysely: Kysely<Database>) {}\n     * ```\n     */\n    commit() {\n        assertNotCommittedOrRolledBack(this.#state);\n        return new Command(async () => {\n            await this.#props.driver.commitTransaction(this.#props.connection.connection);\n            this.#state.isCommitted = true;\n            this.#props.connection.release();\n        });\n    }\n    /**\n     * Rolls back the transaction.\n     *\n     * See {@link commit} and {@link rollbackToSavepoint}.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import type { Kysely } from 'kysely'\n     * import type { Database } from 'type-editor' // imaginary module\n     *\n     * const trx = await db.startTransaction().execute()\n     *\n     * try {\n     *   await doSomething(trx)\n     *\n     *   await trx.commit().execute()\n     * } catch (error) {\n     *   await trx.rollback().execute()\n     * }\n     *\n     * async function doSomething(kysely: Kysely<Database>) {}\n     * ```\n     */\n    rollback() {\n        assertNotCommittedOrRolledBack(this.#state);\n        return new Command(async () => {\n            await this.#props.driver.rollbackTransaction(this.#props.connection.connection);\n            this.#state.isRolledBack = true;\n            this.#props.connection.release();\n        });\n    }\n    /**\n     * Creates a savepoint with a given name.\n     *\n     * See {@link rollbackToSavepoint} and {@link releaseSavepoint}.\n     *\n     * For a type-safe experience, you should use the returned instance from now on.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import type { Kysely } from 'kysely'\n     * import type { Database } from 'type-editor' // imaginary module\n     *\n     * const trx = await db.startTransaction().execute()\n     *\n     * await insertJennifer(trx)\n     *\n     * const trxAfterJennifer = await trx.savepoint('after_jennifer').execute()\n     *\n     * try {\n     *   await doSomething(trxAfterJennifer)\n     * } catch (error) {\n     *   await trxAfterJennifer.rollbackToSavepoint('after_jennifer').execute()\n     * }\n     *\n     * async function insertJennifer(kysely: Kysely<Database>) {}\n     * async function doSomething(kysely: Kysely<Database>) {}\n     * ```\n     */\n    savepoint(savepointName) {\n        assertNotCommittedOrRolledBack(this.#state);\n        return new Command(async () => {\n            await this.#props.driver.savepoint?.(this.#props.connection.connection, savepointName, this.#compileQuery);\n            return new ControlledTransaction({ ...this.#props });\n        });\n    }\n    /**\n     * Rolls back to a savepoint with a given name.\n     *\n     * See {@link savepoint} and {@link releaseSavepoint}.\n     *\n     * You must use the same instance returned by {@link savepoint}, or\n     * escape the type-check by using `as any`.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import type { Kysely } from 'kysely'\n     * import type { Database } from 'type-editor' // imaginary module\n     *\n     * const trx = await db.startTransaction().execute()\n     *\n     * await insertJennifer(trx)\n     *\n     * const trxAfterJennifer = await trx.savepoint('after_jennifer').execute()\n     *\n     * try {\n     *   await doSomething(trxAfterJennifer)\n     * } catch (error) {\n     *   await trxAfterJennifer.rollbackToSavepoint('after_jennifer').execute()\n     * }\n     *\n     * async function insertJennifer(kysely: Kysely<Database>) {}\n     * async function doSomething(kysely: Kysely<Database>) {}\n     * ```\n     */\n    rollbackToSavepoint(savepointName) {\n        assertNotCommittedOrRolledBack(this.#state);\n        return new Command(async () => {\n            await this.#props.driver.rollbackToSavepoint?.(this.#props.connection.connection, savepointName, this.#compileQuery);\n            return new ControlledTransaction({ ...this.#props });\n        });\n    }\n    /**\n     * Releases a savepoint with a given name.\n     *\n     * See {@link savepoint} and {@link rollbackToSavepoint}.\n     *\n     * You must use the same instance returned by {@link savepoint}, or\n     * escape the type-check by using `as any`.\n     *\n     * ### Examples\n     *\n     * ```ts\n     * import type { Kysely } from 'kysely'\n     * import type { Database } from 'type-editor' // imaginary module\n     *\n     * const trx = await db.startTransaction().execute()\n     *\n     * await insertJennifer(trx)\n     *\n     * const trxAfterJennifer = await trx.savepoint('after_jennifer').execute()\n     *\n     * try {\n     *   await doSomething(trxAfterJennifer)\n     * } catch (error) {\n     *   await trxAfterJennifer.rollbackToSavepoint('after_jennifer').execute()\n     * }\n     *\n     * await trxAfterJennifer.releaseSavepoint('after_jennifer').execute()\n     *\n     * await doSomethingElse(trx)\n     *\n     * async function insertJennifer(kysely: Kysely<Database>) {}\n     * async function doSomething(kysely: Kysely<Database>) {}\n     * async function doSomethingElse(kysely: Kysely<Database>) {}\n     * ```\n     */\n    releaseSavepoint(savepointName) {\n        assertNotCommittedOrRolledBack(this.#state);\n        return new Command(async () => {\n            await this.#props.driver.releaseSavepoint?.(this.#props.connection.connection, savepointName, this.#compileQuery);\n            return new ControlledTransaction({ ...this.#props });\n        });\n    }\n    withPlugin(plugin) {\n        return new ControlledTransaction({\n            ...this.#props,\n            executor: this.#props.executor.withPlugin(plugin),\n        });\n    }\n    withoutPlugins() {\n        return new ControlledTransaction({\n            ...this.#props,\n            executor: this.#props.executor.withoutPlugins(),\n        });\n    }\n    withSchema(schema) {\n        return new ControlledTransaction({\n            ...this.#props,\n            executor: this.#props.executor.withPluginAtFront(new WithSchemaPlugin(schema)),\n        });\n    }\n    withTables() {\n        return new ControlledTransaction({ ...this.#props });\n    }\n}\nexport class Command {\n    #cb;\n    constructor(cb) {\n        this.#cb = cb;\n    }\n    /**\n     * Executes the command.\n     */\n    async execute() {\n        return await this.#cb();\n    }\n}\nfunction assertNotCommittedOrRolledBack(state) {\n    if (state.isCommitted) {\n        throw new Error('Transaction is already committed');\n    }\n    if (state.isRolledBack) {\n        throw new Error('Transaction is already rolled back');\n    }\n}\n/**\n * An executor wrapper that asserts that the transaction state is not committed\n * or rolled back when a query is executed.\n *\n * @internal\n */\nclass NotCommittedOrRolledBackAssertingExecutor {\n    #executor;\n    #state;\n    constructor(executor, state) {\n        if (executor instanceof NotCommittedOrRolledBackAssertingExecutor) {\n            this.#executor = executor.#executor;\n        }\n        else {\n            this.#executor = executor;\n        }\n        this.#state = state;\n    }\n    get adapter() {\n        return this.#executor.adapter;\n    }\n    get plugins() {\n        return this.#executor.plugins;\n    }\n    transformQuery(node, queryId) {\n        return this.#executor.transformQuery(node, queryId);\n    }\n    compileQuery(node, queryId) {\n        return this.#executor.compileQuery(node, queryId);\n    }\n    provideConnection(consumer) {\n        return this.#executor.provideConnection(consumer);\n    }\n    executeQuery(compiledQuery, queryId) {\n        assertNotCommittedOrRolledBack(this.#state);\n        return this.#executor.executeQuery(compiledQuery, queryId);\n    }\n    stream(compiledQuery, chunkSize, queryId) {\n        assertNotCommittedOrRolledBack(this.#state);\n        return this.#executor.stream(compiledQuery, chunkSize, queryId);\n    }\n    withConnectionProvider(connectionProvider) {\n        return new NotCommittedOrRolledBackAssertingExecutor(this.#executor.withConnectionProvider(connectionProvider), this.#state);\n    }\n    withPlugin(plugin) {\n        return new NotCommittedOrRolledBackAssertingExecutor(this.#executor.withPlugin(plugin), this.#state);\n    }\n    withPlugins(plugins) {\n        return new NotCommittedOrRolledBackAssertingExecutor(this.#executor.withPlugins(plugins), this.#state);\n    }\n    withPluginAtFront(plugin) {\n        return new NotCommittedOrRolledBackAssertingExecutor(this.#executor.withPluginAtFront(plugin), this.#state);\n    }\n    withoutPlugins() {\n        return new NotCommittedOrRolledBackAssertingExecutor(this.#executor.withoutPlugins(), this.#state);\n    }\n}\n", "/// <reference types=\"./raw-builder.d.ts\" />\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { freeze } from '../util/object-utils.js';\nimport { NOOP_QUERY_EXECUTOR } from '../query-executor/noop-query-executor.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { isOperationNodeSource } from '../operation-node/operation-node-source.js';\nclass RawBuilderImpl {\n    #props;\n    constructor(props) {\n        this.#props = freeze(props);\n    }\n    get expressionType() {\n        return undefined;\n    }\n    get isRawBuilder() {\n        return true;\n    }\n    as(alias) {\n        return new AliasedRawBuilderImpl(this, alias);\n    }\n    $castTo() {\n        return new RawBuilderImpl({ ...this.#props });\n    }\n    $notNull() {\n        return new RawBuilderImpl(this.#props);\n    }\n    withPlugin(plugin) {\n        return new RawBuilderImpl({\n            ...this.#props,\n            plugins: this.#props.plugins !== undefined\n                ? freeze([...this.#props.plugins, plugin])\n                : freeze([plugin]),\n        });\n    }\n    toOperationNode() {\n        return this.#toOperationNode(this.#getExecutor());\n    }\n    compile(executorProvider) {\n        return this.#compile(this.#getExecutor(executorProvider));\n    }\n    async execute(executorProvider) {\n        const executor = this.#getExecutor(executorProvider);\n        return executor.executeQuery(this.#compile(executor), this.#props.queryId);\n    }\n    #getExecutor(executorProvider) {\n        const executor = executorProvider !== undefined\n            ? executorProvider.getExecutor()\n            : NOOP_QUERY_EXECUTOR;\n        return this.#props.plugins !== undefined\n            ? executor.withPlugins(this.#props.plugins)\n            : executor;\n    }\n    #toOperationNode(executor) {\n        return executor.transformQuery(this.#props.rawNode, this.#props.queryId);\n    }\n    #compile(executor) {\n        return executor.compileQuery(this.#toOperationNode(executor), this.#props.queryId);\n    }\n}\nexport function createRawBuilder(props) {\n    return new RawBuilderImpl(props);\n}\nclass AliasedRawBuilderImpl {\n    #rawBuilder;\n    #alias;\n    constructor(rawBuilder, alias) {\n        this.#rawBuilder = rawBuilder;\n        this.#alias = alias;\n    }\n    get expression() {\n        return this.#rawBuilder;\n    }\n    get alias() {\n        return this.#alias;\n    }\n    get rawBuilder() {\n        return this.#rawBuilder;\n    }\n    toOperationNode() {\n        return AliasNode.create(this.#rawBuilder.toOperationNode(), isOperationNodeSource(this.#alias)\n            ? this.#alias.toOperationNode()\n            : IdentifierNode.create(this.#alias));\n    }\n}\n", "/// <reference types=\"./sql.d.ts\" />\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { isOperationNodeSource } from '../operation-node/operation-node-source.js';\nimport { RawNode } from '../operation-node/raw-node.js';\nimport { ValueNode } from '../operation-node/value-node.js';\nimport { parseStringReference } from '../parser/reference-parser.js';\nimport { parseTable } from '../parser/table-parser.js';\nimport { parseValueExpression } from '../parser/value-parser.js';\nimport { createQueryId } from '../util/query-id.js';\nimport { createRawBuilder } from './raw-builder.js';\nexport const sql = Object.assign((sqlFragments, ...parameters) => {\n    return createRawBuilder({\n        queryId: createQueryId(),\n        rawNode: RawNode.create(sqlFragments, parameters?.map(parseParameter) ?? []),\n    });\n}, {\n    ref(columnReference) {\n        return createRawBuilder({\n            queryId: createQueryId(),\n            rawNode: RawNode.createWithChild(parseStringReference(columnReference)),\n        });\n    },\n    val(value) {\n        return createRawBuilder({\n            queryId: createQueryId(),\n            rawNode: RawNode.createWithChild(parseValueExpression(value)),\n        });\n    },\n    value(value) {\n        return this.val(value);\n    },\n    table(tableReference) {\n        return createRawBuilder({\n            queryId: createQueryId(),\n            rawNode: RawNode.createWithChild(parseTable(tableReference)),\n        });\n    },\n    id(...ids) {\n        const fragments = new Array(ids.length + 1).fill('.');\n        fragments[0] = '';\n        fragments[fragments.length - 1] = '';\n        return createRawBuilder({\n            queryId: createQueryId(),\n            rawNode: RawNode.create(fragments, ids.map(IdentifierNode.create)),\n        });\n    },\n    lit(value) {\n        return createRawBuilder({\n            queryId: createQueryId(),\n            rawNode: RawNode.createWithChild(ValueNode.createImmediate(value)),\n        });\n    },\n    literal(value) {\n        return this.lit(value);\n    },\n    raw(sql) {\n        return createRawBuilder({\n            queryId: createQueryId(),\n            rawNode: RawNode.createWithSql(sql),\n        });\n    },\n    join(array, separator = sql `, `) {\n        const nodes = new Array(Math.max(2 * array.length - 1, 0));\n        const sep = separator.toOperationNode();\n        for (let i = 0; i < array.length; ++i) {\n            nodes[2 * i] = parseParameter(array[i]);\n            if (i !== array.length - 1) {\n                nodes[2 * i + 1] = sep;\n            }\n        }\n        return createRawBuilder({\n            queryId: createQueryId(),\n            rawNode: RawNode.createWithChildren(nodes),\n        });\n    },\n});\nfunction parseParameter(param) {\n    if (isOperationNodeSource(param)) {\n        return param.toOperationNode();\n    }\n    return parseValueExpression(param);\n}\n", "/// <reference types=\"./operation-node-visitor.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nexport class OperationNodeVisitor {\n    nodeStack = [];\n    get parentNode() {\n        return this.nodeStack[this.nodeStack.length - 2];\n    }\n    #visitors = freeze({\n        AliasNode: this.visitAlias.bind(this),\n        ColumnNode: this.visitColumn.bind(this),\n        IdentifierNode: this.visitIdentifier.bind(this),\n        SchemableIdentifierNode: this.visitSchemableIdentifier.bind(this),\n        RawNode: this.visitRaw.bind(this),\n        ReferenceNode: this.visitReference.bind(this),\n        SelectQueryNode: this.visitSelectQuery.bind(this),\n        SelectionNode: this.visitSelection.bind(this),\n        TableNode: this.visitTable.bind(this),\n        FromNode: this.visitFrom.bind(this),\n        SelectAllNode: this.visitSelectAll.bind(this),\n        AndNode: this.visitAnd.bind(this),\n        OrNode: this.visitOr.bind(this),\n        ValueNode: this.visitValue.bind(this),\n        ValueListNode: this.visitValueList.bind(this),\n        PrimitiveValueListNode: this.visitPrimitiveValueList.bind(this),\n        ParensNode: this.visitParens.bind(this),\n        JoinNode: this.visitJoin.bind(this),\n        OperatorNode: this.visitOperator.bind(this),\n        WhereNode: this.visitWhere.bind(this),\n        InsertQueryNode: this.visitInsertQuery.bind(this),\n        DeleteQueryNode: this.visitDeleteQuery.bind(this),\n        ReturningNode: this.visitReturning.bind(this),\n        CreateTableNode: this.visitCreateTable.bind(this),\n        AddColumnNode: this.visitAddColumn.bind(this),\n        ColumnDefinitionNode: this.visitColumnDefinition.bind(this),\n        DropTableNode: this.visitDropTable.bind(this),\n        DataTypeNode: this.visitDataType.bind(this),\n        OrderByNode: this.visitOrderBy.bind(this),\n        OrderByItemNode: this.visitOrderByItem.bind(this),\n        GroupByNode: this.visitGroupBy.bind(this),\n        GroupByItemNode: this.visitGroupByItem.bind(this),\n        UpdateQueryNode: this.visitUpdateQuery.bind(this),\n        ColumnUpdateNode: this.visitColumnUpdate.bind(this),\n        LimitNode: this.visitLimit.bind(this),\n        OffsetNode: this.visitOffset.bind(this),\n        OnConflictNode: this.visitOnConflict.bind(this),\n        OnDuplicateKeyNode: this.visitOnDuplicateKey.bind(this),\n        CreateIndexNode: this.visitCreateIndex.bind(this),\n        DropIndexNode: this.visitDropIndex.bind(this),\n        ListNode: this.visitList.bind(this),\n        PrimaryKeyConstraintNode: this.visitPrimaryKeyConstraint.bind(this),\n        UniqueConstraintNode: this.visitUniqueConstraint.bind(this),\n        ReferencesNode: this.visitReferences.bind(this),\n        CheckConstraintNode: this.visitCheckConstraint.bind(this),\n        WithNode: this.visitWith.bind(this),\n        CommonTableExpressionNode: this.visitCommonTableExpression.bind(this),\n        CommonTableExpressionNameNode: this.visitCommonTableExpressionName.bind(this),\n        HavingNode: this.visitHaving.bind(this),\n        CreateSchemaNode: this.visitCreateSchema.bind(this),\n        DropSchemaNode: this.visitDropSchema.bind(this),\n        AlterTableNode: this.visitAlterTable.bind(this),\n        DropColumnNode: this.visitDropColumn.bind(this),\n        RenameColumnNode: this.visitRenameColumn.bind(this),\n        AlterColumnNode: this.visitAlterColumn.bind(this),\n        ModifyColumnNode: this.visitModifyColumn.bind(this),\n        AddConstraintNode: this.visitAddConstraint.bind(this),\n        DropConstraintNode: this.visitDropConstraint.bind(this),\n        RenameConstraintNode: this.visitRenameConstraint.bind(this),\n        ForeignKeyConstraintNode: this.visitForeignKeyConstraint.bind(this),\n        CreateViewNode: this.visitCreateView.bind(this),\n        RefreshMaterializedViewNode: this.visitRefreshMaterializedView.bind(this),\n        DropViewNode: this.visitDropView.bind(this),\n        GeneratedNode: this.visitGenerated.bind(this),\n        DefaultValueNode: this.visitDefaultValue.bind(this),\n        OnNode: this.visitOn.bind(this),\n        ValuesNode: this.visitValues.bind(this),\n        SelectModifierNode: this.visitSelectModifier.bind(this),\n        CreateTypeNode: this.visitCreateType.bind(this),\n        DropTypeNode: this.visitDropType.bind(this),\n        ExplainNode: this.visitExplain.bind(this),\n        DefaultInsertValueNode: this.visitDefaultInsertValue.bind(this),\n        AggregateFunctionNode: this.visitAggregateFunction.bind(this),\n        OverNode: this.visitOver.bind(this),\n        PartitionByNode: this.visitPartitionBy.bind(this),\n        PartitionByItemNode: this.visitPartitionByItem.bind(this),\n        SetOperationNode: this.visitSetOperation.bind(this),\n        BinaryOperationNode: this.visitBinaryOperation.bind(this),\n        UnaryOperationNode: this.visitUnaryOperation.bind(this),\n        UsingNode: this.visitUsing.bind(this),\n        FunctionNode: this.visitFunction.bind(this),\n        CaseNode: this.visitCase.bind(this),\n        WhenNode: this.visitWhen.bind(this),\n        JSONReferenceNode: this.visitJSONReference.bind(this),\n        JSONPathNode: this.visitJSONPath.bind(this),\n        JSONPathLegNode: this.visitJSONPathLeg.bind(this),\n        JSONOperatorChainNode: this.visitJSONOperatorChain.bind(this),\n        TupleNode: this.visitTuple.bind(this),\n        MergeQueryNode: this.visitMergeQuery.bind(this),\n        MatchedNode: this.visitMatched.bind(this),\n        AddIndexNode: this.visitAddIndex.bind(this),\n        CastNode: this.visitCast.bind(this),\n        FetchNode: this.visitFetch.bind(this),\n        TopNode: this.visitTop.bind(this),\n        OutputNode: this.visitOutput.bind(this),\n        OrActionNode: this.visitOrAction.bind(this),\n        CollateNode: this.visitCollate.bind(this),\n    });\n    visitNode = (node) => {\n        this.nodeStack.push(node);\n        this.#visitors[node.kind](node);\n        this.nodeStack.pop();\n    };\n}\n", "/// <reference types=\"./default-query-compiler.d.ts\" />\nimport { CreateTableNode } from '../operation-node/create-table-node.js';\nimport { InsertQueryNode } from '../operation-node/insert-query-node.js';\nimport { OperationNodeVisitor } from '../operation-node/operation-node-visitor.js';\nimport { OperatorNode } from '../operation-node/operator-node.js';\nimport { ParensNode } from '../operation-node/parens-node.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { freeze, isString, isNumber, isBoolean, isNull, isDate, isBigInt, } from '../util/object-utils.js';\nimport { CreateViewNode } from '../operation-node/create-view-node.js';\nimport { SetOperationNode } from '../operation-node/set-operation-node.js';\nimport { MergeQueryNode } from '../operation-node/merge-query-node.js';\nimport { logOnce } from '../util/log-once.js';\nconst LIT_WRAP_REGEX = /'/g;\nexport class DefaultQueryCompiler extends OperationNodeVisitor {\n    #sql = '';\n    #parameters = [];\n    get numParameters() {\n        return this.#parameters.length;\n    }\n    compileQuery(node, queryId) {\n        this.#sql = '';\n        this.#parameters = [];\n        this.nodeStack.splice(0, this.nodeStack.length);\n        this.visitNode(node);\n        return freeze({\n            query: node,\n            queryId,\n            sql: this.getSql(),\n            parameters: [...this.#parameters],\n        });\n    }\n    getSql() {\n        return this.#sql;\n    }\n    visitSelectQuery(node) {\n        const wrapInParens = this.parentNode !== undefined &&\n            !ParensNode.is(this.parentNode) &&\n            !InsertQueryNode.is(this.parentNode) &&\n            !CreateTableNode.is(this.parentNode) &&\n            !CreateViewNode.is(this.parentNode) &&\n            !SetOperationNode.is(this.parentNode);\n        if (this.parentNode === undefined && node.explain) {\n            this.visitNode(node.explain);\n            this.append(' ');\n        }\n        if (wrapInParens) {\n            this.append('(');\n        }\n        if (node.with) {\n            this.visitNode(node.with);\n            this.append(' ');\n        }\n        this.append('select');\n        if (node.distinctOn) {\n            this.append(' ');\n            this.compileDistinctOn(node.distinctOn);\n        }\n        if (node.frontModifiers?.length) {\n            this.append(' ');\n            this.compileList(node.frontModifiers, ' ');\n        }\n        if (node.top) {\n            this.append(' ');\n            this.visitNode(node.top);\n        }\n        if (node.selections) {\n            this.append(' ');\n            this.compileList(node.selections);\n        }\n        if (node.from) {\n            this.append(' ');\n            this.visitNode(node.from);\n        }\n        if (node.joins) {\n            this.append(' ');\n            this.compileList(node.joins, ' ');\n        }\n        if (node.where) {\n            this.append(' ');\n            this.visitNode(node.where);\n        }\n        if (node.groupBy) {\n            this.append(' ');\n            this.visitNode(node.groupBy);\n        }\n        if (node.having) {\n            this.append(' ');\n            this.visitNode(node.having);\n        }\n        if (node.setOperations) {\n            this.append(' ');\n            this.compileList(node.setOperations, ' ');\n        }\n        if (node.orderBy) {\n            this.append(' ');\n            this.visitNode(node.orderBy);\n        }\n        if (node.limit) {\n            this.append(' ');\n            this.visitNode(node.limit);\n        }\n        if (node.offset) {\n            this.append(' ');\n            this.visitNode(node.offset);\n        }\n        if (node.fetch) {\n            this.append(' ');\n            this.visitNode(node.fetch);\n        }\n        if (node.endModifiers?.length) {\n            this.append(' ');\n            this.compileList(this.sortSelectModifiers([...node.endModifiers]), ' ');\n        }\n        if (wrapInParens) {\n            this.append(')');\n        }\n    }\n    visitFrom(node) {\n        this.append('from ');\n        this.compileList(node.froms);\n    }\n    visitSelection(node) {\n        this.visitNode(node.selection);\n    }\n    visitColumn(node) {\n        this.visitNode(node.column);\n    }\n    compileDistinctOn(expressions) {\n        this.append('distinct on (');\n        this.compileList(expressions);\n        this.append(')');\n    }\n    compileList(nodes, separator = ', ') {\n        const lastIndex = nodes.length - 1;\n        for (let i = 0; i <= lastIndex; i++) {\n            this.visitNode(nodes[i]);\n            if (i < lastIndex) {\n                this.append(separator);\n            }\n        }\n    }\n    visitWhere(node) {\n        this.append('where ');\n        this.visitNode(node.where);\n    }\n    visitHaving(node) {\n        this.append('having ');\n        this.visitNode(node.having);\n    }\n    visitInsertQuery(node) {\n        const rootQueryNode = this.nodeStack.find(QueryNode.is);\n        const isSubQuery = rootQueryNode !== node;\n        if (!isSubQuery && node.explain) {\n            this.visitNode(node.explain);\n            this.append(' ');\n        }\n        if (isSubQuery && !MergeQueryNode.is(rootQueryNode)) {\n            this.append('(');\n        }\n        if (node.with) {\n            this.visitNode(node.with);\n            this.append(' ');\n        }\n        this.append(node.replace ? 'replace' : 'insert');\n        // TODO: remove in 0.29.\n        if (node.ignore) {\n            logOnce('`InsertQueryNode.ignore` is deprecated. Use `InsertQueryNode.orAction` instead.');\n            this.append(' ignore');\n        }\n        if (node.orAction) {\n            this.append(' ');\n            this.visitNode(node.orAction);\n        }\n        if (node.top) {\n            this.append(' ');\n            this.visitNode(node.top);\n        }\n        if (node.into) {\n            this.append(' into ');\n            this.visitNode(node.into);\n        }\n        if (node.columns) {\n            this.append(' (');\n            this.compileList(node.columns);\n            this.append(')');\n        }\n        if (node.output) {\n            this.append(' ');\n            this.visitNode(node.output);\n        }\n        if (node.values) {\n            this.append(' ');\n            this.visitNode(node.values);\n        }\n        if (node.defaultValues) {\n            this.append(' ');\n            this.append('default values');\n        }\n        if (node.onConflict) {\n            this.append(' ');\n            this.visitNode(node.onConflict);\n        }\n        if (node.onDuplicateKey) {\n            this.append(' ');\n            this.visitNode(node.onDuplicateKey);\n        }\n        if (node.returning) {\n            this.append(' ');\n            this.visitNode(node.returning);\n        }\n        if (isSubQuery && !MergeQueryNode.is(rootQueryNode)) {\n            this.append(')');\n        }\n        if (node.endModifiers?.length) {\n            this.append(' ');\n            this.compileList(node.endModifiers, ' ');\n        }\n    }\n    visitValues(node) {\n        this.append('values ');\n        this.compileList(node.values);\n    }\n    visitDeleteQuery(node) {\n        const isSubQuery = this.nodeStack.find(QueryNode.is) !== node;\n        if (!isSubQuery && node.explain) {\n            this.visitNode(node.explain);\n            this.append(' ');\n        }\n        if (isSubQuery) {\n            this.append('(');\n        }\n        if (node.with) {\n            this.visitNode(node.with);\n            this.append(' ');\n        }\n        this.append('delete ');\n        if (node.top) {\n            this.visitNode(node.top);\n            this.append(' ');\n        }\n        this.visitNode(node.from);\n        if (node.output) {\n            this.append(' ');\n            this.visitNode(node.output);\n        }\n        if (node.using) {\n            this.append(' ');\n            this.visitNode(node.using);\n        }\n        if (node.joins) {\n            this.append(' ');\n            this.compileList(node.joins, ' ');\n        }\n        if (node.where) {\n            this.append(' ');\n            this.visitNode(node.where);\n        }\n        if (node.orderBy) {\n            this.append(' ');\n            this.visitNode(node.orderBy);\n        }\n        if (node.limit) {\n            this.append(' ');\n            this.visitNode(node.limit);\n        }\n        if (node.returning) {\n            this.append(' ');\n            this.visitNode(node.returning);\n        }\n        if (isSubQuery) {\n            this.append(')');\n        }\n        if (node.endModifiers?.length) {\n            this.append(' ');\n            this.compileList(node.endModifiers, ' ');\n        }\n    }\n    visitReturning(node) {\n        this.append('returning ');\n        this.compileList(node.selections);\n    }\n    visitAlias(node) {\n        this.visitNode(node.node);\n        this.append(' as ');\n        this.visitNode(node.alias);\n    }\n    visitReference(node) {\n        if (node.table) {\n            this.visitNode(node.table);\n            this.append('.');\n        }\n        this.visitNode(node.column);\n    }\n    visitSelectAll(_) {\n        this.append('*');\n    }\n    visitIdentifier(node) {\n        this.append(this.getLeftIdentifierWrapper());\n        this.compileUnwrappedIdentifier(node);\n        this.append(this.getRightIdentifierWrapper());\n    }\n    compileUnwrappedIdentifier(node) {\n        if (!isString(node.name)) {\n            throw new Error('a non-string identifier was passed to compileUnwrappedIdentifier.');\n        }\n        this.append(this.sanitizeIdentifier(node.name));\n    }\n    visitAnd(node) {\n        this.visitNode(node.left);\n        this.append(' and ');\n        this.visitNode(node.right);\n    }\n    visitOr(node) {\n        this.visitNode(node.left);\n        this.append(' or ');\n        this.visitNode(node.right);\n    }\n    visitValue(node) {\n        if (node.immediate) {\n            this.appendImmediateValue(node.value);\n        }\n        else {\n            this.appendValue(node.value);\n        }\n    }\n    visitValueList(node) {\n        this.append('(');\n        this.compileList(node.values);\n        this.append(')');\n    }\n    visitTuple(node) {\n        this.append('(');\n        this.compileList(node.values);\n        this.append(')');\n    }\n    visitPrimitiveValueList(node) {\n        this.append('(');\n        const { values } = node;\n        for (let i = 0; i < values.length; ++i) {\n            this.appendValue(values[i]);\n            if (i !== values.length - 1) {\n                this.append(', ');\n            }\n        }\n        this.append(')');\n    }\n    visitParens(node) {\n        this.append('(');\n        this.visitNode(node.node);\n        this.append(')');\n    }\n    visitJoin(node) {\n        this.append(JOIN_TYPE_SQL[node.joinType]);\n        this.append(' ');\n        this.visitNode(node.table);\n        if (node.on) {\n            this.append(' ');\n            this.visitNode(node.on);\n        }\n    }\n    visitOn(node) {\n        this.append('on ');\n        this.visitNode(node.on);\n    }\n    visitRaw(node) {\n        const { sqlFragments, parameters: params } = node;\n        for (let i = 0; i < sqlFragments.length; ++i) {\n            this.append(sqlFragments[i]);\n            if (params.length > i) {\n                this.visitNode(params[i]);\n            }\n        }\n    }\n    visitOperator(node) {\n        this.append(node.operator);\n    }\n    visitTable(node) {\n        this.visitNode(node.table);\n    }\n    visitSchemableIdentifier(node) {\n        if (node.schema) {\n            this.visitNode(node.schema);\n            this.append('.');\n        }\n        this.visitNode(node.identifier);\n    }\n    visitCreateTable(node) {\n        this.append('create ');\n        if (node.frontModifiers && node.frontModifiers.length > 0) {\n            this.compileList(node.frontModifiers, ' ');\n            this.append(' ');\n        }\n        if (node.temporary) {\n            this.append('temporary ');\n        }\n        this.append('table ');\n        if (node.ifNotExists) {\n            this.append('if not exists ');\n        }\n        this.visitNode(node.table);\n        if (node.selectQuery) {\n            this.append(' as ');\n            this.visitNode(node.selectQuery);\n        }\n        else {\n            this.append(' (');\n            this.compileList([...node.columns, ...(node.constraints ?? [])]);\n            this.append(')');\n            if (node.onCommit) {\n                this.append(' on commit ');\n                this.append(node.onCommit);\n            }\n            if (node.endModifiers && node.endModifiers.length > 0) {\n                this.append(' ');\n                this.compileList(node.endModifiers, ' ');\n            }\n        }\n    }\n    visitColumnDefinition(node) {\n        if (node.ifNotExists) {\n            this.append('if not exists ');\n        }\n        this.visitNode(node.column);\n        this.append(' ');\n        this.visitNode(node.dataType);\n        if (node.unsigned) {\n            this.append(' unsigned');\n        }\n        if (node.frontModifiers && node.frontModifiers.length > 0) {\n            this.append(' ');\n            this.compileList(node.frontModifiers, ' ');\n        }\n        if (node.generated) {\n            this.append(' ');\n            this.visitNode(node.generated);\n        }\n        if (node.identity) {\n            this.append(' identity');\n        }\n        if (node.defaultTo) {\n            this.append(' ');\n            this.visitNode(node.defaultTo);\n        }\n        if (node.notNull) {\n            this.append(' not null');\n        }\n        if (node.unique) {\n            this.append(' unique');\n        }\n        if (node.nullsNotDistinct) {\n            this.append(' nulls not distinct');\n        }\n        if (node.primaryKey) {\n            this.append(' primary key');\n        }\n        if (node.autoIncrement) {\n            this.append(' ');\n            this.append(this.getAutoIncrement());\n        }\n        if (node.references) {\n            this.append(' ');\n            this.visitNode(node.references);\n        }\n        if (node.check) {\n            this.append(' ');\n            this.visitNode(node.check);\n        }\n        if (node.endModifiers && node.endModifiers.length > 0) {\n            this.append(' ');\n            this.compileList(node.endModifiers, ' ');\n        }\n    }\n    getAutoIncrement() {\n        return 'auto_increment';\n    }\n    visitReferences(node) {\n        this.append('references ');\n        this.visitNode(node.table);\n        this.append(' (');\n        this.compileList(node.columns);\n        this.append(')');\n        if (node.onDelete) {\n            this.append(' on delete ');\n            this.append(node.onDelete);\n        }\n        if (node.onUpdate) {\n            this.append(' on update ');\n            this.append(node.onUpdate);\n        }\n    }\n    visitDropTable(node) {\n        this.append('drop table ');\n        if (node.ifExists) {\n            this.append('if exists ');\n        }\n        this.visitNode(node.table);\n        if (node.cascade) {\n            this.append(' cascade');\n        }\n    }\n    visitDataType(node) {\n        this.append(node.dataType);\n    }\n    visitOrderBy(node) {\n        this.append('order by ');\n        this.compileList(node.items);\n    }\n    visitOrderByItem(node) {\n        this.visitNode(node.orderBy);\n        if (node.collation) {\n            this.append(' ');\n            this.visitNode(node.collation);\n        }\n        if (node.direction) {\n            this.append(' ');\n            this.visitNode(node.direction);\n        }\n        if (node.nulls) {\n            this.append(' nulls ');\n            this.append(node.nulls);\n        }\n    }\n    visitGroupBy(node) {\n        this.append('group by ');\n        this.compileList(node.items);\n    }\n    visitGroupByItem(node) {\n        this.visitNode(node.groupBy);\n    }\n    visitUpdateQuery(node) {\n        const rootQueryNode = this.nodeStack.find(QueryNode.is);\n        const isSubQuery = rootQueryNode !== node;\n        if (!isSubQuery && node.explain) {\n            this.visitNode(node.explain);\n            this.append(' ');\n        }\n        if (isSubQuery && !MergeQueryNode.is(rootQueryNode)) {\n            this.append('(');\n        }\n        if (node.with) {\n            this.visitNode(node.with);\n            this.append(' ');\n        }\n        this.append('update ');\n        if (node.top) {\n            this.visitNode(node.top);\n            this.append(' ');\n        }\n        if (node.table) {\n            this.visitNode(node.table);\n            this.append(' ');\n        }\n        this.append('set ');\n        if (node.updates) {\n            this.compileList(node.updates);\n        }\n        if (node.output) {\n            this.append(' ');\n            this.visitNode(node.output);\n        }\n        if (node.from) {\n            this.append(' ');\n            this.visitNode(node.from);\n        }\n        if (node.joins) {\n            if (!node.from) {\n                throw new Error(\"Joins in an update query are only supported as a part of a PostgreSQL 'update set from join' query. If you want to create a MySQL 'update join set' query, see https://kysely.dev/docs/examples/update/my-sql-joins\");\n            }\n            this.append(' ');\n            this.compileList(node.joins, ' ');\n        }\n        if (node.where) {\n            this.append(' ');\n            this.visitNode(node.where);\n        }\n        if (node.orderBy) {\n            this.append(' ');\n            this.visitNode(node.orderBy);\n        }\n        if (node.limit) {\n            this.append(' ');\n            this.visitNode(node.limit);\n        }\n        if (node.returning) {\n            this.append(' ');\n            this.visitNode(node.returning);\n        }\n        if (isSubQuery && !MergeQueryNode.is(rootQueryNode)) {\n            this.append(')');\n        }\n        if (node.endModifiers?.length) {\n            this.append(' ');\n            this.compileList(node.endModifiers, ' ');\n        }\n    }\n    visitColumnUpdate(node) {\n        this.visitNode(node.column);\n        this.append(' = ');\n        this.visitNode(node.value);\n    }\n    visitLimit(node) {\n        this.append('limit ');\n        this.visitNode(node.limit);\n    }\n    visitOffset(node) {\n        this.append('offset ');\n        this.visitNode(node.offset);\n    }\n    visitOnConflict(node) {\n        this.append('on conflict');\n        if (node.columns) {\n            this.append(' (');\n            this.compileList(node.columns);\n            this.append(')');\n        }\n        else if (node.constraint) {\n            this.append(' on constraint ');\n            this.visitNode(node.constraint);\n        }\n        else if (node.indexExpression) {\n            this.append(' (');\n            this.visitNode(node.indexExpression);\n            this.append(')');\n        }\n        if (node.indexWhere) {\n            this.append(' ');\n            this.visitNode(node.indexWhere);\n        }\n        if (node.doNothing === true) {\n            this.append(' do nothing');\n        }\n        else if (node.updates) {\n            this.append(' do update set ');\n            this.compileList(node.updates);\n            if (node.updateWhere) {\n                this.append(' ');\n                this.visitNode(node.updateWhere);\n            }\n        }\n    }\n    visitOnDuplicateKey(node) {\n        this.append('on duplicate key update ');\n        this.compileList(node.updates);\n    }\n    visitCreateIndex(node) {\n        this.append('create ');\n        if (node.unique) {\n            this.append('unique ');\n        }\n        this.append('index ');\n        if (node.ifNotExists) {\n            this.append('if not exists ');\n        }\n        this.visitNode(node.name);\n        if (node.table) {\n            this.append(' on ');\n            this.visitNode(node.table);\n        }\n        if (node.using) {\n            this.append(' using ');\n            this.visitNode(node.using);\n        }\n        if (node.columns) {\n            this.append(' (');\n            this.compileList(node.columns);\n            this.append(')');\n        }\n        if (node.nullsNotDistinct) {\n            this.append(' nulls not distinct');\n        }\n        if (node.where) {\n            this.append(' ');\n            this.visitNode(node.where);\n        }\n    }\n    visitDropIndex(node) {\n        this.append('drop index ');\n        if (node.ifExists) {\n            this.append('if exists ');\n        }\n        this.visitNode(node.name);\n        if (node.table) {\n            this.append(' on ');\n            this.visitNode(node.table);\n        }\n        if (node.cascade) {\n            this.append(' cascade');\n        }\n    }\n    visitCreateSchema(node) {\n        this.append('create schema ');\n        if (node.ifNotExists) {\n            this.append('if not exists ');\n        }\n        this.visitNode(node.schema);\n    }\n    visitDropSchema(node) {\n        this.append('drop schema ');\n        if (node.ifExists) {\n            this.append('if exists ');\n        }\n        this.visitNode(node.schema);\n        if (node.cascade) {\n            this.append(' cascade');\n        }\n    }\n    visitPrimaryKeyConstraint(node) {\n        if (node.name) {\n            this.append('constraint ');\n            this.visitNode(node.name);\n            this.append(' ');\n        }\n        this.append('primary key (');\n        this.compileList(node.columns);\n        this.append(')');\n        this.buildDeferrable(node);\n    }\n    buildDeferrable(node) {\n        if (node.deferrable !== undefined) {\n            if (node.deferrable) {\n                this.append(' deferrable');\n            }\n            else {\n                this.append(' not deferrable');\n            }\n        }\n        if (node.initiallyDeferred !== undefined) {\n            if (node.initiallyDeferred) {\n                this.append(' initially deferred');\n            }\n            else {\n                this.append(' initially immediate');\n            }\n        }\n    }\n    visitUniqueConstraint(node) {\n        if (node.name) {\n            this.append('constraint ');\n            this.visitNode(node.name);\n            this.append(' ');\n        }\n        this.append('unique');\n        if (node.nullsNotDistinct) {\n            this.append(' nulls not distinct');\n        }\n        this.append(' (');\n        this.compileList(node.columns);\n        this.append(')');\n        this.buildDeferrable(node);\n    }\n    visitCheckConstraint(node) {\n        if (node.name) {\n            this.append('constraint ');\n            this.visitNode(node.name);\n            this.append(' ');\n        }\n        this.append('check (');\n        this.visitNode(node.expression);\n        this.append(')');\n    }\n    visitForeignKeyConstraint(node) {\n        if (node.name) {\n            this.append('constraint ');\n            this.visitNode(node.name);\n            this.append(' ');\n        }\n        this.append('foreign key (');\n        this.compileList(node.columns);\n        this.append(') ');\n        this.visitNode(node.references);\n        if (node.onDelete) {\n            this.append(' on delete ');\n            this.append(node.onDelete);\n        }\n        if (node.onUpdate) {\n            this.append(' on update ');\n            this.append(node.onUpdate);\n        }\n        this.buildDeferrable(node);\n    }\n    visitList(node) {\n        this.compileList(node.items);\n    }\n    visitWith(node) {\n        this.append('with ');\n        if (node.recursive) {\n            this.append('recursive ');\n        }\n        this.compileList(node.expressions);\n    }\n    visitCommonTableExpression(node) {\n        this.visitNode(node.name);\n        this.append(' as ');\n        if (isBoolean(node.materialized)) {\n            if (!node.materialized) {\n                this.append('not ');\n            }\n            this.append('materialized ');\n        }\n        this.visitNode(node.expression);\n    }\n    visitCommonTableExpressionName(node) {\n        this.visitNode(node.table);\n        if (node.columns) {\n            this.append('(');\n            this.compileList(node.columns);\n            this.append(')');\n        }\n    }\n    visitAlterTable(node) {\n        this.append('alter table ');\n        this.visitNode(node.table);\n        this.append(' ');\n        if (node.renameTo) {\n            this.append('rename to ');\n            this.visitNode(node.renameTo);\n        }\n        if (node.setSchema) {\n            this.append('set schema ');\n            this.visitNode(node.setSchema);\n        }\n        if (node.addConstraint) {\n            this.visitNode(node.addConstraint);\n        }\n        if (node.dropConstraint) {\n            this.visitNode(node.dropConstraint);\n        }\n        if (node.renameConstraint) {\n            this.visitNode(node.renameConstraint);\n        }\n        if (node.columnAlterations) {\n            this.compileColumnAlterations(node.columnAlterations);\n        }\n        if (node.addIndex) {\n            this.visitNode(node.addIndex);\n        }\n        if (node.dropIndex) {\n            this.visitNode(node.dropIndex);\n        }\n    }\n    visitAddColumn(node) {\n        this.append('add column ');\n        this.visitNode(node.column);\n    }\n    visitRenameColumn(node) {\n        this.append('rename column ');\n        this.visitNode(node.column);\n        this.append(' to ');\n        this.visitNode(node.renameTo);\n    }\n    visitDropColumn(node) {\n        this.append('drop column ');\n        this.visitNode(node.column);\n    }\n    visitAlterColumn(node) {\n        this.append('alter column ');\n        this.visitNode(node.column);\n        this.append(' ');\n        if (node.dataType) {\n            if (this.announcesNewColumnDataType()) {\n                this.append('type ');\n            }\n            this.visitNode(node.dataType);\n            if (node.dataTypeExpression) {\n                this.append('using ');\n                this.visitNode(node.dataTypeExpression);\n            }\n        }\n        if (node.setDefault) {\n            this.append('set default ');\n            this.visitNode(node.setDefault);\n        }\n        if (node.dropDefault) {\n            this.append('drop default');\n        }\n        if (node.setNotNull) {\n            this.append('set not null');\n        }\n        if (node.dropNotNull) {\n            this.append('drop not null');\n        }\n    }\n    visitModifyColumn(node) {\n        this.append('modify column ');\n        this.visitNode(node.column);\n    }\n    visitAddConstraint(node) {\n        this.append('add ');\n        this.visitNode(node.constraint);\n    }\n    visitDropConstraint(node) {\n        this.append('drop constraint ');\n        if (node.ifExists) {\n            this.append('if exists ');\n        }\n        this.visitNode(node.constraintName);\n        if (node.modifier === 'cascade') {\n            this.append(' cascade');\n        }\n        else if (node.modifier === 'restrict') {\n            this.append(' restrict');\n        }\n    }\n    visitRenameConstraint(node) {\n        this.append('rename constraint ');\n        this.visitNode(node.oldName);\n        this.append(' to ');\n        this.visitNode(node.newName);\n    }\n    visitSetOperation(node) {\n        this.append(node.operator);\n        this.append(' ');\n        if (node.all) {\n            this.append('all ');\n        }\n        this.visitNode(node.expression);\n    }\n    visitCreateView(node) {\n        this.append('create ');\n        if (node.orReplace) {\n            this.append('or replace ');\n        }\n        if (node.materialized) {\n            this.append('materialized ');\n        }\n        if (node.temporary) {\n            this.append('temporary ');\n        }\n        this.append('view ');\n        if (node.ifNotExists) {\n            this.append('if not exists ');\n        }\n        this.visitNode(node.name);\n        this.append(' ');\n        if (node.columns) {\n            this.append('(');\n            this.compileList(node.columns);\n            this.append(') ');\n        }\n        if (node.as) {\n            this.append('as ');\n            this.visitNode(node.as);\n        }\n    }\n    visitRefreshMaterializedView(node) {\n        this.append('refresh materialized view ');\n        if (node.concurrently) {\n            this.append('concurrently ');\n        }\n        this.visitNode(node.name);\n        if (node.withNoData) {\n            this.append(' with no data');\n        }\n        else {\n            this.append(' with data');\n        }\n    }\n    visitDropView(node) {\n        this.append('drop ');\n        if (node.materialized) {\n            this.append('materialized ');\n        }\n        this.append('view ');\n        if (node.ifExists) {\n            this.append('if exists ');\n        }\n        this.visitNode(node.name);\n        if (node.cascade) {\n            this.append(' cascade');\n        }\n    }\n    visitGenerated(node) {\n        this.append('generated ');\n        if (node.always) {\n            this.append('always ');\n        }\n        if (node.byDefault) {\n            this.append('by default ');\n        }\n        this.append('as ');\n        if (node.identity) {\n            this.append('identity');\n        }\n        if (node.expression) {\n            this.append('(');\n            this.visitNode(node.expression);\n            this.append(')');\n        }\n        if (node.stored) {\n            this.append(' stored');\n        }\n    }\n    visitDefaultValue(node) {\n        this.append('default ');\n        this.visitNode(node.defaultValue);\n    }\n    visitSelectModifier(node) {\n        if (node.rawModifier) {\n            this.visitNode(node.rawModifier);\n        }\n        else {\n            this.append(SELECT_MODIFIER_SQL[node.modifier]);\n        }\n        if (node.of) {\n            this.append(' of ');\n            this.compileList(node.of, ', ');\n        }\n    }\n    visitCreateType(node) {\n        this.append('create type ');\n        this.visitNode(node.name);\n        if (node.enum) {\n            this.append(' as enum ');\n            this.visitNode(node.enum);\n        }\n    }\n    visitDropType(node) {\n        this.append('drop type ');\n        if (node.ifExists) {\n            this.append('if exists ');\n        }\n        this.visitNode(node.name);\n    }\n    visitExplain(node) {\n        this.append('explain');\n        if (node.options || node.format) {\n            this.append(' ');\n            this.append(this.getLeftExplainOptionsWrapper());\n            if (node.options) {\n                this.visitNode(node.options);\n                if (node.format) {\n                    this.append(this.getExplainOptionsDelimiter());\n                }\n            }\n            if (node.format) {\n                this.append('format');\n                this.append(this.getExplainOptionAssignment());\n                this.append(node.format);\n            }\n            this.append(this.getRightExplainOptionsWrapper());\n        }\n    }\n    visitDefaultInsertValue(_) {\n        this.append('default');\n    }\n    visitAggregateFunction(node) {\n        this.append(node.func);\n        this.append('(');\n        if (node.distinct) {\n            this.append('distinct ');\n        }\n        this.compileList(node.aggregated);\n        if (node.orderBy) {\n            this.append(' ');\n            this.visitNode(node.orderBy);\n        }\n        this.append(')');\n        if (node.withinGroup) {\n            this.append(' within group (');\n            this.visitNode(node.withinGroup);\n            this.append(')');\n        }\n        if (node.filter) {\n            this.append(' filter(');\n            this.visitNode(node.filter);\n            this.append(')');\n        }\n        if (node.over) {\n            this.append(' ');\n            this.visitNode(node.over);\n        }\n    }\n    visitOver(node) {\n        this.append('over(');\n        if (node.partitionBy) {\n            this.visitNode(node.partitionBy);\n            if (node.orderBy) {\n                this.append(' ');\n            }\n        }\n        if (node.orderBy) {\n            this.visitNode(node.orderBy);\n        }\n        this.append(')');\n    }\n    visitPartitionBy(node) {\n        this.append('partition by ');\n        this.compileList(node.items);\n    }\n    visitPartitionByItem(node) {\n        this.visitNode(node.partitionBy);\n    }\n    visitBinaryOperation(node) {\n        this.visitNode(node.leftOperand);\n        this.append(' ');\n        this.visitNode(node.operator);\n        this.append(' ');\n        this.visitNode(node.rightOperand);\n    }\n    visitUnaryOperation(node) {\n        this.visitNode(node.operator);\n        if (!this.isMinusOperator(node.operator)) {\n            this.append(' ');\n        }\n        this.visitNode(node.operand);\n    }\n    isMinusOperator(node) {\n        return OperatorNode.is(node) && node.operator === '-';\n    }\n    visitUsing(node) {\n        this.append('using ');\n        this.compileList(node.tables);\n    }\n    visitFunction(node) {\n        this.append(node.func);\n        this.append('(');\n        this.compileList(node.arguments);\n        this.append(')');\n    }\n    visitCase(node) {\n        this.append('case');\n        if (node.value) {\n            this.append(' ');\n            this.visitNode(node.value);\n        }\n        if (node.when) {\n            this.append(' ');\n            this.compileList(node.when, ' ');\n        }\n        if (node.else) {\n            this.append(' else ');\n            this.visitNode(node.else);\n        }\n        this.append(' end');\n        if (node.isStatement) {\n            this.append(' case');\n        }\n    }\n    visitWhen(node) {\n        this.append('when ');\n        this.visitNode(node.condition);\n        if (node.result) {\n            this.append(' then ');\n            this.visitNode(node.result);\n        }\n    }\n    visitJSONReference(node) {\n        this.visitNode(node.reference);\n        this.visitNode(node.traversal);\n    }\n    visitJSONPath(node) {\n        if (node.inOperator) {\n            this.visitNode(node.inOperator);\n        }\n        this.append(\"'$\");\n        for (const pathLeg of node.pathLegs) {\n            this.visitNode(pathLeg);\n        }\n        this.append(\"'\");\n    }\n    visitJSONPathLeg(node) {\n        const isArrayLocation = node.type === 'ArrayLocation';\n        this.append(isArrayLocation ? '[' : '.');\n        this.append(String(node.value));\n        if (isArrayLocation) {\n            this.append(']');\n        }\n    }\n    visitJSONOperatorChain(node) {\n        for (let i = 0, len = node.values.length; i < len; i++) {\n            if (i === len - 1) {\n                this.visitNode(node.operator);\n            }\n            else {\n                this.append('->');\n            }\n            this.visitNode(node.values[i]);\n        }\n    }\n    visitMergeQuery(node) {\n        if (node.with) {\n            this.visitNode(node.with);\n            this.append(' ');\n        }\n        this.append('merge ');\n        if (node.top) {\n            this.visitNode(node.top);\n            this.append(' ');\n        }\n        this.append('into ');\n        this.visitNode(node.into);\n        if (node.using) {\n            this.append(' ');\n            this.visitNode(node.using);\n        }\n        if (node.whens) {\n            this.append(' ');\n            this.compileList(node.whens, ' ');\n        }\n        if (node.returning) {\n            this.append(' ');\n            this.visitNode(node.returning);\n        }\n        if (node.output) {\n            this.append(' ');\n            this.visitNode(node.output);\n        }\n        if (node.endModifiers?.length) {\n            this.append(' ');\n            this.compileList(node.endModifiers, ' ');\n        }\n    }\n    visitMatched(node) {\n        if (node.not) {\n            this.append('not ');\n        }\n        this.append('matched');\n        if (node.bySource) {\n            this.append(' by source');\n        }\n    }\n    visitAddIndex(node) {\n        this.append('add ');\n        if (node.unique) {\n            this.append('unique ');\n        }\n        this.append('index ');\n        this.visitNode(node.name);\n        if (node.columns) {\n            this.append(' (');\n            this.compileList(node.columns);\n            this.append(')');\n        }\n        if (node.using) {\n            this.append(' using ');\n            this.visitNode(node.using);\n        }\n    }\n    visitCast(node) {\n        this.append('cast(');\n        this.visitNode(node.expression);\n        this.append(' as ');\n        this.visitNode(node.dataType);\n        this.append(')');\n    }\n    visitFetch(node) {\n        this.append('fetch next ');\n        this.visitNode(node.rowCount);\n        this.append(` rows ${node.modifier}`);\n    }\n    visitOutput(node) {\n        this.append('output ');\n        this.compileList(node.selections);\n    }\n    visitTop(node) {\n        this.append(`top(${node.expression})`);\n        if (node.modifiers) {\n            this.append(` ${node.modifiers}`);\n        }\n    }\n    visitOrAction(node) {\n        this.append(node.action);\n    }\n    visitCollate(node) {\n        this.append('collate ');\n        this.visitNode(node.collation);\n    }\n    append(str) {\n        this.#sql += str;\n    }\n    appendValue(parameter) {\n        this.addParameter(parameter);\n        this.append(this.getCurrentParameterPlaceholder());\n    }\n    getLeftIdentifierWrapper() {\n        return '\"';\n    }\n    getRightIdentifierWrapper() {\n        return '\"';\n    }\n    getCurrentParameterPlaceholder() {\n        return '$' + this.numParameters;\n    }\n    getLeftExplainOptionsWrapper() {\n        return '(';\n    }\n    getExplainOptionAssignment() {\n        return ' ';\n    }\n    getExplainOptionsDelimiter() {\n        return ', ';\n    }\n    getRightExplainOptionsWrapper() {\n        return ')';\n    }\n    sanitizeIdentifier(identifier) {\n        const leftWrap = this.getLeftIdentifierWrapper();\n        const rightWrap = this.getRightIdentifierWrapper();\n        let sanitized = '';\n        for (const c of identifier) {\n            sanitized += c;\n            if (c === leftWrap) {\n                sanitized += leftWrap;\n            }\n            else if (c === rightWrap) {\n                sanitized += rightWrap;\n            }\n        }\n        return sanitized;\n    }\n    sanitizeStringLiteral(value) {\n        return value.replace(LIT_WRAP_REGEX, \"''\");\n    }\n    addParameter(parameter) {\n        this.#parameters.push(parameter);\n    }\n    appendImmediateValue(value) {\n        if (isString(value)) {\n            this.appendStringLiteral(value);\n        }\n        else if (isNumber(value) || isBoolean(value)) {\n            this.append(value.toString());\n        }\n        else if (isNull(value)) {\n            this.append('null');\n        }\n        else if (isDate(value)) {\n            this.appendImmediateValue(value.toISOString());\n        }\n        else if (isBigInt(value)) {\n            this.appendImmediateValue(value.toString());\n        }\n        else {\n            throw new Error(`invalid immediate value ${value}`);\n        }\n    }\n    appendStringLiteral(value) {\n        this.append(\"'\");\n        this.append(this.sanitizeStringLiteral(value));\n        this.append(\"'\");\n    }\n    sortSelectModifiers(arr) {\n        arr.sort((left, right) => left.modifier && right.modifier\n            ? SELECT_MODIFIER_PRIORITY[left.modifier] -\n                SELECT_MODIFIER_PRIORITY[right.modifier]\n            : 1);\n        return freeze(arr);\n    }\n    compileColumnAlterations(columnAlterations) {\n        this.compileList(columnAlterations);\n    }\n    /**\n     * controls whether the dialect adds a \"type\" keyword before a column's new data\n     * type in an ALTER TABLE statement.\n     */\n    announcesNewColumnDataType() {\n        return true;\n    }\n}\nconst SELECT_MODIFIER_SQL = freeze({\n    ForKeyShare: 'for key share',\n    ForNoKeyUpdate: 'for no key update',\n    ForUpdate: 'for update',\n    ForShare: 'for share',\n    NoWait: 'nowait',\n    SkipLocked: 'skip locked',\n    Distinct: 'distinct',\n});\nconst SELECT_MODIFIER_PRIORITY = freeze({\n    ForKeyShare: 1,\n    ForNoKeyUpdate: 1,\n    ForUpdate: 1,\n    ForShare: 1,\n    NoWait: 2,\n    SkipLocked: 2,\n    Distinct: 0,\n});\nconst JOIN_TYPE_SQL = freeze({\n    InnerJoin: 'inner join',\n    LeftJoin: 'left join',\n    RightJoin: 'right join',\n    FullJoin: 'full join',\n    CrossJoin: 'cross join',\n    LateralInnerJoin: 'inner join lateral',\n    LateralLeftJoin: 'left join lateral',\n    LateralCrossJoin: 'cross join lateral',\n    OuterApply: 'outer apply',\n    CrossApply: 'cross apply',\n    Using: 'using',\n});\n", "/// <reference types=\"./dummy-driver.d.ts\" />\n/**\n * A driver that does absolutely nothing.\n *\n * You can use this to create Kysely instances solely for building queries\n *\n * ### Examples\n *\n * This example creates a Kysely instance for building postgres queries:\n *\n * ```ts\n * import {\n *   DummyDriver,\n *   Kysely,\n *   PostgresAdapter,\n *   PostgresIntrospector,\n *   PostgresQueryCompiler\n * } from 'kysely'\n * import type { Database } from 'type-editor' // imaginary module\n *\n * const db = new Kysely<Database>({\n *   dialect: {\n *     createAdapter: () => new PostgresAdapter(),\n *     createDriver: () => new DummyDriver(),\n *     createIntrospector: (db: Kysely<any>) => new PostgresIntrospector(db),\n *     createQueryCompiler: () => new PostgresQueryCompiler(),\n *   },\n * })\n * ```\n *\n * You can use it to build a query and compile it to SQL but trying to\n * execute the query will throw an error.\n *\n * ```ts\n * const { sql } = db.selectFrom('person').selectAll().compile()\n * console.log(sql) // select * from \"person\"\n * ```\n */\nexport class DummyDriver {\n    async init() {\n        // Nothing to do here.\n    }\n    async acquireConnection() {\n        return new DummyConnection();\n    }\n    async beginTransaction() {\n        // Nothing to do here.\n    }\n    async commitTransaction() {\n        // Nothing to do here.\n    }\n    async rollbackTransaction() {\n        // Nothing to do here.\n    }\n    async releaseConnection() {\n        // Nothing to do here.\n    }\n    async destroy() {\n        // Nothing to do here.\n    }\n    async releaseSavepoint() {\n        // Nothing to do here.\n    }\n    async rollbackToSavepoint() {\n        // Nothing to do here.\n    }\n    async savepoint() {\n        // Nothing to do here.\n    }\n}\nclass DummyConnection {\n    async executeQuery() {\n        return {\n            rows: [],\n        };\n    }\n    async *streamQuery() {\n        // Nothing to do here.\n    }\n}\n", "/// <reference types=\"./dialect-adapter-base.d.ts\" />\n/**\n * A basic implementation of `DialectAdapter` with sensible default values.\n * Third-party dialects can extend this instead of implementing the `DialectAdapter`\n * interface from scratch. That way all new settings will get default values when\n * they are added and there will be less breaking changes.\n */\nexport class DialectAdapterBase {\n    get supportsCreateIfNotExists() {\n        return true;\n    }\n    get supportsTransactionalDdl() {\n        return false;\n    }\n    get supportsReturning() {\n        return false;\n    }\n    get supportsOutput() {\n        return false;\n    }\n}\n", "/// <reference types=\"./postgres-query-compiler.d.ts\" />\nimport { DefaultQueryCompiler } from '../../query-compiler/default-query-compiler.js';\nconst ID_WRAP_REGEX = /\"/g;\nexport class PostgresQueryCompiler extends DefaultQueryCompiler {\n    sanitizeIdentifier(identifier) {\n        return identifier.replace(ID_WRAP_REGEX, '\"\"');\n    }\n}\n", "/// <reference types=\"./postgres-adapter.d.ts\" />\nimport { sql } from '../../raw-builder/sql.js';\nimport { DialectAdapterBase } from '../dialect-adapter-base.js';\n// Random id for our transaction lock.\nconst LOCK_ID = BigInt('3853314791062309107');\nexport class PostgresAdapter extends DialectAdapterBase {\n    get supportsTransactionalDdl() {\n        return true;\n    }\n    get supportsReturning() {\n        return true;\n    }\n    async acquireMigrationLock(db, _opt) {\n        // Acquire a transaction level advisory lock.\n        await sql `select pg_advisory_xact_lock(${sql.lit(LOCK_ID)})`.execute(db);\n    }\n    async releaseMigrationLock(_db, _opt) {\n        // Nothing to do here. `pg_advisory_xact_lock` is automatically released at the\n        // end of the transaction and since `supportsTransactionalDdl` true, we know\n        // the `db` instance passed to acquireMigrationLock is actually a transaction.\n    }\n}\n", "import {\n  type Compilable,\n  type DialectAdapter,\n  DummyDriver,\n  Kysely,\n  type KyselyPlugin,\n  OperationNodeTransformer,\n  type PluginTransformQueryArgs,\n  type PluginTransformResultArgs,\n  type PrimitiveValueListNode,\n  type QueryCompiler,\n  type QueryResult as KyselyQueryResult,\n  type RootOperationNode,\n  type UnknownRow,\n  ValueListNode,\n  ValueNode,\n  type WhereInterface,\n} from \"kysely\";\n\nimport type { Table } from \"./adapter\";\n\nexport interface BuilderRequirements {\n  Adapter: { new (): DialectAdapter };\n  noParameters?: boolean;\n  QueryCompiler: { new (): QueryCompiler };\n}\n\nexport function getBuilder<DB>(requirements: BuilderRequirements): Kysely<DB> {\n  return new Kysely({\n    dialect: {\n      createAdapter: () => new requirements.Adapter(),\n      createDriver: () => new DummyDriver(),\n      // @ts-expect-error - we don't need built-in introspection in this case\n      createIntrospector: () => null,\n      createQueryCompiler: () => new requirements.QueryCompiler(),\n    },\n    plugins: [...(requirements.noParameters ? [new ImmediateValuePlugin()] : [])],\n  });\n}\n\n/**\n * A plugin that transforms all values to immediate values. This means their injected into the SQL string instead of populating the parameters array.\n * In some situations, a database driver might not support parameters, and this plugin can be used to work around that.\n */\nclass ImmediateValuePlugin implements KyselyPlugin {\n  readonly #transformer = new ImmediateValueTransformer();\n\n  transformQuery(args: PluginTransformQueryArgs): RootOperationNode {\n    return this.#transformer.transformNode(args.node);\n  }\n\n  transformResult(args: PluginTransformResultArgs): Promise<KyselyQueryResult<UnknownRow>> {\n    return Promise.resolve(args.result);\n  }\n}\n\nclass ImmediateValueTransformer extends OperationNodeTransformer {\n  protected override transformPrimitiveValueList(node: PrimitiveValueListNode): PrimitiveValueListNode {\n    return ValueListNode.create(node.values.map(ValueNode.createImmediate)) as never;\n  }\n\n  override transformValue(node: ValueNode): ValueNode {\n    return { ...super.transformValue(node), immediate: true };\n  }\n}\n\ndeclare const queryType: unique symbol;\nexport interface Query<T = unknown> {\n  [queryType]?: T;\n  parameters: readonly unknown[];\n  sql: string;\n}\n\nexport function asQuery<T>(query: string | Query<unknown>): Query<T> {\n  if (typeof query === \"string\") {\n    return { parameters: [], sql: query } as never;\n  }\n\n  return query as never;\n}\n\nexport type QueryResult<T> =\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  T extends Query<infer R> ? R[] : T extends (...args: any[]) => Query<infer R> ? R[] : never;\n\nexport function compile<T>(compileable: Compilable<T>): Query<T> {\n  const compiledQuery = compileable.compile();\n\n  return {\n    parameters: compiledQuery.parameters,\n    sql: compiledQuery.sql,\n  };\n}\n\n/**\n * Applies a filter to the given rows based on the primary key columns of the table.\n *\n * @example db.selectFrom(\"users\").$call(applyInferredRowFilters(rows, columns)).selectAll()\n */\nexport function applyInferredRowFilters(rows: Record<string, unknown>[], columns: Table[\"columns\"]) {\n  const rowFilters = inferRowFilters(rows, columns);\n\n  return <QB extends WhereInterface<any, any>>(qb: QB): QB =>\n    qb.where((eb) => {\n      return eb.or(\n        rowFilters.map((rowFilter) => {\n          return eb.and(rowFilter.map(([columnName, value]) => eb(columnName, value === null ? \"is\" : \"=\", value)));\n        }),\n      );\n    }) as never;\n}\n\n/**\n * Part of a filter that predicts a match.\n * ie. ... WHERE $ColumName = $Value ...\n */\ntype RowFilterPredicate = [ColumnName: string, Value: unknown];\n\n/**\n * A row filter is comprised of one or more predicates.\n */\ntype RowFilter = RowFilterPredicate[];\n\n/**\n * Row filters is simply a set of multiple {@link RowFilter}.\n */\ntype RowFilters = RowFilter[];\n\n/**\n * Infers the filter that is necessary to uniquely identify a given row\n * individually.\n */\nexport function inferRowFilter(row: Record<string, unknown>, columns: Table[\"columns\"]): RowFilter {\n  return Object.entries(\n    Object.values(columns).reduce(\n      (pk, column) => {\n        const { isInPrimaryKey, name: columnName } = column;\n\n        if (!isInPrimaryKey) {\n          return pk;\n        }\n\n        pk[columnName] = row[columnName] ?? null;\n        return pk;\n      },\n      {} as Record<string, unknown>,\n    ),\n  );\n}\n\n/**\n * Infers the filter that is necessary to uniquely identify multiple rows\n * individually.\n */\nexport function inferRowFilters(rows: Record<string, unknown>[], columns: Table[\"columns\"]): RowFilters {\n  return rows.map((row) => inferRowFilter(row, columns));\n}\n", "import { type Kysely, PostgresAdapter, PostgresQueryCompiler } from \"kysely\";\n\nimport { type BuilderRequirements, getBuilder } from \"../query\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getPostgreSQLBuilder<Database = any>(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n): Kysely<Database> {\n  return getBuilder({ ...requirements, Adapter: PostgresAdapter, QueryCompiler: PostgresQueryCompiler });\n}\n", "import { Expression, ExpressionBuilder, sql, SqlBool } from \"kysely\";\n\nimport type {\n  AdapterDeleteDetails,\n  AdapterInsertDetails,\n  AdapterQueryDetails,\n  AdapterUpdateDetails,\n  ColumnFilter,\n  FilterGroup,\n  Table,\n} from \"../adapter\";\nimport { applyInferredRowFilters, type BuilderRequirements, compile } from \"../query\";\nimport type { BigIntString } from \"../type-utils\";\nimport { getPostgreSQLBuilder } from \"./builder\";\nimport type { mockTablesQuery } from \"./introspection\";\n\n/**\n * `ctid` is a system column that represents the physical location of a row in a table.\n * It is a tuple of two integers: `(blockNumber, tupleIndex)`.\n * It is used to uniquely identify a row in a table, even if the row has no primary key, or other unique constraints.\n *\n * Example: '(0,23)' represents the 24th row in the first block of the table.\n */\nexport type CTIDasText = `(${number},${number})`;\n\n/**\n * Inserts one or more rows into a table and returns the inserted rows along with their `ctid`.\n */\nexport function getInsertQuery(\n  details: AdapterInsertDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const { table, rows } = details;\n  const { name: tableName, schema, columns } = table;\n\n  const builder = getPostgreSQLBuilder<Record<string, { ctid: unknown } & Record<string, unknown>>>(requirements);\n  const cols = Object.keys(columns);\n  const emptyRowWorkaround = { [cols[0]!]: sql`default` };\n\n  return compile(\n    builder\n      .withSchema(schema)\n      .insertInto(tableName)\n      .values(rows.map((row) => (Object.keys(row).length === 0 ? emptyRowWorkaround : row)))\n      .returning(cols)\n      .returning((eb) => eb.cast<CTIDasText>(\"ctid\", \"text\").as(\"ctid\")),\n  );\n}\n\n/**\n * Returns a query that selects all columns from a table, along with the `ctid` column, and unbound row count as `oid` (reserved column name that cannot conflict with user columns).\n */\nexport function getSelectQuery(\n  details: AdapterQueryDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    pageIndex,\n    pageSize,\n    sortOrder,\n    table: { name: tableName, schema, columns },\n    filter = { kind: \"FilterGroup\", after: \"and\", filters: [] },\n  } = details;\n\n  const builder = getPostgreSQLBuilder<Record<string, { ctid: unknown } & Record<string, unknown>>>(requirements);\n  const cols = Object.keys(columns);\n\n  const countQuery = builder\n    .withSchema(schema)\n    .selectFrom(tableName)\n    .select((eb) => eb.cast<BigIntString>(eb.fn.coalesce(eb.fn.countAll(), sql.lit(0)), \"text\").as(\"oid\"));\n\n  return compile(\n    builder\n      .with(\"count\", () => countQuery)\n      .withSchema(schema)\n      .selectFrom([tableName, \"count\"])\n      // `oid` is a reserved column name in PostgreSQL, so we use it as an alias for the row count to not conflict with user columns.\n      .select(sql.ref(\"count.oid\").$castTo<BigIntString>().as(\"oid\"))\n      .select((eb) => eb.cast<CTIDasText>(\"ctid\", \"text\").as(\"ctid\"))\n      .select(cols)\n      .$call((qb) => sortOrder.reduce((qb, item) => qb.orderBy(item.column, item.direction), qb))\n      // TODO: cursor pagination?\n      .where(getSelectFilterExpression(filter.filters, columns))\n      .limit(pageSize)\n      // we're injecting the offset value here to avoid serialization complexity (`bigint` is a no-go for `JSON.stringify`).\n      .offset(sql.lit(BigInt(pageIndex) * BigInt(pageSize))),\n  );\n}\n\n// Helper to build an expression builder for a single filter or a group\nfunction buildBaseExpressionBuilder(\n  spec: ColumnFilter | FilterGroup,\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): (eb: ExpressionBuilder<any, any>) => Expression<SqlBool> {\n  if (spec.kind === \"ColumnFilter\") {\n    return (eb) => {\n      const { column, operator, value } = spec;\n\n      const columnRef = sql.ref(column);\n\n      const lhs = columns[column]?.datatype.group === \"enum\" ? eb.cast(columnRef, \"text\") : columnRef;\n\n      return eb(lhs, operator, value);\n    };\n  } else {\n    return getSelectFilterExpression(spec.filters, columns);\n  }\n}\n\nfunction getSelectFilterExpression(\n  filters: (ColumnFilter | FilterGroup)[],\n  columns: Table[\"columns\"],\n): (eb: ExpressionBuilder<any, any>) => Expression<SqlBool> {\n  if (filters.length === 0) return (eb) => eb.lit(true); // no filters, always true\n\n  const orGroupsOfAndBuilders: ((eb: ExpressionBuilder<any, any>) => Expression<SqlBool>)[][] = [];\n  let currentAndGroupBuilders: ((eb: ExpressionBuilder<any, any>) => Expression<SqlBool>)[] = [];\n\n  for (let i = 0; i < filters.length; i++) {\n    currentAndGroupBuilders.push(buildBaseExpressionBuilder(filters[i]!, columns));\n\n    // &n AND group ends if it's the last filter, or the item is followed by an 'or'\n    if (i === filters.length - 1 || filters[i]!.after === \"or\") {\n      orGroupsOfAndBuilders.push(currentAndGroupBuilders);\n      currentAndGroupBuilders = []; // start a new group\n    }\n  }\n\n  return (eb: ExpressionBuilder<any, any>) => {\n    const andExpressions = orGroupsOfAndBuilders.map((group) => {\n      return eb.and(group.map((builder) => builder(eb)));\n    });\n\n    return eb.or(andExpressions);\n  };\n}\n\n/**\n * For testing purposes.\n */\nexport function mockSelectQuery() {\n  return [\n    {\n      created_at: new Date(\"2025-01-26T21:56:12.345Z\"),\n      ctid: \"(0,1)\",\n      deleted_at: null,\n      id: 1,\n      name: \"John Doe\",\n      oid: \"2\",\n      role: \"admin\",\n      name_role: \"Jonn Doe - admin\",\n    },\n    {\n      created_at: new Date(\"2025-01-26T20:56:12.345Z\"),\n      ctid: \"(0,2)\",\n      deleted_at: null,\n      id: 2,\n      name: \"Jane Doe\",\n      oid: \"2\",\n      role: \"poweruser\",\n      name_role: \"Jane Doe - poweruser\",\n    },\n  ] as const satisfies {\n    // best effort no need to go overboard\n    [K in ReturnType<typeof mockTablesQuery>[1][\"columns\"][number][\"name\"] | \"ctid\" | \"oid\"]: unknown;\n  }[];\n}\n\n/**\n * Returns a query that updates a given row in a table with given changes.\n */\nexport function getUpdateQuery(\n  details: AdapterUpdateDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    changes,\n    row,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder = getPostgreSQLBuilder<Record<string, { ctid: unknown } & Record<string, unknown>>>(requirements);\n  const cols = Object.keys(columns);\n\n  return compile(\n    builder\n      .withSchema(schema)\n      .updateTable(tableName)\n      .set(changes)\n      .$call(applyInferredRowFilters([row], columns))\n      .returning(cols)\n      .returning((eb) => [\n        eb.cast<CTIDasText>(\"ctid\", \"text\").as(\"ctid\"),\n        eb\n          .cast<BigIntString>(eb.fn(\"floor\", [eb(eb.fn(\"extract\", [sql`epoch from now()`]), \"*\", 1_000_000)]), \"text\")\n          .as(\"__ps_updated_at__\"),\n      ]),\n  );\n}\n\n/**\n * Returns a query that deletes a given set of rows.\n */\nexport function getDeleteQuery(\n  details: AdapterDeleteDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    rows,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder = getPostgreSQLBuilder<Record<string, { ctid: unknown } & Record<string, unknown>>>(requirements);\n\n  return compile(builder.withSchema(schema).deleteFrom(tableName).$call(applyInferredRowFilters(rows, columns)));\n}\n", "/// <reference types=\"./postgres.d.ts\" />\nimport { sql } from '../raw-builder/sql.js';\n/**\n * A postgres helper for aggregating a subquery (or other expression) into a JSONB array.\n *\n * ### Examples\n *\n * <!-- siteExample(\"select\", \"Nested array\", 110) -->\n *\n * While kysely is not an ORM and it doesn't have the concept of relations, we do provide\n * helpers for fetching nested objects and arrays in a single query. In this example we\n * use the `jsonArrayFrom` helper to fetch person's pets along with the person's id.\n *\n * Please keep in mind that the helpers under the `kysely/helpers` folder, including\n * `jsonArrayFrom`, are not guaranteed to work with third party dialects. In order for\n * them to work, the dialect must automatically parse the `json` data type into\n * JavaScript JSON values like objects and arrays. Some dialects might simply return\n * the data as a JSON string. In these cases you can use the built in `ParseJSONResultsPlugin`\n * to parse the results.\n *\n * ```ts\n * import { jsonArrayFrom } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonArrayFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .orderBy('pet.name')\n *     ).as('pets')\n *   ])\n *   .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"id\", (\n *   select coalesce(json_agg(agg), '[]') from (\n *     select \"pet\".\"id\" as \"pet_id\", \"pet\".\"name\"\n *     from \"pet\"\n *     where \"pet\".\"owner_id\" = \"person\".\"id\"\n *     order by \"pet\".\"name\"\n *   ) as agg\n * ) as \"pets\"\n * from \"person\"\n * ```\n */\nexport function jsonArrayFrom(expr) {\n    return sql `(select coalesce(json_agg(agg), '[]') from ${expr} as agg)`;\n}\n/**\n * A postgres helper for turning a subquery (or other expression) into a JSON object.\n *\n * The subquery must only return one row.\n *\n * ### Examples\n *\n * <!-- siteExample(\"select\", \"Nested object\", 120) -->\n *\n * While kysely is not an ORM and it doesn't have the concept of relations, we do provide\n * helpers for fetching nested objects and arrays in a single query. In this example we\n * use the `jsonObjectFrom` helper to fetch person's favorite pet along with the person's id.\n *\n * Please keep in mind that the helpers under the `kysely/helpers` folder, including\n * `jsonObjectFrom`, are not guaranteed to work with third-party dialects. In order for\n * them to work, the dialect must automatically parse the `json` data type into\n * JavaScript JSON values like objects and arrays. Some dialects might simply return\n * the data as a JSON string. In these cases you can use the built in `ParseJSONResultsPlugin`\n * to parse the results.\n *\n * ```ts\n * import { jsonObjectFrom } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonObjectFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .where('pet.is_favorite', '=', true)\n *     ).as('favorite_pet')\n *   ])\n *   .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"id\", (\n *   select to_json(obj) from (\n *     select \"pet\".\"id\" as \"pet_id\", \"pet\".\"name\"\n *     from \"pet\"\n *     where \"pet\".\"owner_id\" = \"person\".\"id\"\n *     and \"pet\".\"is_favorite\" = $1\n *   ) as obj\n * ) as \"favorite_pet\"\n * from \"person\"\n * ```\n */\nexport function jsonObjectFrom(expr) {\n    return sql `(select to_json(obj) from ${expr} as obj)`;\n}\n/**\n * The PostgreSQL `json_build_object` function.\n *\n * NOTE: This helper is only guaranteed to fully work with the built-in `PostgresDialect`.\n * While the produced SQL is compatible with all PostgreSQL databases, some third-party dialects\n * may not parse the nested JSON into objects. In these cases you can use the built in\n * `ParseJSONResultsPlugin` to parse the results.\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n * import { jsonBuildObject } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonBuildObject({\n *       first: eb.ref('first_name'),\n *       last: eb.ref('last_name'),\n *       full: sql<string>`first_name ||\u00A0' ' || last_name`\n *     }).as('name')\n *   ])\n *   .execute()\n *\n * result[0]?.id\n * result[0]?.name.first\n * result[0]?.name.last\n * result[0]?.name.full\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"id\", json_build_object(\n *   'first', first_name,\n *   'last', last_name,\n *   'full', first_name || ' ' || last_name\n * ) as \"name\"\n * from \"person\"\n * ```\n */\nexport function jsonBuildObject(obj) {\n    return sql `json_build_object(${sql.join(Object.keys(obj).flatMap((k) => [sql.lit(k), obj[k]]))})`;\n}\n/**\n * The PostgreSQL `merge_action` function.\n *\n * This function can be used in a `returning` clause to get the action that was\n * performed in a `mergeInto` query. The function returns one of the following\n * strings: `'INSERT'`, `'UPDATE'`, or `'DELETE'`.\n *\n * ### Examples\n *\n * ```ts\n * import { mergeAction } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .mergeInto('person as p')\n *   .using('person_backup as pb', 'p.id', 'pb.id')\n *   .whenMatched()\n *   .thenUpdateSet(({ ref }) => ({\n *     first_name: ref('pb.first_name'),\n *     updated_at: ref('pb.updated_at').$castTo<string | null>(),\n *   }))\n *   .whenNotMatched()\n *   .thenInsertValues(({ ref}) => ({\n *     id: ref('pb.id'),\n *     first_name: ref('pb.first_name'),\n *     created_at: ref('pb.updated_at'),\n *     updated_at: ref('pb.updated_at').$castTo<string | null>(),\n *   }))\n *   .returning([mergeAction().as('action'), 'p.id', 'p.updated_at'])\n *   .execute()\n *\n * result[0].action\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"person\" as \"p\"\n * using \"person_backup\" as \"pb\" on \"p\".\"id\" = \"pb\".\"id\"\n * when matched then update set\n *   \"first_name\" = \"pb\".\"first_name\",\n *   \"updated_at\" = \"pb\".\"updated_at\"::text\n * when not matched then insert values (\"id\", \"first_name\", \"created_at\", \"updated_at\")\n * values (\"pb\".\"id\", \"pb\".\"first_name\", \"pb\".\"updated_at\", \"pb\".\"updated_at\")\n * returning merge_action() as \"action\", \"p\".\"id\", \"p\".\"updated_at\"\n * ```\n */\nexport function mergeAction() {\n    return sql `merge_action()`;\n}\n", "import { type SelectQueryBuilder, sql } from \"kysely\";\nimport { jsonArrayFrom } from \"kysely/helpers/postgres\";\n\nimport { type BuilderRequirements, compile, type QueryResult } from \"../query\";\nimport { getPostgreSQLBuilder } from \"./builder\";\n\nconst REGULAR_TABLE_KIND = \"r\";\nconst VIEW_TABLE_KIND = \"v\";\nconst TABLE_KINDS = [REGULAR_TABLE_KIND, VIEW_TABLE_KIND] as const;\ntype TableKind = (typeof TABLE_KINDS)[number];\n\ninterface Database {\n  /** columns */\n  \"pg_catalog.pg_attribute\": {\n    /** column order number in its table */\n    attnum: number;\n    /** table/view identifier */\n    attrelid: string;\n    /** column name */\n    attname: string;\n    /** was the column dropped. dropped columns might not be 100% removed immediately. */\n    attisdropped: boolean;\n    /** column datatype identifier */\n    atttypid: string;\n    /**\n     * generation flag for computed columns:\n     * '' (empty) for regular columns,\n     * 's' for STORED generated columns (Postgres GENERATED ALWAYS AS).\n     */\n    attgenerated: \"\" | \"s\";\n    /** NOT NULL constraint: true if the column has a NOT NULL constraint */\n    attnotnull: boolean;\n  };\n  /** resources, e.g. tables, sequences, etc. */\n  \"pg_catalog.pg_class\": {\n    /** resource id */\n    oid: number;\n    /** resource name */\n    relname: string;\n    /** schema id */\n    relnamespace: number;\n    /** resource kind: regular table, view */\n    relkind: TableKind;\n  };\n  /** enum types' values */\n  \"pg_catalog.pg_enum\": {\n    /** enum value */\n    enumlabel: string;\n    /** enum's type id */\n    enumtypid: number;\n  };\n  /** schemas */\n  \"pg_catalog.pg_namespace\": {\n    /** schema name */\n    nspname: string;\n    /** schema id */\n    oid: number;\n  };\n  /** datatypes */\n  \"pg_catalog.pg_type\": {\n    /** type id */\n    oid: number;\n    /** type name */\n    typname: string;\n    /** type's schema (aka namespace) id */\n    typnamespace: number;\n    /**\n     * type's kind\n     *\n     * 'e' - enum type\n     */\n    typtype: \"e\" | (string & {});\n  };\n  /** constraints */\n  \"pg_catalog.pg_constraint\": {\n    /** relation (table) id which this constraint was created for */\n    conrelid: number;\n    /**\n     * constraint type.\n     *\n     * `'p'` - primary key constraint.\n     * `'f'` - foreign key constraint.\n     */\n    contype: \"p\" | \"f\" | (string & {});\n    /**\n     * an ordered array of columns included in the constraint.\n     *\n     * the columns are represented by their ordinal number (`attnum`) in their relation (table).\n     *\n     * @example `'{1,3}'` - a constraint with 2 columns, the 1st & 3rd in their table.\n     */\n    conkey: number[];\n    /** if a foreign key, the referenced table */\n    confrelid: number;\n    /** if a foreign key, the referenced columns */\n    confkey: number[];\n  };\n}\n\n/**\n * Returns a query that returns metadata for all user-defined tables and views in the database.\n */\nexport function getTablesQuery(requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">) {\n  return compile(\n    getPostgreSQLBuilder<Database>(requirements)\n      .selectFrom(\"pg_catalog.pg_class as cls\")\n      .innerJoin(\"pg_catalog.pg_namespace as ns\", \"cls.relnamespace\", \"ns.oid\")\n      .$call(excludeSystemTables)\n      // regular tables or views\n      .where(\"cls.relkind\", \"in\", TABLE_KINDS)\n      .select((eb) => [\n        \"ns.nspname as schema\",\n        \"cls.relname as name\",\n        jsonArrayFrom(\n          eb\n            .selectFrom(\"pg_catalog.pg_attribute as att\")\n            .innerJoin(\"pg_catalog.pg_type as typ\", \"typ.oid\", \"att.atttypid\")\n            .innerJoin(\"pg_catalog.pg_namespace as tns\", \"tns.oid\", \"typ.typnamespace\")\n            .leftJoin(\"pg_catalog.pg_constraint as pk_con\", (jb) =>\n              jb\n                .on(\"pk_con.contype\", \"=\", \"p\")\n                .onRef(\"pk_con.conrelid\", \"=\", \"cls.oid\")\n                .on((eb) => eb(\"att.attnum\", \"=\", eb.fn.any(\"pk_con.conkey\"))),\n            )\n            .leftJoin(\"pg_catalog.pg_constraint as fk_con\", (jb) =>\n              jb\n                .on(\"fk_con.contype\", \"=\", \"f\")\n                .onRef(\"fk_con.conrelid\", \"=\", \"cls.oid\")\n                .on((eb) => eb(\"att.attnum\", \"=\", eb.fn.any(\"fk_con.conkey\"))),\n            )\n            .leftJoin(\"pg_catalog.pg_class as fk_cls\", \"fk_cls.oid\", \"fk_con.confrelid\")\n            .leftJoin(\"pg_catalog.pg_namespace as fk_ns\", \"fk_ns.oid\", \"fk_cls.relnamespace\")\n            .leftJoin(\"pg_catalog.pg_attribute as fk_att\", (jb) =>\n              jb\n                .onRef(\"fk_att.attrelid\", \"=\", \"fk_cls.oid\")\n                // Use a callback for the .on() condition to ensure correct context for types\n                .on((on_eb) => on_eb(\"fk_att.attnum\", \"=\", on_eb.fn.any(\"fk_con.confkey\"))),\n            )\n            .whereRef(\"att.attrelid\", \"=\", \"cls.oid\")\n            // exclude system columns\n            .where(\"att.attnum\", \">=\", 0)\n            .where(\"att.attisdropped\", \"!=\", true)\n            .select([\n              \"att.attname as name\",\n              \"typ.typname as datatype\",\n              \"tns.nspname as datatype_schema\",\n              \"fk_ns.nspname as foreign_key_schema\",\n              \"fk_cls.relname as foreign_key_table\",\n              \"fk_att.attname as foreign_key_column\",\n            ])\n            .select((eb) => [\n              eb(\"pk_con.conkey\", \"is not\", null).$castTo<boolean>().as(\"pk\"),\n              eb(\"att.attgenerated\", \"!=\", \"\").$castTo<boolean>().as(\"computed\"),\n              eb(\"att.attnotnull\", \"!=\", true).$castTo<boolean>().as(\"nullable\"),\n              eb.fn\n                .coalesce(\n                  eb\n                    .selectFrom(\"pg_catalog.pg_enum as enm\")\n                    .whereRef(\"enm.enumtypid\", \"=\", \"typ.oid\")\n                    .select((eb) => eb.fn.jsonAgg(eb.ref(\"enm.enumlabel\")).as(\"o\")),\n                  sql<string[]>`'[]'`,\n                )\n                .as(\"options\"),\n            ]),\n        ).as(\"columns\"),\n      ]),\n  );\n}\n\n/**\n * For testing purposes.\n */\nexport function mockTablesQuery() {\n  return [\n    {\n      schema: \"zoo\",\n      name: \"animals\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"int4\",\n          datatype_schema: \"pg_catalog\",\n          pk: true,\n          computed: false,\n          options: [],\n          nullable: false,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"text\",\n          datatype_schema: \"pg_catalog\",\n          pk: false,\n          computed: false,\n          options: [],\n          nullable: true,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n      ],\n    },\n    {\n      schema: \"public\",\n      name: \"users\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"int4\",\n          datatype_schema: \"pg_catalog\",\n          pk: true,\n          computed: false,\n          options: [],\n          nullable: false,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"created_at\",\n          datatype: \"timestamp\",\n          datatype_schema: \"pg_catalog\",\n          pk: false,\n          computed: false,\n          options: [],\n          nullable: true,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"deleted_at\",\n          datatype: \"timestamp\",\n          datatype_schema: \"pg_catalog\",\n          pk: false,\n          computed: false,\n          options: [],\n          nullable: true,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"role\",\n          datatype: \"varchar\",\n          datatype_schema: \"pg_catalog\",\n          pk: false,\n          computed: false,\n          options: [],\n          nullable: true,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"varchar\",\n          datatype_schema: \"pg_catalog\",\n          pk: false,\n          computed: false,\n          options: [],\n          nullable: true,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"name_role\",\n          datatype: \"text\",\n          datatype_schema: \"pg_catalog\",\n          pk: false,\n          computed: true,\n          options: [],\n          nullable: false,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n      ],\n    },\n  ] as const satisfies QueryResult<typeof getTablesQuery>;\n}\n\n/**\n * Returns a query that returns the current timezone setting of the PostgreSQL database.\n */\nexport function getTimezoneQuery() {\n  const builder = getPostgreSQLBuilder();\n\n  return compile(builder.selectNoFrom(builder.fn<string>(\"current_setting\", [sql.lit(\"timezone\")]).as(\"timezone\")));\n}\n\n/**\n * For testing purposes.\n */\nexport function mockTimezoneQuery() {\n  return [{ timezone: \"UTC\" }] as const satisfies QueryResult<typeof getTimezoneQuery>;\n}\n\n/**\n * We don't want PostgreSQL internals in introspection results. To be used in `$call`.\n */\nfunction excludeSystemTables<\n  T extends SelectQueryBuilder<\n    Database & { ns: Database[\"pg_catalog.pg_namespace\"]; cls: Database[\"pg_catalog.pg_class\"] },\n    \"ns\" | \"cls\",\n    object\n  >,\n>(qb: T): T {\n  return qb.where(`ns.nspname`, `!~`, `^pg_`).where(`ns.nspname`, `!=`, `information_schema`) as never;\n}\n", "import {\n  type Adapter,\n  type AdapterDeleteResult,\n  type AdapterError,\n  type AdapterInsertResult,\n  type AdapterIntrospectResult,\n  type AdapterQueryResult,\n  type AdapterUpdateResult,\n  type Column,\n  createAdapterError,\n  type FilterOperator,\n  type Table,\n} from \"../adapter\";\nimport type { Executor } from \"../executor\";\nimport type { Query, QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { POSTGRESQL_DATA_TYPES_TO_METADATA } from \"./datatype\";\nimport { getDeleteQuery, getInsertQuery, getSelectQuery, getUpdateQuery } from \"./dml\";\nimport { getTablesQuery, getTimezoneQuery, mockTablesQuery, mockTimezoneQuery } from \"./introspection\";\n\nexport interface PostgresAdapterRequirements {\n  executor: Executor;\n  noParameters?: boolean;\n}\n\nexport function createPostgresAdapter(requirements: PostgresAdapterRequirements): Adapter {\n  const { executor, ...otherRequirements } = requirements;\n\n  return {\n    defaultSchema: \"public\",\n    async introspect(options): Promise<Either<AdapterError, AdapterIntrospectResult>> {\n      try {\n        const tablesQuery = getTablesQuery(otherRequirements);\n        const timezoneQuery = getTimezoneQuery();\n\n        const [[tablesError, tables], [timezoneError, timezones]] = await Promise.all([\n          executor.execute(tablesQuery, options),\n          executor.execute(timezoneQuery, options),\n        ]);\n\n        if (tablesError) {\n          return createAdapterError({ error: tablesError, query: tablesQuery });\n        }\n\n        if (timezoneError) {\n          return createAdapterError({ error: timezoneError, query: timezoneQuery });\n        }\n\n        const timezone = timezones[0]?.timezone;\n\n        if (!timezone) {\n          return createAdapterError({ error: new Error(\"Timezone not found\"), query: timezoneQuery });\n        }\n\n        return [null, createIntrospection({ tables, timezone, query: tablesQuery })];\n      } catch (error: unknown) {\n        // TODO: handle properly\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async query(details, options): Promise<Either<AdapterError, AdapterQueryResult>> {\n      try {\n        const query = getSelectQuery(details, otherRequirements);\n        const [error, results] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { filteredRowCount: results[0]?.oid || \"0\", rows: results, query }];\n      } catch (error: unknown) {\n        // TODO: handle properly\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async insert(details, options): Promise<Either<AdapterError, AdapterInsertResult>> {\n      try {\n        const query = getInsertQuery(details, otherRequirements);\n        const [error, rows] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { rows, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async update(details, options): Promise<Either<AdapterError, AdapterUpdateResult>> {\n      try {\n        const query = getUpdateQuery(details, otherRequirements);\n        const [error, results] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        const [row] = results;\n\n        if (!row) {\n          // TODO: custom error?\n          return createAdapterError({ error: new Error(\"Update failed\"), query });\n        }\n\n        return [null, { row, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n    async delete(details, options): Promise<Either<AdapterError, AdapterDeleteResult>> {\n      try {\n        const query = getDeleteQuery(details, otherRequirements);\n        const [error] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { ...details, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n  };\n}\n\nfunction createIntrospection(args: { tables: QueryResult<typeof getTablesQuery>; timezone: string; query: Query }) {\n  const { tables, timezone, query } = args;\n\n  return tables.reduce(\n    (result, row) => {\n      const { schemas } = result;\n      const { columns, name: tableName, schema } = row;\n\n      const columnsRecord = columns.reduce(\n        (columns, column) => {\n          const { datatype, datatype_schema, name: columnName, options, nullable } = column;\n\n          const isArray = datatype.startsWith(\"_\");\n          const strippedDataType = isArray ? datatype.slice(1) : datatype;\n\n          return {\n            ...columns,\n            [columnName]: {\n              datatype: {\n                ...(POSTGRESQL_DATA_TYPES_TO_METADATA[strippedDataType] || {\n                  group: options.length > 0 ? \"enum\" : \"raw\",\n                }),\n                isArray,\n                isNative: datatype_schema === \"pg_catalog\",\n                name: isArray ? `${strippedDataType}[]` : strippedDataType,\n                options,\n                schema: datatype_schema,\n              },\n              isComputed: column.computed,\n              isInPrimaryKey: column.pk,\n              name: columnName,\n              nullable,\n              schema,\n              table: tableName,\n              fkSchema: column.foreign_key_schema,\n              fkTable: column.foreign_key_table,\n              fkColumn: column.foreign_key_column,\n            } as const satisfies Column,\n          };\n        },\n        {} as Table[\"columns\"],\n      );\n\n      if (schemas[schema] === undefined) {\n        schemas[schema] = {\n          name: schema,\n          tables: {},\n        };\n      }\n\n      schemas[schema].tables[tableName] = {\n        columns: columnsRecord,\n        name: tableName,\n        schema,\n      };\n\n      return result;\n    },\n    {\n      schemas: { public: { tables: {}, name: \"public\" } },\n      timezone,\n      filterOperators,\n      query,\n    } satisfies AdapterIntrospectResult as AdapterIntrospectResult,\n  );\n}\n\nconst filterOperators = [\n  \"=\",\n  \"!=\",\n  \">\",\n  \">=\",\n  \"<\",\n  \"<=\",\n  \"is\",\n  \"is not\",\n  \"like\",\n  \"not like\",\n  \"ilike\",\n  \"not ilike\",\n] satisfies FilterOperator[];\n\n/**\n * For testing purposes.\n */\nexport function mockIntrospect() {\n  const tables = mockTablesQuery();\n  const [{ timezone }] = mockTimezoneQuery();\n  const query = { parameters: [], sql: \"<mocked>\" } as Query;\n\n  return createIntrospection({ tables, timezone, query }) as {\n    // best effort, no need go overboard.\n    schemas: {\n      [K in (typeof tables)[number][\"schema\"]]: {\n        name: K;\n        tables: {\n          [T in (typeof tables)[number][\"name\"]]: Table;\n        };\n      };\n    };\n    timezone: typeof timezone;\n    filterOperators: FilterOperator[];\n    query: Query;\n  } satisfies AdapterIntrospectResult;\n}\n"],
  "mappings": "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",
  "names": ["pglite_exports", "__export", "createPGLiteAdapter", "createPGLiteExecutor", "__toCommonJS", "createAdapterError", "args", "error", "query", "adapterError", "POSTGRESQL_DATA_TYPES_TO_METADATA", "isUndefined", "obj", "isString", "isNumber", "isBoolean", "isNull", "isDate", "isBigInt", "isFunction", "obj", "isObject", "freeze", "obj", "asArray", "arg", "isReadonlyArray", "isReadonlyArray", "arg", "noop", "obj", "AlterTableNode", "freeze", "node", "table", "props", "columnAlteration", "IdentifierNode", "freeze", "node", "name", "CreateIndexNode", "freeze", "node", "name", "IdentifierNode", "props", "columns", "CreateSchemaNode", "freeze", "node", "schema", "params", "IdentifierNode", "createSchema", "ON_COMMIT_ACTIONS", "CreateTableNode", "freeze", "node", "table", "createTable", "column", "constraint", "modifier", "params", "SchemableIdentifierNode", "freeze", "node", "identifier", "IdentifierNode", "schema", "DropIndexNode", "freeze", "node", "name", "params", "SchemableIdentifierNode", "dropIndex", "props", "DropSchemaNode", "freeze", "node", "schema", "params", "IdentifierNode", "dropSchema", "DropTableNode", "freeze", "node", "table", "params", "dropIndex", "AliasNode", "freeze", "node", "alias", "TableNode", "freeze", "node", "table", "SchemableIdentifierNode", "schema", "isOperationNodeSource", "obj", "isObject", "isFunction", "isExpression", "obj", "isObject", "isOperationNodeSource", "isAliasedExpression", "isString", "SelectModifierNode", "freeze", "node", "modifier", "of", "AndNode", "freeze", "node", "left", "right", "OrNode", "freeze", "node", "left", "right", "OnNode", "freeze", "node", "filter", "onNode", "operator", "operation", "AndNode", "OrNode", "JoinNode", "freeze", "node", "joinType", "table", "on", "OnNode", "joinNode", "operation", "BinaryOperationNode", "freeze", "node", "leftOperand", "operator", "rightOperand", "COMPARISON_OPERATORS", "ARITHMETIC_OPERATORS", "JSON_OPERATORS", "BINARY_OPERATORS", "UNARY_FILTER_OPERATORS", "UNARY_OPERATORS", "OPERATORS", "OperatorNode", "freeze", "node", "operator", "isJSONOperator", "op", "isString", "JSON_OPERATORS", "ColumnNode", "freeze", "node", "column", "IdentifierNode", "SelectAllNode", "freeze", "node", "ReferenceNode", "freeze", "node", "column", "table", "SelectAllNode", "DynamicReferenceBuilder", "#dynamicReference", "reference", "parseSimpleReferenceExpression", "isDynamicReferenceBuilder", "obj", "isObject", "isOperationNodeSource", "isString", "OrderByItemNode", "freeze", "node", "orderBy", "direction", "props", "RawNode", "freeze", "node", "sqlFragments", "parameters", "sql", "child", "children", "CollateNode", "node", "collation", "freeze", "IdentifierNode", "OrderByItemBuilder", "_OrderByItemBuilder", "#props", "props", "freeze", "OrderByItemNode", "RawNode", "collation", "CollateNode", "LOGGED_MESSAGES", "logOnce", "message", "isOrderByDirection", "thing", "parseOrderBy", "args", "parseOrderByItem", "orderBy", "logOnce", "item", "expr", "modifiers", "parsedRef", "parseOrderByExpression", "OrderByItemNode", "parseOrderByWithModifiers", "isExpressionOrFactory", "parseExpression", "isDynamicReferenceBuilder", "ref", "direction", "parseStringReference", "RawNode", "isExpression", "node", "OrderByItemBuilder", "JSONReferenceNode", "freeze", "node", "reference", "traversal", "JSONOperatorChainNode", "freeze", "node", "operator", "value", "JSONPathNode", "freeze", "node", "inOperator", "jsonPathNode", "pathLeg", "parseSimpleReferenceExpression", "exp", "isString", "parseStringReference", "parseReferenceExpressionOrList", "arg", "isReadonlyArray", "it", "parseReferenceExpression", "isExpressionOrFactory", "parseExpression", "parseJSONReference", "ref", "op", "referenceNode", "isJSONOperator", "JSONReferenceNode", "JSONOperatorChainNode", "OperatorNode", "opWithoutLastChar", "JSONPathNode", "COLUMN_SEPARATOR", "ReferenceNode", "ColumnNode", "parts", "trim", "parseStringReferenceWithTableAndSchema", "parseStringReferenceWithTable", "parseAliasedStringReference", "ALIAS_SEPARATOR", "columnRef", "alias", "AliasNode", "IdentifierNode", "parseColumnName", "column", "parseOrderedColumnName", "ORDER_SEPARATOR", "columnName", "order", "isOrderByDirection", "parseOrderBy", "schema", "table", "TableNode", "str", "PrimitiveValueListNode", "freeze", "node", "values", "ValueListNode", "freeze", "node", "values", "ValueNode", "freeze", "node", "value", "parseValueExpressionOrList", "arg", "isReadonlyArray", "parseValueExpressionList", "parseValueExpression", "exp", "isExpressionOrFactory", "parseExpression", "ValueNode", "isSafeImmediateValue", "value", "isNumber", "isBoolean", "isNull", "parseSafeImmediateValue", "ValueListNode", "it", "PrimitiveValueListNode", "ParensNode", "freeze", "node", "parseValueBinaryOperationOrExpression", "args", "parseValueBinaryOperation", "parseValueExpression", "left", "operator", "right", "isIsOperator", "needsIsOperator", "BinaryOperationNode", "parseReferenceExpression", "parseOperator", "ValueNode", "parseValueExpressionOrList", "parseReferentialBinaryOperation", "parseFilterObject", "obj", "combinator", "parseFilterList", "v", "isUndefined", "k", "list", "withParens", "combine", "AndNode", "OrNode", "OperatorNode", "node", "toOperationNode", "i", "ParensNode", "value", "isNull", "isBoolean", "isString", "OPERATORS", "isOperationNodeSource", "nodeOrSource", "OrderByNode", "freeze", "node", "items", "orderBy", "PartitionByNode", "freeze", "node", "items", "partitionBy", "OverNode", "freeze", "node", "overNode", "items", "OrderByNode", "PartitionByNode", "FromNode", "freeze", "node", "froms", "from", "GroupByNode", "freeze", "node", "items", "groupBy", "HavingNode", "freeze", "node", "filter", "havingNode", "operator", "operation", "AndNode", "OrNode", "InsertQueryNode", "freeze", "node", "into", "withNode", "replace", "insertQuery", "props", "ListNode", "freeze", "node", "items", "UpdateQueryNode", "freeze", "node", "tables", "withNode", "ListNode", "updateQuery", "fromItems", "FromNode", "updates", "limit", "UsingNode", "freeze", "node", "tables", "using", "DeleteQueryNode", "freeze", "node", "fromItems", "withNode", "FromNode", "items", "QueryNode", "deleteNode", "limit", "tables", "UsingNode", "WhereNode", "freeze", "node", "filter", "whereNode", "operator", "operation", "AndNode", "OrNode", "ReturningNode", "freeze", "node", "selections", "returning", "ExplainNode", "freeze", "node", "format", "options", "WhenNode", "freeze", "node", "condition", "whenNode", "result", "MergeQueryNode", "freeze", "node", "into", "withNode", "mergeNode", "using", "when", "then", "WhenNode", "OutputNode", "freeze", "node", "selections", "output", "QueryNode", "freeze", "node", "SelectQueryNode", "InsertQueryNode", "UpdateQueryNode", "DeleteQueryNode", "MergeQueryNode", "modifier", "operation", "WhereNode", "join", "selections", "ReturningNode", "format", "options", "ExplainNode", "top", "OutputNode", "items", "OrderByNode", "SelectQueryNode", "freeze", "node", "withNode", "fromItems", "FromNode", "select", "selections", "expressions", "modifier", "items", "QueryNode", "selectNode", "GroupByNode", "limit", "offset", "fetch", "operation", "HavingNode", "setOperations", "JoinBuilder", "_JoinBuilder", "#props", "props", "freeze", "args", "JoinNode", "parseValueBinaryOperationOrExpression", "lhs", "op", "rhs", "parseReferentialBinaryOperation", "RawNode", "func", "PartitionByItemNode", "freeze", "node", "partitionBy", "parsePartitionBy", "partitionBy", "parseReferenceExpressionOrList", "PartitionByItemNode", "OverBuilder", "_OverBuilder", "#props", "props", "freeze", "args", "OverNode", "parseOrderBy", "QueryNode", "partitionBy", "parsePartitionBy", "func", "SelectionNode", "freeze", "node", "selection", "SelectAllNode", "table", "ReferenceNode", "parseSelectArg", "selection", "isFunction", "expressionBuilder", "isReadonlyArray", "it", "parseSelectExpression", "isString", "SelectionNode", "parseAliasedStringReference", "isDynamicReferenceBuilder", "parseAliasedExpression", "parseSelectAll", "table", "parseSelectAllArg", "parseTable", "ValuesNode", "freeze", "node", "values", "DefaultInsertValueNode", "freeze", "node", "parseInsertExpression", "arg", "objectOrList", "isFunction", "expressionBuilder", "list", "isReadonlyArray", "freeze", "parseInsertColumnsAndValues", "rows", "columns", "parseColumnNamesAndIndexes", "ColumnNode", "ValuesNode", "row", "parseRowValues", "cols", "col", "rowColumns", "rowValues", "hasUndefinedOrComplexColumns", "indexedRowColumns", "columnIdx", "isUndefined", "value", "isExpressionOrFactory", "defaultValue", "DefaultInsertValueNode", "ValueListNode", "it", "parseValueExpression", "PrimitiveValueListNode", "ColumnUpdateNode", "freeze", "node", "column", "value", "parseUpdate", "args", "ColumnUpdateNode", "parseReferenceExpression", "parseValueExpression", "parseUpdateObjectExpression", "update", "updateObj", "isFunction", "expressionBuilder", "_", "value", "key", "ColumnNode", "OnDuplicateKeyNode", "freeze", "node", "updates", "InsertResult", "insertId", "numInsertedOrUpdatedRows", "NoResultError", "node", "isNoResultErrorConstructor", "fn", "OnConflictNode", "freeze", "node", "props", "operation", "WhereNode", "OnConflictBuilder", "_OnConflictBuilder", "#props", "props", "freeze", "column", "columnNode", "ColumnNode", "OnConflictNode", "columns", "columnNodes", "constraintName", "IdentifierNode", "expression", "args", "parseValueBinaryOperationOrExpression", "lhs", "op", "rhs", "parseReferentialBinaryOperation", "OnConflictDoNothingBuilder", "update", "OnConflictUpdateBuilder", "parseUpdateObjectExpression", "func", "_OnConflictUpdateBuilder", "TopNode", "freeze", "node", "expression", "modifiers", "parseTop", "expression", "modifiers", "isNumber", "isBigInt", "isUndefined", "isTopModifiers", "TopNode", "OrActionNode", "freeze", "node", "action", "InsertQueryBuilder", "_InsertQueryBuilder", "#props", "props", "freeze", "insert", "columns", "values", "parseInsertExpression", "InsertQueryNode", "ColumnNode", "expression", "parseExpression", "modifier", "QueryNode", "OrActionNode", "modifiers", "parseTop", "callback", "OnConflictBuilder", "OnConflictNode", "update", "OnDuplicateKeyNode", "parseUpdateObjectExpression", "selection", "parseSelectArg", "parseSelectAll", "args", "table", "func", "condition", "plugin", "compiledQuery", "result", "adapter", "query", "InsertResult", "errorConstructor", "NoResultError", "isNoResultErrorConstructor", "chunkSize", "stream", "item", "format", "options", "DeleteResult", "numDeletedRows", "LimitNode", "freeze", "node", "limit", "DeleteQueryBuilder", "_DeleteQueryBuilder", "#props", "props", "freeze", "args", "QueryNode", "parseValueBinaryOperationOrExpression", "lhs", "op", "rhs", "parseReferentialBinaryOperation", "expression", "modifiers", "parseTop", "tables", "DeleteQueryNode", "parseTableExpressionOrList", "#join", "joinType", "parseJoin", "selection", "parseSelectArg", "table", "parseSelectAll", "parseOrderBy", "limit", "LimitNode", "parseValueExpression", "modifier", "func", "condition", "plugin", "compiledQuery", "result", "adapter", "query", "DeleteResult", "errorConstructor", "NoResultError", "isNoResultErrorConstructor", "chunkSize", "stream", "item", "format", "options", "UpdateResult", "numUpdatedRows", "numChangedRows", "UpdateQueryBuilder", "_UpdateQueryBuilder", "#props", "props", "freeze", "args", "QueryNode", "parseValueBinaryOperationOrExpression", "lhs", "op", "rhs", "parseReferentialBinaryOperation", "expression", "modifiers", "parseTop", "from", "UpdateQueryNode", "parseTableExpressionOrList", "#join", "joinType", "parseJoin", "parseOrderBy", "limit", "LimitNode", "parseValueExpression", "parseUpdate", "selection", "parseSelectArg", "table", "parseSelectAll", "modifier", "func", "condition", "plugin", "compiledQuery", "result", "adapter", "query", "UpdateResult", "errorConstructor", "NoResultError", "isNoResultErrorConstructor", "chunkSize", "stream", "item", "format", "options", "CommonTableExpressionNameNode", "freeze", "node", "tableName", "columnNames", "TableNode", "ColumnNode", "CommonTableExpressionNode", "freeze", "node", "name", "expression", "props", "CTEBuilder", "_CTEBuilder", "#props", "props", "freeze", "CommonTableExpressionNode", "parseCommonTableExpression", "nameOrBuilderCallback", "expression", "expressionNode", "createQueryCreator", "isFunction", "cteBuilderFactory", "CommonTableExpressionNode", "parseCommonTableExpressionName", "name", "CTEBuilder", "parts", "table", "columns", "it", "CommonTableExpressionNameNode", "WithNode", "freeze", "node", "expression", "params", "withNode", "CHARS", "randomString", "length", "chars", "i", "randomChar", "createQueryId", "LazyQueryId", "#queryId", "randomString", "OperationNodeTransformer", "#transformers", "freeze", "node", "queryId", "out", "list", "_queryId", "ROOT_OPERATION_NODES", "freeze", "SCHEMALESS_FUNCTIONS", "WithSchemaTransformer", "OperationNodeTransformer", "#schema", "#schemableIds", "#ctes", "schema", "node", "queryId", "#isRootOperationNode", "ctes", "#collectCTEs", "cte", "tables", "#collectSchemableIds", "table", "transformed", "IdentifierNode", "TableNode", "#transformTableArgsWithoutSchemas", "argsKey", "arg", "schemableIds", "SchemableIdentifierNode", "#collectSchemableId", "from", "#collectSchemableIdsFromTableExpr", "join", "#collectCTEIds", "AliasNode", "ListNode", "id", "expr", "cteId", "WithSchemaPlugin", "#transformer", "schema", "WithSchemaTransformer", "args", "MatchedNode", "freeze", "node", "not", "bySource", "parseMergeWhen", "type", "args", "refRight", "WhenNode", "parseFilterList", "MatchedNode", "parseReferentialBinaryOperation", "parseValueBinaryOperationOrExpression", "parseMergeThen", "result", "isString", "RawNode", "isOperationNodeSource", "Deferred", "#promise", "#resolve", "#reject", "resolve", "reject", "value", "reason", "provideControlledConnection", "connectionProvider", "connectionDefer", "Deferred", "connectionReleaseDefer", "connection", "ex", "freeze", "NO_PLUGINS", "freeze", "QueryExecutorBase", "#plugins", "plugins", "node", "queryId", "plugin", "transformedNode", "compiledQuery", "connection", "result", "logOnce", "#transformResult", "chunkSize", "release", "provideControlledConnection", "NoopQueryExecutor", "_NoopQueryExecutor", "QueryExecutorBase", "plugin", "plugins", "NOOP_QUERY_EXECUTOR", "MergeResult", "numChangedRows", "MergeQueryBuilder", "_MergeQueryBuilder", "#props", "props", "freeze", "modifier", "QueryNode", "expression", "modifiers", "parseTop", "args", "WheneableMergeQueryBuilder", "MergeQueryNode", "parseJoin", "parseSelectArg", "table", "parseSelectAll", "_WheneableMergeQueryBuilder", "#whenMatched", "lhs", "op", "rhs", "refRight", "MatchedThenableMergeQueryBuilder", "parseMergeWhen", "#whenNotMatched", "bySource", "Builder", "NotMatchedThenableMergeQueryBuilder", "func", "condition", "compiledQuery", "result", "adapter", "query", "MergeResult", "errorConstructor", "NoResultError", "isNoResultErrorConstructor", "parseMergeThen", "set", "UpdateQueryBuilder", "NOOP_QUERY_EXECUTOR", "UpdateQueryNode", "ub", "insert", "columns", "values", "parseInsertExpression", "InsertQueryNode", "QueryCreator", "_QueryCreator", "#props", "props", "freeze", "from", "createSelectQueryBuilder", "createQueryId", "SelectQueryNode", "parseTableExpressionOrList", "selection", "parseSelectArg", "table", "InsertQueryBuilder", "InsertQueryNode", "parseTable", "DeleteQueryBuilder", "DeleteQueryNode", "tables", "UpdateQueryBuilder", "UpdateQueryNode", "targetTable", "MergeQueryBuilder", "MergeQueryNode", "parseAliasedTable", "nameOrBuilder", "expression", "cte", "parseCommonTableExpression", "WithNode", "plugin", "schema", "WithSchemaPlugin", "createQueryCreator", "QueryCreator", "NOOP_QUERY_EXECUTOR", "createJoinBuilder", "joinType", "table", "JoinBuilder", "JoinNode", "parseTableExpression", "createOverBuilder", "OverBuilder", "OverNode", "parseJoin", "joinType", "args", "parseSingleOnJoin", "parseCallbackJoin", "parseOnlessJoin", "from", "callback", "createJoinBuilder", "lhsColumn", "rhsColumn", "JoinNode", "parseTableExpression", "parseReferentialBinaryOperation", "OffsetNode", "freeze", "node", "offset", "GroupByItemNode", "freeze", "node", "groupBy", "parseGroupBy", "groupBy", "isFunction", "expressionBuilder", "parseReferenceExpressionOrList", "GroupByItemNode", "SetOperationNode", "freeze", "node", "operator", "expression", "all", "parseSetOperations", "operator", "expression", "all", "isFunction", "createExpressionBuilder", "isReadonlyArray", "expr", "SetOperationNode", "parseExpression", "ExpressionWrapper", "_ExpressionWrapper", "#node", "node", "alias", "AliasedExpressionWrapper", "args", "OrWrapper", "OrNode", "parseValueBinaryOperationOrExpression", "AndWrapper", "AndNode", "#expr", "#alias", "expr", "AliasNode", "isOperationNodeSource", "IdentifierNode", "_OrWrapper", "ParensNode", "_AndWrapper", "FetchNode", "node", "rowCount", "modifier", "ValueNode", "parseFetch", "rowCount", "modifier", "isNumber", "isBigInt", "isFetchModifier", "FetchNode", "value", "SelectQueryBuilderImpl", "_SelectQueryBuilderImpl", "#props", "props", "freeze", "args", "QueryNode", "parseValueBinaryOperationOrExpression", "lhs", "op", "rhs", "parseReferentialBinaryOperation", "SelectQueryNode", "selection", "parseSelectArg", "parseReferenceExpressionOrList", "modifier", "SelectModifierNode", "of", "asArray", "parseTable", "table", "parseSelectAll", "#join", "joinType", "parseJoin", "parseOrderBy", "groupBy", "parseGroupBy", "limit", "LimitNode", "parseValueExpression", "offset", "OffsetNode", "rowCount", "parseFetch", "expression", "modifiers", "parseTop", "parseSetOperations", "alias", "AliasedSelectQueryBuilderImpl", "func", "condition", "ExpressionWrapper", "plugin", "compiledQuery", "result", "errorConstructor", "NoResultError", "isNoResultErrorConstructor", "chunkSize", "stream", "item", "format", "options", "createSelectQueryBuilder", "#queryBuilder", "#alias", "queryBuilder", "AliasNode", "IdentifierNode", "AggregateFunctionNode", "freeze", "node", "aggregateFunction", "aggregated", "aggregateFunctionNode", "orderItems", "withinGroup", "prop", "OrderByNode", "filter", "WhereNode", "over", "FunctionNode", "freeze", "node", "func", "args", "AggregateFunctionBuilder", "_AggregateFunctionBuilder", "#props", "props", "freeze", "alias", "AliasedAggregateFunctionBuilder", "AggregateFunctionNode", "args", "QueryNode", "parseOrderBy", "parseValueBinaryOperationOrExpression", "lhs", "op", "rhs", "parseReferentialBinaryOperation", "over", "builder", "createOverBuilder", "func", "#aggregateFunctionBuilder", "#alias", "aggregateFunctionBuilder", "AliasNode", "IdentifierNode", "createFunctionModule", "fn", "name", "args", "ExpressionWrapper", "FunctionNode", "parseReferenceExpressionOrList", "agg", "AggregateFunctionBuilder", "AggregateFunctionNode", "column", "values", "table", "parseSelectAll", "isString", "parseTable", "UnaryOperationNode", "freeze", "node", "operator", "operand", "parseUnaryOperation", "operator", "operand", "UnaryOperationNode", "OperatorNode", "parseReferenceExpression", "CaseNode", "freeze", "node", "value", "caseNode", "when", "then", "WhenNode", "props", "CaseBuilder", "#props", "props", "freeze", "args", "CaseThenBuilder", "CaseNode", "WhenNode", "parseValueBinaryOperationOrExpression", "valueExpression", "CaseWhenBuilder", "isSafeImmediateValue", "parseSafeImmediateValue", "parseValueExpression", "CaseEndBuilder", "ExpressionWrapper", "JSONPathLegNode", "freeze", "node", "type", "value", "JSONPathBuilder", "#node", "node", "index", "#createBuilderWithPathLeg", "key", "legType", "value", "JSONReferenceNode", "TraversedJSONPathBuilder", "JSONPathNode", "JSONPathLegNode", "JSONOperatorChainNode", "ValueNode", "_TraversedJSONPathBuilder", "alias", "AliasedJSONPathBuilder", "#jsonPath", "#alias", "jsonPath", "AliasNode", "isOperationNodeSource", "IdentifierNode", "TupleNode", "freeze", "node", "values", "SIMPLE_COLUMN_DATA_TYPES", "COLUMN_DATA_TYPE_REGEX", "DataTypeNode", "freeze", "node", "dataType", "isColumnDataType", "r", "parseDataTypeExpression", "dataType", "isOperationNodeSource", "isColumnDataType", "DataTypeNode", "CastNode", "freeze", "node", "expression", "dataType", "createExpressionBuilder", "executor", "NOOP_QUERY_EXECUTOR", "binary", "lhs", "op", "rhs", "ExpressionWrapper", "parseValueBinaryOperation", "unary", "expr", "parseUnaryOperation", "eb", "table", "createSelectQueryBuilder", "createQueryId", "SelectQueryNode", "parseTableExpressionOrList", "reference", "CaseBuilder", "CaseNode", "isUndefined", "parseReferenceExpression", "parseStringReference", "JSONPathBuilder", "parseJSONReference", "JSONPathNode", "parseTable", "value", "parseValueExpression", "values", "TupleNode", "parseSafeImmediateValue", "start", "end", "BinaryOperationNode", "OperatorNode", "AndNode", "exprs", "isReadonlyArray", "parseFilterList", "parseFilterObject", "args", "node", "parseValueBinaryOperationOrExpression", "ParensNode", "dataType", "CastNode", "parseDataTypeExpression", "schema", "WithSchemaPlugin", "createFunctionModule", "expressionBuilder", "_", "parseExpression", "exp", "isOperationNodeSource", "isFunction", "expressionBuilder", "parseAliasedExpression", "isExpressionOrFactory", "obj", "isExpression", "isAliasedExpression", "DynamicTableBuilder", "#table", "table", "alias", "AliasedDynamicTableBuilder", "#alias", "AliasNode", "parseTable", "IdentifierNode", "isAliasedDynamicTableBuilder", "obj", "isObject", "isOperationNodeSource", "isString", "parseTableExpressionOrList", "table", "isReadonlyArray", "it", "parseTableExpression", "isString", "parseAliasedTable", "isAliasedDynamicTableBuilder", "parseAliasedExpression", "from", "ALIAS_SEPARATOR", "alias", "trim", "AliasNode", "parseTable", "IdentifierNode", "SCHEMA_SEPARATOR", "schema", "TableNode", "str", "AddColumnNode", "freeze", "node", "column", "ColumnDefinitionNode", "freeze", "node", "column", "dataType", "ColumnNode", "modifier", "props", "DropColumnNode", "freeze", "node", "column", "ColumnNode", "RenameColumnNode", "freeze", "node", "column", "newColumn", "ColumnNode", "CheckConstraintNode", "freeze", "node", "expression", "constraintName", "IdentifierNode", "ON_MODIFY_FOREIGN_ACTIONS", "ReferencesNode", "freeze", "node", "table", "columns", "references", "onDelete", "onUpdate", "parseDefaultValueExpression", "value", "isOperationNodeSource", "ValueNode", "GeneratedNode", "freeze", "node", "params", "expression", "DefaultValueNode", "freeze", "node", "defaultValue", "parseOnModifyForeignAction", "action", "ON_MODIFY_FOREIGN_ACTIONS", "ColumnDefinitionBuilder", "_ColumnDefinitionBuilder", "#node", "node", "ColumnDefinitionNode", "ref", "references", "parseStringReference", "SelectAllNode", "ReferencesNode", "onDelete", "parseOnModifyForeignAction", "onUpdate", "value", "DefaultValueNode", "parseDefaultValueExpression", "expression", "CheckConstraintNode", "GeneratedNode", "modifier", "func", "ModifyColumnNode", "freeze", "node", "column", "ForeignKeyConstraintNode", "freeze", "node", "sourceColumns", "targetTable", "targetColumns", "constraintName", "ReferencesNode", "IdentifierNode", "props", "ForeignKeyConstraintBuilder", "_ForeignKeyConstraintBuilder", "#node", "node", "onDelete", "ForeignKeyConstraintNode", "parseOnModifyForeignAction", "onUpdate", "func", "AddConstraintNode", "freeze", "node", "constraint", "UniqueConstraintNode", "freeze", "node", "columns", "constraintName", "nullsNotDistinct", "ColumnNode", "IdentifierNode", "props", "DropConstraintNode", "freeze", "node", "constraintName", "IdentifierNode", "dropConstraint", "props", "AlterColumnNode", "freeze", "node", "column", "prop", "value", "ColumnNode", "AlterColumnBuilder", "#column", "column", "dataType", "AlteredColumnBuilder", "AlterColumnNode", "parseDataTypeExpression", "value", "parseDefaultValueExpression", "func", "#alterColumnNode", "alterColumnNode", "AlterTableExecutor", "#props", "props", "freeze", "AlterTableAddForeignKeyConstraintBuilder", "_AlterTableAddForeignKeyConstraintBuilder", "#props", "props", "freeze", "onDelete", "onUpdate", "func", "AlterTableNode", "AddConstraintNode", "AlterTableDropConstraintBuilder", "_AlterTableDropConstraintBuilder", "#props", "props", "freeze", "AlterTableNode", "DropConstraintNode", "func", "PrimaryKeyConstraintNode", "freeze", "node", "columns", "constraintName", "ColumnNode", "IdentifierNode", "props", "AddIndexNode", "freeze", "node", "name", "IdentifierNode", "props", "columns", "AlterTableAddIndexBuilder", "_AlterTableAddIndexBuilder", "#props", "props", "freeze", "AlterTableNode", "AddIndexNode", "column", "parseOrderedColumnName", "columns", "expression", "indexType", "RawNode", "func", "UniqueConstraintNodeBuilder", "_UniqueConstraintNodeBuilder", "#node", "node", "UniqueConstraintNode", "func", "PrimaryKeyConstraintBuilder", "_PrimaryKeyConstraintBuilder", "#node", "node", "PrimaryKeyConstraintNode", "func", "CheckConstraintBuilder", "#node", "node", "func", "RenameConstraintNode", "freeze", "node", "oldName", "newName", "IdentifierNode", "AlterTableBuilder", "#props", "props", "freeze", "newTableName", "AlterTableExecutor", "AlterTableNode", "parseTable", "newSchema", "IdentifierNode", "column", "alteration", "builder", "AlterColumnBuilder", "AlterTableColumnAlteringBuilder", "DropColumnNode", "newColumn", "RenameColumnNode", "columnName", "dataType", "build", "noop", "ColumnDefinitionBuilder", "ColumnDefinitionNode", "parseDataTypeExpression", "AddColumnNode", "ModifyColumnNode", "constraintName", "columns", "uniqueConstraintBuilder", "UniqueConstraintNodeBuilder", "UniqueConstraintNode", "AddConstraintNode", "checkExpression", "constraintBuilder", "CheckConstraintBuilder", "CheckConstraintNode", "targetTable", "targetColumns", "ForeignKeyConstraintBuilder", "ForeignKeyConstraintNode", "ColumnNode", "AlterTableAddForeignKeyConstraintBuilder", "PrimaryKeyConstraintBuilder", "PrimaryKeyConstraintNode", "AlterTableDropConstraintBuilder", "DropConstraintNode", "oldName", "newName", "RenameConstraintNode", "indexName", "AlterTableAddIndexBuilder", "AddIndexNode", "DropIndexNode", "func", "_AlterTableColumnAlteringBuilder", "ImmediateValueTransformer", "OperationNodeTransformer", "node", "ValueListNode", "ValueNode", "CreateIndexBuilder", "_CreateIndexBuilder", "#props", "props", "freeze", "CreateIndexNode", "table", "parseTable", "column", "parseOrderedColumnName", "columns", "expression", "indexType", "RawNode", "args", "transformer", "ImmediateValueTransformer", "QueryNode", "parseValueBinaryOperationOrExpression", "func", "CreateSchemaBuilder", "_CreateSchemaBuilder", "#props", "props", "freeze", "CreateSchemaNode", "func", "parseOnCommitAction", "action", "ON_COMMIT_ACTIONS", "CreateTableBuilder", "_CreateTableBuilder", "#props", "props", "freeze", "CreateTableNode", "onCommit", "parseOnCommitAction", "columnName", "dataType", "build", "noop", "columnBuilder", "ColumnDefinitionBuilder", "ColumnDefinitionNode", "parseDataTypeExpression", "constraintName", "columns", "constraintBuilder", "PrimaryKeyConstraintBuilder", "PrimaryKeyConstraintNode", "uniqueConstraintBuilder", "UniqueConstraintNodeBuilder", "UniqueConstraintNode", "checkExpression", "CheckConstraintBuilder", "CheckConstraintNode", "targetTable", "targetColumns", "builder", "ForeignKeyConstraintBuilder", "ForeignKeyConstraintNode", "ColumnNode", "parseTable", "modifier", "expression", "parseExpression", "func", "DropIndexBuilder", "_DropIndexBuilder", "#props", "props", "freeze", "table", "DropIndexNode", "parseTable", "func", "DropSchemaBuilder", "_DropSchemaBuilder", "#props", "props", "freeze", "DropSchemaNode", "func", "DropTableBuilder", "_DropTableBuilder", "#props", "props", "freeze", "DropTableNode", "func", "CreateViewNode", "freeze", "node", "name", "SchemableIdentifierNode", "createView", "params", "ImmediateValuePlugin", "#transformer", "ImmediateValueTransformer", "args", "CreateViewBuilder", "_CreateViewBuilder", "#props", "props", "freeze", "CreateViewNode", "columns", "parseColumnName", "query", "queryNode", "ImmediateValuePlugin", "func", "DropViewNode", "freeze", "node", "name", "SchemableIdentifierNode", "dropView", "params", "DropViewBuilder", "_DropViewBuilder", "#props", "props", "freeze", "DropViewNode", "func", "CreateTypeNode", "freeze", "node", "name", "createType", "values", "ValueListNode", "ValueNode", "CreateTypeBuilder", "_CreateTypeBuilder", "#props", "props", "freeze", "values", "CreateTypeNode", "func", "DropTypeNode", "freeze", "node", "name", "dropType", "params", "DropTypeBuilder", "_DropTypeBuilder", "#props", "props", "freeze", "DropTypeNode", "func", "parseSchemableIdentifier", "id", "SCHEMA_SEPARATOR", "parts", "trim", "SchemableIdentifierNode", "str", "RefreshMaterializedViewNode", "freeze", "node", "name", "SchemableIdentifierNode", "createView", "params", "RefreshMaterializedViewBuilder", "_RefreshMaterializedViewBuilder", "#props", "props", "freeze", "RefreshMaterializedViewNode", "func", "SchemaModule", "_SchemaModule", "#executor", "executor", "table", "CreateTableBuilder", "createQueryId", "CreateTableNode", "parseTable", "DropTableBuilder", "DropTableNode", "indexName", "CreateIndexBuilder", "CreateIndexNode", "DropIndexBuilder", "DropIndexNode", "schema", "CreateSchemaBuilder", "CreateSchemaNode", "DropSchemaBuilder", "DropSchemaNode", "AlterTableBuilder", "AlterTableNode", "viewName", "CreateViewBuilder", "CreateViewNode", "RefreshMaterializedViewBuilder", "RefreshMaterializedViewNode", "DropViewBuilder", "DropViewNode", "typeName", "CreateTypeBuilder", "CreateTypeNode", "parseSchemableIdentifier", "DropTypeBuilder", "DropTypeNode", "plugin", "WithSchemaPlugin", "DynamicModule", "reference", "DynamicReferenceBuilder", "table", "DynamicTableBuilder", "DefaultConnectionProvider", "#driver", "driver", "consumer", "connection", "DefaultQueryExecutor", "_DefaultQueryExecutor", "QueryExecutorBase", "#compiler", "#adapter", "#connectionProvider", "compiler", "adapter", "connectionProvider", "plugins", "node", "queryId", "consumer", "plugin", "performanceNow", "isFunction", "RuntimeDriver", "#driver", "#log", "#initPromise", "#initDone", "#destroyPromise", "#connections", "driver", "log", "err", "connection", "#needsLogging", "#addLogging", "settings", "savepointName", "compileQuery", "executeQuery", "streamQuery", "dis", "compiledQuery", "caughtError", "startTime", "performanceNow", "error", "#logError", "#logQuery", "chunkSize", "result", "#calculateDurationMillis", "isStream", "ignoreError", "SingleConnectionProvider", "#connection", "#runningPromise", "connection", "consumer", "#run", "runner", "TRANSACTION_ACCESS_MODES", "TRANSACTION_ISOLATION_LEVELS", "validateTransactionSettings", "settings", "LOG_LEVELS", "freeze", "Log", "#levels", "#logger", "config", "isFunction", "defaultLogger", "level", "getEvent", "event", "prefix", "isCompilable", "value", "isObject", "isFunction", "Kysely", "_Kysely", "QueryCreator", "#props", "args", "superProps", "props", "isKyselyProps", "dialect", "driver", "compiler", "adapter", "log", "Log", "runtimeDriver", "RuntimeDriver", "connectionProvider", "DefaultConnectionProvider", "executor", "DefaultQueryExecutor", "freeze", "SchemaModule", "DynamicModule", "value", "CaseBuilder", "CaseNode", "isUndefined", "parseExpression", "createFunctionModule", "TransactionBuilder", "ControlledTransactionBuilder", "ConnectionBuilder", "plugin", "schema", "WithSchemaPlugin", "query", "queryId", "createQueryId", "compiledQuery", "isCompilable", "Transaction", "_Transaction", "obj", "isObject", "callback", "connection", "SingleConnectionProvider", "db", "_TransactionBuilder", "accessMode", "isolationLevel", "kyselyProps", "settings", "validateTransactionSettings", "transaction", "result", "error", "_ControlledTransactionBuilder", "provideControlledConnection", "ControlledTransaction", "_ControlledTransaction", "#compileQuery", "#state", "state", "NotCommittedOrRolledBackAssertingExecutor", "transactionProps", "node", "assertNotCommittedOrRolledBack", "Command", "savepointName", "#cb", "cb", "_NotCommittedOrRolledBackAssertingExecutor", "#executor", "consumer", "chunkSize", "plugins", "RawBuilderImpl", "_RawBuilderImpl", "#props", "props", "freeze", "alias", "AliasedRawBuilderImpl", "plugin", "#toOperationNode", "#getExecutor", "executorProvider", "#compile", "executor", "NOOP_QUERY_EXECUTOR", "createRawBuilder", "#rawBuilder", "#alias", "rawBuilder", "AliasNode", "isOperationNodeSource", "IdentifierNode", "sql", "sqlFragments", "parameters", "createRawBuilder", "createQueryId", "RawNode", "parseParameter", "columnReference", "parseStringReference", "value", "parseValueExpression", "tableReference", "parseTable", "ids", "fragments", "IdentifierNode", "ValueNode", "array", "separator", "nodes", "sep", "i", "param", "isOperationNodeSource", "OperationNodeVisitor", "#visitors", "freeze", "node", "LIT_WRAP_REGEX", "DefaultQueryCompiler", "OperationNodeVisitor", "#sql", "#parameters", "node", "queryId", "freeze", "wrapInParens", "ParensNode", "InsertQueryNode", "CreateTableNode", "CreateViewNode", "SetOperationNode", "expressions", "nodes", "separator", "lastIndex", "i", "rootQueryNode", "QueryNode", "isSubQuery", "MergeQueryNode", "logOnce", "_", "isString", "values", "JOIN_TYPE_SQL", "sqlFragments", "params", "isBoolean", "SELECT_MODIFIER_SQL", "OperatorNode", "pathLeg", "isArrayLocation", "len", "str", "parameter", "identifier", "leftWrap", "rightWrap", "sanitized", "c", "value", "isNumber", "isNull", "isDate", "isBigInt", "arr", "left", "right", "SELECT_MODIFIER_PRIORITY", "columnAlterations", "DummyDriver", "DummyConnection", "DialectAdapterBase", "ID_WRAP_REGEX", "PostgresQueryCompiler", "DefaultQueryCompiler", "identifier", "LOCK_ID", "PostgresAdapter", "DialectAdapterBase", "db", "_opt", "sql", "_db", "getBuilder", "requirements", "Kysely", "DummyDriver", "ImmediateValuePlugin", "#transformer", "ImmediateValueTransformer", "args", "OperationNodeTransformer", "node", "ValueListNode", "ValueNode", "compile", "compileable", "compiledQuery", "applyInferredRowFilters", "rows", "columns", "rowFilters", "inferRowFilters", "qb", "eb", "rowFilter", "columnName", "value", "inferRowFilter", "row", "pk", "column", "isInPrimaryKey", "getPostgreSQLBuilder", "requirements", "getBuilder", "PostgresAdapter", "PostgresQueryCompiler", "getInsertQuery", "details", "requirements", "table", "rows", "tableName", "schema", "columns", "builder", "getPostgreSQLBuilder", "cols", "emptyRowWorkaround", "sql", "compile", "row", "eb", "getSelectQuery", "pageIndex", "pageSize", "sortOrder", "filter", "countQuery", "qb", "item", "getSelectFilterExpression", "buildBaseExpressionBuilder", "spec", "column", "operator", "value", "columnRef", "lhs", "filters", "orGroupsOfAndBuilders", "currentAndGroupBuilders", "i", "andExpressions", "group", "getUpdateQuery", "details", "requirements", "changes", "row", "columns", "tableName", "schema", "builder", "getPostgreSQLBuilder", "cols", "compile", "applyInferredRowFilters", "eb", "sql", "getDeleteQuery", "rows", "jsonArrayFrom", "expr", "sql", "REGULAR_TABLE_KIND", "VIEW_TABLE_KIND", "TABLE_KINDS", "getTablesQuery", "requirements", "compile", "getPostgreSQLBuilder", "excludeSystemTables", "eb", "jsonArrayFrom", "jb", "on_eb", "sql", "getTimezoneQuery", "builder", "getPostgreSQLBuilder", "compile", "sql", "excludeSystemTables", "qb", "createPostgresAdapter", "requirements", "executor", "otherRequirements", "options", "tablesQuery", "getTablesQuery", "timezoneQuery", "getTimezoneQuery", "tablesError", "tables", "timezoneError", "timezones", "createAdapterError", "timezone", "createIntrospection", "error", "details", "query", "getSelectQuery", "results", "getInsertQuery", "rows", "getUpdateQuery", "row", "getDeleteQuery", "args", "result", "schemas", "columns", "tableName", "schema", "columnsRecord", "column", "datatype", "datatype_schema", "columnName", "nullable", "isArray", "strippedDataType", "POSTGRESQL_DATA_TYPES_TO_METADATA", "filterOperators", "createPGLiteExecutor", "pglite", "options", "addDelay", "logging", "query", "abortSignal", "abort", "abortionPromise", "_", "reject", "abortListener", "error", "addedDelay", "queryPGLite", "queryPGLitePossiblyDelayed", "resolve", "shouldLog", "loggableQuery", "now", "result", "duration", "createPGLiteAdapter", "createPostgresAdapter"]
}
