 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
      Overview ¶
This API exposes esbuild's two main operations: building and transforming. It's intended for integrating esbuild into other tools as a library.
If you are just trying to run esbuild from Go without the overhead of creating a child process, there is also an API for the command-line interface itself: https://pkg.go.dev/github.com/evanw/esbuild/pkg/cli.
Build API ¶
This function runs an end-to-end build operation. It takes an array of file paths as entry points, parses them and all of their dependencies, and returns the output files to write to the file system. The available options roughly correspond to esbuild's command-line flags.
Example usage:
package main
import (
    "os"
    "github.com/evanw/esbuild/pkg/api"
)
func main() {
    result := api.Build(api.BuildOptions{
        EntryPoints: []string{"input.js"},
        Outfile:     "output.js",
        Bundle:      true,
        Write:       true,
        LogLevel:    api.LogLevelInfo,
    })
    if len(result.Errors) > 0 {
        os.Exit(1)
    }
}
Transform API ¶
This function transforms a string of source code into JavaScript. It can be used to minify JavaScript, convert TypeScript/JSX to JavaScript, or convert newer JavaScript to older JavaScript. The available options roughly correspond to esbuild's command-line flags.
Example usage:
package main
import (
    "fmt"
    "os"
    "github.com/evanw/esbuild/pkg/api"
)
func main() {
    jsx := `
        import * as React from 'react'
        import * as ReactDOM from 'react-dom'
        ReactDOM.render(
            <h1>Hello, world!</h1>,
            document.getElementById('root')
        );
    `
    result := api.Transform(jsx, api.TransformOptions{
        Loader: api.LoaderJSX,
    })
    fmt.Printf("%d errors and %d warnings\n",
        len(result.Errors), len(result.Warnings))
    os.Stdout.Write(result.Code)
}
Index ¶
- func AnalyzeMetafile(metafile string, opts AnalyzeMetafileOptions) string
- func Context(buildOptions BuildOptions) (BuildContext, *ContextError)
- func FormatMessages(msgs []Message, opts FormatMessagesOptions) []string
- type AbsPaths
- type AnalyzeMetafileOptions
- type BuildContext
- type BuildOptions
- type BuildResult
- type CORSOptions
- type Charset
- type ContextError
- type Drop
- type Engine
- type EngineName
- type EntryPoint
- type Format
- type FormatMessagesOptions
- type JSX
- type LegalComments
- type Loader
- type Location
- type LogLevel
- type MangleQuoted
- type Message
- type MessageKind
- type Note
- type OnEndResult
- type OnLoadArgs
- type OnLoadOptions
- type OnLoadResult
- type OnResolveArgs
- type OnResolveOptions
- type OnResolveResult
- type OnStartResult
- type OutputFile
- type Packages
- type Platform
- type Plugin
- type PluginBuild
- type ResolveKind
- type ResolveOptions
- type ResolveResult
- type ServeOnRequestArgs
- type ServeOptions
- type ServeResult
- type SideEffects
- type SourceMap
- type SourcesContent
- type StderrColor
- type StdinOptions
- type Target
- type TransformOptions
- type TransformResult
- type TreeShaking
- type WatchOptions
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func AnalyzeMetafile ¶ added in v0.12.26
func AnalyzeMetafile(metafile string, opts AnalyzeMetafileOptions) string
Documentation: https://esbuild.github.io/api/#analyze
func Context ¶ added in v0.17.0
func Context(buildOptions BuildOptions) (BuildContext, *ContextError)
Documentation: https://esbuild.github.io/api/#build
func FormatMessages ¶ added in v0.10.1
func FormatMessages(msgs []Message, opts FormatMessagesOptions) []string
Types ¶
type AnalyzeMetafileOptions ¶ added in v0.12.26
type BuildContext ¶ added in v0.17.0
type BuildContext interface {
	// Documentation: https://esbuild.github.io/api/#rebuild
	Rebuild() BuildResult
	// Documentation: https://esbuild.github.io/api/#watch
	Watch(options WatchOptions) error
	// Documentation: https://esbuild.github.io/api/#serve
	Serve(options ServeOptions) (ServeResult, error)
	Cancel()
	Dispose()
}
    type BuildOptions ¶
