Class: Lich::Util::MemoryReleaser::Manager

Inherits:
Object
  • Object
show all
Defined in:
documented/util/memoryreleaser.rb

Overview

Manages the memory releaser settings and operations

Examples:

Creating a manager instance

manager = MemoryReleaser::Manager.new

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeManager

Initializes a new Manager instance



116
117
118
119
# File 'documented/util/memoryreleaser.rb', line 116

def initialize
  load_settings
  @enabled = true
end

Instance Attribute Details

#enabledObject

Returns the value of attribute enabled.



106
107
108
# File 'documented/util/memoryreleaser.rb', line 106

def enabled
  @enabled
end

#intervalObject

Returns the value of attribute interval.



108
109
110
# File 'documented/util/memoryreleaser.rb', line 108

def interval
  @interval
end

#settingsObject (readonly)

Returns the value of attribute settings.



112
113
114
# File 'documented/util/memoryreleaser.rb', line 112

def settings
  @settings
end

#verboseObject

Returns the value of attribute verbose.



110
111
112
# File 'documented/util/memoryreleaser.rb', line 110

def verbose
  @verbose
end

Instance Method Details

#auto_disable!Object



163
164
165
166
167
# File 'documented/util/memoryreleaser.rb', line 163

def auto_disable!
  @settings[:auto_start] = false
  save_settings
  stop if running?
end

#auto_start!Object



157
158
159
160
161
# File 'documented/util/memoryreleaser.rb', line 157

def auto_start!
  @settings[:auto_start] = true
  save_settings
  start
end

#benchmarkObject



259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
# File 'documented/util/memoryreleaser.rb', line 259

def benchmark
  respond "=" * 60
  respond "Memory Usage Before Release:"
  respond "=" * 60
  before = print_memory_stats

  respond "\nReleasing memory..."
  release

  respond "\n" + "=" * 60
  respond "Memory Usage After Release:"
  respond "=" * 60
  after = print_memory_stats

  respond "\n" + "=" * 60
  respond "Change:"
  respond "=" * 60
  print_memory_diff(before, after)
end

#interval!(seconds) ⇒ Object



169
170
171
172
173
174
175
176
177
178
179
180
181
182
# File 'documented/util/memoryreleaser.rb', line 169

def interval!(seconds)
  seconds = [seconds, 60].max # Minimum 60 seconds
  @settings[:interval] = seconds
  @interval = seconds
  save_settings

  # If currently running, restart with new interval
  if running?
    log "Restarting with new interval: #{seconds}s"
    start
  end

  seconds
end

#load_settingsHash

Loads settings from the database

Returns:

  • (Hash)

    The loaded settings

Raises:

  • (StandardError)

    If there’s an error loading settings



124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
# File 'documented/util/memoryreleaser.rb', line 124

def load_settings
  # Load from DB_Store with per-character scope
  scope = "#{XMLData.game}:#{XMLData.name}"
  stored_settings = Lich::Common::DB_Store.read(scope, 'lich_memory_releaser') || {}
  @settings = DEFAULT_SETTINGS.merge(stored_settings)

  # Apply loaded settings to instance variables
  @interval = @settings[:interval]
  @verbose = @settings[:verbose]

  @settings
rescue => e
  # If there's an error loading settings, use defaults
  respond "[MemoryReleaser] Error loading settings: #{e.message}, using defaults"
  @settings = DEFAULT_SETTINGS.dup
  @interval = @settings[:interval]
  @verbose = @settings[:verbose]
  @settings
end

#releaseObject



191
192
193
194
195
# File 'documented/util/memoryreleaser.rb', line 191

def release
  run_gc
  release_to_os
  log "Memory release completed"
end

#running?Boolean

Returns:

  • (Boolean)


243
244
245
246
# File 'documented/util/memoryreleaser.rb', line 243

def running?
  worker = MemoryReleaser.worker_thread
  worker&.alive? || false
end

#save_settingsHash

Saves current settings to the database

Returns:

  • (Hash)

    The saved settings

Raises:

  • (StandardError)

    If there’s an error saving settings



147
148
149
150
151
152
153
154
155
# File 'documented/util/memoryreleaser.rb', line 147

def save_settings
  # Save current settings to DB_Store with per-character scope
  scope = "#{XMLData.game}:#{XMLData.name}"
  Lich::Common::DB_Store.save(scope, 'lich_memory_releaser', @settings)
  @settings
rescue => e
  respond "[MemoryReleaser] Error saving settings: #{e.message}"
  @settings
end

#start(interval: nil, verbose: nil) ⇒ Object



197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
# File 'documented/util/memoryreleaser.rb', line 197

def start(interval: nil, verbose: nil)
  stop if running?

  # Use provided values or fall back to settings
  @interval = interval || @settings[:interval]
  @verbose = verbose.nil? ? @settings[:verbose] : verbose
  @enabled = true

  # Update settings with current values
  @settings[:interval] = @interval
  @settings[:verbose] = @verbose
  save_settings

  # Send command to persistent launcher thread
  MemoryReleaser.command_queue << {
    action: :start_worker,
    interval: @interval,
    verbose: @verbose,
    manager: self
  }

  # Wait for worker to start
  timeout = 0
  until running?
    sleep 0.1
    timeout += 1
    if timeout > 50
      respond "[MemoryReleaser] ERROR: Worker thread failed to start"
      return nil
    end
  end

  MemoryReleaser.worker_thread
end

#statusObject



248
249
250
251
252
253
254
255
256
257
# File 'documented/util/memoryreleaser.rb', line 248

def status
  {
    running: running?,
    enabled: @enabled,
    auto_start: @settings[:auto_start],
    interval: @interval,
    verbose: @verbose,
    platform: RbConfig::CONFIG['host_os']
  }
end

#stopObject



232
233
234
235
236
237
238
239
240
241
# File 'documented/util/memoryreleaser.rb', line 232

def stop
  @enabled = false

  MemoryReleaser.command_queue << {
    action: :stop_worker
  }

  sleep 0.2
  log "Memory releaser stopped"
end

#verbose!(enabled) ⇒ Object



184
185
186
187
188
189
# File 'documented/util/memoryreleaser.rb', line 184

def verbose!(enabled)
  @settings[:verbose] = enabled
  @verbose = enabled
  save_settings
  enabled
end