start_windows.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. package cmd
  2. import (
  3. "context"
  4. "errors"
  5. "fmt"
  6. "os"
  7. "os/exec"
  8. "path/filepath"
  9. "strings"
  10. "syscall"
  11. "github.com/ollama/ollama/api"
  12. )
  13. func startApp(ctx context.Context, client *api.Client) error {
  14. // log.Printf("XXX Attempting to find and start ollama app")
  15. AppName := "ollama app.exe"
  16. exe, err := os.Executable()
  17. if err != nil {
  18. return err
  19. }
  20. appExe := filepath.Join(filepath.Dir(exe), AppName)
  21. _, err = os.Stat(appExe)
  22. if errors.Is(err, os.ErrNotExist) {
  23. // Try the standard install location
  24. localAppData := os.Getenv("LOCALAPPDATA")
  25. appExe = filepath.Join(localAppData, "Ollama", AppName)
  26. _, err := os.Stat(appExe)
  27. if errors.Is(err, os.ErrNotExist) {
  28. // Finally look in the path
  29. appExe, err = exec.LookPath(AppName)
  30. if err != nil {
  31. return errors.New("could not locate ollama app")
  32. }
  33. }
  34. }
  35. // log.Printf("XXX attempting to start app %s", appExe)
  36. cmd_path := "c:\\Windows\\system32\\cmd.exe"
  37. cmd := exec.Command(cmd_path, "/c", appExe)
  38. // TODO - these hide flags aren't working - still pops up a command window for some reason
  39. cmd.SysProcAttr = &syscall.SysProcAttr{CreationFlags: 0x08000000, HideWindow: true}
  40. // TODO this didn't help either...
  41. cmd.Stdin = strings.NewReader("")
  42. cmd.Stdout = os.Stdout
  43. cmd.Stderr = os.Stderr
  44. if err := cmd.Start(); err != nil {
  45. return fmt.Errorf("unable to start ollama app %w", err)
  46. }
  47. if cmd.Process != nil {
  48. defer cmd.Process.Release() //nolint:errcheck
  49. }
  50. return waitForServer(ctx, client)
  51. }