type BuildOptions struct {
	Color       StderrColor         // Documentation: https://esbuild.github.io/api/#color
	LogLevel    LogLevel            // Documentation: https://esbuild.github.io/api/#log-level
	LogLimit    int                 // Documentation: https://esbuild.github.io/api/#log-limit
	LogOverride map[string]LogLevel // Documentation: https://esbuild.github.io/api/#log-override
	AbsPaths    AbsPaths            // Documentation: https://esbuild.github.io/api/#abs-path
	Sourcemap      SourceMap      // Documentation: https://esbuild.github.io/api/#sourcemap
	SourceRoot     string         // Documentation: https://esbuild.github.io/api/#source-root
	SourcesContent SourcesContent // Documentation: https://esbuild.github.io/api/#sources-content
	Target    Target          // Documentation: https://esbuild.github.io/api/#target
	Engines   []Engine        // Documentation: https://esbuild.github.io/api/#target
	Supported map[string]bool // Documentation: https://esbuild.github.io/api/#supported
	MangleProps       string                 // Documentation: https://esbuild.github.io/api/#mangle-props
	ReserveProps      string                 // Documentation: https://esbuild.github.io/api/#mangle-props
	MangleQuoted      MangleQuoted           // Documentation: https://esbuild.github.io/api/#mangle-props
	MangleCache       map[string]interface{} // Documentation: https://esbuild.github.io/api/#mangle-props
	Drop              Drop                   // Documentation: https://esbuild.github.io/api/#drop
	DropLabels        []string               // Documentation: https://esbuild.github.io/api/#drop-labels
	MinifyWhitespace  bool                   // Documentation: https://esbuild.github.io/api/#minify
	MinifyIdentifiers bool                   // Documentation: https://esbuild.github.io/api/#minify
	MinifySyntax      bool                   // Documentation: https://esbuild.github.io/api/#minify
	LineLimit         int                    // Documentation: https://esbuild.github.io/api/#line-limit
	Charset           Charset                // Documentation: https://esbuild.github.io/api/#charset
	TreeShaking       TreeShaking            // Documentation: https://esbuild.github.io/api/#tree-shaking
	IgnoreAnnotations bool                   // Documentation: https://esbuild.github.io/api/#ignore-annotations
	LegalComments     LegalComments          // Documentation: https://esbuild.github.io/api/#legal-comments
	JSX             JSX    // Documentation: https://esbuild.github.io/api/#jsx-mode
	JSXFactory      string // Documentation: https://esbuild.github.io/api/#jsx-factory
	JSXFragment     string // Documentation: https://esbuild.github.io/api/#jsx-fragment
	JSXImportSource string // Documentation: https://esbuild.github.io/api/#jsx-import-source
	JSXDev          bool   // Documentation: https://esbuild.github.io/api/#jsx-dev
	JSXSideEffects  bool   // Documentation: https://esbuild.github.io/api/#jsx-side-effects
	Define    map[string]string // Documentation: https://esbuild.github.io/api/#define
	Pure      []string          // Documentation: https://esbuild.github.io/api/#pure
	KeepNames bool              // Documentation: https://esbuild.github.io/api/#keep-names
	GlobalName        string            // Documentation: https://esbuild.github.io/api/#global-name
	Bundle            bool              // Documentation: https://esbuild.github.io/api/#bundle
	PreserveSymlinks  bool              // Documentation: https://esbuild.github.io/api/#preserve-symlinks
	Splitting         bool              // Documentation: https://esbuild.github.io/api/#splitting
	Outfile           string            // Documentation: https://esbuild.github.io/api/#outfile
	Metafile          bool              // Documentation: https://esbuild.github.io/api/#metafile
	Outdir            string            // Documentation: https://esbuild.github.io/api/#outdir
	Outbase           string            // Documentation: https://esbuild.github.io/api/#outbase
	AbsWorkingDir     string            // Documentation: https://esbuild.github.io/api/#working-directory
	Platform          Platform          // Documentation: https://esbuild.github.io/api/#platform
	Format            Format            // Documentation: https://esbuild.github.io/api/#format
	External          []string          // Documentation: https://esbuild.github.io/api/#external
	Packages          Packages          // Documentation: https://esbuild.github.io/api/#packages
	Alias             map[string]string // Documentation: https://esbuild.github.io/api/#alias
	MainFields        []string          // Documentation: https://esbuild.github.io/api/#main-fields
	Conditions        []string          // Documentation: https://esbuild.github.io/api/#conditions
	Loader            map[string]Loader // Documentation: https://esbuild.github.io/api/#loader
	ResolveExtensions []string          // Documentation: https://esbuild.github.io/api/#resolve-extensions
	Tsconfig          string            // Documentation: https://esbuild.github.io/api/#tsconfig
	TsconfigRaw       string            // Documentation: https://esbuild.github.io/api/#tsconfig-raw
	OutExtension      map[string]string // Documentation: https://esbuild.github.io/api/#out-extension
	PublicPath        string            // Documentation: https://esbuild.github.io/api/#public-path
	Inject            []string          // Documentation: https://esbuild.github.io/api/#inject
	Banner            map[string]string // Documentation: https://esbuild.github.io/api/#banner
	NodePaths         []string          // Documentation: https://esbuild.github.io/api/#node-paths
	EntryNames string // Documentation: https://esbuild.github.io/api/#entry-names
	ChunkNames string // Documentation: https://esbuild.github.io/api/#chunk-names
	AssetNames string // Documentation: https://esbuild.github.io/api/#asset-names
	EntryPoints         []string     // Documentation: https://esbuild.github.io/api/#entry-points
	EntryPointsAdvanced []EntryPoint // Documentation: https://esbuild.github.io/api/#entry-points
	Stdin          *StdinOptions // Documentation: https://esbuild.github.io/api/#stdin
	Write          bool          // Documentation: https://esbuild.github.io/api/#write
	AllowOverwrite bool          // Documentation: https://esbuild.github.io/api/#allow-overwrite
	Plugins        []Plugin      // Documentation: https://esbuild.github.io/plugins/
}
    type BuildResult ¶
