rewind

package
v0.6.3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 3, 2026 License: MIT Imports: 21 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func CleanupOrphans added in v0.6.3

func CleanupOrphans()

CleanupOrphans removes leftover shadow repos from prior sessions that didn't get a chance to clean up (e.g. SIGKILL). Only deletes dirs whose mtime is older than the cutoff so concurrently-running sessions are safe.

Types

type Checkpoint

type Checkpoint struct {
	Hash    string
	Message string
	Time    time.Time
}

type FileDiff

type FileDiff struct {
	Path   string
	Status FileStatus
	Patch  string

	// Original is the file's content at the baseline (empty when added).
	Original string
	// Modified is the file's content in the current working tree (empty when deleted).
	Modified string
}

FileDiff represents a diff for a single file

type FileStatus

type FileStatus int

FileStatus represents the status of a file in the diff

const (
	StatusAdded FileStatus = iota
	StatusModified
	StatusDeleted
)

type Manager

type Manager struct {
	// contains filtered or unexported fields
}

Manager runs a shadow git repo in /tmp that snapshots the working dir on each user turn. Init is async — New returns immediately and methods block on a ready channel until the shadow repo is set up. The shadow repo works in any directory, with or without an existing user .git.

func New

func New(workingDir string) *Manager

New starts a rewind manager for the given working directory. The shadow repo is initialized in a goroutine; methods block on it via the ready channel. Failures during init surface as errors from those methods, so the caller never has to deal with a nil Manager.

func (*Manager) Cleanup

func (m *Manager) Cleanup()

func (*Manager) Commit

func (m *Manager) Commit(message string) error

func (*Manager) DiffFromBaseline

func (m *Manager) DiffFromBaseline() ([]FileDiff, error)

DiffFromBaseline returns the diff between the baseline and the current working tree. The right-hand side is taken from the live working tree (not HEAD), so changes from any source — agent tools, the user's terminal, an external editor — are reflected.

Returns (nil, nil) when the working tree matches the baseline (no diff). Errors are reserved for actual git failures so callers can distinguish.

func (*Manager) Fingerprint added in v0.6.3

func (m *Manager) Fingerprint() uint64

Fingerprint returns a 64-bit digest of the worktree's visible state (relative path, mtime, size for every non-ignored file). Used by the server's polling loop to gate FilesChanged/DiffsChanged emits — when the digest is unchanged we skip the events entirely. Always skips .git and gitignored entries; doesn't hash content, so a `touch` will fire a refetch even when no diff actually changed (the client just gets an empty diff back).

func (*Manager) List

func (m *Manager) List() ([]Checkpoint, error)

func (*Manager) Restore

func (m *Manager) Restore(hash string) error

Restore rolls the working tree back to a checkpoint and re-baselines so "diff from baseline" thereafter means "since the restore." Excludes are loaded before Clean so gitignored files (node_modules, .env, build artifacts) are preserved — without that guard, Clean would silently nuke them on rollback.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL