Files
egutierrez 988e901066 docs: params/output semántico en 506 funciones para composabilidad
Añade campos params y output al frontmatter YAML de las 506 funciones del registry.
Cada parámetro tiene descripción semántica (qué representa, unidades, rango típico)
y cada función describe qué produce su output. Permite a agentes razonar sobre
cadenas de composición (ej: prices → log_return → sharpe_ratio) sin leer código.
2026-04-05 18:45:16 +02:00

45 lines
1.7 KiB
Markdown

---
name: write_dockerfile
kind: function
lang: go
domain: infra
version: "1.0.0"
purity: impure
signature: "func WriteDockerfile(dir, content string) (string, error)"
description: "Escribe content en dir/Dockerfile. Crea el directorio si no existe. Retorna el path absoluto del archivo escrito. Compañera impura de generate_dockerfile."
tags: [docker, dockerfile, io, write, deploy, infra]
uses_functions: [generate_dockerfile_go_infra]
uses_types: []
returns: []
returns_optional: false
error_type: "error_go_core"
imports: [fmt, os, path/filepath]
params:
- name: dir
desc: "directorio donde crear el archivo Dockerfile (se crea si no existe)"
- name: content
desc: "contenido del Dockerfile como string"
output: "ruta absoluta del archivo Dockerfile escrito"
tested: true
tests: ["escribe Dockerfile en directorio existente", "crea directorio si no existe", "retorna path absoluto correcto", "error si dir es path invalido"]
test_file_path: "functions/infra/write_dockerfile_test.go"
file_path: "functions/infra/write_dockerfile.go"
---
## Ejemplo
```go
// Patron puro+impuro: generar contenido y luego escribir
content := GenerateDockerfile("myapp", 8080, map[string]string{"PORT": "8080"})
path, err := WriteDockerfile("/home/user/apps/myapp", content)
if err != nil {
log.Fatal(err)
}
fmt.Println("Dockerfile escrito en:", path)
// /home/user/apps/myapp/Dockerfile
```
## Notas
Patron puro+impuro: generate_dockerfile produce el texto (pura, testeable sin I/O), write_dockerfile lo persiste (impura, efecto secundario aislado). Esto facilita testear la generacion del contenido independientemente de la escritura. Sobreescribe cualquier Dockerfile existente en el directorio.