rum 0.0.1-x86-mswin32-60 → 0.0.3-x86-mswin32-60
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +9 -0
- data/README.md +35 -0
- data/Rakefile +22 -19
- data/bin/rum-client +4 -4
- data/doc/basic.rb +1 -1
- data/doc/doc.html +619 -602
- data/doc/example.rb +1 -1
- data/doc/reference.rb +29 -16
- data/doc/resources/build.rb +14 -12
- data/doc/resources/doc.haml +8 -3
- data/ext/mac/keyboard_hook/EventTap.h +1 -1
- data/ext/mac/keyboard_hook/EventTap.m +9 -9
- data/ext/mac/keyboard_hook/KeyboardHook.xcodeproj/project.pbxproj +12 -9
- data/ext/windows/keyboard_hook/keyboard_hook.c +3 -3
- data/ext/windows/system/autohotkey_stuff.c +12 -10
- data/ext/windows/system/clipboard_watcher.c +2 -2
- data/ext/windows/system/extconf.rb +1 -0
- data/ext/windows/system/input_box.c +9 -9
- data/ext/windows/system/system.c +51 -46
- data/lib/rum/barrel.rb +46 -16
- data/lib/rum/barrel/emacs.rb +1 -1
- data/lib/rum/barrel/emacs_client.rb +32 -5
- data/lib/rum/core.rb +24 -22
- data/lib/rum/dsl.rb +15 -16
- data/lib/rum/gui.rb +3 -3
- data/lib/rum/help.rb +10 -8
- data/lib/rum/hotkey_core.rb +35 -25
- data/lib/rum/mac.rb +1 -1
- data/lib/rum/mac/gui.rb +1 -1
- data/lib/rum/mac/gui/growl.rb +3 -3
- data/lib/rum/mac/irb/completion.rb +13 -13
- data/lib/rum/mac/keyboard_hook.rb +8 -5
- data/lib/rum/mac/layouts.rb +4 -4
- data/lib/rum/mac/system.rb +2 -2
- data/lib/rum/remote.rb +3 -3
- data/lib/rum/server.rb +2 -3
- data/lib/rum/windows.rb +2 -1
- data/lib/rum/windows/app.rb +12 -7
- data/lib/rum/windows/apps.rb +3 -8
- data/lib/rum/windows/gui.rb +8 -8
- data/lib/rum/windows/keyboard.rb +34 -9
- data/lib/rum/windows/keyboard_hook.so +0 -0
- data/lib/rum/windows/layouts.rb +6 -6
- data/lib/rum/windows/system.rb +71 -28
- data/lib/rum/windows/system.so +0 -0
- data/lib/rum/windows/system_foreign_functions.rb +44 -20
- data/rum.gemspec +2 -2
- metadata +19 -21
- data/README +0 -30
data/lib/rum/mac.rb
CHANGED
data/lib/rum/mac/gui.rb
CHANGED
data/lib/rum/mac/gui/growl.rb
CHANGED
@@ -8,7 +8,7 @@ module Rum
|
|
8
8
|
@callbacks = {}
|
9
9
|
GrowlApplicationBridge.setGrowlDelegate(self)
|
10
10
|
end
|
11
|
-
|
11
|
+
|
12
12
|
def registrationDictionaryForGrowl
|
13
13
|
notifications = [@notification_name]
|
14
14
|
{ TicketVersion: 1, AllNotifications: notifications,
|
@@ -42,9 +42,9 @@ module Rum
|
|
42
42
|
framework File.join(File.dirname(__FILE__), 'Growl.framework')
|
43
43
|
@@notifier = Notifier.new('Rum', 'Notification')
|
44
44
|
end
|
45
|
-
|
45
|
+
|
46
46
|
private
|
47
|
-
|
47
|
+
|
48
48
|
def message_backend(text, title, sticky, callback)
|
49
49
|
title ||= 'Rum' # Mac Growl needs a title
|
50
50
|
@@notifier.notify(title, text, sticky, callback)
|
@@ -1,5 +1,5 @@
|
|
1
1
|
#
|
2
|
-
# irb/completor.rb -
|
2
|
+
# irb/completor.rb -
|
3
3
|
# $Release Version: 0.9$
|
4
4
|
# $Revision: 23233 $
|
5
5
|
# by Keiju ISHITSUKA(keiju@ishitsuka.com)
|
@@ -15,16 +15,16 @@ module IRB
|
|
15
15
|
|
16
16
|
ReservedWords = [
|
17
17
|
"BEGIN", "END",
|
18
|
-
"alias", "and",
|
19
|
-
"begin", "break",
|
18
|
+
"alias", "and",
|
19
|
+
"begin", "break",
|
20
20
|
"case", "class",
|
21
21
|
"def", "defined", "do",
|
22
22
|
"else", "elsif", "end", "ensure",
|
23
|
-
"false", "for",
|
24
|
-
"if", "in",
|
25
|
-
"module",
|
23
|
+
"false", "for",
|
24
|
+
"if", "in",
|
25
|
+
"module",
|
26
26
|
"next", "nil", "not",
|
27
|
-
"or",
|
27
|
+
"or",
|
28
28
|
"redo", "rescue", "retry", "return",
|
29
29
|
"self", "super",
|
30
30
|
"then", "true",
|
@@ -32,10 +32,10 @@ module IRB
|
|
32
32
|
"when", "while",
|
33
33
|
"yield",
|
34
34
|
]
|
35
|
-
|
35
|
+
|
36
36
|
CompletionProc = proc { |input|
|
37
37
|
bind = IRB.conf[:MAIN_CONTEXT].workspace.binding
|
38
|
-
|
38
|
+
|
39
39
|
# puts "input: #{input}"
|
40
40
|
|
41
41
|
case input
|
@@ -63,7 +63,7 @@ module IRB
|
|
63
63
|
candidates = Proc.instance_methods.collect{|m| m.to_s}
|
64
64
|
candidates |= Hash.instance_methods.collect{|m| m.to_s}
|
65
65
|
select_message(receiver, message, candidates)
|
66
|
-
|
66
|
+
|
67
67
|
when /^(:[^:.]*)$/
|
68
68
|
# Symbol
|
69
69
|
if Symbol.respond_to?(:all_symbols)
|
@@ -137,7 +137,7 @@ module IRB
|
|
137
137
|
gv = eval("global_variables", bind).collect{|m| m.to_s}
|
138
138
|
lv = eval("local_variables", bind).collect{|m| m.to_s}
|
139
139
|
cv = eval("self.class.constants", bind).collect{|m| m.to_s}
|
140
|
-
|
140
|
+
|
141
141
|
if (gv | lv | cv).include?(receiver)
|
142
142
|
# foo.func and foo is local var.
|
143
143
|
candidates = eval("#{receiver}.methods", bind).collect{|m| m.to_s}
|
@@ -157,7 +157,7 @@ module IRB
|
|
157
157
|
rescue Exception
|
158
158
|
name = ""
|
159
159
|
end
|
160
|
-
next if name != "IRB::Context" and
|
160
|
+
next if name != "IRB::Context" and
|
161
161
|
/^(IRB|SLex|RubyLex|RubyToken)/ =~ name
|
162
162
|
candidates.concat m.instance_methods(false).collect{|x| x.to_s}
|
163
163
|
}
|
@@ -177,7 +177,7 @@ module IRB
|
|
177
177
|
|
178
178
|
else
|
179
179
|
candidates = eval("methods | private_methods | local_variables | self.class.constants", bind).collect{|m| m.to_s}
|
180
|
-
|
180
|
+
|
181
181
|
(candidates|ReservedWords).grep(/^#{Regexp.quote(input)}/)
|
182
182
|
end
|
183
183
|
}
|
@@ -1,4 +1,8 @@
|
|
1
|
-
framework
|
1
|
+
framework 'CoreGraphics' # OS X 10.8 location for kCGKeyboardEventKeycode and related symbols
|
2
|
+
unless defined? KCGKeyboardEventKeycode
|
3
|
+
framework 'ApplicationServices' # 10.7 location
|
4
|
+
end
|
5
|
+
|
2
6
|
framework "#{File.dirname(__FILE__)}/keyboard_hook/KeyboardHook.framework"
|
3
7
|
framework 'Cocoa'
|
4
8
|
|
@@ -16,7 +20,7 @@ module KeyboardHook
|
|
16
20
|
end
|
17
21
|
|
18
22
|
class EventTap
|
19
|
-
def
|
23
|
+
def handleKeyEvent(event)
|
20
24
|
event if @proc.call(event)
|
21
25
|
end
|
22
26
|
|
@@ -41,7 +45,7 @@ class Event
|
|
41
45
|
def keycode
|
42
46
|
get_integer_value_field(KCGKeyboardEventKeycode)
|
43
47
|
end
|
44
|
-
|
48
|
+
|
45
49
|
def id
|
46
50
|
get_integer_value_field(KCGKeyboardEventKeycode)
|
47
51
|
end
|
@@ -63,11 +67,10 @@ class Event
|
|
63
67
|
end
|
64
68
|
|
65
69
|
def get_flags
|
66
|
-
CGEventGetFlags(eventRef)
|
70
|
+
CGEventGetFlags(eventRef)
|
67
71
|
end
|
68
72
|
|
69
73
|
def set_flags(flags)
|
70
74
|
CGEventSetFlags(eventRef, flags)
|
71
75
|
end
|
72
76
|
end
|
73
|
-
|
data/lib/rum/mac/layouts.rb
CHANGED
@@ -3,7 +3,7 @@
|
|
3
3
|
module Rum
|
4
4
|
module Layouts
|
5
5
|
module_function
|
6
|
-
|
6
|
+
|
7
7
|
def default_layout
|
8
8
|
us
|
9
9
|
end
|
@@ -11,7 +11,7 @@ module Rum
|
|
11
11
|
# /System/Library/Frameworks/Carbon.framework/.../Events.h
|
12
12
|
def core
|
13
13
|
core = Layout.new
|
14
|
-
|
14
|
+
|
15
15
|
[['return', "\n", 36],
|
16
16
|
['tab', 48],
|
17
17
|
['space', ' ', 49],
|
@@ -60,7 +60,7 @@ module Rum
|
|
60
60
|
['rightarrow', 124],
|
61
61
|
['downarrow', 125],
|
62
62
|
['uparrow', 126]].each { |key| core.add *key }
|
63
|
-
|
63
|
+
|
64
64
|
core
|
65
65
|
end
|
66
66
|
|
@@ -123,7 +123,7 @@ module Rum
|
|
123
123
|
5 = 9 7 - 8 0 ] o u [ i p _ l j _ k ; _ , / n m .}.each_with_index do |key, id|
|
124
124
|
us.add key, id unless key == '_'
|
125
125
|
end
|
126
|
-
|
126
|
+
|
127
127
|
us.add "'", 39
|
128
128
|
us.add '\\', 42
|
129
129
|
us.add '`', 50
|
data/lib/rum/mac/system.rb
CHANGED
data/lib/rum/remote.rb
CHANGED
@@ -31,15 +31,15 @@ module Rum
|
|
31
31
|
msg.force_encoding Encoding::BINARY
|
32
32
|
write([msg.length].pack('N') + msg)
|
33
33
|
end
|
34
|
-
|
34
|
+
|
35
35
|
def receive
|
36
36
|
if message_size = read(4) # sizeof (N)
|
37
|
-
message_size = message_size.unpack('N')[0]
|
37
|
+
message_size = message_size.unpack('N')[0]
|
38
38
|
read(message_size).force_encoding(Encoding::UTF_8)
|
39
39
|
end
|
40
40
|
end
|
41
41
|
end
|
42
|
-
|
42
|
+
|
43
43
|
def Connection.new(stream)
|
44
44
|
stream.extend Messaging
|
45
45
|
end
|
data/lib/rum/server.rb
CHANGED
@@ -3,7 +3,7 @@ require 'rum/remote'
|
|
3
3
|
module Rum
|
4
4
|
module Server
|
5
5
|
module_function
|
6
|
-
|
6
|
+
|
7
7
|
# This makes it easier for code to check if it runs inside the server thread.
|
8
8
|
def thread
|
9
9
|
@thread
|
@@ -15,7 +15,6 @@ module Rum
|
|
15
15
|
@server = TCPServer.new('127.0.0.1', Remote.default_port)
|
16
16
|
puts "Server started."
|
17
17
|
begin
|
18
|
-
@connection = nil
|
19
18
|
loop do
|
20
19
|
@connection = Remote::Connection.new(@server.accept)
|
21
20
|
handle(@connection)
|
@@ -71,7 +70,7 @@ module Rum
|
|
71
70
|
workspace = Struct.new(:binding).new(binding)
|
72
71
|
context = Struct.new(:workspace).new(workspace)
|
73
72
|
@CONF = { MAIN_CONTEXT: context }
|
74
|
-
|
73
|
+
|
75
74
|
def IRB.conf
|
76
75
|
@CONF
|
77
76
|
end'
|
data/lib/rum/windows.rb
CHANGED
data/lib/rum/windows/app.rb
CHANGED
@@ -3,11 +3,11 @@ module Rum
|
|
3
3
|
include System
|
4
4
|
|
5
5
|
@@apps = {}
|
6
|
-
|
6
|
+
|
7
7
|
def self.add(app)
|
8
8
|
@@apps[app.binary] = app
|
9
9
|
end
|
10
|
-
|
10
|
+
|
11
11
|
def self.remove(app)
|
12
12
|
@@apps.delete(app.binary)
|
13
13
|
end
|
@@ -22,16 +22,21 @@ module Rum
|
|
22
22
|
|
23
23
|
attr_accessor :path, :binary, :matcher
|
24
24
|
|
25
|
-
def initialize(path, *
|
26
|
-
|
25
|
+
def initialize(path, *args)
|
26
|
+
x64 = args.delete :x64
|
27
|
+
@path = append_path_to_programfiles_if_relative(path, x64)
|
27
28
|
@binary = File.basename(@path).sub(/\.exe$/, '').downcase
|
28
|
-
@matcher = WindowMatcher.new(*
|
29
|
+
@matcher = WindowMatcher.new(*args)
|
29
30
|
App.add(self)
|
30
31
|
end
|
31
32
|
|
32
|
-
|
33
|
+
PROGRAM_FILES = ENV['PROGRAMFILES'].gsub('\\', '/')
|
34
|
+
PROGRAM_FILES_X64 = ENV['ProgramW6432'].gsub('\\', '/')
|
35
|
+
|
36
|
+
def append_path_to_programfiles_if_relative(path, x64)
|
33
37
|
if path !~ /^\w:|^%/
|
34
|
-
|
38
|
+
program_files = x64 ? PROGRAM_FILES_X64 : PROGRAM_FILES
|
39
|
+
path = File.join(program_files, path)
|
35
40
|
end
|
36
41
|
path
|
37
42
|
end
|
data/lib/rum/windows/apps.rb
CHANGED
@@ -8,18 +8,13 @@ def Firefox.activate_and_focus_address_bar
|
|
8
8
|
Keyboard.type '(ctrl l)' if activate
|
9
9
|
end
|
10
10
|
|
11
|
-
Photoshop = App.new('Adobe/Adobe Photoshop
|
11
|
+
Photoshop = App.new('Adobe/Adobe Photoshop CS6 (64 Bit)/Photoshop', nil, 'Photoshop', :x64)
|
12
12
|
class << Photoshop
|
13
13
|
def next_blend_mode
|
14
|
-
|
15
|
-
type '(shift 0)'
|
16
|
-
else
|
17
|
-
type '(shift +)'
|
18
|
-
end
|
14
|
+
type '(shift (add))'
|
19
15
|
end
|
20
16
|
|
21
17
|
def previous_blend_mode
|
22
|
-
type '(shift
|
18
|
+
type '(shift (subtract))'
|
23
19
|
end
|
24
20
|
end
|
25
|
-
|
data/lib/rum/windows/gui.rb
CHANGED
@@ -7,7 +7,7 @@ module Rum
|
|
7
7
|
Gui.message "Can't visit a file in Windows Explorer."
|
8
8
|
end
|
9
9
|
end
|
10
|
-
|
10
|
+
|
11
11
|
def open_file file, line=nil
|
12
12
|
System.start file
|
13
13
|
end
|
@@ -23,7 +23,7 @@ module Rum
|
|
23
23
|
def alert_backend text, title
|
24
24
|
System.message_box text, title
|
25
25
|
end
|
26
|
-
|
26
|
+
|
27
27
|
def message_backend text, title, sticky, callback
|
28
28
|
alert text, title
|
29
29
|
end
|
@@ -39,7 +39,7 @@ module Rum
|
|
39
39
|
Message = 'message'
|
40
40
|
|
41
41
|
private
|
42
|
-
|
42
|
+
|
43
43
|
def message_backend(text, title, sticky, callback)
|
44
44
|
unless title
|
45
45
|
title = text
|
@@ -50,13 +50,13 @@ module Rum
|
|
50
50
|
if callback
|
51
51
|
on_click = lambda { |event| callback.call if event[:callback_result] == "CLICK" }
|
52
52
|
end
|
53
|
-
|
53
|
+
|
54
54
|
Growl.client.notify(name: Message, title: title,
|
55
55
|
text: text, sticky: sticky, &on_click)
|
56
56
|
end
|
57
|
-
|
57
|
+
|
58
58
|
module_function
|
59
|
-
|
59
|
+
|
60
60
|
def auto_setup
|
61
61
|
require 'ruby_gntp'
|
62
62
|
@growl = GNTP.new("Rum")
|
@@ -73,10 +73,10 @@ module Rum
|
|
73
73
|
|
74
74
|
module EmacsInteraction
|
75
75
|
private
|
76
|
-
|
76
|
+
|
77
77
|
def interaction(*args)
|
78
78
|
emacs = Emacs.window
|
79
|
-
return
|
79
|
+
return unless emacs
|
80
80
|
unless (emacs_already_active = emacs.active?)
|
81
81
|
old = System.active_window
|
82
82
|
emacs.move(400, 400, 800, 300)
|
data/lib/rum/windows/keyboard.rb
CHANGED
@@ -3,21 +3,24 @@ require 'strscan'
|
|
3
3
|
module Rum
|
4
4
|
module Keyboard
|
5
5
|
extend self
|
6
|
-
|
6
|
+
|
7
7
|
def type(key_sequence, *args)
|
8
8
|
release_core_modifiers unless args.include? :blind
|
9
9
|
type_sequence(key_sequence, args.include?(:slow))
|
10
10
|
end
|
11
|
-
|
11
|
+
|
12
12
|
def type!(key_sequence, *args)
|
13
13
|
release_core_modifiers unless args.include? :blind
|
14
14
|
type_sequence_literally(key_sequence, args.include?(:slow))
|
15
15
|
end
|
16
16
|
|
17
|
+
def type_unicode(key_sequence, *args)
|
18
|
+
release_core_modifiers unless args.include? :blind
|
19
|
+
type_sequence_unicode(key_sequence, args.include?(:slow))
|
20
|
+
end
|
21
|
+
|
17
22
|
def release_core_modifiers
|
18
|
-
|
19
|
-
to_release = Rum.layout.core_modifiers.keys.select { |mod| pressed[mod] }
|
20
|
-
to_release.each { |key| System.send_key_event key, false }
|
23
|
+
Rum.hotkey_processor.release_core_modifiers
|
21
24
|
end
|
22
25
|
|
23
26
|
private
|
@@ -39,7 +42,7 @@ module Rum
|
|
39
42
|
while (char = s.getch)
|
40
43
|
case char
|
41
44
|
when '\\'
|
42
|
-
|
45
|
+
(char = s.getch) and down_and_up(char, slow)
|
43
46
|
when '('
|
44
47
|
key = s.scan(/[^() ]+/)
|
45
48
|
s.skip /\ /
|
@@ -55,10 +58,26 @@ module Rum
|
|
55
58
|
pressed_keys.reverse_each { |key| up key }
|
56
59
|
end
|
57
60
|
|
58
|
-
def
|
59
|
-
|
60
|
-
|
61
|
+
def type_sequence_unicode(key_sequence, slow)
|
62
|
+
s = StringScanner.new(key_sequence)
|
63
|
+
pressed_keys = []
|
64
|
+
while (char = s.getch)
|
65
|
+
case char
|
66
|
+
when '\\'
|
67
|
+
(char = s.getch) and System.send_unicode_char(char)
|
68
|
+
when '('
|
69
|
+
key = s.scan(/[^() ]+/)
|
70
|
+
s.skip /\ /
|
71
|
+
down key
|
72
|
+
pressed_keys << key
|
73
|
+
when ')'
|
74
|
+
up pressed_keys.pop
|
75
|
+
else
|
76
|
+
System.send_unicode_char(char)
|
77
|
+
end
|
78
|
+
sleep 0.01 if slow
|
61
79
|
end
|
80
|
+
pressed_keys.reverse_each { |key| up key }
|
62
81
|
end
|
63
82
|
|
64
83
|
def down(key)
|
@@ -76,5 +95,11 @@ module Rum
|
|
76
95
|
type_sequence(key_sequence, slow)
|
77
96
|
end
|
78
97
|
end
|
98
|
+
|
99
|
+
def send_key(key_alias, down)
|
100
|
+
if key = Rum.layout[key_alias]
|
101
|
+
System.send_key_event key, down
|
102
|
+
end
|
103
|
+
end
|
79
104
|
end
|
80
105
|
end
|