summaryrefslogtreecommitdiff
path: root/logic/cartridge
diff options
context:
space:
mode:
Diffstat (limited to 'logic/cartridge')
-rw-r--r--logic/cartridge/adapters.rb2
-rw-r--r--logic/cartridge/affixes.rb2
-rw-r--r--logic/cartridge/default.rb4
-rw-r--r--logic/cartridge/fetch.rb24
-rw-r--r--logic/cartridge/interaction.rb14
-rw-r--r--logic/cartridge/tools.rb53
6 files changed, 88 insertions, 11 deletions
diff --git a/logic/cartridge/adapters.rb b/logic/cartridge/adapters.rb
index bc8ddaf..4a3fadf 100644
--- a/logic/cartridge/adapters.rb
+++ b/logic/cartridge/adapters.rb
@@ -1,7 +1,7 @@
# frozen_string_literal: true
require_relative '../helpers/hash'
-require_relative './default'
+require_relative 'default'
module NanoBot
module Logic
diff --git a/logic/cartridge/affixes.rb b/logic/cartridge/affixes.rb
index 0b40fa2..bf94d92 100644
--- a/logic/cartridge/affixes.rb
+++ b/logic/cartridge/affixes.rb
@@ -1,7 +1,7 @@
# frozen_string_literal: true
require_relative '../helpers/hash'
-require_relative './default'
+require_relative 'default'
module NanoBot
module Logic
diff --git a/logic/cartridge/default.rb b/logic/cartridge/default.rb
index 43d45d4..24a8e7c 100644
--- a/logic/cartridge/default.rb
+++ b/logic/cartridge/default.rb
@@ -15,7 +15,7 @@ module NanoBot
return @values if @values
path = File.expand_path('../../static/cartridges/default.yml', __dir__)
- cartridge = YAML.safe_load(File.read(path), permitted_classes: [Symbol])
+ cartridge = YAML.safe_load_file(path, permitted_classes: [Symbol])
@values = Logic::Helpers::Hash.symbolize_keys(cartridge)
@values
end
@@ -24,7 +24,7 @@ module NanoBot
return @baseline if @baseline
path = File.expand_path('../../static/cartridges/baseline.yml', __dir__)
- cartridge = YAML.safe_load(File.read(path), permitted_classes: [Symbol])
+ cartridge = YAML.safe_load_file(path, permitted_classes: [Symbol])
@baseline = Logic::Helpers::Hash.symbolize_keys(cartridge)
@baseline
end
diff --git a/logic/cartridge/fetch.rb b/logic/cartridge/fetch.rb
new file mode 100644
index 0000000..2335358
--- /dev/null
+++ b/logic/cartridge/fetch.rb
@@ -0,0 +1,24 @@
+# frozen_string_literal: true
+
+require_relative 'default'
+require_relative '../helpers/hash'
+
+module NanoBot
+ module Logic
+ module Cartridge
+ module Fetch
+ def self.cascate(cartridge, paths)
+ results = paths.map { |path| Helpers::Hash.fetch(cartridge, path) }
+ result = results.find { |candidate| !candidate.nil? }
+ return result unless result.nil?
+
+ results = paths.map { |path| Helpers::Hash.fetch(Default.instance.values, path) }
+ result = results.find { |candidate| !candidate.nil? }
+ return result unless result.nil?
+
+ nil
+ end
+ end
+ end
+ end
+end
diff --git a/logic/cartridge/interaction.rb b/logic/cartridge/interaction.rb
index 160d818..5e8264e 100644
--- a/logic/cartridge/interaction.rb
+++ b/logic/cartridge/interaction.rb
@@ -1,9 +1,7 @@
# frozen_string_literal: true
-require 'sweet-moon'
-
-require_relative './affixes'
-require_relative './adapters'
+require_relative 'affixes'
+require_relative 'adapters'
module NanoBot
module Logic
@@ -12,23 +10,25 @@ module NanoBot
def self.input(cartridge, interface, content)
lua = Adapter.expression(cartridge, interface, :input, :lua)
fennel = Adapter.expression(cartridge, interface, :input, :fennel)
+ clojure = Adapter.expression(cartridge, interface, :input, :clojure)
prefix = Affixes.get(cartridge, interface, :input, :prefix)
suffix = Affixes.get(cartridge, interface, :input, :suffix)
- { content:, prefix:, suffix:, lua:, fennel: }
+ { content:, prefix:, suffix:, lua:, fennel:, clojure: }
end
def self.output(cartridge, interface, result, streaming, _finished)
if streaming
- result[:message] = { content: result[:message], lua: nil, fennel: nil }
+ result[:message] = { content: result[:message], lua: nil, fennel: nil, clojure: nil }
return result
end
lua = Adapter.expression(cartridge, interface, :output, :lua)
fennel = Adapter.expression(cartridge, interface, :output, :fennel)
+ clojure = Adapter.expression(cartridge, interface, :output, :clojure)
- result[:message] = { content: result[:message], lua:, fennel: }
+ result[:message] = { content: result[:message], lua:, fennel:, clojure: }
result
end
diff --git a/logic/cartridge/tools.rb b/logic/cartridge/tools.rb
new file mode 100644
index 0000000..6a45bf0
--- /dev/null
+++ b/logic/cartridge/tools.rb
@@ -0,0 +1,53 @@
+# frozen_string_literal: true
+
+require_relative 'fetch'
+require_relative 'affixes'
+require_relative 'adapters'
+
+module NanoBot
+ module Logic
+ module Cartridge
+ module Tools
+ def self.fetch_from_interface(cartridge, interface, action, path)
+ Fetch.cascate(cartridge, [
+ [:interfaces, interface, :tools, action].concat(path),
+ [:interfaces, :tools, action].concat(path),
+ %i[interfaces tools].concat(path)
+ ])
+ end
+
+ def self.feedback?(cartridge, interface, action)
+ Fetch.cascate(cartridge, [
+ [:interfaces, interface, :tools, action, :feedback],
+ [:interfaces, :tools, action, :feedback],
+ %i[interfaces tools feedback]
+ ])
+ end
+
+ def self.input(cartridge, interface, content)
+ lua = Adapter.expression(cartridge, interface, :input, :lua)
+ fennel = Adapter.expression(cartridge, interface, :input, :fennel)
+
+ prefix = Affixes.get(cartridge, interface, :input, :prefix)
+ suffix = Affixes.get(cartridge, interface, :input, :suffix)
+
+ { content:, prefix:, suffix:, lua:, fennel: }
+ end
+
+ def self.output(cartridge, interface, result, streaming, _finished)
+ if streaming
+ result[:message] = { content: result[:message], lua: nil, fennel: nil }
+ return result
+ end
+
+ lua = Adapter.expression(cartridge, interface, :output, :lua)
+ fennel = Adapter.expression(cartridge, interface, :output, :fennel)
+
+ result[:message] = { content: result[:message], lua:, fennel: }
+
+ result
+ end
+ end
+ end
+ end
+end