-
Notifications
You must be signed in to change notification settings - Fork 0
/
timer.pl
97 lines (79 loc) · 1.64 KB
/
timer.pl
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#!/usr/bin/env perl
use strict;
use warnings;
use DateTime;
use File::Slurp 'slurp';
use Term::ReadKey;
use Time::HiRes 'time';
$| = 1;
ReadMode 3;
END { ReadMode 0 }
my $start = DateTime->new(
year => 2018,
month => 11,
day => 30,
hour => 21,
minute => 0,
second => 0,
time_zone => 'America/New_York',
)->epoch;
my $end = DateTime->new(
year => 2018,
month => 12,
day => 2,
hour => 22,
minute => 0,
second => 0,
time_zone => 'America/New_York',
)->epoch;
my $duration = $end - $start;
my $devtime = r() || 0;
my $running = 1;
while (1) {
my $now = time;
while (1) {
my $key = ReadKey(-1);
last if !defined $key;
$running = !$running if $key eq ' ';
}
if ($now >= $start && $running) {
$devtime += 10;
w($devtime);
}
print "\e[2J\e[0;0H";
my $progress = ($now - $start) / ($end - $start);
my $column = int(49 * $progress);
printf " devtime: %s %s realtime: %s / 49:00\n", fmt($devtime), $running ? '…' : '*', fmt($now - $start);
for my $i (0..48) {
if ($progress > $i/49) {
print "#";
}
else {
print ".";
}
}
my $back = 49 - $column;
$back = 0 if $back < 0;
print "\e[${back}D";
if ($now >= $start && $now <= $end) {
system("/usr/sbin/screencapture -x /dev/null /Volumes/thufir/shawn/ld43/@{[int $now]}.png 2>/dev/null");
}
sleep 10 - (time - $now);
}
sub fmt {
my $s = shift;
$s = 0 if $s < 0;
my $m = int($s / 60);
$s -= $m * 60;
my $h = int($m / 60);
$m -= $h * 60;
sprintf "%02d:%02d", $h, $m;
}
sub r {
slurp '.ld-time';
}
sub w {
my $d = shift;
open my $handle, '>', '.ld-time' or die $1;
print $handle $d;
}