llamafile 0.3.8 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 68db87a8277357f5bc2266e2d8fe44147843e47d63441d04ef8d06f49844f728
4
- data.tar.gz: ea3280d662a835f465161dbf6f2f24c7c5cd882ab487b5b4ddf83574d4d43fe6
3
+ metadata.gz: 1d5ace415bdc363019cd82cc1283c52d1ae5cafe7f5e29f8d669928a66deaebb
4
+ data.tar.gz: 9b180bf88730e626e29b56a85d5dcbe263be7b0c23a1ee6d378eb129b8700582
5
5
  SHA512:
6
- metadata.gz: 191544fa8d4b97b1cf1b3c4d8b227f0573d1b94fbee0d075f1005d74d58a1014c8abe0835072dcf69cf323e11c2bda47dec46ee4ea70d767d56fe50d260a8e17
7
- data.tar.gz: a6790741facb38badb8dae985fd30511c093b9aed909deb1fd4f572f286df6daf15f4ef1d63b507c4aac94b230177f52127570730806487814a3bcf210ab7c55
6
+ metadata.gz: f6ed8efcddbcce2369f91146148af1a5b7e38c3eb14b6a584b2f930f486c55409ce42a004924ea567fe85164c63249a1182cc8d1b5a45dad6ac6da4602680e9b
7
+ data.tar.gz: 0cab64789570ad78cf2c8a55e6789442b66eab83fadb60a7cb4fcd230eeb5a80328cad659a6032626595d0bd328aff5830c702875954c2d698bf11babd7fcd33
@@ -27,7 +27,7 @@ module LLAMA
27
27
  base_uri ENV['LLAMA']
28
28
  #default_timeout 120
29
29
  end
30
- def self.post h={}
30
+ def self.post h={}, &b
31
31
  #puts %[LLAMA IN: #{h}]
32
32
  hh = {
33
33
  headers: {
@@ -38,18 +38,26 @@ module LLAMA
38
38
  body: JSON.generate(DEF.merge(h))
39
39
  }
40
40
  #puts %[LLAMA PACK: #{hh}]
41
- begin
42
- r = Llama.post('/completion', hh)
43
- #puts %[LLAMA CODE: #{r.code}]
44
- if r.code == 200
45
- return r['content'].gsub(/<.+>/, "").gsub(/\s\s+/, " ").gsub(/\n+/, "\n");
46
- else
47
- return false
41
+ fiber = Fiber.new do |hhh|
42
+ begin
43
+ r = Llama.post('/completion', hhh)
44
+ #puts %[LLAMA CODE: #{r.code}]
45
+ if r.code == 200
46
+ rr = r['content'].gsub(/<.+>/, "").gsub(/\s\s+/, " ").gsub(/\n+/, "\n");
47
+ if block_given?
48
+ Fiber.yield b.call(rr);
49
+ else
50
+ Fiber.yield rr;
51
+ end
52
+ else
53
+ Fiber.yield false
54
+ end
55
+ rescue => err
56
+ puts %[LLAMA POST ERR: #{err}]
57
+ Fiber.yield false
48
58
  end
49
- rescue => err
50
- puts %[LLAMA POST ERR: #{err}]
51
- return false
52
59
  end
60
+ fiber.resume(hh)
53
61
  end
54
62
 
55
63
  def self.make h={}
@@ -77,6 +85,7 @@ module LLAMA
77
85
  def self.test h={}
78
86
  fiber = Fiber.new do |hh|
79
87
  hh[:grammar] = GRAMMAR[:bool]
88
+ hh[:n_predict] = 4
80
89
  if LLAMA.post(hh) == 'yes'
81
90
  Fiber.yield true
82
91
  else
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Llamafile
4
- VERSION = "0.3.8"
4
+ VERSION = "0.4.0"
5
5
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: llamafile
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.8
4
+ version: 0.4.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Erik Olson