2018-03-31 04:58:57 +02:00
|
|
|
package addrs
|
|
|
|
|
2018-04-04 03:03:47 +02:00
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
)
|
|
|
|
|
2018-03-31 04:58:57 +02:00
|
|
|
// ModuleCall is the address of a call from the current module to a child
|
|
|
|
// module.
|
|
|
|
//
|
|
|
|
// There is no "Abs" version of ModuleCall because an absolute module path
|
|
|
|
// is represented by ModuleInstance.
|
|
|
|
type ModuleCall struct {
|
|
|
|
referenceable
|
|
|
|
Name string
|
|
|
|
}
|
|
|
|
|
2018-04-04 03:03:47 +02:00
|
|
|
func (c ModuleCall) String() string {
|
|
|
|
return "module." + c.Name
|
|
|
|
}
|
|
|
|
|
2018-03-31 04:58:57 +02:00
|
|
|
// Instance returns the address of an instance of the receiver identified by
|
|
|
|
// the given key.
|
|
|
|
func (c ModuleCall) Instance(key InstanceKey) ModuleCallInstance {
|
|
|
|
return ModuleCallInstance{
|
|
|
|
Call: c,
|
|
|
|
Key: key,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// ModuleCallInstance is the address of one instance of a module created from
|
|
|
|
// a module call, which might create multiple instances using "count" or
|
|
|
|
// "for_each" arguments.
|
|
|
|
type ModuleCallInstance struct {
|
|
|
|
referenceable
|
|
|
|
Call ModuleCall
|
|
|
|
Key InstanceKey
|
|
|
|
}
|
|
|
|
|
2018-04-04 03:03:47 +02:00
|
|
|
func (c ModuleCallInstance) String() string {
|
|
|
|
if c.Key == NoKey {
|
|
|
|
return c.Call.String()
|
|
|
|
}
|
|
|
|
return fmt.Sprintf("module.%s%s", c.Call.Name, c.Key)
|
|
|
|
}
|
|
|
|
|
2018-05-03 20:53:06 +02:00
|
|
|
// ModuleInstance returns the address of the module instance that corresponds
|
|
|
|
// to the receiving call instance when resolved in the given calling module.
|
|
|
|
// In other words, it returns the child module instance that the receving
|
|
|
|
// call instance creates.
|
|
|
|
func (c ModuleCallInstance) ModuleInstance(caller ModuleInstance) ModuleInstance {
|
|
|
|
return caller.Child(c.Call.Name, c.Key)
|
|
|
|
}
|
|
|
|
|
2020-03-20 17:18:48 +01:00
|
|
|
// Output returns the absolute address of an output of the receiver identified by its
|
2018-03-31 04:58:57 +02:00
|
|
|
// name.
|
2020-03-20 17:18:48 +01:00
|
|
|
func (c ModuleCallInstance) Output(name string) AbsModuleCallOutput {
|
|
|
|
return AbsModuleCallOutput{
|
2018-03-31 04:58:57 +02:00
|
|
|
Call: c,
|
|
|
|
Name: name,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-20 17:18:48 +01:00
|
|
|
// ModuleCallOutput is the address of a named output and its associated
|
|
|
|
// ModuleCall, which may expand into multiple module instances
|
2018-03-31 04:58:57 +02:00
|
|
|
type ModuleCallOutput struct {
|
2020-03-20 17:18:48 +01:00
|
|
|
referenceable
|
|
|
|
Call ModuleCall
|
|
|
|
Name string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m ModuleCallOutput) String() string {
|
|
|
|
return fmt.Sprintf("%s.%s", m.Call.String(), m.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
// AbsModuleCallOutput is the address of a particular named output produced by
|
|
|
|
// an instance of a module call.
|
|
|
|
type AbsModuleCallOutput struct {
|
2018-03-31 04:58:57 +02:00
|
|
|
referenceable
|
|
|
|
Call ModuleCallInstance
|
|
|
|
Name string
|
|
|
|
}
|
2018-04-04 03:03:47 +02:00
|
|
|
|
2020-03-20 17:18:48 +01:00
|
|
|
func (co AbsModuleCallOutput) String() string {
|
2018-04-04 03:03:47 +02:00
|
|
|
return fmt.Sprintf("%s.%s", co.Call.String(), co.Name)
|
|
|
|
}
|
2018-05-03 20:53:06 +02:00
|
|
|
|
|
|
|
// AbsOutputValue returns the absolute output value address that corresponds
|
|
|
|
// to the receving module call output address, once resolved in the given
|
|
|
|
// calling module.
|
2020-03-20 17:18:48 +01:00
|
|
|
func (co AbsModuleCallOutput) AbsOutputValue(caller ModuleInstance) AbsOutputValue {
|
2018-05-03 20:53:06 +02:00
|
|
|
moduleAddr := co.Call.ModuleInstance(caller)
|
|
|
|
return moduleAddr.OutputValue(co.Name)
|
|
|
|
}
|