Skip to content
This repository has been archived by the owner on Dec 15, 2022. It is now read-only.

Commit

Permalink
types: add type name to scope earlier so that look-ups in recursive c…
Browse files Browse the repository at this point in the history
…alls see them, otherwise duplicates can be produced

Signed-off-by: Muvaffak Onus <[email protected]>
  • Loading branch information
muvaf committed Dec 22, 2021
1 parent 3306e6e commit 802f0fd
Showing 1 changed file with 6 additions and 3 deletions.
9 changes: 6 additions & 3 deletions pkg/types/builder.go
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,11 @@ func (g *Builder) buildResource(res *schema.Resource, cfg *config.Resource, tfPa
}
obsName := types.NewTypeName(token.NoPos, g.Package, obsTypeName, nil)

// We insert them to the package scope so that the type name calculations in
// recursive calls are checked against their upper level type's name as well.
g.Package.Scope().Insert(paramName)
g.Package.Scope().Insert(obsName)

// Note(turkenh): We don't know how many number of fields would be a
// parameter or an observation in advance, hence opted for not to
// preallocate (//nolint:prealloc). But we know a rough upper bound,
Expand Down Expand Up @@ -205,18 +210,16 @@ func (g *Builder) buildResource(res *schema.Resource, cfg *config.Resource, tfPa
}

// NOTE(muvaf): Not every struct has both computed and configurable fields,
// so some of the types we generate here are empty and unnecessary. However,
// so some types we generate here are empty and unnecessary. However,
// there are valid types with zero fields and we don't have the information
// to differentiate between valid zero fields and unnecessary one. So we generate
// two structs for every complex type.
// See usage of wafv2EmptySchema() in aws_wafv2_web_acl here:
// https://github.com/hashicorp/terraform-provider-aws/blob/main/aws/wafv2_helper.go#L13
paramType := types.NewNamed(paramName, types.NewStruct(paramFields, paramTags), nil)
g.Package.Scope().Insert(paramType.Obj())
g.genTypes = append(g.genTypes, paramType)

obsType := types.NewNamed(obsName, types.NewStruct(obsFields, obsTags), nil)
g.Package.Scope().Insert(obsType.Obj())
g.genTypes = append(g.genTypes, obsType)

return paramType, obsType, nil
Expand Down

0 comments on commit 802f0fd

Please sign in to comment.