Borg/examples/create_tim_programmatically/main.go
Claude fe0f85a069
Some checks failed
Go / build (push) Failing after 3s
mkdocs / deploy (push) Failing after 10s
Release / release (push) Failing after 4s
chore: migrate module path from github.com to forge.lthn.ai
Move module declaration and all internal imports from
github.com/Snider/Borg to forge.lthn.ai/Snider/Borg. Also updates
Enchantrix dependency path to forge.lthn.ai/Snider/Enchantrix.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-22 21:39:18 +00:00

35 lines
781 B
Go

package main
import (
"log"
"os"
"forge.lthn.ai/Snider/Borg/pkg/datanode"
"forge.lthn.ai/Snider/Borg/pkg/tim"
)
func main() {
// Create a new DataNode and add a file to it.
dn := datanode.New()
dn.AddData("hello.txt", []byte("Hello from within the tim!"))
// Create a new TerminalIsolationMatrix from the DataNode.
m, err := tim.FromDataNode(dn)
if err != nil {
log.Fatalf("Failed to create tim: %v", err)
}
// Serialize the tim to a tarball.
tarball, err := m.ToTar()
if err != nil {
log.Fatalf("Failed to serialize tim to tar: %v", err)
}
// Write the tarball to a file.
err = os.WriteFile("programmatic.tim", tarball, 0644)
if err != nil {
log.Fatalf("Failed to write tim file: %v", err)
}
log.Println("Successfully created programmatic.tim")
}