Modelo Golang com switch & ForEach
Eu preciso criarbash.sh arquivo do programa golang, que deve fazer o seguinte:
CrioPara cada loop em dependências e leia o tipo e de acordo com o tipo print diferente mensagem de eco (comandos) Eu preciso que ele trabalheinterruptor notype
da dependência com Golang
por exemplo. algo como seguir
Para cada entrada de dependência, adicione a mensagem de tipo echo
#!/bin/bash
for a in $(dependencies.type)
echo $runner //from type
done
o que eu fiz é o seguinte que não funciona
A ideia de que, para dependências, digite"runner1"(consulte o valor da propriedade type na instância struct de dependência) Eu preciso executarvários comandos e para"runner2" Eu preciso corrervários comandos diferentesE esses comandos (como echo api1 para runner1 etc) acima devem ser escritos no bash.script que preciso criar a partir do modelopacote principal
import (
"fmt"
"log"
"text/template"
"gopkg.in/yaml.v2"
"os"
)
type File struct {
TypeVersion string `yaml:"_type-version"`
Dependency []Dependency
}
type Dependency struct {
Name string
Type string
CWD string
Install []Install
}
type Install map[string]string
var data = `
_type-version: "1.0.0"
dependency:
- name: ui
type: runner
cwd: /ui
install:
- name: api
- name: ui2
type: runner2
cwd: /ui2
install:
- name: api2
`
func main() {
f := File{}
err := yaml.Unmarshal([]byte(data), &f)
if err != nil {
log.Fatalf("error: %v", err)
}
d, err := yaml.Marshal(&f)
if err != nil {
log.Fatalf("error: %v", err)
}
fmt.Printf("--- t dump:\n%s\n\n", string(d))
wd, _ := os.Getwd()
newfile, err := os.Create(wd + "/" + "bash.sh") // Truncates if file already exists
if err != nil {
fmt.Errorf("Failed to create file: %s , %s", wd+"/"+"bash.sh", err)
}
fmt.Println(newfile)
const File = `
#!/bin/bash
{{.dependency}},
{{if .Type runner2}}
echo "type is runner2"
{{- else}}
echo "type is %S"
{{- end}}
{{end}}
`
t := template.Must(template.New("bash.sh").Parse(File))
for _, r := range f.Dependency {
err := t.Execute(os.Stdout, r)
if err != nil {
log.Println("executing template:", err)
}
}
}
atualizar
Por exemplo
digamos que eu mapeie como segue e a estrutura de dependências deve trabalhar com a estrutura da API para saber qual comando executar para cada valor de tipo
API := map[string]string {
{
“runner1” : “api1”,
},
{
“runner2” : “api2”,
}
}
É assim que o script deve ficar no final
#bin/bash
// in context of dep1
echo runner1
submitting api1
// in context of dep2
echo runner2
submitting api2