File: beginend.rb

package info (click to toggle)
amarok 3.3.1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 112,168 kB
  • sloc: cpp: 195,056; xml: 4,322; ansic: 2,634; javascript: 673; ruby: 528; python: 507; sh: 252; makefile: 12
file content (55 lines) | stat: -rwxr-xr-x 2,461 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#!/usr/bin/ruby
###########################################################################
#   Parses the Amarok debug log and prints methods which have unbalanced  #
#   BEGIN and END. This script only works for those methods with a        #
#   DEBUG_BLOCK.                                                          #
#                                                                         #
#   Copyright                                                             #
#   (C) 2010 Casey Link <unnamedrambler@gmail.com>                        #
#                                                                         #
#   This program is free software; you can redistribute it and/or modify  #
#   it under the terms of the GNU General Public License as published by  #
#   the Free Software Foundation; either version 2 of the License, or     #
#   (at your option) any later version.                                   #
#                                                                         #
#   This program is distributed in the hope that it will be useful,       #
#   but WITHOUT ANY WARRANTY; without even the implied warranty of        #
#   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         #
#   GNU General Public License for more details.                          #
#                                                                         #
#   You should have received a copy of the GNU General Public License     #
#   along with this program; if not, write to the                         #
#   Free Software Foundation, Inc.,                                       #
#   51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.         #
###########################################################################

# Use: cat amarok.log | beginend.rb

input = STDIN.read
stack = []

input.each_line do |line|
    begins = line.scan(/amarok:\s+BEGIN: (.*)/)
    if begins[0] != nil
      stack.push(begins[0][0].strip)
    end
    ends = line.scan(/amarok:\s+END__: (.*) - (.*)/)
    if ends[0] != nil 
      if !stack.include? ends[0][0].strip
        # could this ever happen?
	puts "Method ended but not begun: #{ends[0][0]}"
      else
        # only delete the most recent matching block
        last = stack.rindex(ends[0][0].strip)
        stack.delete_at(last)
      end
    end
end

# Any remaining methods blocks will be unbalanced
stack.each do |block|
  puts "Not ended: #{block}"
end

puts "Done."