blinkenlights 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
data/GPL ADDED
@@ -0,0 +1,340 @@
1
+ GNU GENERAL PUBLIC LICENSE
2
+ Version 2, June 1991
3
+
4
+ Copyright (C) 1989, 1991 Free Software Foundation, Inc.
5
+ 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
6
+ Everyone is permitted to copy and distribute verbatim copies
7
+ of this license document, but changing it is not allowed.
8
+
9
+ Preamble
10
+
11
+ The licenses for most software are designed to take away your
12
+ freedom to share and change it. By contrast, the GNU General Public
13
+ License is intended to guarantee your freedom to share and change free
14
+ software--to make sure the software is free for all its users. This
15
+ General Public License applies to most of the Free Software
16
+ Foundation's software and to any other program whose authors commit to
17
+ using it. (Some other Free Software Foundation software is covered by
18
+ the GNU Library General Public License instead.) You can apply it to
19
+ your programs, too.
20
+
21
+ When we speak of free software, we are referring to freedom, not
22
+ price. Our General Public Licenses are designed to make sure that you
23
+ have the freedom to distribute copies of free software (and charge for
24
+ this service if you wish), that you receive source code or can get it
25
+ if you want it, that you can change the software or use pieces of it
26
+ in new free programs; and that you know you can do these things.
27
+
28
+ To protect your rights, we need to make restrictions that forbid
29
+ anyone to deny you these rights or to ask you to surrender the rights.
30
+ These restrictions translate to certain responsibilities for you if you
31
+ distribute copies of the software, or if you modify it.
32
+
33
+ For example, if you distribute copies of such a program, whether
34
+ gratis or for a fee, you must give the recipients all the rights that
35
+ you have. You must make sure that they, too, receive or can get the
36
+ source code. And you must show them these terms so they know their
37
+ rights.
38
+
39
+ We protect your rights with two steps: (1) copyright the software, and
40
+ (2) offer you this license which gives you legal permission to copy,
41
+ distribute and/or modify the software.
42
+
43
+ Also, for each author's protection and ours, we want to make certain
44
+ that everyone understands that there is no warranty for this free
45
+ software. If the software is modified by someone else and passed on, we
46
+ want its recipients to know that what they have is not the original, so
47
+ that any problems introduced by others will not reflect on the original
48
+ authors' reputations.
49
+
50
+ Finally, any free program is threatened constantly by software
51
+ patents. We wish to avoid the danger that redistributors of a free
52
+ program will individually obtain patent licenses, in effect making the
53
+ program proprietary. To prevent this, we have made it clear that any
54
+ patent must be licensed for everyone's free use or not licensed at all.
55
+
56
+ The precise terms and conditions for copying, distribution and
57
+ modification follow.
58
+
59
+ GNU GENERAL PUBLIC LICENSE
60
+ TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
61
+
62
+ 0. This License applies to any program or other work which contains
63
+ a notice placed by the copyright holder saying it may be distributed
64
+ under the terms of this General Public License. The "Program", below,
65
+ refers to any such program or work, and a "work based on the Program"
66
+ means either the Program or any derivative work under copyright law:
67
+ that is to say, a work containing the Program or a portion of it,
68
+ either verbatim or with modifications and/or translated into another
69
+ language. (Hereinafter, translation is included without limitation in
70
+ the term "modification".) Each licensee is addressed as "you".
71
+
72
+ Activities other than copying, distribution and modification are not
73
+ covered by this License; they are outside its scope. The act of
74
+ running the Program is not restricted, and the output from the Program
75
+ is covered only if its contents constitute a work based on the
76
+ Program (independent of having been made by running the Program).
77
+ Whether that is true depends on what the Program does.
78
+
79
+ 1. You may copy and distribute verbatim copies of the Program's
80
+ source code as you receive it, in any medium, provided that you
81
+ conspicuously and appropriately publish on each copy an appropriate
82
+ copyright notice and disclaimer of warranty; keep intact all the
83
+ notices that refer to this License and to the absence of any warranty;
84
+ and give any other recipients of the Program a copy of this License
85
+ along with the Program.
86
+
87
+ You may charge a fee for the physical act of transferring a copy, and
88
+ you may at your option offer warranty protection in exchange for a fee.
89
+
90
+ 2. You may modify your copy or copies of the Program or any portion
91
+ of it, thus forming a work based on the Program, and copy and
92
+ distribute such modifications or work under the terms of Section 1
93
+ above, provided that you also meet all of these conditions:
94
+
95
+ a) You must cause the modified files to carry prominent notices
96
+ stating that you changed the files and the date of any change.
97
+
98
+ b) You must cause any work that you distribute or publish, that in
99
+ whole or in part contains or is derived from the Program or any
100
+ part thereof, to be licensed as a whole at no charge to all third
101
+ parties under the terms of this License.
102
+
103
+ c) If the modified program normally reads commands interactively
104
+ when run, you must cause it, when started running for such
105
+ interactive use in the most ordinary way, to print or display an
106
+ announcement including an appropriate copyright notice and a
107
+ notice that there is no warranty (or else, saying that you provide
108
+ a warranty) and that users may redistribute the program under
109
+ these conditions, and telling the user how to view a copy of this
110
+ License. (Exception: if the Program itself is interactive but
111
+ does not normally print such an announcement, your work based on
112
+ the Program is not required to print an announcement.)
113
+
114
+ These requirements apply to the modified work as a whole. If
115
+ identifiable sections of that work are not derived from the Program,
116
+ and can be reasonably considered independent and separate works in
117
+ themselves, then this License, and its terms, do not apply to those
118
+ sections when you distribute them as separate works. But when you
119
+ distribute the same sections as part of a whole which is a work based
120
+ on the Program, the distribution of the whole must be on the terms of
121
+ this License, whose permissions for other licensees extend to the
122
+ entire whole, and thus to each and every part regardless of who wrote it.
123
+
124
+ Thus, it is not the intent of this section to claim rights or contest
125
+ your rights to work written entirely by you; rather, the intent is to
126
+ exercise the right to control the distribution of derivative or
127
+ collective works based on the Program.
128
+
129
+ In addition, mere aggregation of another work not based on the Program
130
+ with the Program (or with a work based on the Program) on a volume of
131
+ a storage or distribution medium does not bring the other work under
132
+ the scope of this License.
133
+
134
+ 3. You may copy and distribute the Program (or a work based on it,
135
+ under Section 2) in object code or executable form under the terms of
136
+ Sections 1 and 2 above provided that you also do one of the following:
137
+
138
+ a) Accompany it with the complete corresponding machine-readable
139
+ source code, which must be distributed under the terms of Sections
140
+ 1 and 2 above on a medium customarily used for software interchange; or,
141
+
142
+ b) Accompany it with a written offer, valid for at least three
143
+ years, to give any third party, for a charge no more than your
144
+ cost of physically performing source distribution, a complete
145
+ machine-readable copy of the corresponding source code, to be
146
+ distributed under the terms of Sections 1 and 2 above on a medium
147
+ customarily used for software interchange; or,
148
+
149
+ c) Accompany it with the information you received as to the offer
150
+ to distribute corresponding source code. (This alternative is
151
+ allowed only for noncommercial distribution and only if you
152
+ received the program in object code or executable form with such
153
+ an offer, in accord with Subsection b above.)
154
+
155
+ The source code for a work means the preferred form of the work for
156
+ making modifications to it. For an executable work, complete source
157
+ code means all the source code for all modules it contains, plus any
158
+ associated interface definition files, plus the scripts used to
159
+ control compilation and installation of the executable. However, as a
160
+ special exception, the source code distributed need not include
161
+ anything that is normally distributed (in either source or binary
162
+ form) with the major components (compiler, kernel, and so on) of the
163
+ operating system on which the executable runs, unless that component
164
+ itself accompanies the executable.
165
+
166
+ If distribution of executable or object code is made by offering
167
+ access to copy from a designated place, then offering equivalent
168
+ access to copy the source code from the same place counts as
169
+ distribution of the source code, even though third parties are not
170
+ compelled to copy the source along with the object code.
171
+
172
+ 4. You may not copy, modify, sublicense, or distribute the Program
173
+ except as expressly provided under this License. Any attempt
174
+ otherwise to copy, modify, sublicense or distribute the Program is
175
+ void, and will automatically terminate your rights under this License.
176
+ However, parties who have received copies, or rights, from you under
177
+ this License will not have their licenses terminated so long as such
178
+ parties remain in full compliance.
179
+
180
+ 5. You are not required to accept this License, since you have not
181
+ signed it. However, nothing else grants you permission to modify or
182
+ distribute the Program or its derivative works. These actions are
183
+ prohibited by law if you do not accept this License. Therefore, by
184
+ modifying or distributing the Program (or any work based on the
185
+ Program), you indicate your acceptance of this License to do so, and
186
+ all its terms and conditions for copying, distributing or modifying
187
+ the Program or works based on it.
188
+
189
+ 6. Each time you redistribute the Program (or any work based on the
190
+ Program), the recipient automatically receives a license from the
191
+ original licensor to copy, distribute or modify the Program subject to
192
+ these terms and conditions. You may not impose any further
193
+ restrictions on the recipients' exercise of the rights granted herein.
194
+ You are not responsible for enforcing compliance by third parties to
195
+ this License.
196
+
197
+ 7. If, as a consequence of a court judgment or allegation of patent
198
+ infringement or for any other reason (not limited to patent issues),
199
+ conditions are imposed on you (whether by court order, agreement or
200
+ otherwise) that contradict the conditions of this License, they do not
201
+ excuse you from the conditions of this License. If you cannot
202
+ distribute so as to satisfy simultaneously your obligations under this
203
+ License and any other pertinent obligations, then as a consequence you
204
+ may not distribute the Program at all. For example, if a patent
205
+ license would not permit royalty-free redistribution of the Program by
206
+ all those who receive copies directly or indirectly through you, then
207
+ the only way you could satisfy both it and this License would be to
208
+ refrain entirely from distribution of the Program.
209
+
210
+ If any portion of this section is held invalid or unenforceable under
211
+ any particular circumstance, the balance of the section is intended to
212
+ apply and the section as a whole is intended to apply in other
213
+ circumstances.
214
+
215
+ It is not the purpose of this section to induce you to infringe any
216
+ patents or other property right claims or to contest validity of any
217
+ such claims; this section has the sole purpose of protecting the
218
+ integrity of the free software distribution system, which is
219
+ implemented by public license practices. Many people have made
220
+ generous contributions to the wide range of software distributed
221
+ through that system in reliance on consistent application of that
222
+ system; it is up to the author/donor to decide if he or she is willing
223
+ to distribute software through any other system and a licensee cannot
224
+ impose that choice.
225
+
226
+ This section is intended to make thoroughly clear what is believed to
227
+ be a consequence of the rest of this License.
228
+
229
+ 8. If the distribution and/or use of the Program is restricted in
230
+ certain countries either by patents or by copyrighted interfaces, the
231
+ original copyright holder who places the Program under this License
232
+ may add an explicit geographical distribution limitation excluding
233
+ those countries, so that distribution is permitted only in or among
234
+ countries not thus excluded. In such case, this License incorporates
235
+ the limitation as if written in the body of this License.
236
+
237
+ 9. The Free Software Foundation may publish revised and/or new versions
238
+ of the General Public License from time to time. Such new versions will
239
+ be similar in spirit to the present version, but may differ in detail to
240
+ address new problems or concerns.
241
+
242
+ Each version is given a distinguishing version number. If the Program
243
+ specifies a version number of this License which applies to it and "any
244
+ later version", you have the option of following the terms and conditions
245
+ either of that version or of any later version published by the Free
246
+ Software Foundation. If the Program does not specify a version number of
247
+ this License, you may choose any version ever published by the Free Software
248
+ Foundation.
249
+
250
+ 10. If you wish to incorporate parts of the Program into other free
251
+ programs whose distribution conditions are different, write to the author
252
+ to ask for permission. For software which is copyrighted by the Free
253
+ Software Foundation, write to the Free Software Foundation; we sometimes
254
+ make exceptions for this. Our decision will be guided by the two goals
255
+ of preserving the free status of all derivatives of our free software and
256
+ of promoting the sharing and reuse of software generally.
257
+
258
+ NO WARRANTY
259
+
260
+ 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
261
+ FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
262
+ OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
263
+ PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
264
+ OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
265
+ MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
266
+ TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
267
+ PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
268
+ REPAIR OR CORRECTION.
269
+
270
+ 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
271
+ WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
272
+ REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
273
+ INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
274
+ OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
275
+ TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
276
+ YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
277
+ PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
278
+ POSSIBILITY OF SUCH DAMAGES.
279
+
280
+ END OF TERMS AND CONDITIONS
281
+
282
+ How to Apply These Terms to Your New Programs
283
+
284
+ If you develop a new program, and you want it to be of the greatest
285
+ possible use to the public, the best way to achieve this is to make it
286
+ free software which everyone can redistribute and change under these terms.
287
+
288
+ To do so, attach the following notices to the program. It is safest
289
+ to attach them to the start of each source file to most effectively
290
+ convey the exclusion of warranty; and each file should have at least
291
+ the "copyright" line and a pointer to where the full notice is found.
292
+
293
+ <one line to give the program's name and a brief idea of what it does.>
294
+ Copyright (C) <year> <name of author>
295
+
296
+ This program is free software; you can redistribute it and/or modify
297
+ it under the terms of the GNU General Public License as published by
298
+ the Free Software Foundation; either version 2 of the License, or
299
+ (at your option) any later version.
300
+
301
+ This program is distributed in the hope that it will be useful,
302
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
303
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
304
+ GNU General Public License for more details.
305
+
306
+ You should have received a copy of the GNU General Public License
307
+ along with this program; if not, write to the Free Software
308
+ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
309
+
310
+
311
+ Also add information on how to contact you by electronic and paper mail.
312
+
313
+ If the program is interactive, make it output a short notice like this
314
+ when it starts in an interactive mode:
315
+
316
+ Gnomovision version 69, Copyright (C) year name of author
317
+ Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
318
+ This is free software, and you are welcome to redistribute it
319
+ under certain conditions; type `show c' for details.
320
+
321
+ The hypothetical commands `show w' and `show c' should show the appropriate
322
+ parts of the General Public License. Of course, the commands you use may
323
+ be called something other than `show w' and `show c'; they could even be
324
+ mouse-clicks or menu items--whatever suits your program.
325
+
326
+ You should also get your employer (if you work as a programmer) or your
327
+ school, if any, to sign a "copyright disclaimer" for the program, if
328
+ necessary. Here is a sample; alter the names:
329
+
330
+ Yoyodyne, Inc., hereby disclaims all copyright interest in the program
331
+ `Gnomovision' (which makes passes at compilers) written by James Hacker.
332
+
333
+ <signature of Ty Coon>, 1 April 1989
334
+ Ty Coon, President of Vice
335
+
336
+ This General Public License does not permit incorporating your program into
337
+ proprietary programs. If your program is a subroutine library, you may
338
+ consider it more useful to permit linking proprietary applications with the
339
+ library. If this is what you want to do, use the GNU Library General
340
+ Public License instead of this License.
data/README.en ADDED
@@ -0,0 +1,43 @@
1
+ Requirements
2
+ ============
3
+
4
+ This library requires Linux at the moment, and isn't usable on other Unixes
5
+ (yet). Depending on your keyboard LED positions some tweaking may be necessary,
6
+ see the RDOC documentation.
7
+
8
+ Installation
9
+ ============
10
+
11
+ Just type into the command line as root:
12
+
13
+ # ruby install.rb
14
+
15
+ Or if you already use rubygems (you should!) just type and rubygems fetches
16
+ the gem and installs it for you:
17
+
18
+ # gem install blinkenlights
19
+
20
+ Documentation
21
+ =============
22
+
23
+ To create the documentation of this module, type
24
+
25
+ $ ruby make_doc.rb
26
+
27
+ and the API documentation is generated by your rdoc command in
28
+ the doc/ sub-directory.
29
+
30
+ In the examples direcotry is a small example that shows, how to let the lights
31
+ blink, if network packets were received. You very likely have to run it as
32
+ root.
33
+
34
+ Author
35
+ ======
36
+
37
+ Florian Frank <flori@ping.de>
38
+
39
+ License
40
+ =======
41
+
42
+ GNU General Public License (GPL), Version 2
43
+
data/Rakefile ADDED
@@ -0,0 +1,74 @@
1
+ require 'rake/gempackagetask'
2
+ require 'rbconfig'
3
+
4
+ include Config
5
+
6
+ PKG_NAME = 'blinkenlights'
7
+ PKG_VERSION = File.read('VERSION').chomp
8
+ PKG_FILES = FileList["**/*"].exclude(/CVS|^pkg|^coverage|^doc/)
9
+
10
+ desc "Installing library"
11
+ task :install do
12
+ ruby 'install.rb'
13
+ end
14
+
15
+ task :doc do
16
+ ruby 'make_doc.rb'
17
+ end
18
+
19
+ desc "Removing generated files"
20
+ task :clean do
21
+ rm_rf 'doc'
22
+ rm_rf 'coverage'
23
+ end
24
+
25
+ spec = Gem::Specification.new do |s|
26
+ #### Basic information.
27
+
28
+ s.name = 'blinkenlights'
29
+ s.version = PKG_VERSION
30
+ s.summary = "Control the Blinkenlights on your keyboard from Ruby"
31
+ s.description = ""
32
+
33
+ #### Dependencies and requirements.
34
+
35
+ #s.add_dependency('log4r', '> 1.0.4')
36
+ #s.requirements << ""
37
+
38
+ s.files = PKG_FILES
39
+
40
+ #### C code extensions.
41
+
42
+ #s.extensions << "ext/extconf.rb"
43
+
44
+ #### Load-time details: library and application (you will need one or both).
45
+
46
+ s.require_path = 'lib' # Use these for libraries.
47
+ s.autorequire = 'blinkenlights'
48
+
49
+ #s.bindir = "bin" # Use these for applications.
50
+ #s.executables = ["bla.rb"]
51
+ #s.default_executable = "bla.rb"
52
+
53
+ #### Documentation and testing.
54
+
55
+ s.has_rdoc = true
56
+ #s.extra_rdoc_files = rd.rdoc_files.reject { |fn| fn =~ /\.rb$/ }.to_a
57
+ s.rdoc_options << '--title' << 'BlinkenLights in Ruby' << '--main' << 'BlinkenLights'
58
+ #s.test_files << 'tests/runner.rb'
59
+
60
+ #### Author and project details.
61
+
62
+ s.author = "Florian Frank"
63
+ s.email = "flori@ping.de"
64
+ s.homepage = "http://blinkenlights.rubyforge.org"
65
+ s.rubyforge_project = "blinkenlights"
66
+ end
67
+
68
+ Rake::GemPackageTask.new(spec) do |pkg|
69
+ pkg.need_tar = true
70
+ pkg.package_files += PKG_FILES
71
+ end
72
+
73
+ task :release => [ :clean, :package ]
74
+ # vim: set et sw=2 ts=2:
data/VERSION ADDED
@@ -0,0 +1 @@
1
+ 0.0.1
@@ -0,0 +1,29 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'blinkenlights'
4
+ include BlinkenLights::Constants
5
+
6
+ proc_net_dev = '/proc/net/dev'
7
+ dev = ARGV.shift || 'eth0'
8
+
9
+ bl = BlinkenLights.new
10
+ trap(:INT) do
11
+ bl.close if bl
12
+ exit
13
+ end
14
+
15
+ old_rx, old_tx = 0, 0
16
+ loop do
17
+ bl.off
18
+ line = File.read(proc_net_dev).grep(/#{dev}:/)
19
+ line.empty? and fail "Unknown device #{dev} in #{proc_net_dev}"
20
+ parts = line[0].scan(/\s+\d+/)
21
+ rx, tx = parts[0].to_i, parts[8].to_i
22
+ bl.digital = case [ rx != old_rx, tx != old_tx ]
23
+ when [ true, true ] then LED_LEFT | LED_RIGHT
24
+ when [ false, true ] then LED_RIGHT
25
+ when [ true, false ] then LED_LEFT
26
+ else 0
27
+ end
28
+ old_rx, old_tx = rx, tx
29
+ end
data/install.rb ADDED
@@ -0,0 +1,12 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'rbconfig'
4
+ require 'fileutils'
5
+ include FileUtils::Verbose
6
+ include Config
7
+
8
+ dest = CONFIG["sitelibdir"]
9
+ mkdir_p(dest)
10
+ file = 'lib/blinkenlights.rb'
11
+ install(file, dest)
12
+ # vim: set et sw=4 ts=4:
@@ -0,0 +1,399 @@
1
+ # = blinkenlights.rb - Controlling the keyboard LEDs from Ruby
2
+ #
3
+ # == Author
4
+ #
5
+ # Florian Frank mailto:flori@ping.de
6
+ #
7
+ # == License
8
+ #
9
+ # This is free software; you can redistribute it and/or modify it under the
10
+ # terms of the GNU General Public License Version 2 as published by the Free
11
+ # Software Foundation: www.gnu.org/copyleft/gpl.html
12
+ #
13
+ # == Download
14
+ #
15
+ # The latest version of <b>blinkenlights</b> can be found at
16
+ #
17
+ # * http://rubyforge.org/frs/?group_id=1021
18
+ #
19
+ # The homepage of this library is located at
20
+ #
21
+ # * http://blinkenlights.rubyforge.org
22
+ #
23
+ # == Description
24
+ #
25
+ # This Ruby library is named after an old joke, see
26
+ # http://catb.org/~esr/jargon/html/B/blinkenlights.html
27
+ #
28
+ # It enables you to control the LEDs on your keyboard to signal digital numbers
29
+ # between 0 and 7, events like received/transmitted network packets, or just
30
+ # let them blink in visually pleasing patterns.
31
+ #
32
+ # == Examples
33
+ #
34
+ # The block form opens the TTY, that controls the LEDs, and closes/resets
35
+ # the LEDs it after the block has been processed:
36
+ # require 'blinkenlights'
37
+ # BlinkenLights.open do |bl|
38
+ # bl.off
39
+ # bl.circle
40
+ # end
41
+ #
42
+ # It's also possible to manually close the object:
43
+ # require 'blinkenlights'
44
+ # bl = BlinkenLights.new
45
+ # bl.off
46
+ # 100.times { bl.random }
47
+ # bl.close
48
+ #
49
+ # There's also a short example examples/netblinker.rb in the distribution
50
+ # directory of this library, that shows how to let the lights blink if network
51
+ # packets are received/transmitted on your host.
52
+ class BlinkenLights
53
+
54
+ # Module to hold the BlinkenLights constants.
55
+ module Constants
56
+ # The default tty. It happens to be the one, I run X on. ;)
57
+ DEF_TTY = '/dev/tty8'
58
+
59
+ # DEF_DELAY is the default standard delay in seconds, that is slept everytime
60
+ # the LED state is changed. If it is too small your keyboard may become
61
+ # confused about its LEDs' status.
62
+ DEF_DELAY = 0.1
63
+
64
+ # Scroll Lock LED (from /usr/include/linux/kd.h)
65
+ LED_SCR = 0x01
66
+
67
+ # Num Lock LED (from /usr/include/linux/kd.h)
68
+ LED_NUM = 0x02
69
+
70
+ # Caps Lock LED (from /usr/include/linux/kd.h)
71
+ LED_CAP = 0x04
72
+
73
+ # Return current LED state (from /usr/include/linux/kd.h)
74
+ KDGETLED = 0x4B31
75
+
76
+ # Set LED state [lights, not flags] (from /usr/include/linux/kd.h)
77
+ KDSETLED = 0x4B32
78
+
79
+ # In order from left to right. This setting may have to be tweaked, if your
80
+ # keyboard has some unusual LED positions.
81
+ LEDS = [ :LED_NUM, :LED_CAP, :LED_SCR ]
82
+
83
+ # Values for LEDs from left to right
84
+ LEDS_VALUES = LEDS.map { |c| self.const_get(c) }
85
+
86
+ # In order from lowest to highest
87
+ DIGITAL = [ :LED_SCR, :LED_NUM, :LED_CAP ]
88
+
89
+ # The left LED
90
+ LED_LEFT = 4
91
+
92
+ # The middle LED
93
+ LED_MIDDLE = 2
94
+
95
+ # The right LED
96
+ LED_RIGHT = 1
97
+ end
98
+ include Constants
99
+
100
+ # Creates a BlinkenLights instance for _tty_, a full pathname like
101
+ # '/dev/tty8' to control the LEDs. _delay_ is the standard delay in seconds,
102
+ # that is slept everytime the LED state is changed. If _delay_ is too small
103
+ # your keyboard may become confused about its LEDs' status.
104
+ def initialize(tty = DEF_TTY, delay = DEF_DELAY)
105
+ @tty = File.new(tty, File::RDWR)
106
+ @delay = delay
107
+ @old_leds = get
108
+ end
109
+
110
+ # The standard delay of this BlinkenLights instance.
111
+ attr_accessor :delay
112
+
113
+ # Creates a BlinkenLights instance and yields to it. After the block returns
114
+ # the BlinkenLights#close method is called.
115
+ def self.open(tty = DEF_TTY, delay = DEF_DELAY)
116
+ obj = new(tty, delay)
117
+ yield obj
118
+ ensure
119
+ obj.close if obj
120
+ end
121
+
122
+ # Close the open console tty after resetting LEDs to the original state.
123
+ def close
124
+ reset
125
+ @tty.close
126
+ self
127
+ end
128
+
129
+ # Resets the LED state to the starting state (when the BlinkenLights object
130
+ # was created).
131
+ def reset
132
+ set @old_leds
133
+ self
134
+ end
135
+
136
+ # Switch off all LEDs.
137
+ def off
138
+ set 0
139
+ self
140
+ end
141
+
142
+ # Switch on all LEDs.
143
+ def on
144
+ set 7
145
+ self
146
+ end
147
+
148
+ # Set LEDs to _number_ in binary digital mode.
149
+ def digital=(number)
150
+ number %= 8
151
+ setting = 0
152
+ 0.upto(2) do |i|
153
+ if number[i] == 1
154
+ setting |= 1 << DIGITAL.index(LEDS[2 - i])
155
+ end
156
+ end
157
+ set setting
158
+ end
159
+
160
+ # Return the state of the LEDs expressed in binary digital mode.
161
+ def digital
162
+ setting = get
163
+ result = 0
164
+ 2.downto(0) do |i|
165
+ if setting[i] == 1
166
+ result |= 1 << (2 - LEDS_VALUES.index(1 << i))
167
+ end
168
+ end
169
+ result
170
+ end
171
+
172
+ # Blink all the LEDs from the left to the right. Sleep for _delay_ seconds in
173
+ # between.
174
+ def left_to_right(delay = 0.0)
175
+ for i in [ LED_LEFT, LED_MIDDLE, LED_RIGHT ]
176
+ self.digital = i
177
+ sleep delay
178
+ end
179
+ self
180
+ end
181
+
182
+ # Blink all the LEDs from the right to the left. Sleep for _delay_ seconds in
183
+ # between.
184
+ def right_to_left(delay = 0.0)
185
+ for i in [ LED_RIGHT, LED_MIDDLE, LED_LEFT ]
186
+ self.digital = i
187
+ sleep delay
188
+ end
189
+ self
190
+ end
191
+
192
+ # Blink all the LEDs from the left to the right, and then from the right to
193
+ # the left. Sleep for _delay_ seconds in between.
194
+ def circle(delay = 0.0)
195
+ left_to_right(delay)
196
+ right_to_left(delay)
197
+ self
198
+ end
199
+
200
+ # Blink all the LEDs from the right to the left, and then from the left to
201
+ # the right. Sleep for _delay_ seconds in between.
202
+ def reverse_circle(delay = 0.0)
203
+ right_to_left(delay)
204
+ left_to_right(delay)
205
+ self
206
+ end
207
+
208
+ # Switch some of the LEDs on by random. Then sleep for _delay_ seconds.
209
+ def random(delay = 0.0)
210
+ self.digital = rand(8)
211
+ sleep delay
212
+ self
213
+ end
214
+
215
+ # Converge, that is, first blink the outer LEDs, then blink the inner LED.
216
+ # Sleep for _delay_ seconds in between.
217
+ def converge(delay = 0.0)
218
+ for i in [ LED_LEFT|LED_RIGHT, LED_MIDDLE ]
219
+ self.digital = i
220
+ sleep delay
221
+ end
222
+ self
223
+ end
224
+
225
+ # Diverge, that is, first blink the inner LED, then blink the outer LEDs.
226
+ # Sleep for _delay_ seconds in between.
227
+ def diverge(delay = 0.0)
228
+ for i in [ LED_MIDDLE, LED_LEFT|LED_RIGHT ]
229
+ self.digital = i
230
+ sleep delay
231
+ end
232
+ self
233
+ end
234
+
235
+ # Return the state of the Scroll Lock LED: true for switched on, false for
236
+ # off.
237
+ def scr
238
+ (get & LED_SCR) != 0
239
+ end
240
+
241
+ # Switch the Scroll Lock LED on, if _toggle_ is true, off, otherwise.
242
+ def scr=(toggle)
243
+ old = get
244
+ if toggle
245
+ set old | LED_SCR
246
+ else
247
+ set old & ~LED_SCR
248
+ end
249
+ end
250
+
251
+ # Switch the Scroll Lock LED on, if it was off before. Switch the Scroll Lock
252
+ # LED off, if it was on before.
253
+ def toggle_scr(delay = 0.0)
254
+ self.scr = !scr
255
+ sleep 0.0
256
+ self
257
+ end
258
+
259
+ # Return the state of the Caps Lock LED: true for switched on, false for off.
260
+ def cap
261
+ (get & LED_CAP) != 0
262
+ end
263
+
264
+ # Switch the Caps Lock LED on, if _toggle_ is true, off, otherwise.
265
+ def cap=(toggle)
266
+ old = get
267
+ if toggle
268
+ set old | LED_CAP
269
+ else
270
+ set old & ~LED_CAP
271
+ end
272
+ end
273
+
274
+ # Switch the Caps Lock LED on, if it was off before. Switch the Caps Lock
275
+ # LED off, if it was on before.
276
+ def toggle_cap(delay = 0.0)
277
+ self.cap = !cap
278
+ sleep delay
279
+ self
280
+ end
281
+
282
+ # Return the state of the Num Lock LED: true for switched on, false for off.
283
+ def num
284
+ (get & LED_NUM) != 0
285
+ end
286
+
287
+ # Switch the Num Lock LED on, if _toggle_ is true, off, otherwise.
288
+ def num=(toggle)
289
+ old = get
290
+ if toggle
291
+ set old | LED_NUM
292
+ else
293
+ set old & ~LED_NUM
294
+ end
295
+ end
296
+
297
+ # Switch the Num Lock LED on, if it was off before. Switch the Num Lock LED
298
+ # off, if it was on before.
299
+ def toggle_num(delay = 0.0)
300
+ self.num = !num
301
+ self
302
+ end
303
+
304
+ # Return the state of the left LED: true for switched on, false for
305
+ # off.
306
+ def left
307
+ (digital & LED_LEFT) != 0
308
+ end
309
+
310
+ # Switch the left LED on, if _toggle_ is true, off, otherwise.
311
+ def left=(toggle)
312
+ old = digital
313
+ if toggle
314
+ self.digital = old | LED_LEFT
315
+ else
316
+ self.digital = old & ~LED_LEFT
317
+ end
318
+ end
319
+
320
+ # Switch the left LED on, if it was off before. Switch the left
321
+ # LED off, if it was on before.
322
+ def toggle_left(delay = 0.0)
323
+ self.left = !left
324
+ sleep 0.0
325
+ self
326
+ end
327
+
328
+ # Return the state of the middle LED: true for switched on, false for off.
329
+ def middle
330
+ (digital & LED_MIDDLE) != 0
331
+ end
332
+
333
+ # Switch the middle LED on, if _toggle_ is true, off, otherwise.
334
+ def middle=(toggle)
335
+ old = digital
336
+ if toggle
337
+ self.digital = old | LED_MIDDLE
338
+ else
339
+ self.digital = old & ~LED_MIDDLE
340
+ end
341
+ end
342
+
343
+ # Switch the middle LED on, if it was off before. Switch the middle LED off,
344
+ # if it was on before.
345
+ def toggle_middle(delay = 0.0)
346
+ self.middle = !middle
347
+ sleep delay
348
+ self
349
+ end
350
+
351
+ # Return the state of the right LED: true for switched on, false for off.
352
+ def right
353
+ (digital & LED_RIGHT) != 0
354
+ end
355
+
356
+ # Switch the right LED on, if _toggle_ is true, off, otherwise.
357
+ def right=(toggle)
358
+ old = digital
359
+ if toggle
360
+ self.digital = old | LED_RIGHT
361
+ else
362
+ self.digital = old & ~LED_RIGHT
363
+ end
364
+ end
365
+
366
+ # Switch the right LED on, if it was off before. Switch the right off, if it
367
+ # was on before.
368
+ def toggle_right(delay = 0.0)
369
+ self.right = !right
370
+ self
371
+ end
372
+
373
+ # Set the state of the LEDs to integer _number_. (Quite low level)
374
+ def set(number)
375
+ @tty.ioctl(KDSETLED, number)
376
+ sleep @delay
377
+ number
378
+ end
379
+
380
+ # Return the state of the LEDs as an integer _number_. (Quite low level)
381
+ def get
382
+ char = [0].pack('C')
383
+ @tty.ioctl(KDGETLED, char)
384
+ char.unpack('C')[0]
385
+ end
386
+
387
+ # Return a string representation of this BlinkenLights instance, showing
388
+ # some interesting data.
389
+ def to_s
390
+ if @tty.closed?
391
+ "#<#{self.class}: closed>"
392
+ else
393
+ "#<#{self.class}: delay=#{@delay}s, tty=#{@tty.path}," +
394
+ " LEDs=#{'%03b' % self.digital}>"
395
+ end
396
+ end
397
+
398
+ alias inspect to_s
399
+ end
data/make_doc.rb ADDED
@@ -0,0 +1,5 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ system "rdoc -m BlinkenLights lib/blinkenlights.rb"
4
+ # vim: set et sw=4 ts=4:
5
+
metadata ADDED
@@ -0,0 +1,52 @@
1
+ --- !ruby/object:Gem::Specification
2
+ rubygems_version: 0.8.11
3
+ specification_version: 1
4
+ name: blinkenlights
5
+ version: !ruby/object:Gem::Version
6
+ version: 0.0.1
7
+ date: 2005-10-18 00:00:00 +02:00
8
+ summary: Control the Blinkenlights on your keyboard from Ruby
9
+ require_paths:
10
+ - lib
11
+ email: flori@ping.de
12
+ homepage: http://blinkenlights.rubyforge.org
13
+ rubyforge_project: blinkenlights
14
+ description: ''
15
+ autorequire: blinkenlights
16
+ default_executable:
17
+ bindir: bin
18
+ has_rdoc: true
19
+ required_ruby_version: !ruby/object:Gem::Version::Requirement
20
+ requirements:
21
+ -
22
+ - ">"
23
+ - !ruby/object:Gem::Version
24
+ version: 0.0.0
25
+ version:
26
+ platform: ruby
27
+ signing_key:
28
+ cert_chain:
29
+ authors:
30
+ - Florian Frank
31
+ files:
32
+ - Rakefile
33
+ - GPL
34
+ - examples
35
+ - README.en
36
+ - VERSION
37
+ - install.rb
38
+ - make_doc.rb
39
+ - lib
40
+ - examples/netblinker.rb
41
+ - lib/blinkenlights.rb
42
+ test_files: []
43
+ rdoc_options:
44
+ - "--title"
45
+ - BlinkenLights in Ruby
46
+ - "--main"
47
+ - BlinkenLights
48
+ extra_rdoc_files: []
49
+ executables: []
50
+ extensions: []
51
+ requirements: []
52
+ dependencies: []