Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
c26c51a9
Commit
c26c51a9
authored
Jun 30, 2014
by
Terry Jan Reedy
Browse files
Options
Browse Files
Download
Plain Diff
Merge with 3.4
parents
b1f9ed75
f5ac57dc
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
51 additions
and
61 deletions
+51
-61
Lib/turtle.py
Lib/turtle.py
+1
-1
Lib/turtledemo/clock.py
Lib/turtledemo/clock.py
+1
-5
Lib/turtledemo/colormixer.py
Lib/turtledemo/colormixer.py
+0
-2
Lib/turtledemo/demohelp.txt
Lib/turtledemo/demohelp.txt
+4
-1
Lib/turtledemo/minimal_hanoi.py
Lib/turtledemo/minimal_hanoi.py
+0
-1
Lib/turtledemo/nim.py
Lib/turtledemo/nim.py
+5
-5
Lib/turtledemo/two_canvases.py
Lib/turtledemo/two_canvases.py
+40
-46
No files found.
Lib/turtle.py
View file @
c26c51a9
...
...
@@ -140,7 +140,7 @@ _tg_turtle_functions = ['back', 'backward', 'begin_fill', 'begin_poly', 'bk',
_tg_utilities
=
[
'write_docstringdict'
,
'done'
]
__all__
=
(
_tg_classes
+
_tg_screen_functions
+
_tg_turtle_functions
+
_tg_utilities
)
# + _math_functions)
_tg_utilities
+
[
'Terminator'
]
)
# + _math_functions)
_alias_list
=
[
'addshape'
,
'backward'
,
'bk'
,
'fd'
,
'ht'
,
'lt'
,
'pd'
,
'pos'
,
'pu'
,
'rt'
,
'seth'
,
'setpos'
,
'setposition'
,
'st'
,
...
...
Lib/turtledemo/clock.py
View file @
c26c51a9
...
...
@@ -11,11 +11,8 @@ and time
------------------------------------
"""
from
turtle
import
*
from
turtle
import
Terminator
# not in __all__
from
datetime
import
datetime
mode
(
"logo"
)
def
jump
(
distanz
,
winkel
=
0
):
penup
()
right
(
winkel
)
...
...
@@ -43,7 +40,6 @@ def make_hand_shape(name, laenge, spitze):
hand_form
=
get_poly
()
register_shape
(
name
,
hand_form
)
def
clockface
(
radius
):
reset
()
pensize
(
7
)
...
...
@@ -84,7 +80,6 @@ def setup():
writer
.
pu
()
writer
.
bk
(
85
)
def
wochentag
(
t
):
wochentag
=
[
"Monday"
,
"Tuesday"
,
"Wednesday"
,
"Thursday"
,
"Friday"
,
"Saturday"
,
"Sunday"
]
...
...
@@ -131,6 +126,7 @@ def main():
return
"EVENTLOOP"
if
__name__
==
"__main__"
:
mode
(
"logo"
)
msg
=
main
()
print
(
msg
)
mainloop
()
Lib/turtledemo/colormixer.py
View file @
c26c51a9
# colormixer
from
turtle
import
Screen
,
Turtle
,
mainloop
import
sys
sys
.
setrecursionlimit
(
20000
)
# overcomes, for now, an instability of Python 3.0
class
ColorTurtle
(
Turtle
):
...
...
Lib/turtledemo/demohelp.txt
View file @
c26c51a9
...
...
@@ -54,6 +54,9 @@
(2) How to add your own demos to the demo repository
- Place the file in the same directory as turtledemo/__main__.py
IMPORTANT! When imported, the demo should not modify the system
by calling functions in other modules, such as sys, tkinter, or
turtle. Global variables should be initialized in main().
- The code must contain a main() function which will
be executed by the viewer (see provided example scripts).
...
...
@@ -65,7 +68,7 @@
if __name__ == '__main__':
main()
mainloop() # keep window
mainloop() # keep window
open
python -m turtledemo.mydemo # will then run it
...
...
Lib/turtledemo/minimal_hanoi.py
View file @
c26c51a9
...
...
@@ -18,7 +18,6 @@ stretched to rectangles by shapesize()
---------------------------------------
"""
from
turtle
import
*
from
turtle
import
Terminator
# not in __all__
class
Disc
(
Turtle
):
def
__init__
(
self
,
n
):
...
...
Lib/turtledemo/nim.py
View file @
c26c51a9
...
...
@@ -143,7 +143,6 @@ class NimView(object):
self
.
writer
.
write
(
msg1
,
align
=
"center"
,
font
=
(
"Courier"
,
14
,
"bold"
))
self
.
screen
.
tracer
(
True
)
def
setup
(
self
):
self
.
screen
.
tracer
(
False
)
for
row
in
range
(
3
):
...
...
@@ -181,6 +180,7 @@ class NimView(object):
if
self
.
game
.
state
==
Nim
.
OVER
:
self
.
screen
.
clear
()
class
NimController
(
object
):
def
__init__
(
self
,
game
):
...
...
@@ -201,6 +201,7 @@ class NimController(object):
self
.
game
.
model
.
notify_move
(
row
,
col
)
self
.
BUSY
=
False
class
Nim
(
object
):
CREATED
=
0
RUNNING
=
1
...
...
@@ -213,11 +214,10 @@ class Nim(object):
self
.
controller
=
NimController
(
self
)
mainscreen
=
turtle
.
Screen
()
mainscreen
.
mode
(
"standard"
)
mainscreen
.
setup
(
SCREENWIDTH
,
SCREENHEIGHT
)
def
main
():
mainscreen
=
turtle
.
Screen
()
mainscreen
.
mode
(
"standard"
)
mainscreen
.
setup
(
SCREENWIDTH
,
SCREENHEIGHT
)
nim
=
Nim
(
mainscreen
)
return
"EVENTLOOP!"
...
...
Lib/turtledemo/two_canvases.py
View file @
c26c51a9
"""turtledemo.two_canvases
Use TurtleScreen and RawTurtle to draw on two
distinct canvases.
distinct canvases in a separate windows. The
new window must be separately closed in
addition to pressing the STOP button.
"""
#The final mainloop only serves to keep the window open.
#TODO: This runs in its own two-canvas window when selected in the
#demoviewer examples menu but the text is not loaded and the previous
#example is left visible. If the ending mainloop is removed, the text
#Eis loaded, this run again in a third window, and if start is pressed,
#demoviewer raises an error because main is not found, and then freezes.
from
turtle
import
TurtleScreen
,
RawTurtle
,
TK
root
=
TK
.
Tk
()
cv1
=
TK
.
Canvas
(
root
,
width
=
300
,
height
=
200
,
bg
=
"#ddffff"
)
cv2
=
TK
.
Canvas
(
root
,
width
=
300
,
height
=
200
,
bg
=
"#ffeeee"
)
cv1
.
pack
()
cv2
.
pack
()
def
main
():
root
=
TK
.
Tk
()
cv1
=
TK
.
Canvas
(
root
,
width
=
300
,
height
=
200
,
bg
=
"#ddffff"
)
cv2
=
TK
.
Canvas
(
root
,
width
=
300
,
height
=
200
,
bg
=
"#ffeeee"
)
cv1
.
pack
()
cv2
.
pack
()
s1
=
TurtleScreen
(
cv1
)
s1
.
bgcolor
(
0.85
,
0.85
,
1
)
s2
=
TurtleScreen
(
cv2
)
s2
.
bgcolor
(
1
,
0.85
,
0.85
)
s1
=
TurtleScreen
(
cv1
)
s1
.
bgcolor
(
0.85
,
0.85
,
1
)
s2
=
TurtleScreen
(
cv2
)
s2
.
bgcolor
(
1
,
0.85
,
0.85
)
p
=
RawTurtle
(
s1
)
q
=
RawTurtle
(
s2
)
p
=
RawTurtle
(
s1
)
q
=
RawTurtle
(
s2
)
p
.
color
(
"red"
,
(
1
,
0.85
,
0.85
))
p
.
width
(
3
)
q
.
color
(
"blue"
,
(
0.85
,
0.85
,
1
))
q
.
width
(
3
)
p
.
color
(
"red"
,
(
1
,
0.85
,
0.85
))
p
.
width
(
3
)
q
.
color
(
"blue"
,
(
0.85
,
0.85
,
1
))
q
.
width
(
3
)
for
t
in
p
,
q
:
t
.
shape
(
"turtle"
)
t
.
lt
(
36
)
for
t
in
p
,
q
:
t
.
shape
(
"turtle"
)
t
.
lt
(
36
)
q
.
lt
(
180
)
q
.
lt
(
180
)
for
t
in
p
,
q
:
t
.
begin_fill
()
for
i
in
range
(
5
):
for
t
in
p
,
q
:
t
.
fd
(
50
)
t
.
lt
(
72
)
for
t
in
p
,
q
:
t
.
end_fill
()
t
.
lt
(
54
)
t
.
pu
()
t
.
bk
(
50
)
## Want to get some info?
#print(s1, s2)
#print(p, q)
#print(s1.turtles())
#print(s2.turtles())
TK
.
mainloop
()
t
.
begin_fill
()
for
i
in
range
(
5
):
for
t
in
p
,
q
:
t
.
fd
(
50
)
t
.
lt
(
72
)
for
t
in
p
,
q
:
t
.
end_fill
()
t
.
lt
(
54
)
t
.
pu
()
t
.
bk
(
50
)
return
"EVENTLOOP"
if
__name__
==
'__main__'
:
main
()
TK
.
mainloop
()
# keep window open until user closes it
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment