2024-02-15 17:15:09 -08:00
|
|
|
package gpu
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"log/slog"
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
"runtime"
|
|
|
|
"strings"
|
2024-03-08 09:45:55 -08:00
|
|
|
"sync"
|
|
|
|
)
|
2024-02-15 17:15:09 -08:00
|
|
|
|
2024-03-08 09:45:55 -08:00
|
|
|
var (
|
|
|
|
lock sync.Mutex
|
|
|
|
payloadsDir = ""
|
2024-02-15 17:15:09 -08:00
|
|
|
)
|
|
|
|
|
2024-03-08 09:45:55 -08:00
|
|
|
func PayloadsDir() (string, error) {
|
|
|
|
lock.Lock()
|
|
|
|
defer lock.Unlock()
|
|
|
|
if payloadsDir == "" {
|
|
|
|
tmpDir, err := os.MkdirTemp("", "ollama")
|
|
|
|
if err != nil {
|
|
|
|
return "", fmt.Errorf("failed to generate tmp dir: %w", err)
|
|
|
|
}
|
|
|
|
payloadsDir = tmpDir
|
2024-02-15 17:15:09 -08:00
|
|
|
}
|
2024-03-08 09:45:55 -08:00
|
|
|
return payloadsDir, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func Cleanup() {
|
|
|
|
lock.Lock()
|
|
|
|
defer lock.Unlock()
|
|
|
|
if payloadsDir != "" {
|
2024-03-09 15:56:48 -08:00
|
|
|
slog.Debug("cleaning up", "dir", payloadsDir)
|
2024-03-08 09:45:55 -08:00
|
|
|
err := os.RemoveAll(payloadsDir)
|
|
|
|
if err != nil {
|
2024-03-09 15:56:48 -08:00
|
|
|
slog.Warn("failed to clean up", "dir", payloadsDir, "err", err)
|
2024-02-15 17:15:09 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func UpdatePath(dir string) {
|
|
|
|
if runtime.GOOS == "windows" {
|
|
|
|
tmpDir := filepath.Dir(dir)
|
|
|
|
pathComponents := strings.Split(os.Getenv("PATH"), ";")
|
|
|
|
i := 0
|
|
|
|
for _, comp := range pathComponents {
|
|
|
|
if strings.EqualFold(comp, dir) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
// Remove any other prior paths to our temp dir
|
|
|
|
if !strings.HasPrefix(strings.ToLower(comp), strings.ToLower(tmpDir)) {
|
|
|
|
pathComponents[i] = comp
|
|
|
|
i++
|
|
|
|
}
|
|
|
|
}
|
|
|
|
newPath := strings.Join(append([]string{dir}, pathComponents...), ";")
|
|
|
|
slog.Info(fmt.Sprintf("Updating PATH to %s", newPath))
|
|
|
|
os.Setenv("PATH", newPath)
|
|
|
|
}
|
|
|
|
// linux and darwin rely on rpath
|
|
|
|
}
|