File: deprecated.rb

package info (click to toggle)
ruby-launchy 2.5.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 292 kB
  • sloc: ruby: 1,285; makefile: 6
file content (52 lines) | stat: -rw-r--r-- 1,364 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
module Launchy
  #
  # This class is deprecated and will be removed 
  #
  class Browser
    def self.run( *args )
      Browser.new.visit( args[0] )
    end

    def visit( url )
      _warn "You made a call to a deprecated Launchy API. This call should be changed to 'Launchy.open( uri )'"
      report_caller_context( caller )

      ::Launchy.open( url )
    end

    private

    def find_caller_context( stack )
      caller_file = stack.find do |line|
        not line.index( __FILE__ )
      end
      if caller_file then
        caller_fname, caller_line, _ = caller_file.split(":")
        if File.readable?( caller_fname ) then
          caller_lines = IO.readlines( caller_fname )
          context = [ caller_file ]
          context << caller_lines[(caller_line.to_i)-3, 5] 
          return context.flatten
        end
      end
      return []
    end

    def report_caller_context( stack )
      context = find_caller_context( stack )
      if context.size > 0 then
        _warn "I think I was able to find the location that needs to be fixed. Please go look at:"
        _warn
        context.each do |line|
          _warn line.rstrip
        end
        _warn
        _warn "If this is not the case, please file a bug. #{Launchy.bug_report_message}"
      end
    end

    def _warn( msg = "" )
      warn "WARNING: #{msg}"
    end
  end
end