type BuildResult struct {
	Errors   []Message
	Warnings []Message
	OutputFiles []OutputFile
	Metafile    string
	MangleCache map[string]interface{}
}
    func Build ¶
func Build(options BuildOptions) BuildResult
Documentation: https://esbuild.github.io/api/#build
type CORSOptions ¶ added in v0.25.4
type CORSOptions struct {
	Origin []string
}
    Documentation: https://esbuild.github.io/api/#cors
type ContextError ¶ added in v0.17.0
type ContextError struct {
	Errors []Message // Option validation errors are returned here
}
    func (*ContextError) Error ¶ added in v0.17.0
func (err *ContextError) Error() string
type Engine ¶ added in v0.5.25
type Engine struct {
	Name    EngineName
	Version string
}
    type EngineName ¶ added in v0.5.25
type EngineName uint8
const ( EngineChrome EngineName = iota EngineDeno EngineEdge EngineFirefox EngineHermes EngineIE EngineIOS EngineNode EngineOpera EngineRhino EngineSafari )
type EntryPoint ¶ added in v0.11.0
type FormatMessagesOptions ¶ added in v0.10.1
type FormatMessagesOptions struct {
	TerminalWidth int
	Kind          MessageKind
	Color         bool
}
    type LegalComments ¶ added in v0.11.15
type LegalComments uint8
const ( LegalCommentsDefault LegalComments = iota LegalCommentsNone LegalCommentsInline LegalCommentsEndOfFile LegalCommentsLinked LegalCommentsExternal )
type MangleQuoted ¶ added in v0.14.24
type MangleQuoted uint8
const ( MangleQuotedFalse MangleQuoted = iota MangleQuotedTrue )
type MessageKind ¶ added in v0.10.1
type MessageKind uint8
const ( ErrorMessage MessageKind = iota WarningMessage )
type OnEndResult ¶ added in v0.17.0
type OnLoadArgs ¶ added in v0.8.1
type OnLoadArgs struct {
	Path       string
	Namespace  string
	Suffix     string
	PluginData interface{}
	With       map[string]string
}
    Documentation: https://esbuild.github.io/plugins/#on-load-arguments
type OnLoadOptions ¶ added in v0.8.1
Documentation: https://esbuild.github.io/plugins/#on-load-options
type OnLoadResult ¶ added in v0.8.1
type OnLoadResult struct {
	PluginName string
	Errors   []Message
	Warnings []Message
	Contents   *string
	ResolveDir string
	Loader     Loader
	PluginData interface{}
	WatchFiles []string
	WatchDirs  []string
}
    Documentation: https://esbuild.github.io/plugins/#on-load-results
