forked from akkana/scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsieve.py
executable file
·102 lines (81 loc) · 2.51 KB
/
sieve.py
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
98
99
100
101
102
#!/usr/bin/env python
from __future__ import print_function
import curses
import time
import sys
errstr = ''
numwidth = 5
fmt = '%%%dd' % numwidth
stdscr = curses.initscr()
curses.noecho()
curses.cbreak()
#if curses.can_change_color():
if curses.has_colors():
curses.start_color()
curses.use_default_colors()
curses.init_pair(1, curses.COLOR_WHITE, curses.COLOR_CYAN)
curses.init_pair(2, curses.COLOR_WHITE, curses.COLOR_RED)
colorpair = curses.color_pair(1)
highlightpair = curses.color_pair(2)
else:
colorpair = curses.A_REVERSE
highlightpair = curses.A_BOLD
def cleanup():
curses.nocbreak()
stdscr.keypad(0)
curses.echo()
curses.endwin()
if errstr:
print("Errors:", errstr)
sys.exit(0)
height, width = stdscr.getmaxyx()
width -= numwidth+1
height -= 1
# How many numbers will fit on a line, or on the whole screen?
numsperline = int(width / numwidth)
maxnum = numsperline * height
attributes = [0] * (maxnum+2)
logf = open("/tmp/sieve.log", "w", buffering=1)
print("Maxnum is", maxnum, file=logf)
def redraw_screen(highlight=None):
num = 0
while True:
num += 1
x = ((num-1) % numsperline) * numwidth
y = int ((num-1) / numsperline)
if y >= height:
return
if x < numwidth:
print(".\n", file=logf)
print("'%s' @ (%d, %d) " % (fmt % num, x, y), end=' ', file=logf)
#errstr += "'%s' @ (%d, %d) " % (fmt % num, x, y)
#errstr += "\nstdscr.addstr(%d, %d, '%s')" % (y, x, fmt % num)
if highlight == num:
stdscr.addstr(y, x, fmt % num, highlightpair)
else:
stdscr.addstr(y, x, fmt % num, attributes[num])
stdscr.refresh()
print("Refreshed", file=logf)
return num
try:
key = None
divisor = 1
while key != ord('q'):
# Skip past known composites to the next prime:
divisor += 1
while attributes[divisor]:
divisor += 1
print("divisor++ to", divisor, file=logf)
print(divisor, "is prime", file=logf)
for i in range(1, maxnum):
if i > divisor and i % divisor == 0:
print("Setting attribute for", i, file=logf)
attributes[i] = colorpair
print("Finished setting attributes for", divisor, file=logf)
redraw_screen(highlight=divisor)
key = stdscr.getch()
except Exception as e:
errstr += "Exception: " + str(e)
finally:
# Don't have to call cleanup() -- it'll be called magically
cleanup()