2020-02-27 18:04:34 +00:00
|
|
|
// Copyright 2016-2020, Pulumi Corporation.
|
|
|
|
//
|
|
|
|
// Licensed 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.
|
|
|
|
|
2020-03-09 17:35:20 +00:00
|
|
|
package codegen
|
2020-02-27 18:04:34 +00:00
|
|
|
|
|
|
|
import (
|
2020-06-17 21:02:45 +00:00
|
|
|
"github.com/pgavlin/goldmark/ast"
|
2020-03-26 17:30:04 +00:00
|
|
|
|
2021-03-17 13:20:05 +00:00
|
|
|
"github.com/pulumi/pulumi/pkg/v3/codegen/schema"
|
2020-03-26 17:30:04 +00:00
|
|
|
)
|
|
|
|
|
2020-03-09 17:35:20 +00:00
|
|
|
// DocLanguageHelper is an interface for extracting language-specific information from a Pulumi schema.
|
|
|
|
// See the implementation for this interface under each of the language code generators.
|
|
|
|
type DocLanguageHelper interface {
|
2020-03-23 21:17:14 +00:00
|
|
|
GetPropertyName(p *schema.Property) (string, error)
|
2020-12-16 17:22:44 +00:00
|
|
|
GetEnumName(e *schema.Enum, typeName string) (string, error)
|
2020-04-14 20:59:23 +00:00
|
|
|
GetDocLinkForResourceType(pkg *schema.Package, moduleName, typeName string) string
|
2020-04-15 18:58:08 +00:00
|
|
|
GetDocLinkForPulumiType(pkg *schema.Package, typeName string) string
|
2020-04-14 20:59:23 +00:00
|
|
|
GetDocLinkForResourceInputOrOutputType(pkg *schema.Package, moduleName, typeName string, input bool) string
|
|
|
|
GetDocLinkForFunctionInputOrOutputType(pkg *schema.Package, moduleName, typeName string, input bool) string
|
2021-06-24 16:17:55 +00:00
|
|
|
GetLanguageTypeString(pkg *schema.Package, moduleName string, t schema.Type, input bool) string
|
2020-04-28 00:47:01 +00:00
|
|
|
|
|
|
|
GetFunctionName(modName string, f *schema.Function) string
|
2020-03-12 00:58:12 +00:00
|
|
|
// GetResourceFunctionResultName returns the name of the result type when a static resource function is used to lookup
|
|
|
|
// an existing resource.
|
2020-04-28 00:47:01 +00:00
|
|
|
GetResourceFunctionResultName(modName string, f *schema.Function) string
|
2021-08-12 21:31:15 +00:00
|
|
|
|
|
|
|
GetMethodName(m *schema.Method) string
|
2021-10-01 18:33:02 +00:00
|
|
|
GetMethodResultName(pkg *schema.Package, modName string, r *schema.Resource, m *schema.Method) string
|
2021-08-12 21:31:15 +00:00
|
|
|
|
2020-05-12 22:37:37 +00:00
|
|
|
// GetModuleDocLink returns the display name and the link for a module (including root modules) in a given package.
|
|
|
|
GetModuleDocLink(pkg *schema.Package, modName string) (string, string)
|
2020-02-27 18:04:34 +00:00
|
|
|
}
|
2020-03-26 17:30:04 +00:00
|
|
|
|
2020-06-18 19:32:15 +00:00
|
|
|
func filterExamples(source []byte, node ast.Node, lang string) {
|
2020-06-17 21:02:45 +00:00
|
|
|
var c, next ast.Node
|
|
|
|
for c = node.FirstChild(); c != nil; c = next {
|
2020-06-18 19:32:15 +00:00
|
|
|
filterExamples(source, c, lang)
|
2020-03-26 17:30:04 +00:00
|
|
|
|
2020-06-17 21:02:45 +00:00
|
|
|
next = c.NextSibling()
|
|
|
|
switch c := c.(type) {
|
|
|
|
case *ast.FencedCodeBlock:
|
2020-11-09 14:12:58 +00:00
|
|
|
sourceLang := string(c.Language(source))
|
|
|
|
if sourceLang != lang && sourceLang != "sh" {
|
2020-06-17 21:02:45 +00:00
|
|
|
node.RemoveChild(node, c)
|
|
|
|
}
|
|
|
|
case *schema.Shortcode:
|
|
|
|
switch string(c.Name) {
|
|
|
|
case schema.ExampleShortcode:
|
|
|
|
hasCode := false
|
|
|
|
for gc := c.FirstChild(); gc != nil; gc = gc.NextSibling() {
|
|
|
|
if gc.Kind() == ast.KindFencedCodeBlock {
|
|
|
|
hasCode = true
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if hasCode {
|
|
|
|
var grandchild, nextGrandchild ast.Node
|
|
|
|
for grandchild = c.FirstChild(); grandchild != nil; grandchild = nextGrandchild {
|
|
|
|
nextGrandchild = grandchild.NextSibling()
|
|
|
|
node.InsertBefore(node, c, grandchild)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
node.RemoveChild(node, c)
|
|
|
|
case schema.ExamplesShortcode:
|
|
|
|
if first := c.FirstChild(); first != nil {
|
|
|
|
first.SetBlankPreviousLines(c.HasBlankPreviousLines())
|
|
|
|
}
|
|
|
|
|
|
|
|
var grandchild, nextGrandchild ast.Node
|
|
|
|
for grandchild = c.FirstChild(); grandchild != nil; grandchild = nextGrandchild {
|
|
|
|
nextGrandchild = grandchild.NextSibling()
|
|
|
|
node.InsertBefore(node, c, grandchild)
|
|
|
|
}
|
|
|
|
node.RemoveChild(node, c)
|
|
|
|
}
|
2020-03-26 17:30:04 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-06-18 19:32:15 +00:00
|
|
|
// FilterExamples filters the code snippets in a schema docstring to include only those that target the given language.
|
|
|
|
func FilterExamples(description string, lang string) string {
|
2020-03-26 17:30:04 +00:00
|
|
|
if description == "" {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
2020-06-17 21:02:45 +00:00
|
|
|
source := []byte(description)
|
|
|
|
parsed := schema.ParseDocs(source)
|
2020-06-18 19:32:15 +00:00
|
|
|
filterExamples(source, parsed, lang)
|
2020-06-17 21:02:45 +00:00
|
|
|
return schema.RenderDocsToString(source, parsed)
|
2020-03-26 17:30:04 +00:00
|
|
|
}
|