type OnResolveArgs ¶ added in v0.8.1
type OnResolveArgs struct {
	Path       string
	Importer   string
	Namespace  string
	ResolveDir string
	Kind       ResolveKind
	PluginData interface{}
	With       map[string]string
}
    Documentation: https://esbuild.github.io/plugins/#on-resolve-arguments
type OnResolveOptions ¶ added in v0.8.1
Documentation: https://esbuild.github.io/plugins/#on-resolve-options
type OnResolveResult ¶ added in v0.8.1
type OnResolveResult struct {
	PluginName string
	Errors   []Message
	Warnings []Message
	Path        string
	External    bool
	SideEffects SideEffects
	Namespace   string
	Suffix      string
	PluginData  interface{}
	WatchFiles []string
	WatchDirs  []string
}
    Documentation: https://esbuild.github.io/plugins/#on-resolve-results
type OnStartResult ¶ added in v0.11.15
type OutputFile ¶
type Plugin ¶ added in v0.8.1
type Plugin struct {
	Name  string
	Setup func(PluginBuild)
}
    type PluginBuild ¶ added in v0.8.1
type PluginBuild struct {
	// Documentation: https://esbuild.github.io/plugins/#build-options
	InitialOptions *BuildOptions
	// Documentation: https://esbuild.github.io/plugins/#resolve
	Resolve func(path string, options ResolveOptions) ResolveResult
	// Documentation: https://esbuild.github.io/plugins/#on-start
	OnStart func(callback func() (OnStartResult, error))
	// Documentation: https://esbuild.github.io/plugins/#on-end
	OnEnd func(callback func(result *BuildResult) (OnEndResult, error))
	// Documentation: https://esbuild.github.io/plugins/#on-resolve
	OnResolve func(options OnResolveOptions, callback func(OnResolveArgs) (OnResolveResult, error))
	// Documentation: https://esbuild.github.io/plugins/#on-load
	OnLoad func(options OnLoadOptions, callback func(OnLoadArgs) (OnLoadResult, error))
	// Documentation: https://esbuild.github.io/plugins/#on-dispose
	OnDispose func(callback func())
}
    type ResolveKind ¶ added in v0.8.52
type ResolveKind uint8
const ( ResolveNone ResolveKind = iota ResolveEntryPoint ResolveJSImportStatement ResolveJSRequireCall ResolveJSDynamicImport ResolveJSRequireResolve ResolveCSSImportRule ResolveCSSComposesFrom ResolveCSSURLToken )
type ResolveOptions ¶ added in v0.14.8
type ResolveOptions struct {
	PluginName string
	Importer   string
	Namespace  string
	ResolveDir string
	Kind       ResolveKind
	PluginData interface{}
	With       map[string]string
}
    Documentation: https://esbuild.github.io/plugins/#resolve-options
type ResolveResult ¶ added in v0.14.8
type ResolveResult struct {
	Errors   []Message
	Warnings []Message
	Path        string
	External    bool
	SideEffects bool
	Namespace   string
	Suffix      string
	PluginData  interface{}
}
    Documentation: https://esbuild.github.io/plugins/#resolve-results
type ServeOnRequestArgs ¶ added in v0.8.12
type ServeOptions ¶ added in v0.8.12
type ServeOptions struct {
	Port      int
	Host      string
	Servedir  string
	Keyfile   string
	Certfile  string
	Fallback  string
	CORS      CORSOptions
	OnRequest func(ServeOnRequestArgs)
}
    Documentation: https://esbuild.github.io/api/#serve-arguments
type ServeResult ¶ added in v0.8.12
Documentation: https://esbuild.github.io/api/#serve-return-values
type SideEffects ¶ added in v0.12.8
type SideEffects uint8
const ( SideEffectsTrue SideEffects = iota SideEffectsFalse )
type SourcesContent ¶ added in v0.8.27
type SourcesContent uint8
const ( SourcesContentInclude SourcesContent = iota SourcesContentExclude )
type StderrColor ¶
type StderrColor uint8
const ( ColorIfTerminal StderrColor = iota ColorNever ColorAlways )
type StdinOptions ¶ added in v0.6.1
type TransformOptions ¶
type TransformOptions struct {
	Color       StderrColor         // Documentation: https://esbuild.github.io/api/#color
	LogLevel    LogLevel            // Documentation: https://esbuild.github.io/api/#log-level
	LogLimit    int                 // Documentation: https://esbuild.github.io/api/#log-limit
	LogOverride map[string]LogLevel // Documentation: https://esbuild.github.io/api/#log-override
	AbsPaths    AbsPaths            // Documentation: https://esbuild.github.io/api/#abs-path
	Sourcemap      SourceMap      // Documentation: https://esbuild.github.io/api/#sourcemap
	SourceRoot     string         // Documentation: https://esbuild.github.io/api/#source-root
	SourcesContent SourcesContent // Documentation: https://esbuild.github.io/api/#sources-content
	Target    Target          // Documentation: https://esbuild.github.io/api/#target
	Engines   []Engine        // Documentation: https://esbuild.github.io/api/#target
	Supported map[string]bool // Documentation: https://esbuild.github.io/api/#supported
	Platform   Platform // Documentation: https://esbuild.github.io/api/#platform
	Format     Format   // Documentation: https://esbuild.github.io/api/#format
	GlobalName string   // Documentation: https://esbuild.github.io/api/#global-name
	MangleProps       string                 // Documentation: https://esbuild.github.io/api/#mangle-props
	ReserveProps      string                 // Documentation: https://esbuild.github.io/api/#mangle-props
	MangleQuoted      MangleQuoted           // Documentation: https://esbuild.github.io/api/#mangle-props
	MangleCache       map[string]interface{} // Documentation: https://esbuild.github.io/api/#mangle-props
	Drop              Drop                   // Documentation: https://esbuild.github.io/api/#drop
	DropLabels        []string               // Documentation: https://esbuild.github.io/api/#drop-labels
	MinifyWhitespace  bool                   // Documentation: https://esbuild.github.io/api/#minify
	MinifyIdentifiers bool                   // Documentation: https://esbuild.github.io/api/#minify
	MinifySyntax      bool                   // Documentation: https://esbuild.github.io/api/#minify
	LineLimit         int                    // Documentation: https://esbuild.github.io/api/#line-limit
	Charset           Charset                // Documentation: https://esbuild.github.io/api/#charset
	TreeShaking       TreeShaking            // Documentation: https://esbuild.github.io/api/#tree-shaking
	IgnoreAnnotations bool                   // Documentation: https://esbuild.github.io/api/#ignore-annotations
	LegalComments     LegalComments          // Documentation: https://esbuild.github.io/api/#legal-comments
	JSX             JSX    // Documentation: https://esbuild.github.io/api/#jsx
	JSXFactory      string // Documentation: https://esbuild.github.io/api/#jsx-factory
	JSXFragment     string // Documentation: https://esbuild.github.io/api/#jsx-fragment
	JSXImportSource string // Documentation: https://esbuild.github.io/api/#jsx-import-source
	JSXDev          bool   // Documentation: https://esbuild.github.io/api/#jsx-dev
	JSXSideEffects  bool   // Documentation: https://esbuild.github.io/api/#jsx-side-effects
	TsconfigRaw string // Documentation: https://esbuild.github.io/api/#tsconfig-raw
	Banner      string // Documentation: https://esbuild.github.io/api/#banner
	Define    map[string]string // Documentation: https://esbuild.github.io/api/#define
	Pure      []string          // Documentation: https://esbuild.github.io/api/#pure
	KeepNames bool              // Documentation: https://esbuild.github.io/api/#keep-names
	Sourcefile string // Documentation: https://esbuild.github.io/api/#sourcefile
	Loader     Loader // Documentation: https://esbuild.github.io/api/#loader
}
    type TransformResult ¶
type TransformResult struct {
	Errors   []Message
	Warnings []Message
	Code          []byte
	Map           []byte
	LegalComments []byte
	MangleCache map[string]interface{}
}
    func Transform ¶
func Transform(input string, options TransformOptions) TransformResult
Documentation: https://esbuild.github.io/api/#transform
type TreeShaking ¶ added in v0.8.10
type TreeShaking uint8
const ( TreeShakingDefault TreeShaking = iota TreeShakingFalse TreeShakingTrue )
type WatchOptions ¶ added in v0.17.0
type WatchOptions struct {
	Delay int // In milliseconds
}
    Documentation: https://esbuild.github.io/api/#watch-arguments