Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 4 additions & 10 deletions internal/cmd/createdb.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,7 @@ import (
"github.com/spf13/cobra"
"github.com/sqlc-dev/sqlc/internal/config"
"github.com/sqlc-dev/sqlc/internal/dbmanager"
"github.com/sqlc-dev/sqlc/internal/migrations"
"github.com/sqlc-dev/sqlc/internal/sql/sqlpath"
"github.com/sqlc-dev/sqlc/internal/schemautil"
)

var createDBCmd = &cobra.Command{
Expand Down Expand Up @@ -76,17 +75,12 @@ func CreateDB(ctx context.Context, dir, filename, querySetName string, o *Option
}

var ddl []string
files, err := sqlpath.Glob(queryset.Schema)
ddl, err = schemautil.LoadSchemasForApply(queryset.Schema, string(queryset.Engine), func(warning string) {
fmt.Fprintln(o.Stderr, warning)
})
if err != nil {
return err
}
for _, schema := range files {
contents, err := os.ReadFile(schema)
if err != nil {
return fmt.Errorf("read file: %w", err)
}
ddl = append(ddl, migrations.RemoveRollbackStatements(string(contents)))
}

now := time.Now().UTC().UnixNano()
client := dbmanager.NewClient(conf.Servers)
Expand Down
6 changes: 6 additions & 0 deletions internal/cmd/generate.go
Original file line number Diff line number Diff line change
Expand Up @@ -306,6 +306,9 @@ func parse(ctx context.Context, name, dir string, sql config.SQL, combo config.C
return nil, true
}
if err := c.ParseCatalog(sql.Schema); err != nil {
for _, warning := range c.Warnings() {
fmt.Fprintln(stderr, warning)
}
fmt.Fprintf(stderr, "# package %s\n", name)
if parserErr, ok := err.(*multierr.Error); ok {
for _, fileErr := range parserErr.Errs() {
Expand All @@ -316,6 +319,9 @@ func parse(ctx context.Context, name, dir string, sql config.SQL, combo config.C
}
return nil, true
}
for _, warning := range c.Warnings() {
fmt.Fprintln(stderr, warning)
}
if parserOpts.Debug.DumpCatalog {
debug.Dump(c.Catalog())
}
Expand Down
10 changes: 5 additions & 5 deletions internal/cmd/process.go
Original file line number Diff line number Diff line change
Expand Up @@ -122,12 +122,12 @@ func processQuerySets(ctx context.Context, rp ResultProcessor, conf *config.Conf
if err := grp.Wait(); err != nil {
return err
}
if errored {
for i, _ := range stderrs {
if _, err := io.Copy(stderr, &stderrs[i]); err != nil {
return err
}
for i := range stderrs {
if _, err := io.Copy(stderr, &stderrs[i]); err != nil {
return err
}
}
if errored {
return fmt.Errorf("errored")
}
return nil
Expand Down
14 changes: 4 additions & 10 deletions internal/cmd/verify.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,11 +14,10 @@ import (

"github.com/sqlc-dev/sqlc/internal/config"
"github.com/sqlc-dev/sqlc/internal/dbmanager"
"github.com/sqlc-dev/sqlc/internal/migrations"
"github.com/sqlc-dev/sqlc/internal/plugin"
"github.com/sqlc-dev/sqlc/internal/quickdb"
pb "github.com/sqlc-dev/sqlc/internal/quickdb/v1"
"github.com/sqlc-dev/sqlc/internal/sql/sqlpath"
"github.com/sqlc-dev/sqlc/internal/schemautil"
)

func init() {
Expand Down Expand Up @@ -93,17 +92,12 @@ func Verify(ctx context.Context, dir, filename string, opts *Options) error {

// Read the schema files into memory, removing rollback statements
var ddl []string
files, err := sqlpath.Glob(current.Schema)
ddl, err = schemautil.LoadSchemasForApply(current.Schema, string(current.Engine), func(warning string) {
fmt.Fprintln(stderr, warning)
})
if err != nil {
return err
}
for _, schema := range files {
contents, err := os.ReadFile(schema)
if err != nil {
return fmt.Errorf("read file: %w", err)
}
ddl = append(ddl, migrations.RemoveRollbackStatements(string(contents)))
}

var codegen plugin.GenerateRequest
if err := proto.Unmarshal(qs.CodegenRequest.Contents, &codegen); err != nil {
Expand Down
30 changes: 10 additions & 20 deletions internal/cmd/vet.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,12 +27,11 @@ import (
"github.com/sqlc-dev/sqlc/internal/config"
"github.com/sqlc-dev/sqlc/internal/dbmanager"
"github.com/sqlc-dev/sqlc/internal/debug"
"github.com/sqlc-dev/sqlc/internal/migrations"
"github.com/sqlc-dev/sqlc/internal/opts"
"github.com/sqlc-dev/sqlc/internal/plugin"
"github.com/sqlc-dev/sqlc/internal/quickdb"
"github.com/sqlc-dev/sqlc/internal/schemautil"
"github.com/sqlc-dev/sqlc/internal/shfmt"
"github.com/sqlc-dev/sqlc/internal/sql/sqlpath"
"github.com/sqlc-dev/sqlc/internal/vet"
)

Expand Down Expand Up @@ -422,18 +421,12 @@ func (c *checker) fetchDatabaseUri(ctx context.Context, s config.SQL) (string, f
c.Client = dbmanager.NewClient(c.Conf.Servers)
})

var ddl []string
files, err := sqlpath.Glob(s.Schema)
ddl, err := schemautil.LoadSchemasForApply(s.Schema, string(s.Engine), func(warning string) {
fmt.Fprintln(c.Stderr, warning)
})
if err != nil {
return "", cleanup, err
}
for _, schema := range files {
contents, err := os.ReadFile(schema)
if err != nil {
return "", cleanup, fmt.Errorf("read file: %w", err)
}
ddl = append(ddl, migrations.RemoveRollbackStatements(string(contents)))
}

resp, err := c.Client.CreateDatabase(ctx, &dbmanager.CreateDatabaseRequest{
Engine: string(s.Engine),
Expand Down Expand Up @@ -540,18 +533,15 @@ func (c *checker) checkSQL(ctx context.Context, s config.SQL) error {
defer db.Close()
// For in-memory SQLite databases, apply migrations
if isInMemorySQLite(dburl) {
files, err := sqlpath.Glob(s.Schema)
ddl, err := schemautil.LoadSchemasForApply(s.Schema, string(s.Engine), func(warning string) {
fmt.Fprintln(c.Stderr, warning)
})
if err != nil {
return fmt.Errorf("schema: %w", err)
}
for _, schema := range files {
contents, err := os.ReadFile(schema)
if err != nil {
return fmt.Errorf("read schema file: %w", err)
}
ddl := migrations.RemoveRollbackStatements(string(contents))
if _, err := db.ExecContext(ctx, ddl); err != nil {
return fmt.Errorf("apply schema %s: %w", schema, err)
for _, stmt := range ddl {
if _, err := db.ExecContext(ctx, stmt); err != nil {
return fmt.Errorf("apply schema: %w", err)
}
}
}
Expand Down
8 changes: 6 additions & 2 deletions internal/compiler/compile.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,8 +38,12 @@ func (c *Compiler) parseCatalog(schemas []string) error {
merr.Add(filename, "", 0, err)
continue
}
contents := migrations.RemoveRollbackStatements(string(blob))
contents = migrations.RemovePsqlMetaCommands(contents)
contents, warnings, err := migrations.PreprocessSchema(string(blob), string(c.conf.Engine))
if err != nil {
merr.Add(filename, string(blob), 0, err)
continue
}
c.warns = append(c.warns, warnings...)
c.schema = append(c.schema, contents)

// In database-only mode, we parse the schema to validate syntax
Expand Down
7 changes: 7 additions & 0 deletions internal/compiler/engine.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ type Compiler struct {
selector selector

schema []string
warns []string

// databaseOnlyMode indicates that the compiler should use database-only analysis
// and skip building the internal catalog from schema files (analyzer.database: only)
Expand Down Expand Up @@ -138,6 +139,12 @@ func (c *Compiler) Result() *Result {
return c.result
}

// Warnings returns a copy of any non-fatal schema preprocessing warnings
// collected while parsing the catalog.
func (c *Compiler) Warnings() []string {
return append([]string(nil), c.warns...)
}

func (c *Compiler) Close(ctx context.Context) {
if c.analyzer != nil {
c.analyzer.Close(ctx)
Expand Down
5 changes: 1 addition & 4 deletions internal/endtoend/testdata/pg_dump/exec.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,3 @@
{
"contexts": ["base"],
"meta": {
"invalid_schema": true
}
"contexts": ["base"]
}
Loading
Loading