"Fossies" - the Fresh Open Source Software Archive 
Member "xterm-379/vttests/blink.pl" (13 Jul 2007, 4160 Bytes) of package /linux/misc/xterm-379.tgz:
As a special service "Fossies" has tried to format the requested source page into HTML format using (guessed) Perl source code syntax highlighting (style:
standard) with prefixed line numbers and
code folding option.
Alternatively you can here
view or
download the uninterpreted source code file.
For more information about "blink.pl" see the
Fossies "Dox" file reference documentation.
1 #!/usr/bin/env perl
2 # $XTermId: blink.pl,v 1.2 2007/07/13 00:28:38 tom Exp $
3 # -----------------------------------------------------------------------------
4 # this file is part of xterm
5 #
6 # Copyright 2007 by Thomas E. Dickey
7 #
8 # All Rights Reserved
9 #
10 # Permission is hereby granted, free of charge, to any person obtaining a
11 # copy of this software and associated documentation files (the
12 # "Software"), to deal in the Software without restriction, including
13 # without limitation the rights to use, copy, modify, merge, publish,
14 # distribute, sublicense, and/or sell copies of the Software, and to
15 # permit persons to whom the Software is furnished to do so, subject to
16 # the following conditions:
17 #
18 # The above copyright notice and this permission notice shall be included
19 # in all copies or substantial portions of the Software.
20 #
21 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
22 # OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
23 # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
24 # IN NO EVENT SHALL THE ABOVE LISTED COPYRIGHT HOLDER(S) BE LIABLE FOR ANY
25 # CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
26 # TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
27 # SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28 #
29 # Except as contained in this notice, the name(s) of the above copyright
30 # holders shall not be used in advertising or otherwise to promote the
31 # sale, use or other dealings in this Software without prior written
32 # authorization.
33 # -----------------------------------------------------------------------------
34 # Write a test pattern which includes some blinking text in scattered
35 # locations, to test scrollback of blinking text.
36 use strict;
37
38 use Getopt::Std;
39
40 our ($opt_n, $opt_r, $opt_w);
41 our ($lineno, $test_string, $term_width);
42
43 # returns a string of two-column characters given an ASCII alpha/numeric string
44 sub double_cells($) {
45 my $value = $_[0];
46 $value =~ s/ / /g;
47 pack("U*",
48 map { ($_ <= 32 || $_ > 127) # if non-ASCII character...
49 ? 32 # ...just show a blank
50 : (0xff00 + ($_ - 32)) # map to "Fullwidth Form"
51 } unpack("C*", $value)); # unpack unsigned-char characters
52 }
53
54 # vary the starting point of each line, to make a more interesting pattern
55 sub starts_of($) {
56 my $value = $_[0];
57 if (defined($opt_w)) {
58 # 0,1,1,2,2,3,3,...
59 $value = (($value + 1) / 2) % length($test_string);
60 } else {
61 $value %= length($test_string);
62 }
63 return $value;
64 }
65
66 # vary the length of each line from $term_width - 5 to $term_width + 5, then
67 # double it, and then repeat. That's 22/cycle.
68 sub length_of($) {
69 my $value = $_[0];
70 my $cycle = $value % 22;
71 if ( $cycle < 11 ) {
72 $value = $term_width;
73 } else {
74 $value = $term_width * 2;
75 $cycle /= 2;
76 }
77 return $value + $cycle - 5;
78 }
79
80 # write the text for the given line-number
81 sub testit($) {
82 my $number = $_[0];
83 my $length = length_of($number);
84 if ( defined($opt_n) ) {
85 printf "%5d ", $number % 99999;
86 $length -= 6;
87 }
88 # if we're printing double-column characters, we have half as much
89 # space effectively - but don't forget the remainder, so we can push
90 # the characters by single-columns.
91 my $starts = starts_of($number);
92 if ( defined($opt_w) ) {
93 printf " ", if ( ($number % 2 ) != 0);
94 $length = ($length + (($number + 1) % 2)) / 2;
95 }
96 my $string = substr($test_string, $starts);
97 while ( length($string) < $length ) {
98 $string = $string . $test_string;
99 }
100 $string = substr($string, 0, $length);
101 if ( defined($opt_w) ) {
102 $string = double_cells($string);
103 }
104 printf "%s\n", $string;
105 }
106
107 sub main::HELP_MESSAGE() {
108 printf STDERR <<EOF
109 Usage: $0 [options]
110
111 Options:
112
113 -n write line-numbers
114 -r repeat indefinitely
115 -w write wide-characters
116 EOF
117 ;
118 exit;
119 }
120
121 &getopts('nrw') || die();
122
123 $term_width=`tput cols`;
124
125 $test_string="0123456789 abcdefghijklmnopqrstuvwxyz ABCDEFGHIJKLMNOPQRSTUVWXYZ";
126
127 binmode(STDOUT, ":utf8");
128 if ( defined($opt_r) ) {
129 for ($lineno = 0; ; ++$lineno) {
130 testit($lineno);
131 }
132 } else {
133 for ($lineno = 0; $lineno < 24; ++$lineno) {
134 testit($lineno);
135 }
136 }
137
138 exit;