import * as ___react___ from 'react'; import * as ___react_dom___ from 'react-dom'; function require(mod) { if (mod === 'react') return ___react___; if (mod === 'react-dom') return ___react_dom___; throw new Error(`Unknown module ${mod}`); } import{G as m}from"./chunk-LR52PZTP.js";var g=1024,u=50*g,d=new Set(["delete","insert","select","update","values","with"]);function q(e){let t=e.trim();if(t.length===0)return{diagnostic:{from:0,message:"Type a SQL statement to lint.",severity:"info",to:0},ok:!1};if(t.length>u)return{diagnostic:{from:0,message:`SQL lint limit exceeded (${u} characters).`,severity:"error",to:Math.min(1,t.length)},ok:!1};let n=m(e);if(n.length===0)return{diagnostic:{from:0,message:"Type a SQL statement to lint.",severity:"info",to:0},ok:!1};for(let r of n){let o=p(r.statement);if(!o||!d.has(o))return{diagnostic:{from:r.from,message:"SQL lint supports SELECT, WITH, VALUES, INSERT, UPDATE, and DELETE statements.",severity:"error",to:Math.min(e.length,r.from+1)},ok:!1}}return{ok:!0,statements:n}}function T(e){let{error:t,sql:n}=e,r=Math.max(0,e.positionOffset??0),o=f({sql:n,position:void 0,sqlLength:n.length});if(!(t instanceof Error))return[{from:o.from,message:"SQL lint failed.",severity:"error",source:"postgres",to:o.to}];let i=L(t),s=h(t),{from:a,to:c}=f({message:t.message,position:S(t),sql:n,sqlLength:n.length}),l=i==="57014"?"Lint query timed out. Simplify the statement and try again.":t.message;return[{code:i,from:a+r,message:l,severity:s,source:"postgres",to:c+r}]}function p(e){return/^\s*([A-Za-z_]+)/.exec(e)?.[1]?.toLowerCase()??null}function L(e){let t=e;return typeof t.code=="string"?t.code:void 0}function S(e){let t=e,{position:n}=t;if(typeof n=="number"&&Number.isFinite(n))return n;if(typeof n=="string"){let r=Number.parseInt(n,10);return Number.isFinite(r)?r:void 0}}function h(e){return e.severity==="WARNING"?"warning":"error"}function f(e){let{message:t,position:n,sql:r,sqlLength:o}=e;if(n==null&&t){let a=E(r,t);if(a)return a}let i=Math.max(o-1,0),s=Math.min(i,Math.max(0,(Number.isFinite(n)?n:1)-1));return o===0?{from:0,to:0}:{from:s,to:Math.max(s+1,s)}}function E(e,t){let r=/"([^"]+)"/.exec(t)?.[1];if(!r)return null;let o=e.toLowerCase(),i=r.toLowerCase(),s=o.indexOf(i);return s<0?null:{from:s,to:Math.min(e.length,s+r.length)}}export{u as a,d as b,q as c,T as d}; //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../data/postgres-core/sql-lint.ts"],
  "sourcesContent": ["import type { AdapterSqlLintDiagnostic } from \"../adapter\";\nimport { splitTopLevelSqlStatements } from \"../sql-statements\";\n\nconst BYTES_PER_KILOBYTE = 1024;\n\nexport const SQL_LINT_MAX_LENGTH = 50 * BYTES_PER_KILOBYTE;\nexport const SQL_LINT_ALLOWED_STATEMENT_KEYWORDS = new Set([\n  \"delete\",\n  \"insert\",\n  \"select\",\n  \"update\",\n  \"values\",\n  \"with\",\n]);\n\nexport interface SqlLintValidatedStatement {\n  from: number;\n  statement: string;\n  to: number;\n}\n\nexport type SqlLintValidationResult =\n  | { ok: true; statements: SqlLintValidatedStatement[] }\n  | { diagnostic: AdapterSqlLintDiagnostic; ok: false };\n\nexport function validateSqlForLint(sql: string): SqlLintValidationResult {\n  const normalizedSql = sql.trim();\n\n  if (normalizedSql.length === 0) {\n    return {\n      diagnostic: {\n        from: 0,\n        message: \"Type a SQL statement to lint.\",\n        severity: \"info\",\n        to: 0,\n      },\n      ok: false,\n    };\n  }\n\n  if (normalizedSql.length > SQL_LINT_MAX_LENGTH) {\n    return {\n      diagnostic: {\n        from: 0,\n        message: `SQL lint limit exceeded (${SQL_LINT_MAX_LENGTH} characters).`,\n        severity: \"error\",\n        to: Math.min(1, normalizedSql.length),\n      },\n      ok: false,\n    };\n  }\n\n  const statements = splitTopLevelSqlStatements(sql);\n\n  if (statements.length === 0) {\n    return {\n      diagnostic: {\n        from: 0,\n        message: \"Type a SQL statement to lint.\",\n        severity: \"info\",\n        to: 0,\n      },\n      ok: false,\n    };\n  }\n\n  for (const statement of statements) {\n    const firstKeyword = getStatementFirstKeyword(statement.statement);\n\n    if (\n      !firstKeyword ||\n      !SQL_LINT_ALLOWED_STATEMENT_KEYWORDS.has(firstKeyword)\n    ) {\n      return {\n        diagnostic: {\n          from: statement.from,\n          message:\n            \"SQL lint supports SELECT, WITH, VALUES, INSERT, UPDATE, and DELETE statements.\",\n          severity: \"error\",\n          to: Math.min(sql.length, statement.from + 1),\n        },\n        ok: false,\n      };\n    }\n  }\n\n  return { ok: true, statements };\n}\n\nexport function createLintDiagnosticsFromPostgresError(args: {\n  error: unknown;\n  positionOffset?: number;\n  sql: string;\n}): AdapterSqlLintDiagnostic[] {\n  const { error, sql } = args;\n  const positionOffset = Math.max(0, args.positionOffset ?? 0);\n  const fallbackRange = getDiagnosticRange({\n    sql,\n    position: undefined,\n    sqlLength: sql.length,\n  });\n\n  if (!(error instanceof Error)) {\n    return [\n      {\n        from: fallbackRange.from,\n        message: \"SQL lint failed.\",\n        severity: \"error\",\n        source: \"postgres\",\n        to: fallbackRange.to,\n      },\n    ];\n  }\n\n  const code = getPostgresErrorCode(error);\n  const severity = getPostgresErrorSeverity(error);\n  const { from, to } = getDiagnosticRange({\n    message: error.message,\n    position: getPostgresErrorPosition(error),\n    sql,\n    sqlLength: sql.length,\n  });\n\n  const message =\n    code === \"57014\"\n      ? \"Lint query timed out. Simplify the statement and try again.\"\n      : error.message;\n\n  return [\n    {\n      code,\n      from: from + positionOffset,\n      message,\n      severity,\n      source: \"postgres\",\n      to: to + positionOffset,\n    },\n  ];\n}\n\nfunction getStatementFirstKeyword(statement: string): string | null {\n  const match = /^\\s*([A-Za-z_]+)/.exec(statement);\n  return match?.[1]?.toLowerCase() ?? null;\n}\n\nfunction getPostgresErrorCode(error: Error): string | undefined {\n  const withCode = error as Error & { code?: unknown };\n  return typeof withCode.code === \"string\" ? withCode.code : undefined;\n}\n\nfunction getPostgresErrorPosition(error: Error): number | undefined {\n  const withPosition = error as Error & { position?: unknown };\n  const { position } = withPosition;\n\n  if (typeof position === \"number\" && Number.isFinite(position)) {\n    return position;\n  }\n\n  if (typeof position === \"string\") {\n    const parsed = Number.parseInt(position, 10);\n    return Number.isFinite(parsed) ? parsed : undefined;\n  }\n\n  return undefined;\n}\n\nfunction getPostgresErrorSeverity(\n  error: Error,\n): AdapterSqlLintDiagnostic[\"severity\"] {\n  const withSeverity = error as Error & { severity?: unknown };\n  return withSeverity.severity === \"WARNING\" ? \"warning\" : \"error\";\n}\n\nfunction getDiagnosticRange(args: {\n  message?: string;\n  position: number | undefined;\n  sql: string;\n  sqlLength: number;\n}): { from: number; to: number } {\n  const { message, position, sql, sqlLength } = args;\n\n  if (position == null && message) {\n    const inferredRange = inferRangeFromMessage(sql, message);\n\n    if (inferredRange) {\n      return inferredRange;\n    }\n  }\n\n  const maxFrom = Math.max(sqlLength - 1, 0);\n  const from = Math.min(\n    maxFrom,\n    Math.max(0, (Number.isFinite(position) ? (position as number) : 1) - 1),\n  );\n\n  if (sqlLength === 0) {\n    return { from: 0, to: 0 };\n  }\n\n  return { from, to: Math.max(from + 1, from) };\n}\n\nfunction inferRangeFromMessage(\n  sql: string,\n  message: string,\n): { from: number; to: number } | null {\n  const quotedTokenMatch = /\"([^\"]+)\"/.exec(message);\n  const token = quotedTokenMatch?.[1];\n\n  if (!token) {\n    return null;\n  }\n\n  const lowerSql = sql.toLowerCase();\n  const lowerToken = token.toLowerCase();\n  const from = lowerSql.indexOf(lowerToken);\n\n  if (from < 0) {\n    return null;\n  }\n\n  return {\n    from,\n    to: Math.min(sql.length, from + token.length),\n  };\n}\n"],
  "mappings": "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",
  "names": ["BYTES_PER_KILOBYTE", "SQL_LINT_MAX_LENGTH", "SQL_LINT_ALLOWED_STATEMENT_KEYWORDS", "validateSqlForLint", "sql", "normalizedSql", "statements", "splitTopLevelSqlStatements", "statement", "firstKeyword", "getStatementFirstKeyword", "createLintDiagnosticsFromPostgresError", "args", "error", "positionOffset", "fallbackRange", "getDiagnosticRange", "code", "getPostgresErrorCode", "severity", "getPostgresErrorSeverity", "from", "to", "getPostgresErrorPosition", "message", "withCode", "withPosition", "position", "parsed", "sqlLength", "inferredRange", "inferRangeFromMessage", "maxFrom", "token", "lowerSql", "lowerToken"]
}
