Documentation ¶
Index ¶
Constants ¶
View Source
const DefaultMaxTokens = 1000
View Source
const DefaultSystemPrompt = "You are a helpful assistant."
View Source
const DefaultTemperature = 0.7
Variables ¶
View Source
var ChatCmd = &cobra.Command{ Use: "chat", Short: "read a chat from stdin and send to LLM chat", Run: func(cmd *cobra.Command, args []string) { input := "" if len(args) == 0 { stdin, err := io.ReadAll(os.Stdin) if err != nil { slog.Error("failed to read input", "err", err) return } input = string(stdin) } else { input = strings.Join(args, " ") } var f = cmd.Flags() var temperature float32 = DefaultTemperature var maxTokens int = DefaultMaxTokens lines := strings.Split(string(input), "\n") if strings.HasPrefix(lines[0], "#") { temperature = getTemperature(lines[0]) maxTokens = getMaxTokens(lines[0]) lines = lines[0:] } else { if m, err := f.GetInt("max_tokens"); err == nil { maxTokens = m } if t, err := f.GetFloat32("temperature"); err == nil { temperature = t } } chatClient := vichat.New().WithTemperature(temperature).WithMaxTokens(maxTokens) prompts := CreatePrompts(lines) if len(prompts) == 0 { slog.Error("invalid input") return } var isFirst = false if len(prompts) == 1 && prompts[0].Type != chat.MessageTypeSystem { isFirst = true prompts = append([]chat.PromptMessage{{ Type: chat.MessageTypeSystem, Prompt: prompt.New(DefaultSystemPrompt), }}, prompts...) } messages := chat.New(prompts...) resp, err := chatClient.Chat(context.TODO(), messages) if err != nil { slog.Error("failed", "err", err.Error()) return } term, _ := f.GetBool("term") if isatty.IsTerminal(os.Stdout.Fd()) || isatty.IsCygwinTerminal(os.Stderr.Fd()) { if term { if strings.Contains(resp, "```") { fmt.Println() resp = string(markdown.Render(resp, 90, 4)) } fmt.Println() fmt.Println(resp) fmt.Println() } else if isFirst { tmpf, err := os.CreateTemp(os.TempDir(), "*.chat") if err != nil { slog.Error("failed to create temp file", "err", err.Error()) fmt.Println(resp) } fmt.Fprintf(tmpf, "# temperature=%.1f, max_tokens=%d\n\n", temperature, maxTokens) for _, p := range prompts { prefix := "" switch p.Type { case chat.MessageTypeSystem: prefix = "SYSTEM: " case chat.MessageTypeUser: prefix = "USER: " case chat.MessageTypeAssistant: prefix = "AI: " } fmt.Fprintf(tmpf, "%s%s\n\n", prefix, strings.Trim(p.Prompt.String(), "\r\n")) } fmt.Fprintf(tmpf, "AI: %s\n\nUSER: ", resp) tmpf.Close() cmd := exec.Command("vim", "-c", "/AI: ", tmpf.Name()) cmd.Stdin = os.Stdin cmd.Stdout = os.Stdout cmd.Stderr = os.Stderr cmd.Run() } } else { fmt.Println(resp) } }, }
View Source
var InstallCmd = &cobra.Command{ Use: "install-vim-plugin", Short: "install the vim plugin", Aliases: []string{"i"}, Run: func(cmd *cobra.Command, args []string) { installVim() }, }
View Source
var TokCmd = &cobra.Command{ Use: "tok", Short: "given a piece of text, tok estimate the num of tokens for a given model offline", Run: func(cmd *cobra.Command, args []string) { f := cmd.Flags() model, err := f.GetString("model") if err != nil { slog.Error("failed", "err", err) } text, err := io.ReadAll(os.Stdin) if err != nil { slog.Error("failed", "err", err) } toks, err := vichat.Tokenize(string(text), model) if err != nil { slog.Error("failed", "err", err) return } fmt.Println(len(toks)) }, }
Functions ¶
func CreatePrompts ¶
func CreatePrompts(lines []string) []chat.PromptMessage
Types ¶
This section is empty.
Click to show internal directories.
Click to hide internal directories.