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
afa90eb3
Commit
afa90eb3
authored
Jun 10, 2000
by
Andrew M. Kuchling
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add contents of curses package
parent
9c4bbef0
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
68 additions
and
0 deletions
+68
-0
Lib/curses/__init__.py
Lib/curses/__init__.py
+18
-0
Lib/curses/wrapper.py
Lib/curses/wrapper.py
+50
-0
No files found.
Lib/curses/__init__.py
0 → 100644
View file @
afa90eb3
"""curses
The main package for curses support for Python. Normally used by importing
the package, and perhaps a particular module inside it.
import curses
from curses import textpad
curses.initwin()
...
"""
__revision__
=
"$Id$"
from
_curses
import
*
from
curses.wrapper
import
wrapper
Lib/curses/wrapper.py
0 → 100644
View file @
afa90eb3
"""curses.wrapper
Contains one function, wrapper(), which runs another function which
should be the rest of your curses-based application. If the
application raises an exception, wrapper() will restore the terminal
to a sane state so you can read the resulting traceback.
"""
import
sys
,
curses
def
wrapper
(
func
,
*
rest
):
"""Wrapper function that initializes curses and calls another function,
restoring normal keyboard/screen behavior on error.
The callable object 'func' is then passed the main window 'stdscr'
as its first argument, followed by any other arguments passed to
wrapper().
"""
res
=
None
try
:
# Initialize curses
stdscr
=
curses
.
initscr
()
# Turn off echoing of keys, and enter cbreak mode,
# where no buffering is performed on keyboard input
curses
.
noecho
()
;
curses
.
cbreak
()
# In keypad mode, escape sequences for special keys
# (like the cursor keys) will be interpreted and
# a special value like curses.KEY_LEFT will be returned
stdscr
.
keypad
(
1
)
res
=
apply
(
func
,
(
stdscr
,)
+
rest
)
except
:
# In the event of an error, restore the terminal
# to a sane state.
stdscr
.
keypad
(
0
)
curses
.
echo
()
;
curses
.
nocbreak
()
curses
.
endwin
()
# Pass the exception upwards
(
exc_type
,
exc_value
,
exc_traceback
)
=
sys
.
exc_info
()
raise
exc_type
,
exc_value
,
exc_traceback
else
:
# Set everything back to normal
stdscr
.
keypad
(
0
)
curses
.
echo
()
;
curses
.
nocbreak
()
curses
.
endwin
()
# Terminate curses
return
res
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