mirror of
https://github.com/wailsapp/wails.git
synced 2025-05-05 21:02:13 +08:00

* Support variadic arguments and slice, pointer types * Fix computation of type namespaces * Improve comments and general formatting * Set default values correctly for composite types * Add templates for bindings Additionally: * fixes generation of tuple return type * improves imports and namespacing in JS mode * general cleanup of generated code * Simplify import list construction * Refactor type generation code Improves support for unknown types (encoded as any) and maps (using Typescript index signatures) * Support slices with pointer elements * Match encoding/json behaviour in struct parser * Update tests and example * Add tests for complex method signatures and json tag parsing * Add test `function_multiple_files` * Attempt looking up idents with missing denotation * Update test data * fix quoted bool field * Test quoted booleans * Delete old parser code * Remove old test data * Update bindgen flags * Makes call by ID the default * Add package loading code * Add static analyser * Temporarily ignore binding generation code * Add complex slice expressions test * Fix variable reference analysis * Unwrap casts to interface types * Complete code comments * Refactor static analyser * Restrict options struct usage * Update tests * Fix method selector sink and source processing * Improve Set API * Add package info collector * Rename analyser package to analyse * Improve template functions * Add index file templates * Add glue code for binding generation * Refactor collection and rendering code * Implement binding generator * Implement global index generation * Improve marshaler and alias handling * Use package path in binding calls by name * Implement model collection and rendering * Fix wrong exit condition in analyser * Fix enum rendering * Generate shortcuts for all packages. * Implement generator tests * Ignore non-pointer bound types * Treat main package specially * Compute stats * Plug new API into generate command * Support all named types * Update JS runtime * Report dual role types * Remove go1.22 syntax * Fix type assertion in TS bindings * encoding/json compliance for arrays and slices * Ignore got files in testdata * Cleanup type rendering mechanism * Update JS runtime * Implement generic models * Add missing field in renderer initialisation * Improve generic creation code * Add generic model test * Add error reporting infrastructure * Support configurable file names * Detect file naming collisions * Print final error report * New shortcut file structure + collision detection * Update test layout and data * Autoconfiguration for analyser tests * Live progress reporting * Update code comments * Fix model doc rendering * Simplify name resolution * Add test for out of tree types * Fix generic creation code * Fix potential collisions between methods and models * Fix generic class alias rendering * Report model discovery in debug mode * Add interface mode for JS * Collect interface method comments * Add interface methods test * Unwrap generic instantiations in method receivers * Fix rendering of nullable types in interface mode * Fix rendering of class aliases * Expose promise cancel method to typescript * Update test data * Update binding example * Fix rendering of aliased quoted type params * Move to strongly typed bindings * Implement lightweight analyser * Update test cases * Update binding example * Add complex instantiation test * Load full dependency tree * Rewrite collector * Update renderer to match new collector * Update generator to match new collector * Update test data * Update binding example * Configure includes and injections by language * Improve system path resolution * Support rich conditions in inject/include directives * Fix error handling in Generator.Generate * Retrieve compiled go file paths from fileset * Do not rely on struct info in struct flattening algorithm * Fix doc comment for findDeclaraion * Fix bugs in embedded field handling * Fix bugs and comments in package collection * Remove useless fields from ServiceInfo * Fix empty line at the beginning of TS indexes * Remove global index and shortcuts * Remove generation tests for individual packages * Enforce lower-case file names * Update test data * Improve error reporting * Update binding example * Reintroduce go1.22 syntax * Improve relative import path computation * Improve alias support * Add alias test * Update test data * Remove no services error * Rename global analyser test * Add workaround and test for bug in typeutil.Map * Update test data * Do not split fully qualified names * Update typeutil package and remove workaround * Unify alias/named type handling * Fix rendering of generic named class aliases * Fix rendering of array types * Minor tweaks and cleanups * Rmove namespaced export construct * Update test data * Update binding example * Break type cycles * Fix typo in comment * Fix creation code for cyclic types * Fix type of variadic params in interface mode * Update test data * Fix bad whitespace * Refactor type assertions inside bound methods * Update test data * Rename field application.Options.Bind to Services * Rename parser package to generator * Update binding example * Update test data * Update generator readme * Add typescript test harness * Move test output to new subfolder * Fix code generation bugs * Use .js extensions in TS mode imports * Update test data * Revert default generator output dir to frontend/bindings * Bump runtime package version * Update templates * Update changelog * Improve newline handling --------- Co-authored-by: Andreas Bichinger <andreas.bichinger@gmail.com>
137 lines
3.8 KiB
Go
137 lines
3.8 KiB
Go
package render
|
|
|
|
import (
|
|
"bufio"
|
|
"bytes"
|
|
"go/ast"
|
|
"strings"
|
|
"unicode"
|
|
|
|
"github.com/wailsapp/wails/v3/internal/generator/collect"
|
|
)
|
|
|
|
// hasdoc checks whether the given comment group contains actual doc comments.
|
|
func hasdoc(group *ast.CommentGroup) bool {
|
|
if group == nil {
|
|
return false
|
|
}
|
|
|
|
// TODO: this is horrible, make it more efficient?
|
|
return strings.ContainsFunc(group.Text(), func(r rune) bool { return !unicode.IsSpace(r) })
|
|
}
|
|
|
|
var commentTerminator = []byte("*/")
|
|
|
|
// jsdoc splits the given comment into lines and rewrites it as follows:
|
|
// - first, line terminators are stripped;
|
|
// - then a line terminator, the indent string and ' * '
|
|
// are prepended to each line;
|
|
// - occurrences of the comment terminator '*/' are replaced with '* /'
|
|
// to avoid accidentally terminating the surrounding comment.
|
|
//
|
|
// All lines thus modified are joined back together.
|
|
//
|
|
// The returned string can be inserted in a multiline JSDoc comment
|
|
// with the given indentation.
|
|
func jsdoc(comment string, indent string) string {
|
|
var builder strings.Builder
|
|
prefix := []byte(newline + indent + " * ")
|
|
|
|
scanner := bufio.NewScanner(bytes.NewReader([]byte(comment)))
|
|
for scanner.Scan() {
|
|
line := scanner.Bytes()
|
|
|
|
// Prepend prefix.
|
|
builder.Write(prefix)
|
|
|
|
// Escape comment terminators.
|
|
for t := bytes.Index(line, commentTerminator); t >= 0; t = bytes.Index(line, commentTerminator) {
|
|
builder.Write(line[:t+1])
|
|
builder.WriteRune(' ')
|
|
line = line[t+1:]
|
|
}
|
|
|
|
builder.Write(line)
|
|
}
|
|
|
|
return builder.String()
|
|
}
|
|
|
|
// jsdocline removes all newlines in the given comment
|
|
// and escapes comment terminators using the same strategy as jsdoc.
|
|
func jsdocline(comment string) string {
|
|
var builder strings.Builder
|
|
|
|
scanner := bufio.NewScanner(bytes.NewReader([]byte(comment)))
|
|
for scanner.Scan() {
|
|
line := bytes.TrimSpace(scanner.Bytes())
|
|
if len(line) == 0 {
|
|
// Skip empty lines.
|
|
continue
|
|
}
|
|
|
|
// Prepend space to separate lines.
|
|
builder.WriteRune(' ')
|
|
|
|
// Escape comment terminators.
|
|
for t := bytes.Index(line, commentTerminator); t >= 0; t = bytes.Index(line, commentTerminator) {
|
|
builder.Write(line[:t+1])
|
|
builder.WriteRune(' ')
|
|
line = line[t+1:]
|
|
}
|
|
|
|
builder.Write(line)
|
|
}
|
|
|
|
// Return resulting string, but skip initial space.
|
|
return builder.String()[1:]
|
|
}
|
|
|
|
// isjsdocid returns true if the given string is a valid ECMAScript identifier,
|
|
// excluding unicode escape sequences. This is the property name format supported by JSDoc.
|
|
func isjsdocid(name string) bool {
|
|
for i, r := range name {
|
|
if i == 0 && !id_start(r) && r != '$' && r != '_' {
|
|
return false
|
|
} else if i > 0 && !id_continue(r) && r != '$' {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
}
|
|
|
|
// isjsdocobj returns true if all field names in the given model
|
|
// are valid jsdoc property names.
|
|
func isjsdocobj(model *collect.ModelInfo) bool {
|
|
if len(model.Fields) == 0 {
|
|
return false
|
|
}
|
|
for _, decl := range model.Fields {
|
|
for _, field := range decl {
|
|
if !isjsdocid(field.JsonName) {
|
|
return false
|
|
}
|
|
}
|
|
}
|
|
return true
|
|
}
|
|
|
|
// id_start returns true if the given rune is in the ID_Start category
|
|
// according to UAX#31 (https://unicode.org/reports/tr31/).
|
|
func id_start(r rune) bool {
|
|
return (unicode.IsLetter(r) ||
|
|
unicode.Is(unicode.Nl, r) ||
|
|
unicode.Is(unicode.Other_ID_Start, r)) && !unicode.Is(unicode.Pattern_Syntax, r) && !unicode.Is(unicode.Pattern_White_Space, r)
|
|
}
|
|
|
|
// id_continue returns true if the given rune is in the ID_Continue category
|
|
// according to UAX#31 (https://unicode.org/reports/tr31/).
|
|
func id_continue(r rune) bool {
|
|
return (id_start(r) ||
|
|
unicode.Is(unicode.Mn, r) ||
|
|
unicode.Is(unicode.Mc, r) ||
|
|
unicode.Is(unicode.Nd, r) ||
|
|
unicode.Is(unicode.Pc, r) ||
|
|
unicode.Is(unicode.Other_ID_Continue, r)) && !unicode.Is(unicode.Pattern_Syntax, r) && !unicode.Is(unicode.Pattern_White_Space, r)
|
|
}
|