2022-04-19 16:39:23 +00:00
|
|
|
// Code generated by test DO NOT EDIT.
|
|
|
|
// *** WARNING: Do not edit by hand unless you're certain you know what you are doing! ***
|
2021-11-18 20:23:30 +00:00
|
|
|
|
|
|
|
package example
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"reflect"
|
|
|
|
|
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
|
2023-06-14 16:34:49 +00:00
|
|
|
"plain-object-defaults/example/internal"
|
2021-11-23 23:10:15 +00:00
|
|
|
"plain-object-defaults/example/mod1"
|
2021-11-18 20:23:30 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type ModuleTest struct {
|
|
|
|
pulumi.CustomResourceState
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewModuleTest registers a new resource with the given unique name, arguments, and options.
|
|
|
|
func NewModuleTest(ctx *pulumi.Context,
|
|
|
|
name string, args *ModuleTestArgs, opts ...pulumi.ResourceOption) (*ModuleTest, error) {
|
|
|
|
if args == nil {
|
|
|
|
args = &ModuleTestArgs{}
|
|
|
|
}
|
|
|
|
|
2021-11-23 23:10:15 +00:00
|
|
|
if args.Mod1 != nil {
|
2021-12-03 20:28:43 +00:00
|
|
|
args.Mod1 = args.Mod1.ToTypPtrOutput().ApplyT(func(v *mod1.Typ) *mod1.Typ { return v.Defaults() }).(mod1.TypPtrOutput)
|
2021-11-23 23:10:15 +00:00
|
|
|
}
|
|
|
|
if args.Val != nil {
|
2021-12-03 20:28:43 +00:00
|
|
|
args.Val = args.Val.ToTypPtrOutput().ApplyT(func(v *Typ) *Typ { return v.Defaults() }).(TypPtrOutput)
|
2021-11-23 23:10:15 +00:00
|
|
|
}
|
2023-06-14 16:34:49 +00:00
|
|
|
opts = internal.PkgResourceDefaultOpts(opts)
|
2021-11-18 20:23:30 +00:00
|
|
|
var resource ModuleTest
|
|
|
|
err := ctx.RegisterResource("example:index:moduleTest", name, args, &resource, opts...)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return &resource, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetModuleTest gets an existing ModuleTest resource's state with the given name, ID, and optional
|
|
|
|
// state properties that are used to uniquely qualify the lookup (nil if not required).
|
|
|
|
func GetModuleTest(ctx *pulumi.Context,
|
|
|
|
name string, id pulumi.IDInput, state *ModuleTestState, opts ...pulumi.ResourceOption) (*ModuleTest, error) {
|
|
|
|
var resource ModuleTest
|
|
|
|
err := ctx.ReadResource("example:index:moduleTest", name, id, state, &resource, opts...)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return &resource, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Input properties used for looking up and filtering ModuleTest resources.
|
|
|
|
type moduleTestState struct {
|
|
|
|
}
|
|
|
|
|
|
|
|
type ModuleTestState struct {
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ModuleTestState) ElementType() reflect.Type {
|
|
|
|
return reflect.TypeOf((*moduleTestState)(nil)).Elem()
|
|
|
|
}
|
|
|
|
|
|
|
|
type moduleTestArgs struct {
|
|
|
|
Mod1 *mod1.Typ `pulumi:"mod1"`
|
|
|
|
Val *Typ `pulumi:"val"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// The set of arguments for constructing a ModuleTest resource.
|
|
|
|
type ModuleTestArgs struct {
|
|
|
|
Mod1 mod1.TypPtrInput
|
|
|
|
Val TypPtrInput
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ModuleTestArgs) ElementType() reflect.Type {
|
|
|
|
return reflect.TypeOf((*moduleTestArgs)(nil)).Elem()
|
|
|
|
}
|
|
|
|
|
|
|
|
type ModuleTestInput interface {
|
|
|
|
pulumi.Input
|
|
|
|
|
|
|
|
ToModuleTestOutput() ModuleTestOutput
|
|
|
|
ToModuleTestOutputWithContext(ctx context.Context) ModuleTestOutput
|
|
|
|
}
|
|
|
|
|
|
|
|
func (*ModuleTest) ElementType() reflect.Type {
|
[codegen/go] Remove ResourcePtr input/output types (#8449)
These changes remove the `Ptr` variants of input/ouptut types for
resources. A `TPtr` input or output is normally generated for `T` if `T`
is present in an `optional(input(T))` or `optional(output(T))` and if
the Go representation for `T` is not nilable. The generation of `Ptr`
variants for resource types breaks the latter rule: the canonical
representation of a resource type named `Foo` is a pointer to a struct
type named `Foo` (i.e. `*Foo`). `Foo` itself is not a resource, as it
does not implement the Go `Resource` interface. Because this
representation already accommodates `nil` to indicate the lack of a
value, we need not generate `FooPtr{Input,Output}` types.
Besides being unnecessary, the implementation of `Ptr` types for
resources was incorrect. Rather than using `**Foo` as their element
type, these types use `*Foo`--identical to the element type used for
the normal input/output types. Furthermore, the generated code for
at least `FooOutput.ToFooPtrOutputWithContext` and `FooPtrOutput.Elem`
was incorrect, making these types virtually unusable in practice.
Finally, these `Ptr` types should never appear on input/output
properties in practice, as the logic we use to generate input and output
type references never generates them for `optional({input,output}(T)).
Instead, it generates references to the standard input/output types.
Though this is _technically_ a breaking change--it changes the set of
exported types for any package that defines resources--I believe that in
practice it will be invisible to users for the reasons stated above.
These types are not usable, and were never referenced.
This is preparatory work for #7943.
2021-11-23 18:24:56 +00:00
|
|
|
return reflect.TypeOf((**ModuleTest)(nil)).Elem()
|
2021-11-18 20:23:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (i *ModuleTest) ToModuleTestOutput() ModuleTestOutput {
|
|
|
|
return i.ToModuleTestOutputWithContext(context.Background())
|
|
|
|
}
|
|
|
|
|
|
|
|
func (i *ModuleTest) ToModuleTestOutputWithContext(ctx context.Context) ModuleTestOutput {
|
|
|
|
return pulumi.ToOutputWithContext(ctx, i).(ModuleTestOutput)
|
|
|
|
}
|
|
|
|
|
|
|
|
type ModuleTestOutput struct{ *pulumi.OutputState }
|
|
|
|
|
|
|
|
func (ModuleTestOutput) ElementType() reflect.Type {
|
[codegen/go] Remove ResourcePtr input/output types (#8449)
These changes remove the `Ptr` variants of input/ouptut types for
resources. A `TPtr` input or output is normally generated for `T` if `T`
is present in an `optional(input(T))` or `optional(output(T))` and if
the Go representation for `T` is not nilable. The generation of `Ptr`
variants for resource types breaks the latter rule: the canonical
representation of a resource type named `Foo` is a pointer to a struct
type named `Foo` (i.e. `*Foo`). `Foo` itself is not a resource, as it
does not implement the Go `Resource` interface. Because this
representation already accommodates `nil` to indicate the lack of a
value, we need not generate `FooPtr{Input,Output}` types.
Besides being unnecessary, the implementation of `Ptr` types for
resources was incorrect. Rather than using `**Foo` as their element
type, these types use `*Foo`--identical to the element type used for
the normal input/output types. Furthermore, the generated code for
at least `FooOutput.ToFooPtrOutputWithContext` and `FooPtrOutput.Elem`
was incorrect, making these types virtually unusable in practice.
Finally, these `Ptr` types should never appear on input/output
properties in practice, as the logic we use to generate input and output
type references never generates them for `optional({input,output}(T)).
Instead, it generates references to the standard input/output types.
Though this is _technically_ a breaking change--it changes the set of
exported types for any package that defines resources--I believe that in
practice it will be invisible to users for the reasons stated above.
These types are not usable, and were never referenced.
This is preparatory work for #7943.
2021-11-23 18:24:56 +00:00
|
|
|
return reflect.TypeOf((**ModuleTest)(nil)).Elem()
|
2021-11-18 20:23:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (o ModuleTestOutput) ToModuleTestOutput() ModuleTestOutput {
|
|
|
|
return o
|
|
|
|
}
|
|
|
|
|
|
|
|
func (o ModuleTestOutput) ToModuleTestOutputWithContext(ctx context.Context) ModuleTestOutput {
|
|
|
|
return o
|
|
|
|
}
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
pulumi.RegisterInputType(reflect.TypeOf((*ModuleTestInput)(nil)).Elem(), &ModuleTest{})
|
|
|
|
pulumi.RegisterOutputType(ModuleTestOutput{})
|
|
|
|
}
|