GitHub
Tests: 12 • Commercial: 2 • Pet projects: 4 • Legacy: 4
Total: 22

.NET Framework

Test
2021

Project Request

ASP.NET MVC • C# • SQL Server
Idea of the project: if someone wants to order a project development, here you can send an application.
Test
2020

ProjectC

ASP.NET MVC • C# • JSON • jQuery
JSON data processing.
Test
2020

Vehicle Maintenance

ASP.NET MVC • VB.NET • JSON
Idea of the project: if someone wants to order a project development, here you can send an application.
Test
2019

Movie Navigator

ASP.NET MVC • VB.NET
Request information about movie from IMDB.
Test
2018

Customers Exchange

ASP.NET MVC • C# • SQL Server
Automated teller machine emulation.
Test
2016

ATM

ASP.NET MVC • C#
Automated teller machine emulation.

.NET Core

Pet project
2022

Mail Daemon

.NET 9 • Console • JSON
Utility to send mails with customizable settings.

Custom

Code
2024

Buns of code

.NET Framework • C# • JavaScript
Code snippets from my projects, ready to use; tiny tests; code examples.

PHP

Test
2024

Mediabox

PHP 8 • Laravel 11 • Vue.js • Composer • SQLite
Test project for media files management.
Test
2020

Loan Castle

PHP • MariaDB
Jums jāizstrādā kāda lielāk projekta prototips. Izstrādājot prototipu, paturiet prātā, ka projektam attīstoties, šo prototipu varētu vajadzēt pilnveidot.
Test
2020

Content Management

PHP • MySQL • AJAX
Создать простой сайт, где будет страница с формой для авторизации и страница для авторизованного пользователя.
Test
2019

Laravel

PHP • Laravel • Vue.js • Composer • SQLite
Izveidot aplikāciju, kura ik pēc noteikta intervāla (60 sekundes) veic ierakstu datubāzē izmantojot Laravel freimworka iebūvēto funkcionalitāti.
Test
2019

Phone Check

PHP • JavaScript • JSON • Docker
Implement application to detect country by phone number.

Frontend

Test
2021

Forex Wall

npm • React
For this exercise, what we need is a simple live wall for tracking currencies.

Business projects

Commercial
2008

Certification Center

.NET Framework 4.8 • ASP.NET Web Forms • C# • LINQ • SQL Server • ADO.NET • Dapper • JavaScript • jQuery • Git
Transport registration and certification services in Latvia, Customer Relationship Management.
Commercial
2000

Amerikas Auto

.NET Framework 4.8 • ASP.NET Web Forms • C# • LINQ • SQL Server • ADO.NET • Entity Framework • JavaScript • jQuery • Git
Car service and spare parts for all USA and European car models, Customer Relationship Management.

Pet projects

Pet project
2023

Geolocation Assistant

.NET 8 • ASP.NET Core • C# • Web API • JSON • Git
Website for determining geolocation by IP or geotagged photo.
Pet project
2008

Web Dynamics

.NET Framework 4.8 • ASP.NET Web Forms • C# • LINQ • Web API • JSON • SQL Server • Dapper • JavaScript • jQuery • SVG • Git
Software development blog. Articles, books, videos, content management.
Pet project
2000

Blackball

.NET Framework 4.8 • ASP.NET Web Forms • C# • LINQ • Web API • JSON • XML • SQL Server • Dapper • JavaScript • jQuery • SVG • Git
My entertainment portal created from scratch.

Good old times

Legacy
2000

DOS Clock

Turbo Pascal • Assembler
Digital clock.
Legacy
2000

BrainOut

Turbo Pascal • Assembler
Tank battle game.
Legacy
1999

Airport Administrator

Turbo Pascal
Курсовая работа в институте.
Legacy
1998

Atomizer

Turbo Pascal • Assembler
Atomizer, aka «Studio2D». Graphic raster editor. AGI is my own «Atomizer Generated Image» file format.

Mediabox

2024 Test

Test project for media files management.

PHP 8 Laravel 11 Vue.js Composer SQLite
Information
Source code
  app
  Http
  .bin
  vite
  lib
  dist
  esm
  node
  lib
  core
  env
  node
  lib
  lib
  lib
  lib
  dist
  lib
  lib
  dist
  es
  lib
  vite
  dist
  node
  dist
  css
  js
  app
  data
  logs
  Unit
  math
  src
  src
  src
  docs
  en
  lib
  src
  src
  Cron
  src
  src
  Core
  ORM
  Spot
  filp
  src
  css
  js
  Util
  src
  src
  src
  src
  psr7
  src
  src
  Core
  Text
  Type
  Xml
  Core
  Text
  Type
  Xml
  src
  Auth
  make
  Bus
  View
  Auth
  Bus
  Http
  Mail
  View
  Auth
  Bus
  Http
  dist
  Http
  Json
  Log
  Mail
  html
  text
  Jobs
  lang
  en
  View
  pint
  pint
  src
  sail
  8.0
  8.1
  8.2
  8.3
  src
  src
  src
  src
  Node
  Util
  Node
  Node
  Node
  Data
  Node
  Node
  Util
  Xml
  src
  src
  src
  docs
  Pass
  src
  Curl
  Test
  src
  Date
  Spl
  lazy
  src
  Cli
  Lang
  List
  src
  src
  lib
  Node
  Expr
  Cast
  Name
  Stmt
  src
  src
  Html
  src
  xml
  src
  src
  src
  Data
  Node
  Html
  css
  js
  Xml
  Util
  src
  src
  src
  src
  src
  Test
  Test
  Math
  Type
  Api
  Rule
  Stub
  Api
  PHPT
  Cli
  Xml
  Util
  PHP
  Xml
  psr
  src
  src
  src
  src
  src
  docs
  src
  log
  src
  src
  psy
  src
  Hoa
  77
  78
  Sudo
  Util
  src
  src
  Map
  Tool
  uuid
  src
  Time
  Guid
  Lazy
  Math
  Dce
  Node
  Time
  Type
  src
  src
  src
  src
  src
  diff
  src
  src
  src
  src
  src
  src
  src
  src
  type
  src
  type
  src
  Test
  CI
  Node
  css
  js
  File
  Test
  Log
  Test
  Smtp
  Auth
  mime
  Part
  Test
  Test
  data
  data
  Test
  Util
  Test
  uid
  css
  js
  Test
  yaml
  Tag
  src
  src
  Css
  Rule
  src
  File
  Util
  voku
  src
  voku
  data
  src
  .env
Root / node_modules / rollup / dist / es / shared / parseAst.js
/* @license     Rollup.js v4.21.0     Sun, 18 Aug 2024 05:55:06 GMT - commit c4bb050938778bcbe7b3b3ea3419f7fa70d60f5b     https://github.com/rollup/rollup     Released under the MIT License. */ import { parse, parseAsync } from '../../native.js'; import { resolve, basename, extname, dirname } from 'node:path'; // This file is generated by scripts/generate-node-types.js. // Do not edit this file directly. const ArrowFunctionExpression = 'ArrowFunctionExpression'; const BlockStatement = 'BlockStatement'; const CallExpression = 'CallExpression'; const CatchClause = 'CatchClause'; const ExportDefaultDeclaration = 'ExportDefaultDeclaration'; const ExpressionStatement = 'ExpressionStatement'; const Identifier = 'Identifier'; const Literal = 'Literal'; const PanicError = 'PanicError'; const ParseError = 'ParseError'; const Program = 'Program'; const Property = 'Property'; const ReturnStatement = 'ReturnStatement'; const StaticBlock = 'StaticBlock'; const TemplateLiteral = 'TemplateLiteral'; const VariableDeclarator = 'VariableDeclarator'; const BLANK = Object.freeze(Object.create(null)); const EMPTY_OBJECT = Object.freeze({}); const EMPTY_ARRAY = Object.freeze([]); const EMPTY_SET = Object.freeze(new (class extends Set { add() { throw new Error('Cannot add to empty set'); } })()); // This file is generated by scripts/generate-string-constants.js. // Do not edit this file directly. const FIXED_STRINGS = [ 'var', 'let', 'const', 'init', 'get', 'set', 'constructor', 'method', '-', '+', '!', '~', 'typeof', 'void', 'delete', '++', '--', '==', '!=', '===', '!==', '<', '<=', '>', '>=', '<<', '>>', '>>>', '+', '-', '*', '/', '%', '|', '^', '&', '||', '&&', 'in', 'instanceof', '**', '??', '=', '+=', '-=', '*=', '/=', '%=', '<<=', '>>=', '>>>=', '|=', '^=', '&=', '**=', '&&=', '||=', '??=', 'pure', 'noSideEffects', 'sourcemap', 'using', 'await using' ]; const ANNOTATION_KEY = '_rollupAnnotations'; const INVALID_ANNOTATION_KEY = '_rollupRemoved'; const convertAnnotations = (position, buffer) => { if (position === 0) return EMPTY_ARRAY; const length = buffer[position++]; const list = []; for (let index = 0; index < length; index++) { list.push(convertAnnotation(buffer[position++], buffer)); } return list; }; const convertAnnotation = (position, buffer) => { const start = buffer[position++]; const end = buffer[position++]; const type = FIXED_STRINGS[buffer[position]]; return { end, start, type }; }; /** @typedef {import('./types').Location} Location */ /** * @param {import('./types').Range} range * @param {number} index */ function rangeContains(range, index) {     return range.start <= index && index < range.end; } /** * @param {string} source * @param {import('./types').Options} [options] */ function getLocator(source, options = {}) {     const { offsetLine = 0, offsetColumn = 0 } = options;     let start = 0;     const ranges = source.split('\n').map((line, i) => {         const end = start + line.length + 1;         /** @type {import('./types').Range} */         const range = { start, end, line: i };         start = end;         return range;     });     let i = 0;     /**      * @param {string | number} search      * @param {number} [index]      * @returns {Location | undefined}      */     function locator(search, index) {         if (typeof search === 'string') {             search = source.indexOf(search, index ?? 0);         }         if (search === -1) return undefined;         let range = ranges[i];         const d = search >= range.end ? 1 : -1;         while (range) {             if (rangeContains(range, search)) {                 return {                     line: offsetLine + range.line,                     column: offsetColumn + search - range.start,                     character: search                 };             }             i += d;             range = ranges[i];         }     }     return locator; } /** * @param {string} source * @param {string | number} search * @param {import('./types').Options} [options] * @returns {Location | undefined} */ function locate(source, search, options) {     return getLocator(source, options)(search, options && options.startIndex); } function spaces(index) { let result = ''; while (index--) result += ' '; return result; } function tabsToSpaces(value) { return value.replace(/^\t+/, match => match.split('\t').join(' ')); } const LINE_TRUNCATE_LENGTH = 120; const MIN_CHARACTERS_SHOWN_AFTER_LOCATION = 10; const ELLIPSIS = '...'; function getCodeFrame(source, line, column) { let lines = source.split('\n'); // Needed if a plugin did not generate correct sourcemaps if (line > lines.length) return ''; const maxLineLength = Math.max(tabsToSpaces(lines[line - 1].slice(0, column)).length + MIN_CHARACTERS_SHOWN_AFTER_LOCATION + ELLIPSIS.length, LINE_TRUNCATE_LENGTH); const frameStart = Math.max(0, line - 3); let frameEnd = Math.min(line + 2, lines.length); lines = lines.slice(frameStart, frameEnd); while (!/\S/.test(lines[lines.length - 1])) { lines.pop(); frameEnd -= 1; } const digits = String(frameEnd).length; return lines .map((sourceLine, index) => { const isErrorLine = frameStart + index + 1 === line; let lineNumber = String(index + frameStart + 1); while (lineNumber.length < digits) lineNumber = ` ${lineNumber}`; let displayedLine = tabsToSpaces(sourceLine); if (displayedLine.length > maxLineLength) { displayedLine = `${displayedLine.slice(0, maxLineLength - ELLIPSIS.length)}${ELLIPSIS}`; } if (isErrorLine) { const indicator = spaces(digits + 2 + tabsToSpaces(sourceLine.slice(0, column)).length) + '^'; return `${lineNumber}: ${displayedLine}\n${indicator}`; } return `${lineNumber}: ${displayedLine}`; }) .join('\n'); } const LOGLEVEL_SILENT = 'silent'; const LOGLEVEL_ERROR = 'error'; const LOGLEVEL_WARN = 'warn'; const LOGLEVEL_INFO = 'info'; const LOGLEVEL_DEBUG = 'debug'; const logLevelPriority = { [LOGLEVEL_DEBUG]: 0, [LOGLEVEL_INFO]: 1, [LOGLEVEL_SILENT]: 3, [LOGLEVEL_WARN]: 2 }; const ABSOLUTE_PATH_REGEX = /^(?:\/|(?:[A-Za-z]:)?[/\\|])/; const RELATIVE_PATH_REGEX = /^\.?\.(\/|$)/; function isAbsolute(path) { return ABSOLUTE_PATH_REGEX.test(path); } function isRelative(path) { return RELATIVE_PATH_REGEX.test(path); } const BACKSLASH_REGEX = /\\/g; function normalize(path) { return path.replace(BACKSLASH_REGEX, '/'); } function printQuotedStringList(list, verbs) { const isSingleItem = list.length <= 1; const quotedList = list.map(item => `"${item}"`); let output = isSingleItem ? quotedList[0] : `${quotedList.slice(0, -1).join(', ')} and ${quotedList.slice(-1)[0]}`; if (verbs) { output += ` ${isSingleItem ? verbs[0] : verbs[1]}`; } return output; } const ANY_SLASH_REGEX = /[/\\]/; function relative(from, to) { const fromParts = from.split(ANY_SLASH_REGEX).filter(Boolean); const toParts = to.split(ANY_SLASH_REGEX).filter(Boolean); if (fromParts[0] === '.') fromParts.shift(); if (toParts[0] === '.') toParts.shift(); while (fromParts[0] && toParts[0] && fromParts[0] === toParts[0]) { fromParts.shift(); toParts.shift(); } while (toParts[0] === '..' && fromParts.length > 0) { toParts.shift(); fromParts.pop(); } while (fromParts.pop()) { toParts.unshift('..'); } return toParts.join('/'); } function getAliasName(id) { const base = basename(id); return base.slice(0, Math.max(0, base.length - extname(id).length)); } function relativeId(id) { if (!isAbsolute(id)) return id; return relative(resolve(), id); } function isPathFragment(name) { // starting with "/", "./", "../", "C:/" return (name[0] === '/' || (name[0] === '.' && (name[1] === '/' || name[1] === '.')) || isAbsolute(name)); } const UPPER_DIR_REGEX = /^(\.\.\/)*\.\.$/; function getImportPath(importerId, targetPath, stripJsExtension, ensureFileName) { while (targetPath.startsWith('../')) { targetPath = targetPath.slice(3); importerId = '_/' + importerId; } let relativePath = normalize(relative(dirname(importerId), targetPath)); if (stripJsExtension && relativePath.endsWith('.js')) { relativePath = relativePath.slice(0, -3); } if (ensureFileName) { if (relativePath === '') return '../' + basename(targetPath); if (UPPER_DIR_REGEX.test(relativePath)) { return [...relativePath.split('/'), '..', basename(targetPath)].join('/'); } } return relativePath ? (relativePath.startsWith('..') ? relativePath : './' + relativePath) : '.'; } function isValidUrl(url) { try { new URL(url); } catch { return false; } return true; } function getRollupUrl(snippet) { return `https://rollupjs.org/${snippet}`; } function addTrailingSlashIfMissed(url) { if (!url.endsWith('/')) { return url + '/'; } return url; } // troubleshooting const URL_AVOIDING_EVAL = 'troubleshooting/#avoiding-eval'; const URL_NAME_IS_NOT_EXPORTED = 'troubleshooting/#error-name-is-not-exported-by-module'; const URL_THIS_IS_UNDEFINED = 'troubleshooting/#error-this-is-undefined'; const URL_TREATING_MODULE_AS_EXTERNAL_DEPENDENCY = 'troubleshooting/#warning-treating-module-as-external-dependency'; const URL_SOURCEMAP_IS_LIKELY_TO_BE_INCORRECT = 'troubleshooting/#warning-sourcemap-is-likely-to-be-incorrect'; const URL_OUTPUT_AMD_ID = 'configuration-options/#output-amd-id'; const URL_OUTPUT_AMD_BASEPATH = 'configuration-options/#output-amd-basepath'; const URL_OUTPUT_DIR = 'configuration-options/#output-dir'; const URL_OUTPUT_EXPORTS = 'configuration-options/#output-exports'; const URL_OUTPUT_EXTEND = 'configuration-options/#output-extend'; const URL_OUTPUT_EXTERNALIMPORTATTRIBUTES = 'configuration-options/#output-externalimportattributes'; const URL_OUTPUT_FORMAT = 'configuration-options/#output-format'; const URL_OUTPUT_GENERATEDCODE = 'configuration-options/#output-generatedcode'; const URL_OUTPUT_GLOBALS = 'configuration-options/#output-globals'; const URL_OUTPUT_INLINEDYNAMICIMPORTS = 'configuration-options/#output-inlinedynamicimports'; const URL_OUTPUT_INTEROP = 'configuration-options/#output-interop'; const URL_OUTPUT_MANUALCHUNKS = 'configuration-options/#output-manualchunks'; const URL_OUTPUT_NAME = 'configuration-options/#output-name'; const URL_OUTPUT_SOURCEMAPBASEURL = 'configuration-options/#output-sourcemapbaseurl'; const URL_OUTPUT_SOURCEMAPFILE = 'configuration-options/#output-sourcemapfile'; const URL_PRESERVEENTRYSIGNATURES = 'configuration-options/#preserveentrysignatures'; const URL_TREESHAKE = 'configuration-options/#treeshake'; const URL_TREESHAKE_PURE = 'configuration-options/#pure'; const URL_TREESHAKE_NOSIDEEFFECTS = 'configuration-options/#no-side-effects'; const URL_TREESHAKE_MODULESIDEEFFECTS = 'configuration-options/#treeshake-modulesideeffects'; const URL_WATCH = 'configuration-options/#watch'; function error(base) { throw base instanceof Error ? base : getRollupError(base); } function getRollupError(base) { augmentLogMessage(base); const errorInstance = Object.assign(new Error(base.message), base); Object.defineProperty(errorInstance, 'name', { value: 'RollupError', writable: true }); return errorInstance; } function augmentCodeLocation(properties, pos, source, id) { if (typeof pos === 'object') { const { line, column } = pos; properties.loc = { column, file: id, line }; } else { properties.pos = pos; const location = locate(source, pos, { offsetLine: 1 }); if (!location) { return; } const { line, column } = location; properties.loc = { column, file: id, line }; } if (properties.frame === undefined) { const { line, column } = properties.loc; properties.frame = getCodeFrame(source, line, column); } } const symbolAugmented = Symbol('augmented'); function augmentLogMessage(log) { // Make sure to only augment the log message once if (!(log.plugin || log.loc) || log[symbolAugmented]) { return; } log[symbolAugmented] = true; let prefix = ''; if (log.plugin) { prefix += `[plugin ${log.plugin}] `; } const id = log.id || log.loc?.file; if (id) { const position = log.loc ? ` (${log.loc.line}:${log.loc.column})` : ''; prefix += `${relativeId(id)}${position}: `; } log.message = prefix + log.message; } // Error codes should be sorted alphabetically while errors should be sorted by // error code below const ADDON_ERROR = 'ADDON_ERROR', ALREADY_CLOSED = 'ALREADY_CLOSED', AMBIGUOUS_EXTERNAL_NAMESPACES = 'AMBIGUOUS_EXTERNAL_NAMESPACES', ANONYMOUS_PLUGIN_CACHE = 'ANONYMOUS_PLUGIN_CACHE', ASSET_NOT_FINALISED = 'ASSET_NOT_FINALISED', ASSET_NOT_FOUND = 'ASSET_NOT_FOUND', ASSET_SOURCE_ALREADY_SET = 'ASSET_SOURCE_ALREADY_SET', ASSET_SOURCE_MISSING = 'ASSET_SOURCE_MISSING', BAD_LOADER = 'BAD_LOADER', CANNOT_CALL_NAMESPACE = 'CANNOT_CALL_NAMESPACE', CANNOT_EMIT_FROM_OPTIONS_HOOK = 'CANNOT_EMIT_FROM_OPTIONS_HOOK', CHUNK_NOT_GENERATED = 'CHUNK_NOT_GENERATED', CHUNK_INVALID = 'CHUNK_INVALID', CIRCULAR_DEPENDENCY = 'CIRCULAR_DEPENDENCY', CIRCULAR_REEXPORT = 'CIRCULAR_REEXPORT', CONST_REASSIGN = 'CONST_REASSIGN', CYCLIC_CROSS_CHUNK_REEXPORT = 'CYCLIC_CROSS_CHUNK_REEXPORT', DEPRECATED_FEATURE = 'DEPRECATED_FEATURE', DUPLICATE_ARGUMENT_NAME = 'DUPLICATE_ARGUMENT_NAME', DUPLICATE_EXPORT = 'DUPLICATE_EXPORT', DUPLICATE_PLUGIN_NAME = 'DUPLICATE_PLUGIN_NAME', EMPTY_BUNDLE = 'EMPTY_BUNDLE', EVAL = 'EVAL', EXTERNAL_MODULES_CANNOT_BE_INCLUDED_IN_MANUAL_CHUNKS = 'EXTERNAL_MODULES_CANNOT_BE_INCLUDED_IN_MANUAL_CHUNKS', EXTERNAL_MODULES_CANNOT_BE_TRANSFORMED_TO_MODULES = 'EXTERNAL_MODULES_CANNOT_BE_TRANSFORMED_TO_MODULES', EXTERNAL_SYNTHETIC_EXPORTS = 'EXTERNAL_SYNTHETIC_EXPORTS', FILE_NAME_CONFLICT = 'FILE_NAME_CONFLICT', FILE_NOT_FOUND = 'FILE_NOT_FOUND', FIRST_SIDE_EFFECT = 'FIRST_SIDE_EFFECT', ILLEGAL_IDENTIFIER_AS_NAME = 'ILLEGAL_IDENTIFIER_AS_NAME', ILLEGAL_REASSIGNMENT = 'ILLEGAL_REASSIGNMENT', INCONSISTENT_IMPORT_ATTRIBUTES = 'INCONSISTENT_IMPORT_ATTRIBUTES', INVALID_ANNOTATION = 'INVALID_ANNOTATION', INPUT_HOOK_IN_OUTPUT_PLUGIN = 'INPUT_HOOK_IN_OUTPUT_PLUGIN', INVALID_CHUNK = 'INVALID_CHUNK', INVALID_EXPORT_OPTION = 'INVALID_EXPORT_OPTION', INVALID_EXTERNAL_ID = 'INVALID_EXTERNAL_ID', INVALID_IMPORT_ATTRIBUTE = 'INVALID_IMPORT_ATTRIBUTE', INVALID_LOG_POSITION = 'INVALID_LOG_POSITION', INVALID_OPTION = 'INVALID_OPTION', INVALID_PLUGIN_HOOK = 'INVALID_PLUGIN_HOOK', INVALID_ROLLUP_PHASE = 'INVALID_ROLLUP_PHASE', INVALID_SETASSETSOURCE = 'INVALID_SETASSETSOURCE', INVALID_TLA_FORMAT = 'INVALID_TLA_FORMAT', MISSING_EXPORT = 'MISSING_EXPORT', MISSING_GLOBAL_NAME = 'MISSING_GLOBAL_NAME', MISSING_IMPLICIT_DEPENDANT = 'MISSING_IMPLICIT_DEPENDANT', MISSING_NAME_OPTION_FOR_IIFE_EXPORT = 'MISSING_NAME_OPTION_FOR_IIFE_EXPORT', MISSING_NODE_BUILTINS = 'MISSING_NODE_BUILTINS', MISSING_OPTION = 'MISSING_OPTION', MIXED_EXPORTS = 'MIXED_EXPORTS', MODULE_LEVEL_DIRECTIVE = 'MODULE_LEVEL_DIRECTIVE', NAMESPACE_CONFLICT = 'NAMESPACE_CONFLICT', NO_TRANSFORM_MAP_OR_AST_WITHOUT_CODE = 'NO_TRANSFORM_MAP_OR_AST_WITHOUT_CODE', OPTIMIZE_CHUNK_STATUS = 'OPTIMIZE_CHUNK_STATUS', PARSE_ERROR = 'PARSE_ERROR', PLUGIN_ERROR = 'PLUGIN_ERROR', REDECLARATION_ERROR = 'REDECLARATION_ERROR', SHIMMED_EXPORT = 'SHIMMED_EXPORT', SOURCEMAP_BROKEN = 'SOURCEMAP_BROKEN', SOURCEMAP_ERROR = 'SOURCEMAP_ERROR', SYNTHETIC_NAMED_EXPORTS_NEED_NAMESPACE_EXPORT = 'SYNTHETIC_NAMED_EXPORTS_NEED_NAMESPACE_EXPORT', THIS_IS_UNDEFINED = 'THIS_IS_UNDEFINED', UNEXPECTED_NAMED_IMPORT = 'UNEXPECTED_NAMED_IMPORT', UNKNOWN_OPTION = 'UNKNOWN_OPTION', UNRESOLVED_ENTRY = 'UNRESOLVED_ENTRY', UNRESOLVED_IMPORT = 'UNRESOLVED_IMPORT', UNUSED_EXTERNAL_IMPORT = 'UNUSED_EXTERNAL_IMPORT', VALIDATION_ERROR = 'VALIDATION_ERROR'; function logAddonNotGenerated(message, hook, plugin) { return { code: ADDON_ERROR, message: `Could not retrieve "${hook}". Check configuration of plugin "${plugin}". \tError Message: ${message}` }; } function logAlreadyClosed() { return { code: ALREADY_CLOSED, message: 'Bundle is already closed, no more calls to "generate" or "write" are allowed.' }; } function logAmbiguousExternalNamespaces(binding, reexportingModule, usedModule, sources) { return { binding, code: AMBIGUOUS_EXTERNAL_NAMESPACES, ids: sources, message: `Ambiguous external namespace resolution: "${relativeId(reexportingModule)}" re-exports "${binding}" from one of the external modules ${printQuotedStringList(sources.map(module => relativeId(module)))}, guessing "${relativeId(usedModule)}".`, reexporter: reexportingModule }; } function logAnonymousPluginCache() { return { code: ANONYMOUS_PLUGIN_CACHE, message: 'A plugin is trying to use the Rollup cache but is not declaring a plugin name or cacheKey.' }; } function logAssetNotFinalisedForFileName(name) { return { code: ASSET_NOT_FINALISED, message: `Plugin error - Unable to get file name for asset "${name}". Ensure that the source is set and that generate is called first. If you reference assets via import.meta.ROLLUP_FILE_URL_<referenceId>, you need to either have set their source after "renderStart" or need to provide an explicit "fileName" when emitting them.` }; } function logAssetReferenceIdNotFoundForSetSource(assetReferenceId) { return { code: ASSET_NOT_FOUND, message: `Plugin error - Unable to set the source for unknown asset "${assetReferenceId}".` }; } function logAssetSourceAlreadySet(name) { return { code: ASSET_SOURCE_ALREADY_SET, message: `Unable to set the source for asset "${name}", source already set.` }; } function logNoAssetSourceSet(assetName) { return { code: ASSET_SOURCE_MISSING, message: `Plugin error creating asset "${assetName}" - no asset source set.` }; } function logBadLoader(id) { return { code: BAD_LOADER, message: `Error loading "${relativeId(id)}": plugin load hook should return a string, a { code, map } object, or nothing/null.` }; } function logCannotCallNamespace(name) { return { code: CANNOT_CALL_NAMESPACE, message: `Cannot call a namespace ("${name}").` }; } function logCannotEmitFromOptionsHook() { return { code: CANNOT_EMIT_FROM_OPTIONS_HOOK, message: `Cannot emit files or set asset sources in the "outputOptions" hook, use the "renderStart" hook instead.` }; } function logChunkNotGeneratedForFileName(name) { return { code: CHUNK_NOT_GENERATED, message: `Plugin error - Unable to get file name for emitted chunk "${name}". You can only get file names once chunks have been generated after the "renderStart" hook.` }; } function logChunkInvalid({ fileName, code }, { pos, message }) { const errorProperties = { code: CHUNK_INVALID, message: `Chunk "${fileName}" is not valid JavaScript: ${message}.` }; augmentCodeLocation(errorProperties, pos, code, fileName); return errorProperties; } function logCircularDependency(cyclePath) { return { code: CIRCULAR_DEPENDENCY, ids: cyclePath, message: `Circular dependency: ${cyclePath.map(relativeId).join(' -> ')}` }; } function logCircularReexport(exportName, exporter) { return { code: CIRCULAR_REEXPORT, exporter, message: `"${exportName}" cannot be exported from "${relativeId(exporter)}" as it is a reexport that references itself.` }; } function logCyclicCrossChunkReexport(exportName, exporter, reexporter, importer, preserveModules) { return { code: CYCLIC_CROSS_CHUNK_REEXPORT, exporter, id: importer, message: `Export "${exportName}" of module "${relativeId(exporter)}" was reexported through module "${relativeId(reexporter)}" while both modules are dependencies of each other and will end up in different chunks by current Rollup settings. This scenario is not well supported at the moment as it will produce a circular dependency between chunks and will likely lead to broken execution order.\nEither change the import in "${relativeId(importer)}" to point directly to the exporting module or ${preserveModules ? 'do not use "output.preserveModules"' : 'reconfigure "output.manualChunks"'} to ensure these modules end up in the same chunk.`, reexporter }; } function logDeprecation(deprecation, urlSnippet, plugin) { return { code: DEPRECATED_FEATURE, message: deprecation, url: getRollupUrl(urlSnippet), ...({}) }; } function logConstVariableReassignError() { return { code: CONST_REASSIGN, message: 'Cannot reassign a variable declared with `const`' }; } function logDuplicateArgumentNameError(name) { return { code: DUPLICATE_ARGUMENT_NAME, message: `Duplicate argument name "${name}"` }; } function logDuplicateExportError(name) { return { code: DUPLICATE_EXPORT, message: `Duplicate export "${name}"` }; } function logDuplicatePluginName(plugin) { return { code: DUPLICATE_PLUGIN_NAME, message: `The plugin name ${plugin} is being used twice in the same build. Plugin names must be distinct or provide a cacheKey (please post an issue to the plugin if you are a plugin user).` }; } function logEmptyChunk(chunkName) { return { code: EMPTY_BUNDLE, message: `Generated an empty chunk: "${chunkName}".`, names: [chunkName] }; } function logEval(id) { return { code: EVAL, id, message: `Use of eval in "${relativeId(id)}" is strongly discouraged as it poses security risks and may cause issues with minification.`, url: getRollupUrl(URL_AVOIDING_EVAL) }; } function logExternalSyntheticExports(id, importer) { return { code: EXTERNAL_SYNTHETIC_EXPORTS, exporter: id, message: `External "${id}" cannot have "syntheticNamedExports" enabled (imported by "${relativeId(importer)}").` }; } function logFileNameConflict(fileName) { return { code: FILE_NAME_CONFLICT, message: `The emitted file "${fileName}" overwrites a previously emitted file of the same name.` }; } function logFileReferenceIdNotFoundForFilename(assetReferenceId) { return { code: FILE_NOT_FOUND, message: `Plugin error - Unable to get file name for unknown file "${assetReferenceId}".` }; } function logFirstSideEffect(source, id, { line, column }) { return { code: FIRST_SIDE_EFFECT, message: `First side effect in ${relativeId(id)} is at (${line}:${column})\n${getCodeFrame(source, line, column)}` }; } function logIllegalIdentifierAsName(name) { return { code: ILLEGAL_IDENTIFIER_AS_NAME, message: `Given name "${name}" is not a legal JS identifier. If you need this, you can try "output.extend: true".`, url: getRollupUrl(URL_OUTPUT_EXTEND) }; } function logIllegalImportReassignment(name, importingId) { return { code: ILLEGAL_REASSIGNMENT, message: `Illegal reassignment of import "${name}" in "${relativeId(importingId)}".` }; } function logInconsistentImportAttributes(existingAttributes, newAttributes, source, importer) { return { code: INCONSISTENT_IMPORT_ATTRIBUTES, message: `Module "${relativeId(importer)}" tried to import "${relativeId(source)}" with ${formatAttributes(newAttributes)} attributes, but it was already imported elsewhere with ${formatAttributes(existingAttributes)} attributes. Please ensure that import attributes for the same module are always consistent.` }; } const formatAttributes = (attributes) => { const entries = Object.entries(attributes); if (entries.length === 0) return 'no'; return entries.map(([key, value]) => `"${key}": "${value}"`).join(', '); }; function logInvalidAnnotation(comment, id, type) { return { code: INVALID_ANNOTATION, id, message: `A comment\n\n"${comment}"\n\nin "${relativeId(id)}" contains an annotation that Rollup cannot interpret due to the position of the comment. The comment will be removed to avoid issues.`, url: getRollupUrl(type === 'noSideEffects' ? URL_TREESHAKE_NOSIDEEFFECTS : URL_TREESHAKE_PURE) }; } function logInputHookInOutputPlugin(pluginName, hookName) { return { code: INPUT_HOOK_IN_OUTPUT_PLUGIN, message: `The "${hookName}" hook used by the output plugin ${pluginName} is a build time hook and will not be run for that plugin. Either this plugin cannot be used as an output plugin, or it should have an option to configure it as an output plugin.` }; } function logCannotAssignModuleToChunk(moduleId, assignToAlias, currentAlias) { return { code: INVALID_CHUNK, message: `Cannot assign "${relativeId(moduleId)}" to the "${assignToAlias}" chunk as it is already in the "${currentAlias}" chunk.` }; } function logInvalidExportOptionValue(optionValue) { return { code: INVALID_EXPORT_OPTION, message: `"output.exports" must be "default", "named", "none", "auto", or left unspecified (defaults to "auto"), received "${optionValue}".`, url: getRollupUrl(URL_OUTPUT_EXPORTS) }; } function logIncompatibleExportOptionValue(optionValue, keys, entryModule) { return { code: INVALID_EXPORT_OPTION, message: `"${optionValue}" was specified for "output.exports", but entry module "${relativeId(entryModule)}" has the following exports: ${printQuotedStringList(keys)}`, url: getRollupUrl(URL_OUTPUT_EXPORTS) }; } function logInternalIdCannotBeExternal(source, importer) { return { code: INVALID_EXTERNAL_ID, message: `"${source}" is imported as an external by "${relativeId(importer)}", but is already an existing non-external module id.` }; } function logImportOptionsAreInvalid(importer) { return { code: INVALID_IMPORT_ATTRIBUTE, message: `Rollup could not statically analyze the options argument of a dynamic import in "${relativeId(importer)}". Dynamic import options need to be an object with a nested attributes object.` }; } function logImportAttributeIsInvalid(importer) { return { code: INVALID_IMPORT_ATTRIBUTE, message: `Rollup could not statically analyze an import attribute of a dynamic import in "${relativeId(importer)}". Import attributes need to have string keys and values. The attribute will be removed.` }; } function logInvalidLogPosition(plugin) { return { code: INVALID_LOG_POSITION, message: `Plugin "${plugin}" tried to add a file position to a log or warning. This is only supported in the "transform" hook at the moment and will be ignored.` }; } function logInvalidOption(option, urlSnippet, explanation, value) { return { code: INVALID_OPTION, message: `Invalid value ${value === undefined ? '' : `${JSON.stringify(value)} `}for option "${option}" - ${explanation}.`, url: getRollupUrl(urlSnippet) }; } function logInvalidAddonPluginHook(hook, plugin) { return { code: INVALID_PLUGIN_HOOK, hook, message: `Error running plugin hook "${hook}" for plugin "${plugin}", expected a string, a function hook or an object with a "handler" string or function.`, plugin }; } function logInvalidFunctionPluginHook(hook, plugin) { return { code: INVALID_PLUGIN_HOOK, hook, message: `Error running plugin hook "${hook}" for plugin "${plugin}", expected a function hook or an object with a "handler" function.`, plugin }; } function logInvalidRollupPhaseForChunkEmission() { return { code: INVALID_ROLLUP_PHASE, message: `Cannot emit chunks after module loading has finished.` }; } function logInvalidSetAssetSourceCall() { return { code: INVALID_SETASSETSOURCE, message: `setAssetSource cannot be called in transform for caching reasons. Use emitFile with a source, or call setAssetSource in another hook.` }; } function logInvalidFormatForTopLevelAwait(id, format) { return { code: INVALID_TLA_FORMAT, id, message: `Module format "${format}" does not support top-level await. Use the "es" or "system" output formats rather.` }; } function logMissingEntryExport(binding, exporter) { return { binding, code: MISSING_EXPORT, exporter, message: `Exported variable "${binding}" is not defined in "${relativeId(exporter)}".`, url: getRollupUrl(URL_NAME_IS_NOT_EXPORTED) }; } function logMissingExport(binding, importingModule, exporter) { const isJson = extname(exporter) === '.json'; return { binding, code: MISSING_EXPORT, exporter, id: importingModule, message: `"${binding}" is not exported by "${relativeId(exporter)}", imported by "${relativeId(importingModule)}".${isJson ? ' (Note that you need @rollup/plugin-json to import JSON files)' : ''}`, url: getRollupUrl(URL_NAME_IS_NOT_EXPORTED) }; } function logMissingGlobalName(externalId, guess) { return { code: MISSING_GLOBAL_NAME, id: externalId, message: `No name was provided for external module "${externalId}" in "output.globals" – guessing "${guess}".`, names: [guess], url: getRollupUrl(URL_OUTPUT_GLOBALS) }; } function logImplicitDependantCannotBeExternal(unresolvedId, implicitlyLoadedBefore) { return { code: MISSING_IMPLICIT_DEPENDANT, message: `Module "${relativeId(unresolvedId)}" that should be implicitly loaded before "${relativeId(implicitlyLoadedBefore)}" cannot be external.` }; } function logUnresolvedImplicitDependant(unresolvedId, implicitlyLoadedBefore) { return { code: MISSING_IMPLICIT_DEPENDANT, message: `Module "${relativeId(unresolvedId)}" that should be implicitly loaded before "${relativeId(implicitlyLoadedBefore)}" could not be resolved.` }; } function logImplicitDependantIsNotIncluded(module) { const implicitDependencies = [...module.implicitlyLoadedBefore] .map(dependency => relativeId(dependency.id)) .sort(); return { code: MISSING_IMPLICIT_DEPENDANT, message: `Module "${relativeId(module.id)}" that should be implicitly loaded before ${printQuotedStringList(implicitDependencies)} is not included in the module graph. Either it was not imported by an included module or only via a tree-shaken dynamic import, or no imported bindings were used and it had otherwise no side-effects.` }; } function logMissingNameOptionForIifeExport() { return { code: MISSING_NAME_OPTION_FOR_IIFE_EXPORT, message: `If you do not supply "output.name", you may not be able to access the exports of an IIFE bundle.`, url: getRollupUrl(URL_OUTPUT_NAME) }; } function logMissingNameOptionForUmdExport() { return { code: MISSING_NAME_OPTION_FOR_IIFE_EXPORT, message: 'You must supply "output.name" for UMD bundles that have exports so that the exports are accessible in environments without a module loader.', url: getRollupUrl(URL_OUTPUT_NAME) }; } function logMissingNodeBuiltins(externalBuiltins) { return { code: MISSING_NODE_BUILTINS, ids: externalBuiltins, message: `Creating a browser bundle that depends on Node.js built-in modules (${printQuotedStringList(externalBuiltins)}). You might need to include https://github.com/FredKSchott/rollup-plugin-polyfill-node` }; } // eslint-disable-next-line unicorn/prevent-abbreviations function logMissingFileOrDirOption() { return { code: MISSING_OPTION, message: 'You must specify "output.file" or "output.dir" for the build.', url: getRollupUrl(URL_OUTPUT_DIR) }; } function logMixedExport(facadeModuleId, name) { return { code: MIXED_EXPORTS, id: facadeModuleId, message: `Entry module "${relativeId(facadeModuleId)}" is using named and default exports together. Consumers of your bundle will have to use \`${name || 'chunk'}.default\` to access the default export, which may not be what you want. Use \`output.exports: "named"\` to disable this warning.`, url: getRollupUrl(URL_OUTPUT_EXPORTS) }; } function logModuleLevelDirective(directive, id) { return { code: MODULE_LEVEL_DIRECTIVE, id, message: `Module level directives cause errors when bundled, "${directive}" in "${relativeId(id)}" was ignored.` }; } function logNamespaceConflict(binding, reexportingModuleId, sources) { return { binding, code: NAMESPACE_CONFLICT, ids: sources, message: `Conflicting namespaces: "${relativeId(reexportingModuleId)}" re-exports "${binding}" from one of the modules ${printQuotedStringList(sources.map(moduleId => relativeId(moduleId)))} (will be ignored).`, reexporter: reexportingModuleId }; } function logNoTransformMapOrAstWithoutCode(pluginName) { return { code: NO_TRANSFORM_MAP_OR_AST_WITHOUT_CODE, message: `The plugin "${pluginName}" returned a "map" or "ast" without returning ` + 'a "code". This will be ignored.' }; } function logOptimizeChunkStatus(chunks, smallChunks, pointInTime) { return { code: OPTIMIZE_CHUNK_STATUS, message: `${pointInTime}, there are\n` + `${chunks} chunks, of which\n` + `${smallChunks} are below minChunkSize.` }; } function logParseError(message, pos) { return { code: PARSE_ERROR, message, pos }; } function logRedeclarationError(name) { return { code: REDECLARATION_ERROR, message: `Identifier "${name}" has already been declared` }; } function logModuleParseError(error, moduleId) { let message = error.message.replace(/ \(\d+:\d+\)$/, ''); if (moduleId.endsWith('.json')) { message += ' (Note that you need @rollup/plugin-json to import JSON files)'; } else if (!moduleId.endsWith('.js')) { message += ' (Note that you need plugins to import files that are not JavaScript)'; } return { cause: error, code: PARSE_ERROR, id: moduleId, message, stack: error.stack }; } function logPluginError(error, plugin, { hook, id } = {}) { const code = error.code; if (!error.pluginCode && code != null && (typeof code !== 'string' || !code.startsWith('PLUGIN_'))) { error.pluginCode = code; } error.code = PLUGIN_ERROR; error.plugin = plugin; if (hook) { error.hook = hook; } if (id) { error.id = id; } return error; } function logShimmedExport(id, binding) { return { binding, code: SHIMMED_EXPORT, exporter: id, message: `Missing export "${binding}" has been shimmed in module "${relativeId(id)}".` }; } function logSourcemapBroken(plugin) { return { code: SOURCEMAP_BROKEN, message: `Sourcemap is likely to be incorrect: a plugin (${plugin}) was used to transform files, but didn't generate a sourcemap for the transformation. Consult the plugin documentation for help`, plugin, url: getRollupUrl(URL_SOURCEMAP_IS_LIKELY_TO_BE_INCORRECT) }; } function logConflictingSourcemapSources(filename) { return { code: SOURCEMAP_BROKEN, message: `Multiple conflicting contents for sourcemap source ${filename}` }; } function logInvalidSourcemapForError(error, id, column, line, pos) { return { cause: error, code: SOURCEMAP_ERROR, id, loc: { column, file: id, line }, message: `Error when using sourcemap for reporting an error: ${error.message}`, pos }; } function logSyntheticNamedExportsNeedNamespaceExport(id, syntheticNamedExportsOption) { return { code: SYNTHETIC_NAMED_EXPORTS_NEED_NAMESPACE_EXPORT, exporter: id, message: `Module "${relativeId(id)}" that is marked with \`syntheticNamedExports: ${JSON.stringify(syntheticNamedExportsOption)}\` needs ${typeof syntheticNamedExportsOption === 'string' && syntheticNamedExportsOption !== 'default' ? `an explicit export named "${syntheticNamedExportsOption}"` : 'a default export'} that does not reexport an unresolved named export of the same module.` }; } function logThisIsUndefined() { return { code: THIS_IS_UNDEFINED, message: `The 'this' keyword is equivalent to 'undefined' at the top level of an ES module, and has been rewritten`, url: getRollupUrl(URL_THIS_IS_UNDEFINED) }; } function logUnexpectedNamedImport(id, imported, isReexport) { const importType = isReexport ? 'reexport' : 'import'; return { code: UNEXPECTED_NAMED_IMPORT, exporter: id, message: `The named export "${imported}" was ${importType}ed from the external module "${relativeId(id)}" even though its interop type is "defaultOnly". Either remove or change this ${importType} or change the value of the "output.interop" option.`, url: getRollupUrl(URL_OUTPUT_INTEROP) }; } function logUnexpectedNamespaceReexport(id) { return { code: UNEXPECTED_NAMED_IMPORT, exporter: id, message: `There was a namespace "*" reexport from the external module "${relativeId(id)}" even though its interop type is "defaultOnly". This will be ignored as namespace reexports only reexport named exports. If this is not intended, either remove or change this reexport or change the value of the "output.interop" option.`, url: getRollupUrl(URL_OUTPUT_INTEROP) }; } function logUnknownOption(optionType, unknownOptions, validOptions) { return { code: UNKNOWN_OPTION, message: `Unknown ${optionType}: ${unknownOptions.join(', ')}. Allowed options: ${validOptions.join(', ')}` }; } function logEntryCannotBeExternal(unresolvedId) { return { code: UNRESOLVED_ENTRY, message: `Entry module "${relativeId(unresolvedId)}" cannot be external.` }; } function logExternalModulesCannotBeIncludedInManualChunks(source) { return { code: EXTERNAL_MODULES_CANNOT_BE_INCLUDED_IN_MANUAL_CHUNKS, message: `"${source}" cannot be included in manualChunks because it is resolved as an external module by the "external" option or plugins.` }; } function logExternalModulesCannotBeTransformedToModules(source) { return { code: EXTERNAL_MODULES_CANNOT_BE_TRANSFORMED_TO_MODULES, message: `${source} is resolved as a module now, but it was an external module before. Please check whether there are conflicts in your Rollup options "external" and "manualChunks", manualChunks cannot include external modules.` }; } function logUnresolvedEntry(unresolvedId) { return { code: UNRESOLVED_ENTRY, message: `Could not resolve entry module "${relativeId(unresolvedId)}".` }; } function logUnresolvedImport(source, importer) { return { code: UNRESOLVED_IMPORT, exporter: source, id: importer, message: `Could not resolve "${source}" from "${relativeId(importer)}"` }; } function logUnresolvedImportTreatedAsExternal(source, importer) { return { code: UNRESOLVED_IMPORT, exporter: source, id: importer, message: `"${source}" is imported by "${relativeId(importer)}", but could not be resolved – treating it as an external dependency.`, url: getRollupUrl(URL_TREATING_MODULE_AS_EXTERNAL_DEPENDENCY) }; } function logUnusedExternalImports(externalId, names, importers) { return { code: UNUSED_EXTERNAL_IMPORT, exporter: externalId, ids: importers, message: `${printQuotedStringList(names, [ 'is', 'are' ])} imported from external module "${externalId}" but never used in ${printQuotedStringList(importers.map(importer => relativeId(importer)))}.`, names }; } function logFailedValidation(message) { return { code: VALIDATION_ERROR, message }; } function warnDeprecation(deprecation, urlSnippet, activeDeprecation, options, plugin) { warnDeprecationWithOptions(deprecation, urlSnippet, activeDeprecation, options.onLog, options.strictDeprecations); } function warnDeprecationWithOptions(deprecation, urlSnippet, activeDeprecation, log, strictDeprecations, plugin) { { const warning = logDeprecation(deprecation, urlSnippet); if (strictDeprecations) { return error(warning); } log(LOGLEVEL_WARN, warning); } } // This file is generated by scripts/generate-buffer-to-ast.js. // Do not edit this file directly. function convertProgram(buffer) { const node = convertNode(0, buffer); switch (node.type) { case PanicError: { return error(getRollupError(logParseError(node.message))); } case ParseError: { return error(getRollupError(logParseError(node.message, node.start))); } default: { return node; } } } /* eslint-disable sort-keys */ const nodeConverters = [ function panicError(position, buffer) { return { type: 'PanicError', start: buffer[position], end: buffer[position + 1], message: buffer.convertString(buffer[position + 2]) }; }, function parseError(position, buffer) { return { type: 'ParseError', start: buffer[position], end: buffer[position + 1], message: buffer.convertString(buffer[position + 2]) }; }, function arrayExpression(position, buffer) { return { type: 'ArrayExpression', start: buffer[position], end: buffer[position + 1], elements: convertNodeList(buffer[position + 2], buffer) }; }, function arrayPattern(position, buffer) { return { type: 'ArrayPattern', start: buffer[position], end: buffer[position + 1], elements: convertNodeList(buffer[position + 2], buffer) }; }, function arrowFunctionExpression(position, buffer) { const flags = buffer[position + 2]; const annotations = convertAnnotations(buffer[position + 3], buffer); return { type: 'ArrowFunctionExpression', start: buffer[position], end: buffer[position + 1], async: (flags & 1) === 1, expression: (flags & 2) === 2, generator: (flags & 4) === 4, ...(annotations.length > 0 ? { [ANNOTATION_KEY]: annotations } : {}), params: convertNodeList(buffer[position + 4], buffer), body: convertNode(buffer[position + 5], buffer), id: null }; }, function assignmentExpression(position, buffer) { return { type: 'AssignmentExpression', start: buffer[position], end: buffer[position + 1], operator: FIXED_STRINGS[buffer[position + 2]], left: convertNode(buffer[position + 3], buffer), right: convertNode(buffer[position + 4], buffer) }; }, function assignmentPattern(position, buffer) { return { type: 'AssignmentPattern', start: buffer[position], end: buffer[position + 1], left: convertNode(buffer[position + 2], buffer), right: convertNode(buffer[position + 3], buffer) }; }, function awaitExpression(position, buffer) { return { type: 'AwaitExpression', start: buffer[position], end: buffer[position + 1], argument: convertNode(buffer[position + 2], buffer) }; }, function binaryExpression(position, buffer) { return { type: 'BinaryExpression', start: buffer[position], end: buffer[position + 1], operator: FIXED_STRINGS[buffer[position + 2]], left: convertNode(buffer[position + 3], buffer), right: convertNode(buffer[position + 4], buffer) }; }, function blockStatement(position, buffer) { return { type: 'BlockStatement', start: buffer[position], end: buffer[position + 1], body: convertNodeList(buffer[position + 2], buffer) }; }, function breakStatement(position, buffer) { const labelPosition = buffer[position + 2]; return { type: 'BreakStatement', start: buffer[position], end: buffer[position + 1], label: labelPosition === 0 ? null : convertNode(labelPosition, buffer) }; }, function callExpression(position, buffer) { const flags = buffer[position + 2]; const annotations = convertAnnotations(buffer[position + 3], buffer); return { type: 'CallExpression', start: buffer[position], end: buffer[position + 1], optional: (flags & 1) === 1, ...(annotations.length > 0 ? { [ANNOTATION_KEY]: annotations } : {}), callee: convertNode(buffer[position + 4], buffer), arguments: convertNodeList(buffer[position + 5], buffer) }; }, function catchClause(position, buffer) { const parameterPosition = buffer[position + 2]; return { type: 'CatchClause', start: buffer[position], end: buffer[position + 1], param: parameterPosition === 0 ? null : convertNode(parameterPosition, buffer), body: convertNode(buffer[position + 3], buffer) }; }, function chainExpression(position, buffer) { return { type: 'ChainExpression', start: buffer[position], end: buffer[position + 1], expression: convertNode(buffer[position + 2], buffer) }; }, function classBody(position, buffer) { return { type: 'ClassBody', start: buffer[position], end: buffer[position + 1], body: convertNodeList(buffer[position + 2], buffer) }; }, function classDeclaration(position, buffer) { const idPosition = buffer[position + 3]; const superClassPosition = buffer[position + 4]; return { type: 'ClassDeclaration', start: buffer[position], end: buffer[position + 1], decorators: convertNodeList(buffer[position + 2], buffer), id: idPosition === 0 ? null : convertNode(idPosition, buffer), superClass: superClassPosition === 0 ? null : convertNode(superClassPosition, buffer), body: convertNode(buffer[position + 5], buffer) }; }, function classExpression(position, buffer) { const idPosition = buffer[position + 3]; const superClassPosition = buffer[position + 4]; return { type: 'ClassExpression', start: buffer[position], end: buffer[position + 1], decorators: convertNodeList(buffer[position + 2], buffer), id: idPosition === 0 ? null : convertNode(idPosition, buffer), superClass: superClassPosition === 0 ? null : convertNode(superClassPosition, buffer), body: convertNode(buffer[position + 5], buffer) }; }, function conditionalExpression(position, buffer) { return { type: 'ConditionalExpression', start: buffer[position], end: buffer[position + 1], test: convertNode(buffer[position + 2], buffer), consequent: convertNode(buffer[position + 3], buffer), alternate: convertNode(buffer[position + 4], buffer) }; }, function continueStatement(position, buffer) { const labelPosition = buffer[position + 2]; return { type: 'ContinueStatement', start: buffer[position], end: buffer[position + 1], label: labelPosition === 0 ? null : convertNode(labelPosition, buffer) }; }, function debuggerStatement(position, buffer) { return { type: 'DebuggerStatement', start: buffer[position], end: buffer[position + 1] }; }, function decorator(position, buffer) { return { type: 'Decorator', start: buffer[position], end: buffer[position + 1], expression: convertNode(buffer[position + 2], buffer) }; }, function directive(position, buffer) { return { type: 'ExpressionStatement', start: buffer[position], end: buffer[position + 1], directive: buffer.convertString(buffer[position + 2]), expression: convertNode(buffer[position + 3], buffer) }; }, function doWhileStatement(position, buffer) { return { type: 'DoWhileStatement', start: buffer[position], end: buffer[position + 1], body: convertNode(buffer[position + 2], buffer), test: convertNode(buffer[position + 3], buffer) }; }, function emptyStatement(position, buffer) { return { type: 'EmptyStatement', start: buffer[position], end: buffer[position + 1] }; }, function exportAllDeclaration(position, buffer) { const exportedPosition = buffer[position + 2]; return { type: 'ExportAllDeclaration', start: buffer[position], end: buffer[position + 1], exported: exportedPosition === 0 ? null : convertNode(exportedPosition, buffer), source: convertNode(buffer[position + 3], buffer), attributes: convertNodeList(buffer[position + 4], buffer) }; }, function exportDefaultDeclaration(position, buffer) { return { type: 'ExportDefaultDeclaration', start: buffer[position], end: buffer[position + 1], declaration: convertNode(buffer[position + 2], buffer) }; }, function exportNamedDeclaration(position, buffer) { const sourcePosition = buffer[position + 3]; const declarationPosition = buffer[position + 5]; return { type: 'ExportNamedDeclaration', start: buffer[position], end: buffer[position + 1], specifiers: convertNodeList(buffer[position + 2], buffer), source: sourcePosition === 0 ? null : convertNode(sourcePosition, buffer), attributes: convertNodeList(buffer[position + 4], buffer), declaration: declarationPosition === 0 ? null : convertNode(declarationPosition, buffer) }; }, function exportSpecifier(position, buffer) { const local = convertNode(buffer[position + 2], buffer); const exportedPosition = buffer[position + 3]; return { type: 'ExportSpecifier', start: buffer[position], end: buffer[position + 1], local, exported: exportedPosition === 0 ? { ...local } : convertNode(exportedPosition, buffer) }; }, function expressionStatement(position, buffer) { return { type: 'ExpressionStatement', start: buffer[position], end: buffer[position + 1], expression: convertNode(buffer[position + 2], buffer) }; }, function forInStatement(position, buffer) { return { type: 'ForInStatement', start: buffer[position], end: buffer[position + 1], left: convertNode(buffer[position + 2], buffer), right: convertNode(buffer[position + 3], buffer), body: convertNode(buffer[position + 4], buffer) }; }, function forOfStatement(position, buffer) { const flags = buffer[position + 2]; return { type: 'ForOfStatement', start: buffer[position], end: buffer[position + 1], await: (flags & 1) === 1, left: convertNode(buffer[position + 3], buffer), right: convertNode(buffer[position + 4], buffer), body: convertNode(buffer[position + 5], buffer) }; }, function forStatement(position, buffer) { const initPosition = buffer[position + 2]; const testPosition = buffer[position + 3]; const updatePosition = buffer[position + 4]; return { type: 'ForStatement', start: buffer[position], end: buffer[position + 1], init: initPosition === 0 ? null : convertNode(initPosition, buffer), test: testPosition === 0 ? null : convertNode(testPosition, buffer), update: updatePosition === 0 ? null : convertNode(updatePosition, buffer), body: convertNode(buffer[position + 5], buffer) }; }, function functionDeclaration(position, buffer) { const flags = buffer[position + 2]; const annotations = convertAnnotations(buffer[position + 3], buffer); const idPosition = buffer[position + 4]; return { type: 'FunctionDeclaration', start: buffer[position], end: buffer[position + 1], async: (flags & 1) === 1, generator: (flags & 2) === 2, ...(annotations.length > 0 ? { [ANNOTATION_KEY]: annotations } : {}), id: idPosition === 0 ? null : convertNode(idPosition, buffer), params: convertNodeList(buffer[position + 5], buffer), body: convertNode(buffer[position + 6], buffer), expression: false }; }, function functionExpression(position, buffer) { const flags = buffer[position + 2]; const annotations = convertAnnotations(buffer[position + 3], buffer); const idPosition = buffer[position + 4]; return { type: 'FunctionExpression', start: buffer[position], end: buffer[position + 1], async: (flags & 1) === 1, generator: (flags & 2) === 2, ...(annotations.length > 0 ? { [ANNOTATION_KEY]: annotations } : {}), id: idPosition === 0 ? null : convertNode(idPosition, buffer), params: convertNodeList(buffer[position + 5], buffer), body: convertNode(buffer[position + 6], buffer), expression: false }; }, function identifier(position, buffer) { return { type: 'Identifier', start: buffer[position], end: buffer[position + 1], name: buffer.convertString(buffer[position + 2]) }; }, function ifStatement(position, buffer) { const alternatePosition = buffer[position + 4]; return { type: 'IfStatement', start: buffer[position], end: buffer[position + 1], test: convertNode(buffer[position + 2], buffer), consequent: convertNode(buffer[position + 3], buffer), alternate: alternatePosition === 0 ? null : convertNode(alternatePosition, buffer) }; }, function importAttribute(position, buffer) { return { type: 'ImportAttribute', start: buffer[position], end: buffer[position + 1], key: convertNode(buffer[position + 2], buffer), value: convertNode(buffer[position + 3], buffer) }; }, function importDeclaration(position, buffer) { return { type: 'ImportDeclaration', start: buffer[position], end: buffer[position + 1], specifiers: convertNodeList(buffer[position + 2], buffer), source: convertNode(buffer[position + 3], buffer), attributes: convertNodeList(buffer[position + 4], buffer) }; }, function importDefaultSpecifier(position, buffer) { return { type: 'ImportDefaultSpecifier', start: buffer[position], end: buffer[position + 1], local: convertNode(buffer[position + 2], buffer) }; }, function importExpression(position, buffer) { const optionsPosition = buffer[position + 3]; return { type: 'ImportExpression', start: buffer[position], end: buffer[position + 1], source: convertNode(buffer[position + 2], buffer), options: optionsPosition === 0 ? null : convertNode(optionsPosition, buffer) }; }, function importNamespaceSpecifier(position, buffer) { return { type: 'ImportNamespaceSpecifier', start: buffer[position], end: buffer[position + 1], local: convertNode(buffer[position + 2], buffer) }; }, function importSpecifier(position, buffer) { const importedPosition = buffer[position + 2]; const local = convertNode(buffer[position + 3], buffer); return { type: 'ImportSpecifier', start: buffer[position], end: buffer[position + 1], imported: importedPosition === 0 ? { ...local } : convertNode(importedPosition, buffer), local }; }, function labeledStatement(position, buffer) { return { type: 'LabeledStatement', start: buffer[position], end: buffer[position + 1], label: convertNode(buffer[position + 2], buffer), body: convertNode(buffer[position + 3], buffer) }; }, function literalBigInt(position, buffer) { const bigint = buffer.convertString(buffer[position + 2]); return { type: 'Literal', start: buffer[position], end: buffer[position + 1], bigint, raw: buffer.convertString(buffer[position + 3]), value: BigInt(bigint) }; }, function literalBoolean(position, buffer) { const flags = buffer[position + 2]; const value = (flags & 1) === 1; return { type: 'Literal', start: buffer[position], end: buffer[position + 1], value, raw: value ? 'true' : 'false' }; }, function literalNull(position, buffer) { return { type: 'Literal', start: buffer[position], end: buffer[position + 1], raw: 'null', value: null }; }, function literalNumber(position, buffer) { const rawPosition = buffer[position + 2]; return { type: 'Literal', start: buffer[position], end: buffer[position + 1], raw: rawPosition === 0 ? undefined : buffer.convertString(rawPosition), value: new DataView(buffer.buffer).getFloat64((position + 3) << 2, true) }; }, function literalRegExp(position, buffer) { const flags = buffer.convertString(buffer[position + 2]); const pattern = buffer.convertString(buffer[position + 3]); return { type: 'Literal', start: buffer[position], end: buffer[position + 1], raw: `/${pattern}/${flags}`, regex: { flags, pattern }, value: new RegExp(pattern, flags) }; }, function literalString(position, buffer) { const rawPosition = buffer[position + 3]; return { type: 'Literal', start: buffer[position], end: buffer[position + 1], value: buffer.convertString(buffer[position + 2]), raw: rawPosition === 0 ? undefined : buffer.convertString(rawPosition) }; }, function logicalExpression(position, buffer) { return { type: 'LogicalExpression', start: buffer[position], end: buffer[position + 1], operator: FIXED_STRINGS[buffer[position + 2]], left: convertNode(buffer[position + 3], buffer), right: convertNode(buffer[position + 4], buffer) }; }, function memberExpression(position, buffer) { const flags = buffer[position + 2]; return { type: 'MemberExpression', start: buffer[position], end: buffer[position + 1], computed: (flags & 1) === 1, optional: (flags & 2) === 2, object: convertNode(buffer[position + 3], buffer), property: convertNode(buffer[position + 4], buffer) }; }, function metaProperty(position, buffer) { return { type: 'MetaProperty', start: buffer[position], end: buffer[position + 1], meta: convertNode(buffer[position + 2], buffer), property: convertNode(buffer[position + 3], buffer) }; }, function methodDefinition(position, buffer) { const flags = buffer[position + 2]; return { type: 'MethodDefinition', start: buffer[position], end: buffer[position + 1], static: (flags & 1) === 1, computed: (flags & 2) === 2, decorators: convertNodeList(buffer[position + 3], buffer), key: convertNode(buffer[position + 4], buffer), value: convertNode(buffer[position + 5], buffer), kind: FIXED_STRINGS[buffer[position + 6]] }; }, function newExpression(position, buffer) { const annotations = convertAnnotations(buffer[position + 2], buffer); return { type: 'NewExpression', start: buffer[position], end: buffer[position + 1], ...(annotations.length > 0 ? { [ANNOTATION_KEY]: annotations } : {}), callee: convertNode(buffer[position + 3], buffer), arguments: convertNodeList(buffer[position + 4], buffer) }; }, function objectExpression(position, buffer) { return { type: 'ObjectExpression', start: buffer[position], end: buffer[position + 1], properties: convertNodeList(buffer[position + 2], buffer) }; }, function objectPattern(position, buffer) { return { type: 'ObjectPattern', start: buffer[position], end: buffer[position + 1], properties: convertNodeList(buffer[position + 2], buffer) }; }, function privateIdentifier(position, buffer) { return { type: 'PrivateIdentifier', start: buffer[position], end: buffer[position + 1], name: buffer.convertString(buffer[position + 2]) }; }, function program(position, buffer) { const invalidAnnotations = convertAnnotations(buffer[position + 3], buffer); return { type: 'Program', start: buffer[position], end: buffer[position + 1], body: convertNodeList(buffer[position + 2], buffer), ...(invalidAnnotations.length > 0 ? { [INVALID_ANNOTATION_KEY]: invalidAnnotations } : {}), sourceType: 'module' }; }, function property(position, buffer) { const flags = buffer[position + 2]; const keyPosition = buffer[position + 3]; const value = convertNode(buffer[position + 4], buffer); return { type: 'Property', start: buffer[position], end: buffer[position + 1], method: (flags & 1) === 1, shorthand: (flags & 2) === 2, computed: (flags & 4) === 4, key: keyPosition === 0 ? { ...value } : convertNode(keyPosition, buffer), value, kind: FIXED_STRINGS[buffer[position + 5]] }; }, function propertyDefinition(position, buffer) { const flags = buffer[position + 2]; const valuePosition = buffer[position + 5]; return { type: 'PropertyDefinition', start: buffer[position], end: buffer[position + 1], static: (flags & 1) === 1, computed: (flags & 2) === 2, decorators: convertNodeList(buffer[position + 3], buffer), key: convertNode(buffer[position + 4], buffer), value: valuePosition === 0 ? null : convertNode(valuePosition, buffer) }; }, function restElement(position, buffer) { return { type: 'RestElement', start: buffer[position], end: buffer[position + 1], argument: convertNode(buffer[position + 2], buffer) }; }, function returnStatement(position, buffer) { const argumentPosition = buffer[position + 2]; return { type: 'ReturnStatement', start: buffer[position], end: buffer[position + 1], argument: argumentPosition === 0 ? null : convertNode(argumentPosition, buffer) }; }, function sequenceExpression(position, buffer) { return { type: 'SequenceExpression', start: buffer[position], end: buffer[position + 1], expressions: convertNodeList(buffer[position + 2], buffer) }; }, function spreadElement(position, buffer) { return { type: 'SpreadElement', start: buffer[position], end: buffer[position + 1], argument: convertNode(buffer[position + 2], buffer) }; }, function staticBlock(position, buffer) { return { type: 'StaticBlock', start: buffer[position], end: buffer[position + 1], body: convertNodeList(buffer[position + 2], buffer) }; }, function superElement(position, buffer) { return { type: 'Super', start: buffer[position], end: buffer[position + 1] }; }, function switchCase(position, buffer) { const testPosition = buffer[position + 2]; return { type: 'SwitchCase', start: buffer[position], end: buffer[position + 1], test: testPosition === 0 ? null : convertNode(testPosition, buffer), consequent: convertNodeList(buffer[position + 3], buffer) }; }, function switchStatement(position, buffer) { return { type: 'SwitchStatement', start: buffer[position], end: buffer[position + 1], discriminant: convertNode(buffer[position + 2], buffer), cases: convertNodeList(buffer[position + 3], buffer) }; }, function taggedTemplateExpression(position, buffer) { return { type: 'TaggedTemplateExpression', start: buffer[position], end: buffer[position + 1], tag: convertNode(buffer[position + 2], buffer), quasi: convertNode(buffer[position + 3], buffer) }; }, function templateElement(position, buffer) { const flags = buffer[position + 2]; const cookedPosition = buffer[position + 3]; const cooked = cookedPosition === 0 ? undefined : buffer.convertString(cookedPosition); const raw = buffer.convertString(buffer[position + 4]); return { type: 'TemplateElement', start: buffer[position], end: buffer[position + 1], tail: (flags & 1) === 1, value: { cooked, raw } }; }, function templateLiteral(position, buffer) { return { type: 'TemplateLiteral', start: buffer[position], end: buffer[position + 1], quasis: convertNodeList(buffer[position + 2], buffer), expressions: convertNodeList(buffer[position + 3], buffer) }; }, function thisExpression(position, buffer) { return { type: 'ThisExpression', start: buffer[position], end: buffer[position + 1] }; }, function throwStatement(position, buffer) { return { type: 'ThrowStatement', start: buffer[position], end: buffer[position + 1], argument: convertNode(buffer[position + 2], buffer) }; }, function tryStatement(position, buffer) { const handlerPosition = buffer[position + 3]; const finalizerPosition = buffer[position + 4]; return { type: 'TryStatement', start: buffer[position], end: buffer[position + 1], block: convertNode(buffer[position + 2], buffer), handler: handlerPosition === 0 ? null : convertNode(handlerPosition, buffer), finalizer: finalizerPosition === 0 ? null : convertNode(finalizerPosition, buffer) }; }, function unaryExpression(position, buffer) { return { type: 'UnaryExpression', start: buffer[position], end: buffer[position + 1], operator: FIXED_STRINGS[buffer[position + 2]], argument: convertNode(buffer[position + 3], buffer), prefix: true }; }, function updateExpression(position, buffer) { const flags = buffer[position + 2]; return { type: 'UpdateExpression', start: buffer[position], end: buffer[position + 1], prefix: (flags & 1) === 1, operator: FIXED_STRINGS[buffer[position + 3]], argument: convertNode(buffer[position + 4], buffer) }; }, function variableDeclaration(position, buffer) { return { type: 'VariableDeclaration', start: buffer[position], end: buffer[position + 1], kind: FIXED_STRINGS[buffer[position + 2]], declarations: convertNodeList(buffer[position + 3], buffer) }; }, function variableDeclarator(position, buffer) { const initPosition = buffer[position + 3]; return { type: 'VariableDeclarator', start: buffer[position], end: buffer[position + 1], id: convertNode(buffer[position + 2], buffer), init: initPosition === 0 ? null : convertNode(initPosition, buffer) }; }, function whileStatement(position, buffer) { return { type: 'WhileStatement', start: buffer[position], end: buffer[position + 1], test: convertNode(buffer[position + 2], buffer), body: convertNode(buffer[position + 3], buffer) }; }, function yieldExpression(position, buffer) { const flags = buffer[position + 2]; const argumentPosition = buffer[position + 3]; return { type: 'YieldExpression', start: buffer[position], end: buffer[position + 1], delegate: (flags & 1) === 1, argument: argumentPosition === 0 ? null : convertNode(argumentPosition, buffer) }; } ]; function convertNode(position, buffer) { const nodeType = buffer[position]; const converter = nodeConverters[nodeType]; /* istanbul ignore if: This should never be executed but is a safeguard against faulty buffers */ if (!converter) { console.trace(); throw new Error(`Unknown node type: ${nodeType}`); } return converter(position + 1, buffer); } function convertNodeList(position, buffer) { if (position === 0) return EMPTY_ARRAY; const length = buffer[position++]; const list = []; for (let index = 0; index < length; index++) { const nodePosition = buffer[position++]; list.push(nodePosition ? convertNode(nodePosition, buffer) : null); } return list; } function getAstBuffer(astBuffer) { const array = new Uint32Array(astBuffer.buffer); let convertString; if (typeof Buffer !== 'undefined' && astBuffer instanceof Buffer) { convertString = (position) => { const length = array[position++]; const bytePosition = position << 2; return astBuffer.toString('utf8', bytePosition, bytePosition + length); }; } else { const textDecoder = new TextDecoder(); convertString = (position) => { const length = array[position++]; const bytePosition = position << 2; return textDecoder.decode(astBuffer.subarray(bytePosition, bytePosition + length)); }; } return Object.assign(array, { convertString }); } const parseAst = (input, { allowReturnOutsideFunction = false } = {}) => convertProgram(getAstBuffer(parse(input, allowReturnOutsideFunction))); const parseAstAsync = async (input, { allowReturnOutsideFunction = false, signal } = {}) => convertProgram(getAstBuffer(await parseAsync(input, allowReturnOutsideFunction, signal))); export { ANNOTATION_KEY, ArrowFunctionExpression, BLANK, BlockStatement, CallExpression, CatchClause, EMPTY_ARRAY, EMPTY_OBJECT, EMPTY_SET, ExportDefaultDeclaration, ExpressionStatement, FIXED_STRINGS, INVALID_ANNOTATION_KEY, Identifier, LOGLEVEL_DEBUG, LOGLEVEL_ERROR, LOGLEVEL_INFO, LOGLEVEL_WARN, Literal, Program, Property, ReturnStatement, StaticBlock, TemplateLiteral, URL_OUTPUT_AMD_BASEPATH, URL_OUTPUT_AMD_ID, URL_OUTPUT_DIR, URL_OUTPUT_EXTERNALIMPORTATTRIBUTES, URL_OUTPUT_FORMAT, URL_OUTPUT_GENERATEDCODE, URL_OUTPUT_INLINEDYNAMICIMPORTS, URL_OUTPUT_INTEROP, URL_OUTPUT_MANUALCHUNKS, URL_OUTPUT_SOURCEMAPBASEURL, URL_OUTPUT_SOURCEMAPFILE, URL_PRESERVEENTRYSIGNATURES, URL_TREESHAKE, URL_TREESHAKE_MODULESIDEEFFECTS, URL_WATCH, VariableDeclarator, addTrailingSlashIfMissed, augmentCodeLocation, augmentLogMessage, convertAnnotations, convertNode, error, getAliasName, getAstBuffer, getImportPath, getRollupError, isAbsolute, isPathFragment, isRelative, isValidUrl, locate, logAddonNotGenerated, logAlreadyClosed, logAmbiguousExternalNamespaces, logAnonymousPluginCache, logAssetNotFinalisedForFileName, logAssetReferenceIdNotFoundForSetSource, logAssetSourceAlreadySet, logBadLoader, logCannotAssignModuleToChunk, logCannotCallNamespace, logCannotEmitFromOptionsHook, logChunkInvalid, logChunkNotGeneratedForFileName, logCircularDependency, logCircularReexport, logConflictingSourcemapSources, logConstVariableReassignError, logCyclicCrossChunkReexport, logDuplicateArgumentNameError, logDuplicateExportError, logDuplicatePluginName, logEmptyChunk, logEntryCannotBeExternal, logEval, logExternalModulesCannotBeIncludedInManualChunks, logExternalModulesCannotBeTransformedToModules, logExternalSyntheticExports, logFailedValidation, logFileNameConflict, logFileReferenceIdNotFoundForFilename, logFirstSideEffect, logIllegalIdentifierAsName, logIllegalImportReassignment, logImplicitDependantCannotBeExternal, logImplicitDependantIsNotIncluded, logImportAttributeIsInvalid, logImportOptionsAreInvalid, logIncompatibleExportOptionValue, logInconsistentImportAttributes, logInputHookInOutputPlugin, logInternalIdCannotBeExternal, logInvalidAddonPluginHook, logInvalidAnnotation, logInvalidExportOptionValue, logInvalidFormatForTopLevelAwait, logInvalidFunctionPluginHook, logInvalidLogPosition, logInvalidOption, logInvalidRollupPhaseForChunkEmission, logInvalidSetAssetSourceCall, logInvalidSourcemapForError, logLevelPriority, logMissingEntryExport, logMissingExport, logMissingFileOrDirOption, logMissingGlobalName, logMissingNameOptionForIifeExport, logMissingNameOptionForUmdExport, logMissingNodeBuiltins, logMixedExport, logModuleLevelDirective, logModuleParseError, logNamespaceConflict, logNoAssetSourceSet, logNoTransformMapOrAstWithoutCode, logOptimizeChunkStatus, logParseError, logPluginError, logRedeclarationError, logShimmedExport, logSourcemapBroken, logSyntheticNamedExportsNeedNamespaceExport, logThisIsUndefined, logUnexpectedNamedImport, logUnexpectedNamespaceReexport, logUnknownOption, logUnresolvedEntry, logUnresolvedImplicitDependant, logUnresolvedImport, logUnresolvedImportTreatedAsExternal, logUnusedExternalImports, normalize, parseAst, parseAstAsync, printQuotedStringList, relative, relativeId, warnDeprecation };