57 lines
2.6 KiB
Go
57 lines
2.6 KiB
Go
// Licensed to Pulumi Corporation ("Pulumi") under one or more
|
|
// contributor license agreements. See the NOTICE file distributed with
|
|
// this work for additional information regarding copyright ownership.
|
|
// Pulumi licenses this file to You under the Apache License, Version 2.0
|
|
// (the "License"); you may not use this file except in compliance with
|
|
// the License. You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
// Package pack contains the core LumiPack metadata types.
|
|
package pack
|
|
|
|
import (
|
|
"github.com/pulumi/lumi/pkg/compiler/ast"
|
|
"github.com/pulumi/lumi/pkg/diag"
|
|
"github.com/pulumi/lumi/pkg/tokens"
|
|
)
|
|
|
|
// Package is a top-level package definition.
|
|
type Package struct {
|
|
Name tokens.PackageName `json:"name"` // a required fully qualified name.
|
|
|
|
Description *string `json:"description,omitempty"` // an optional informational description.
|
|
Author *string `json:"author,omitempty"` // an optional author.
|
|
Website *string `json:"website,omitempty"` // an optional website for additional info.
|
|
License *string `json:"license,omitempty"` // an optional license governing this package's usage.
|
|
|
|
Analyzers *Analyzers `json:"analyzers,omitempty"` // any analyzers enabled for this project.
|
|
Dependencies *Dependencies `json:"dependencies,omitempty"` // all of the package dependencies.
|
|
Modules *ast.Modules `json:"modules,omitempty"` // a collection of top-level modules.
|
|
Aliases *ModuleAliases `json:"aliases,omitempty"` // an optional mapping of aliased module names.
|
|
|
|
Doc *diag.Document `json:"-"` // the document from which this package came.
|
|
}
|
|
|
|
var _ diag.Diagable = (*Package)(nil)
|
|
|
|
func (s *Package) Where() (*diag.Document, *diag.Location) {
|
|
return s.Doc, nil
|
|
}
|
|
|
|
// Analyzers is a list of analyzers to run on this project.
|
|
type Analyzers []tokens.QName
|
|
|
|
// Dependencies maps dependency names to the full URL, including version, of the package.
|
|
type Dependencies map[tokens.PackageName]PackageURLString
|
|
|
|
// ModuleAliases can be used to map module names to other module names during binding. This is useful for representing
|
|
// "default" modules in various forms; e.g., "index" as ".default"; "lib/index" as "lib"; and so on.
|
|
type ModuleAliases map[tokens.ModuleName]tokens.ModuleName
|