roast-ai 1.0.1 → 1.0.2

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: a5ba7cc0a49bb69453853fcd6f4e2976d06260a9fc0c5c949007f313fba05a24
4
- data.tar.gz: bd2a41c501b808ccea6970c7cb2af195848708fc23acb2c35aae6fa3a143b05d
3
+ metadata.gz: 309884973e075e4d94e5eb7ea3b3192ebe5cbcf5d08a60312c1054f9567d4eb9
4
+ data.tar.gz: b79c03de093e577e77b480e7c67ac5dd510572eeb51887ea9147a03474a6f76a
5
5
  SHA512:
6
- metadata.gz: 475cd2ca97a13f701fd4c699257090b2b89b559bde22b1391506daa8c876dbbd6a3d2711d6e46a2a22f34db1c83477a373728575eeb9178c113447ec624048d5
7
- data.tar.gz: 4a68745484d9aa4da868cf99340eb27578d507c632a2d935c5e6aa5dc037501db56ed271042f295d0e3d8a4e8247cef9eec5aaa66dad02295a9e020cd2d3085f
6
+ metadata.gz: 78d6f38126192dd69853a1bfe8bfe15c5f8ee6ee34f4cf998af534ff215c7a774e0af250409de94027ae36ed0b159a624ad6c4f1c837c40dfc24b72a8b6fe1cd
7
+ data.tar.gz: f36f8a9ad38f0c4e8d0ee15b88c212a59d831613024d9825f362fceba8619d1ad27289142e5f47c53300ac6036753733b7c4c5d3cc27781efbc21f54c63b69de
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- roast-ai (1.0.1)
4
+ roast-ai (1.0.2)
5
5
  activesupport (~> 8.0)
6
6
  async (>= 2.34)
7
7
  rainbow (>= 3.0.0)
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: ../..
3
3
  specs:
4
- roast-ai (1.0.1)
4
+ roast-ai (1.0.2)
5
5
  activesupport (~> 8.0)
6
6
  async (>= 2.34)
7
7
  rainbow (>= 3.0.0)
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: ../..
3
3
  specs:
4
- roast-ai (1.0.1)
4
+ roast-ai (1.0.2)
5
5
  activesupport (~> 8.0)
6
6
  async (>= 2.34)
7
7
  rainbow (>= 3.0.0)
@@ -146,17 +146,22 @@ module Roast
146
146
  message.messages.each { |msg| handle_message(msg) }
147
147
  end
148
148
 
149
- @result.session = message.session_id if message.session_id.present?
149
+ if message.session_id.present?
150
+ (Event << { debug: "New Claude Session ID: #{message.session_id}" }) if @result.session != message.session_id
151
+ @result.session = message.session_id
152
+ end
150
153
 
151
154
  formatted_message = message.format(@context)
152
155
  puts formatted_message if formatted_message.present? && @show_progress
153
156
 
154
157
  unless message.unparsed.blank?
155
158
  # TODO: do something better with unhandled data so we can improve the parser
156
- Roast::Log.warn("Unhandled data in Claude #{message.type} message:")
157
- Roast::Log.warn(JSON.pretty_generate(message.unparsed))
158
- Roast::Log.debug("[FULL MESSAGE: #{message.type}]")
159
- Roast::Log.debug(message.inspect)
159
+ Event << {
160
+ debug: <<~DEBUG,
161
+ Unhandled data in Claude #{message.type} message:
162
+ #{JSON.pretty_generate(message.unparsed)}
163
+ DEBUG
164
+ }
160
165
  end
161
166
 
162
167
  raise ClaudeFailedError, message.error if message.error.present?
@@ -9,6 +9,7 @@ module Roast
9
9
  module Messages
10
10
  class UserMessage < Message
11
11
  IGNORED_FIELDS = [
12
+ :isSynthetic,
12
13
  :parent_tool_use_id,
13
14
  :tool_use_result,
14
15
  ].freeze
@@ -98,7 +98,7 @@ module Roast
98
98
  begin
99
99
  stdout_handler&.call(line)
100
100
  rescue => e
101
- Roast::Log.warn("stdout_handler raised: #{e.class} - #{e.message}")
101
+ Event << { warn: "stdout_handler raised: #{e.class} - #{e.message}" }
102
102
  end
103
103
  end
104
104
  buffer
@@ -114,7 +114,7 @@ module Roast
114
114
  begin
115
115
  stderr_handler&.call(line)
116
116
  rescue => e
117
- Roast::Log.warn("stderr_handler raised: #{e.class} - #{e.message}")
117
+ Event << { warn: "stderr_handler raised: #{e.class} - #{e.message}" }
118
118
  end
119
119
  end
120
120
  buffer
@@ -181,7 +181,7 @@ module Roast
181
181
  rescue Errno::ESRCH
182
182
  # Process already terminated
183
183
  rescue Errno::EPERM
184
- Roast::Log.error("Could not kill process #{pid}: Permission denied")
184
+ Event << { error: "Could not kill process #{pid}: Permission denied" }
185
185
  end
186
186
 
187
187
  #: (Integer) -> bool
@@ -116,7 +116,7 @@ module Roast
116
116
 
117
117
  #: (Event) -> void
118
118
  def handle_log_event(event)
119
- Roast::Log.logger.add(event.log_severity, event.log_message)
119
+ Roast::Log.logger.add(event.log_severity, "#{format_path(event)} #{event.log_message}")
120
120
  end
121
121
 
122
122
  #: (Event) -> void
data/lib/roast/version.rb CHANGED
@@ -2,5 +2,5 @@
2
2
  # frozen_string_literal: true
3
3
 
4
4
  module Roast
5
- VERSION = "1.0.1"
5
+ VERSION = "1.0.2"
6
6
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: roast-ai
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.1
4
+ version: 1.0.2
5
5
  platform: ruby
6
6
  authors:
7
7
  - Shopify