Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
OpenDAS
ollama
Commits
2010cbc5
Unverified
Commit
2010cbc5
authored
Apr 24, 2024
by
Michael Yang
Committed by
GitHub
Apr 24, 2024
Browse files
Merge pull request #3833 from ollama/mxyng/fix-from
fix: from blob
parents
ade4b555
ac0801ec
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
96 additions
and
87 deletions
+96
-87
cmd/cmd.go
cmd/cmd.go
+96
-87
No files found.
cmd/cmd.go
View file @
2010cbc5
...
...
@@ -17,6 +17,7 @@ import (
"os"
"os/signal"
"path/filepath"
"regexp"
"runtime"
"strings"
"syscall"
...
...
@@ -53,8 +54,6 @@ func CreateHandler(cmd *cobra.Command, args []string) error {
p
:=
progress
.
NewProgress
(
os
.
Stderr
)
defer
p
.
Stop
()
bars
:=
make
(
map
[
string
]
*
progress
.
Bar
)
modelfile
,
err
:=
os
.
ReadFile
(
filename
)
if
err
!=
nil
{
return
err
...
...
@@ -95,32 +94,92 @@ func CreateHandler(cmd *cobra.Command, args []string) error {
return
err
}
// TODO make this work w/ adapters
if
fi
.
IsDir
()
{
tf
,
err
:=
os
.
CreateTemp
(
""
,
"ollama-tf"
)
// this is likely a safetensors or pytorch directory
// TODO make this work w/ adapters
tempfile
,
err
:=
tempZipFiles
(
path
)
if
err
!=
nil
{
return
err
}
defer
os
.
RemoveAll
(
t
f
.
Name
()
)
defer
os
.
RemoveAll
(
t
empfile
)
zf
:=
zip
.
NewWriter
(
tf
)
path
=
tempfile
}
files
:=
[]
string
{}
digest
,
err
:=
createBlob
(
cmd
,
client
,
path
)
if
err
!=
nil
{
return
err
}
name
:=
c
.
Name
if
c
.
Name
==
"model"
{
name
=
"from"
}
re
:=
regexp
.
MustCompile
(
fmt
.
Sprintf
(
`(?im)^(%s)\s+%s\s*$`
,
name
,
c
.
Args
))
modelfile
=
re
.
ReplaceAll
(
modelfile
,
[]
byte
(
"$1 @"
+
digest
))
}
}
bars
:=
make
(
map
[
string
]
*
progress
.
Bar
)
fn
:=
func
(
resp
api
.
ProgressResponse
)
error
{
if
resp
.
Digest
!=
""
{
spinner
.
Stop
()
bar
,
ok
:=
bars
[
resp
.
Digest
]
if
!
ok
{
bar
=
progress
.
NewBar
(
fmt
.
Sprintf
(
"pulling %s..."
,
resp
.
Digest
[
7
:
19
]),
resp
.
Total
,
resp
.
Completed
)
bars
[
resp
.
Digest
]
=
bar
p
.
Add
(
resp
.
Digest
,
bar
)
}
bar
.
Set
(
resp
.
Completed
)
}
else
if
status
!=
resp
.
Status
{
spinner
.
Stop
()
status
=
resp
.
Status
spinner
=
progress
.
NewSpinner
(
status
)
p
.
Add
(
status
,
spinner
)
}
return
nil
}
quantization
,
_
:=
cmd
.
Flags
()
.
GetString
(
"quantization"
)
request
:=
api
.
CreateRequest
{
Name
:
args
[
0
],
Modelfile
:
string
(
modelfile
),
Quantization
:
quantization
}
if
err
:=
client
.
Create
(
cmd
.
Context
(),
&
request
,
fn
);
err
!=
nil
{
return
err
}
return
nil
}
func
tempZipFiles
(
path
string
)
(
string
,
error
)
{
tempfile
,
err
:=
os
.
CreateTemp
(
""
,
"ollama-tf"
)
if
err
!=
nil
{
return
""
,
err
}
defer
tempfile
.
Close
()
zipfile
:=
zip
.
NewWriter
(
tempfile
)
defer
zipfile
.
Close
()
tfiles
,
err
:=
filepath
.
Glob
(
filepath
.
Join
(
path
,
"pytorch_model-*.bin"
))
if
err
!=
nil
{
return
err
return
""
,
err
}
else
if
len
(
tfiles
)
==
0
{
tfiles
,
err
=
filepath
.
Glob
(
filepath
.
Join
(
path
,
"model-*.safetensors"
))
if
err
!=
nil
{
return
err
return
""
,
err
}
}
files
:=
[]
string
{}
files
=
append
(
files
,
tfiles
...
)
if
len
(
files
)
==
0
{
return
fmt
.
Errorf
(
"no models were found in '%s'"
,
path
)
return
""
,
fmt
.
Errorf
(
"no models were found in '%s'"
,
path
)
}
// add the safetensor/torch config file + tokenizer
...
...
@@ -142,90 +201,40 @@ func CreateHandler(cmd *cobra.Command, args []string) error {
if
os
.
IsNotExist
(
err
)
{
continue
}
else
if
err
!=
nil
{
return
err
return
""
,
err
}
}
else
{
continue
}
}
else
if
err
!=
nil
{
return
err
return
""
,
err
}
fi
,
err
:=
f
.
Stat
()
if
err
!=
nil
{
return
err
return
""
,
err
}
h
,
err
:=
zip
.
FileInfoHeader
(
fi
)
if
err
!=
nil
{
return
err
return
""
,
err
}
h
.
Name
=
filepath
.
Base
(
fn
)
h
.
Method
=
zip
.
Store
w
,
err
:=
z
f
.
CreateHeader
(
h
)
w
,
err
:=
z
ipfile
.
CreateHeader
(
h
)
if
err
!=
nil
{
return
err
return
""
,
err
}
_
,
err
=
io
.
Copy
(
w
,
f
)
if
err
!=
nil
{
return
err
}
}
if
err
:=
zf
.
Close
();
err
!=
nil
{
return
err
}
if
err
:=
tf
.
Close
();
err
!=
nil
{
return
err
}
path
=
tf
.
Name
()
}
digest
,
err
:=
createBlob
(
cmd
,
client
,
path
)
if
err
!=
nil
{
return
err
}
modelfile
=
bytes
.
ReplaceAll
(
modelfile
,
[]
byte
(
c
.
Args
),
[]
byte
(
"@"
+
digest
))
}
}
fn
:=
func
(
resp
api
.
ProgressResponse
)
error
{
if
resp
.
Digest
!=
""
{
spinner
.
Stop
()
bar
,
ok
:=
bars
[
resp
.
Digest
]
if
!
ok
{
bar
=
progress
.
NewBar
(
fmt
.
Sprintf
(
"pulling %s..."
,
resp
.
Digest
[
7
:
19
]),
resp
.
Total
,
resp
.
Completed
)
bars
[
resp
.
Digest
]
=
bar
p
.
Add
(
resp
.
Digest
,
bar
)
}
bar
.
Set
(
resp
.
Completed
)
}
else
if
status
!=
resp
.
Status
{
spinner
.
Stop
()
status
=
resp
.
Status
spinner
=
progress
.
NewSpinner
(
status
)
p
.
Add
(
status
,
spinner
)
}
return
nil
return
""
,
err
}
quantization
,
_
:=
cmd
.
Flags
()
.
GetString
(
"quantization"
)
request
:=
api
.
CreateRequest
{
Name
:
args
[
0
],
Modelfile
:
string
(
modelfile
),
Quantization
:
quantization
}
if
err
:=
client
.
Create
(
cmd
.
Context
(),
&
request
,
fn
);
err
!=
nil
{
return
err
}
return
nil
return
tempfile
.
Name
(),
nil
}
func
createBlob
(
cmd
*
cobra
.
Command
,
client
*
api
.
Client
,
path
string
)
(
string
,
error
)
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment