"git@developer.sourcefind.cn:OpenDAS/ollama.git" did not exist on "6b800aa7b70379d5b024fdf9cb868d45ae85d14d"
Commit f5f79049 authored by Mohit Gaur's avatar Mohit Gaur
Browse files

Incorporate code review improvements

parent ed89da92
...@@ -2,14 +2,12 @@ package parser ...@@ -2,14 +2,12 @@ package parser
import ( import (
"bufio" "bufio"
"bytes"
"errors" "errors"
"fmt" "fmt"
"io" "io"
"strings"
) )
const multilineString = `"""`
type Command struct { type Command struct {
Name string Name string
Args string Args string
...@@ -34,21 +32,23 @@ func Parse(reader io.Reader) ([]Command, error) { ...@@ -34,21 +32,23 @@ func Parse(reader io.Reader) ([]Command, error) {
continue continue
} }
switch strings.ToUpper(string(fields[0])) { switch string(bytes.ToUpper(fields[0])) {
case "FROM": case "FROM":
command.Name = "model" command.Name = "model"
command.Args = string(fields[1]) command.Args = string(fields[1])
// copy command for validation // copy command for validation
modelCommand = command modelCommand = command
case "LICENSE", "TEMPLATE", "SYSTEM", "PROMPT": case "LICENSE", "TEMPLATE", "SYSTEM", "PROMPT":
command.Name = strings.ToLower(string(fields[0])) command.Name = string(bytes.ToLower(fields[0]))
command.Args = string(fields[1]) command.Args = string(fields[1])
case "PARAMETER": case "PARAMETER":
fields = bytes.SplitN(fields[1], []byte(" "), 2) fields = bytes.SplitN(fields[1], []byte(" "), 2)
command.Name = string(fields[0]) command.Name = string(fields[0])
command.Args = string(fields[1]) command.Args = string(fields[1])
default: default:
return nil, fmt.Errorf("unknown command: %s", fields[0]) // log a warning for unknown commands
fmt.Printf("WARNING: Unknown command: %s\n", fields[0])
continue
} }
commands = append(commands, command) commands = append(commands, command)
...@@ -63,6 +63,8 @@ func Parse(reader io.Reader) ([]Command, error) { ...@@ -63,6 +63,8 @@ func Parse(reader io.Reader) ([]Command, error) {
} }
func scanModelfile(data []byte, atEOF bool) (advance int, token []byte, err error) { func scanModelfile(data []byte, atEOF bool) (advance int, token []byte, err error) {
const multilineString = `"""`
newline := bytes.IndexByte(data, '\n') newline := bytes.IndexByte(data, '\n')
if start := bytes.Index(data, []byte(multilineString)); start >= 0 && start < newline { if start := bytes.Index(data, []byte(multilineString)); start >= 0 && start < newline {
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment