Ошибка "nil не может быть принудительно введена в Fixnum" - PullRequest
0 голосов
/ 23 февраля 2012

Все,
Я бьюсь головой об кусок кода после обновления до Ruby 1.9.3.Он прекрасно работает в Ruby 1.8.7.Код выполняет поиск процесса и получает значение «rsize» для этого процесса, сохраняет его в файле и затем строит график.Но в ruby ​​1.9.3 я продолжаю получать эту ошибку:
ОШИБКА TypeError: невозможно принудительно привести nil к Fixnum

SVG / Graph / Graph.rb: 375: in `* *: nil не может быть принудительно введен в Fixnum (TypeError)

Вот код, который отслеживает использование памяти процессом Safari

def begin_memprofile
clear_screen
FileUtils.mkdir_p "#{PATH}"

begin
  loop do
      cmd = "top -l 1 -stats pid,rsize,command |grep Safari | awk '{print $2};'"  
      process_data = `#{cmd}`.split("\n") # array
      arr=process_data[0]
      log "Data: #{arr}"
      if arr =~ /^[0-9]+M[\+\-]?$/  # accepts rsize values like 80M+, 80M-, 80M
          memory= arr.to_s.scan(/\d+/).first.to_i 
      end    
      log "Memory: #{memory}"
      data = [Time.now.to_i, memory]
      write_memory(data) # This function writes data into a csv file
      sleep(INTERVAL)
  end
end
 end

Файл CSVбудет иметь два столбца (метка времени, память).Пример значения будет выглядеть следующим образом:
1329972936 80
1329972937 50

Приведенный выше код выполняется в цикле, пока пользователь не нажмет CTRL + C. Когда пользователь делает это, я вызываю функцию, которая извлекает данные изCSV-файл и отображает график

  def render_graph
if !File.exist?(CSV_FILENAME) 
  log "Could not open csv file."
  exit_profiler
end

data = []
fields = []
csv_data = {}


# import data
File.open(CSV_FILENAME, "r").each_line do |line|
  line = line.strip.split(',')
  csv_data[line.first.to_s] = line.last
end
pp "#{csv_data}"



csv_data.each do |row|
  content = row.first
  log "Creating data point: #{content}:: #{row.last.to_i}"
  fields << content
  data << row.last.to_i
end

# strip any nil elements
data.compact!
fields.compact!

        graph = SVG::Graph::Line.new({
  :show_graph_title => true,
  :graph_title => 'Memory Footprint (MB)',
  :height => 800, 
  :width => 1024, 
  :y_title => "RSIZE(MB)",
  :x_title => "TIME",
  :fields => fields
})

graph.add_data(
  :data => data,
  :title => "data"
)

graph.show_y_guidelines = true
graph.min_scale_value = 0

graph.show_x_title = true
graph.show_y_title = true

graph.show_data_points = true
graph.show_data_values = true
graph.show_x_labels = true
graph.rotate_x_labels = false

graph.area_fill = true


# config graph
graph.scale_integers = true
graph.key = false

File.open("#{PATH}/memory-#{TIMESTAMP}.svg", 'w') {|f| 
  f << graph.burn
}    
     end

Я новичок в ruby ​​и изменяю чужой код. Я обновился до ruby ​​1.9.3, потому что я хотел отсортированные хэши.Я не могу понять, почему я получаю эту ошибку.

Ответы [ 3 ]

1 голос
/ 03 июня 2012

Получил в SVG / Graph / Graph.rb из SVG :: Graph V0.6.1. Проблема с methods.include? строка

В Ruby V1.9.3 его следует заменить на self.respond_to? (Str).

[root@victor svg_graph_0.6.1]# grep respond_to lib/SVG/Graph/*.rb
lib/SVG/Graph/Graph.rb: set_defaults if self.respond_to?( "set_defaults" )
lib/SVG/Graph/Graph.rb:        calculations if self.respond_to?('calculations')
lib/SVG/Graph/Graph.rb:          self.send( key.to_s+"=", value ) if 
                                       self.respond_to?( key.to_s )

Также SVG :: Graph V0.6.1 install.rb больше не работает в Ruby 1.9.3. Он должен быть заменен файлом gemspec.

[root@victor svg_graph_0.6.1]# cat SVG.gemspec
s = Gem::Specification.new do |spec|
        spec.description = <<-EOF
           SVG::Graph V0.6.1 generates HTTP image/svg+xml graphs.
EOF
        spec.author = 'Sean E. Russell'
        spec.email = 'ser@germane.software.com'
#       spec.rubyforge_project = 'SVG::Graph'
        spec.homepage = 'http://www.germane-software.com/software/SVG/SVG::Graph/'
        spec.name = 'SVG'
        spec.version = '0.6.1'
        spec.summary = 'Ruby based Graphs library.'
        spec.files = Dir['lib/**/*.rb']
#       spec.require_path = '.'
end

Конечно из корневого каталога SVG :: Вы должны:

[root@victor svg_graph_0.6.1] mkdir lib
[root@victor svg_graph_0.6.1] cp -R SVG/ lib/

тогда еще из SVG :: Graph корневая директория, вам нужно

[root@victor svg_graph_0.6.1]# /usr/bin/gem uninstall SVG
[root@victor svg_graph_0.6.1]# /usr/bin/gem build SVG.gemspec
[root@victor svg_graph_0.6.1]# /usr/bin/gem install SVG

Я размещу на своем веб-сайте мою версию SVG :: Graph для Ruby 1.9.3

С уважением, Philippe

1 голос
/ 15 июня 2012

SVG :: Graph Версия 0.6.1 для Ruby 1.8.x и Ruby 1.9.x находится по адресу http://vouters.dyndns.org/zip/svg_graph_0.6.1.tar.gz Сюда входит добавление личного кода.Как использовать и установить это описано в http://vouters.dyndns.org/tima/HP-UX-OpenView-Ruby-Displaying_System_Metrics_on_Web_browsers.html вместе с тем, как я его использую.

С уважением, Филипп

0 голосов
/ 24 февраля 2012

Ошибка означает, что у вас есть значение nil, где вы должны иметь Fixnum. На вашем месте я бы попытался использовать rdebug, чтобы определить, в чем проблема с вашим кодом.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...