Module: LLM::Sequel::Plugin::InstanceMethods

Defined in:
lib/llm/sequel/plugin.rb

Constant Summary collapse

Utils =
Plugin::Utils

Instance Method Summary collapse

Instance Method Details

#llmLLM::Provider

Returns the resolved provider instance for this record.

Returns:



297
298
299
300
301
302
303
# File 'lib/llm/sequel/plugin.rb', line 297

def llm
  options = self.class.llm_plugin_options
  return @llm if @llm
  @llm = Utils.resolve_provider(self, options, Plugin::EMPTY_HASH)
  @llm.tracer = Utils.resolve_option(self, options[:tracer]) if options[:tracer]
  @llm
end

#askLLM::Response

Continues the stored context with new input and flushes it.

Returns:

See Also:



170
171
172
173
# File 'lib/llm/sequel/plugin.rb', line 170

def ask(...)
  options = self.class.llm_plugin_options
  ctx.ask(...).tap { Utils.save!(self, ctx, options) }
end

#waitArray<LLM::Function::Return>

Waits for queued tool work to finish.

Returns:

See Also:



179
180
181
# File 'lib/llm/sequel/plugin.rb', line 179

def wait(...)
  ctx.wait(...)
end

#modeSymbol

Returns:

  • (Symbol)

See Also:



186
187
188
# File 'lib/llm/sequel/plugin.rb', line 186

def mode
  ctx.mode
end

#messagesArray<LLM::Message>

Returns:

See Also:



193
194
195
# File 'lib/llm/sequel/plugin.rb', line 193

def messages
  ctx.messages
end

#model!String

Note:

The bang is used because Sequel reserves model for the underlying model class on instances.

Returns:

  • (String)

See Also:



202
203
204
# File 'lib/llm/sequel/plugin.rb', line 202

def model!
  ctx.model
end

#functionsArray<LLM::Function>

Returns:

See Also:



209
210
211
# File 'lib/llm/sequel/plugin.rb', line 209

def functions
  ctx.functions
end

#functions?Boolean

Returns:

  • (Boolean)

See Also:



216
217
218
# File 'lib/llm/sequel/plugin.rb', line 216

def functions?
  ctx.functions?
end

#returnsArray<LLM::Function::Return>

Returns:

See Also:



223
224
225
# File 'lib/llm/sequel/plugin.rb', line 223

def returns
  ctx.returns
end

#costLLM::Cost

Returns:

See Also:



230
231
232
# File 'lib/llm/sequel/plugin.rb', line 230

def cost
  ctx.cost
end

#context_windowInteger

Returns:

  • (Integer)

See Also:



237
238
239
240
241
# File 'lib/llm/sequel/plugin.rb', line 237

def context_window
  ctx.context_window
rescue LLM::NoSuchModelError, LLM::NoSuchRegistryError
  0
end

#usageLLM::Object

Returns usage from the mapped usage columns.

Returns:



246
247
248
# File 'lib/llm/sequel/plugin.rb', line 246

def usage
  ctx.usage || LLM::Object.from(input_tokens: 0, output_tokens: 0, total_tokens: 0)
end

#interrupt!nil Also known as: cancel!

Returns:

  • (nil)

See Also:



253
254
255
# File 'lib/llm/sequel/plugin.rb', line 253

def interrupt!
  ctx.interrupt!
end

#promptLLM::Prompt Also known as: build_prompt

Returns:

See Also:



261
262
263
# File 'lib/llm/sequel/plugin.rb', line 261

def prompt(&)
  ctx.prompt(&)
end

#image_urlLLM::Object

Returns:

See Also:



269
270
271
# File 'lib/llm/sequel/plugin.rb', line 269

def image_url(...)
  ctx.image_url(...)
end

#local_fileLLM::Object

Returns:

See Also:



276
277
278
# File 'lib/llm/sequel/plugin.rb', line 276

def local_file(...)
  ctx.local_file(...)
end

#remote_fileLLM::Object

Returns:

See Also:



283
284
285
# File 'lib/llm/sequel/plugin.rb', line 283

def remote_file(...)
  ctx.remote_file(...)
end

#tracerLLM::Tracer

Returns:

See Also:



290
291
292
# File 'lib/llm/sequel/plugin.rb', line 290

def tracer
  ctx.tracer
end

#talkLLM::Response

Continues the stored context with new input and flushes it.

Returns:

See Also:



161
162
163
164
# File 'lib/llm/sequel/plugin.rb', line 161

def talk(...)
  options = self.class.llm_plugin_options
  ctx.talk(...).tap { Utils.save!(self, ctx, options) }
end