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
b978d18f
Commit
b978d18f
authored
Dec 09, 1997
by
Guido van Rossum
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Guess... :-)
parent
3d20986d
Changes
6
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
474 additions
and
167 deletions
+474
-167
Lib/dos-8x3/configpa.py
Lib/dos-8x3/configpa.py
+255
-0
Lib/dos-8x3/posixfil.py
Lib/dos-8x3/posixfil.py
+2
-2
Lib/dos-8x3/posixpat.py
Lib/dos-8x3/posixpat.py
+194
-162
Lib/dos-8x3/test_fcn.py
Lib/dos-8x3/test_fcn.py
+7
-2
Lib/dos-8x3/test_str.py
Lib/dos-8x3/test_str.py
+15
-0
Lib/dos-8x3/test_tim.py
Lib/dos-8x3/test_tim.py
+1
-1
No files found.
Lib/dos-8x3/configpa.py
0 → 100644
View file @
b978d18f
"""Configuration file parser.
A setup file consists of sections, lead by a "[section]" header,
and followed by "name: value" entries, with continuations and such in
the style of rfc822.
The option values can contain format strings which refer to other
values in the same section, or values in a special [DEFAULT] section.
For example:
something: %(dir)s/whatever
would resolve the "%(dir)s" to the value of dir. All reference
expansions are done late, on demand.
Intrinsic defaults can be specified by passing them into the
ConfigParser constructor as a dictionary.
class:
ConfigParser -- responsible for for parsing a list of
configuration files, and managing the parsed database.
methods:
__init__(defaults=None) -- create the parser and specify a
dictionary of intrinsic defaults. The
keys must be strings, the values must
be appropriate for %()s string
interpolation. Note that `name' is
always an intrinsic default; it's value
is the section's name.
sections() -- return all the configuration section names, sans DEFAULT
options(section) -- return list of configuration options for the named
section
read(*filenames) -- read and parse the list of named configuration files
get(section, option, raw=0) -- return a string value for the named
option. All % interpolations are
expanded in the return values, based on
the defaults passed into the constructor
and the DEFAULT section.
getint(section, options) -- like get(), but convert value to an integer
getfloat(section, options) -- like get(), but convert value to a float
getboolean(section, options) -- like get(), but convert value to
a boolean (currently defined as 0
or 1, only)
"""
import
sys
import
string
import
regex
from
types
import
ListType
SECTHEAD_RE
=
"^
\
[
\
([-A-Za-z0-9]*
\
)
\
]["
+
string
.
whitespace
+
"]*$"
secthead_cre
=
regex
.
compile
(
SECTHEAD_RE
)
OPTION_RE
=
"^
\
([-A-Z
a
-z0-9.]+
\
)
\
(:
\
|[
"
+ string.whitespace + "
]
*=
\
)
\
(.
*
\
)
$
"
option_cre = regex.compile(OPTION_RE)
DEFAULTSECT = "
DEFAULT
"
# exception classes
class Error:
def __init__(self, msg=''):
self.__msg = msg
def __repr__(self):
return self.__msg
class NoSectionError(Error):
def __init__(self, section):
Error.__init__(self, 'No section: %s' % section)
self.section = section
class DuplicateSectionError(Error):
def __init__(self, section):
Error.__init__(self, "
Section
%
s
already
exists
" % section)
self.section = section
class NoOptionError(Error):
def __init__(self, option, section):
Error.__init__(self, "
No
option
`
%
s
' in section: %s" %
(option, section))
self.option = option
self.section = section
class InterpolationError(Error):
def __init__(self, reference, option, section):
Error.__init__(self,
"Bad value substitution: sect `%s'
,
opt
`%s', ref `
%
s
'"
% (section, option, reference))
self.reference = reference
self.option = option
self.section = section
class ConfigParser:
def __init__(self, defaults=None):
self.__sections = {}
if defaults is None:
self.__defaults = {}
else:
self.__defaults = defaults
def defaults(self):
return self.__defaults
def sections(self):
"""Return a list of section names, excluding [DEFAULT]"""
# self.__sections will never have [DEFAULT] in it
return self.__sections.keys()
def add_section(self, section):
"""Create a new section in the configuration.
Raise DuplicateSectionError if a section by the specified name
already exists.
"""
if self.__sections.has_key(section):
raise DuplicateSectionError(section)
self.__sections[section] = {}
def has_section(self, section):
"""Indicate whether the named section is present in the configuration.
The DEFAULT section is not acknowledged.
"""
return self.__sections.has_key(section)
def options(self, section):
try:
opts = self.__sections[section].copy()
except KeyError:
raise NoSectionError(section)
opts.update(self.__defaults)
return opts.keys()
def read(self, filenames):
"""Read and parse a list of filenames."""
if type(filenames) is type(''):
filenames = [filenames]
for file in filenames:
try:
fp = open(file, 'r')
self.__read(fp)
except IOError:
pass
def get(self, section, option, raw=0):
"""Get an option value for a given section.
All % interpolations are expanded in the return values, based
on the defaults passed into the constructor.
The section DEFAULT is special.
"""
try:
d = self.__sections[section].copy()
except KeyError:
if section == DEFAULTSECT:
d = {}
else:
raise NoSectionError(section)
d.update(self.__defaults)
option = string.lower(option)
try:
rawval = d[option]
except KeyError:
raise NoOptionError(option, section)
# do the string interpolation
if raw:
return rawval
try:
return rawval % d
except KeyError, key:
raise InterpolationError(key, option, section)
def __get(self, section, conv, option):
return conv(self.get(section, option))
def getint(self, section, option):
return self.__get(section, string.atoi, option)
def getfloat(self, section, option):
return self.__get(section, string.atof, option)
def getboolean(self, section, option):
v = self.get(section, option)
val = string.atoi(v)
if val not in (0, 1):
raise ValueError, '
Not
a
boolean
:
%
s
' % v
return val
def __read(self, fp):
"""Parse a sectioned setup file.
The sections in setup file contains a title line at the top,
indicated by a name in square brackets (`[]'
),
plus
key
/
value
options
lines
,
indicated
by
`
name
:
value
' format lines.
Continuation are represented by an embedded newline then
leading whitespace. Blank lines, lines beginning with a '
#',
and
just
about
everything
else
is
ignored
.
"""
cursect = None # None, or a dictionary
optname = None
lineno = 0
while 1:
line = fp.readline()
if not line:
break
lineno = lineno + 1
# comment or blank line?
if string.strip(line) == '' or line[0] in '#;':
continue
if string.lower(string.split(line)[0]) == 'rem'
\
and line[0] == "r": # no leading whitespace
continue
# continuation line?
if line[0] in '
\
t
' and cursect <> None and optname:
value = string.strip(line)
if value:
cursect = cursect[optname] + '
\
n
' + value
# a section header?
elif secthead_cre.match(line) >= 0:
sectname = secthead_cre.group(1)
if self.__sections.has_key(sectname):
cursect = self.__sections[sectname]
elif sectname == DEFAULTSECT:
cursect = self.__defaults
else:
cursect = {'name': sectname}
self.__sections[sectname] = cursect
# So sections can't start with a continuation line.
optname = None
# an option line?
elif option_cre.match(line) >= 0:
optname, optval = option_cre.group(1, 3)
optname = string.lower(optname)
optval = string.strip(optval)
# allow empty values
if optval == '""':
optval = ''
cursect[optname] = optval
# an error
else:
print 'Error in %s at %d: %s', (fp.name, lineno, `line`)
Lib/dos-8x3/posixfil.py
View file @
b978d18f
...
@@ -177,7 +177,7 @@ class _posixfile_:
...
@@ -177,7 +177,7 @@ class _posixfile_:
# Hack by davem@magnet.com to get locking to go on freebsd;
# Hack by davem@magnet.com to get locking to go on freebsd;
# additions for AIX by Vladimir.Marangozov@imag.fr
# additions for AIX by Vladimir.Marangozov@imag.fr
import
sys
,
os
import
sys
,
os
if
sys
.
platform
==
'freebsd2'
:
if
sys
.
platform
in
(
'netbsd1'
,
'freebsd2'
,
'freebsd3'
)
:
flock
=
struct
.
pack
(
'lxxxxlxxxxlhh'
,
\
flock
=
struct
.
pack
(
'lxxxxlxxxxlhh'
,
\
l_start
,
l_len
,
os
.
getpid
(),
l_type
,
l_whence
)
l_start
,
l_len
,
os
.
getpid
(),
l_type
,
l_whence
)
elif
sys
.
platform
in
[
'aix3'
,
'aix4'
]:
elif
sys
.
platform
in
[
'aix3'
,
'aix4'
]:
...
@@ -190,7 +190,7 @@ class _posixfile_:
...
@@ -190,7 +190,7 @@ class _posixfile_:
flock
=
fcntl
.
fcntl
(
self
.
_file_
.
fileno
(),
cmd
,
flock
)
flock
=
fcntl
.
fcntl
(
self
.
_file_
.
fileno
(),
cmd
,
flock
)
if
'?'
in
how
:
if
'?'
in
how
:
if
sys
.
platform
==
'freebsd2'
:
if
sys
.
platform
in
(
'netbsd1'
,
'freebsd2'
,
'freebsd3'
)
:
l_start
,
l_len
,
l_pid
,
l_type
,
l_whence
=
\
l_start
,
l_len
,
l_pid
,
l_type
,
l_whence
=
\
struct
.
unpack
(
'lxxxxlxxxxlhh'
,
flock
)
struct
.
unpack
(
'lxxxxlxxxxlhh'
,
flock
)
elif
sys
.
platform
in
[
'aix3'
,
'aix4'
]:
elif
sys
.
platform
in
[
'aix3'
,
'aix4'
]:
...
...
Lib/dos-8x3/posixpat.py
View file @
b978d18f
This diff is collapsed.
Click to expand it.
Lib/dos-8x3/test_fcn.py
View file @
b978d18f
...
@@ -5,7 +5,7 @@
...
@@ -5,7 +5,7 @@
import
struct
import
struct
import
fcntl
import
fcntl
import
FCNTL
import
FCNTL
import
os
import
os
,
sys
from
test_support
import
verbose
from
test_support
import
verbose
filename
=
'/tmp/delete-me'
filename
=
'/tmp/delete-me'
...
@@ -16,7 +16,12 @@ rv = fcntl.fcntl(f.fileno(), FCNTL.F_SETFL, os.O_NONBLOCK)
...
@@ -16,7 +16,12 @@ rv = fcntl.fcntl(f.fileno(), FCNTL.F_SETFL, os.O_NONBLOCK)
if
verbose
:
if
verbose
:
print
'Status from fnctl with O_NONBLOCK: '
,
rv
print
'Status from fnctl with O_NONBLOCK: '
,
rv
lockdata
=
struct
.
pack
(
'hhllhh'
,
FCNTL
.
F_WRLCK
,
0
,
0
,
0
,
0
,
0
)
if
sys
.
platform
in
(
'netbsd1'
,
'freebsd2'
,
'freebsd3'
):
lockdata
=
struct
.
pack
(
'lxxxxlxxxxlhh'
,
0
,
0
,
0
,
FCNTL
.
F_WRLCK
,
0
)
elif
sys
.
platform
in
[
'aix3'
,
'aix4'
]:
lockdata
=
struct
.
pack
(
'hhlllii'
,
FCNTL
.
F_WRLCK
,
0
,
0
,
0
,
0
,
0
,
0
)
else
:
lockdata
=
struct
.
pack
(
'hhllhh'
,
FCNTL
.
F_WRLCK
,
0
,
0
,
0
,
0
,
0
)
if
verbose
:
if
verbose
:
print
'struct.pack: '
,
`lockdata`
print
'struct.pack: '
,
`lockdata`
...
...
Lib/dos-8x3/test_str.py
View file @
b978d18f
...
@@ -45,6 +45,12 @@ test('split', 'this is the split function',
...
@@ -45,6 +45,12 @@ test('split', 'this is the split function',
[
'this'
,
'is'
,
'the'
,
'split'
,
'function'
])
[
'this'
,
'is'
,
'the'
,
'split'
,
'function'
])
test
(
'split'
,
'a|b|c|d'
,
[
'a'
,
'b'
,
'c'
,
'd'
],
'|'
)
test
(
'split'
,
'a|b|c|d'
,
[
'a'
,
'b'
,
'c'
,
'd'
],
'|'
)
test
(
'split'
,
'a|b|c|d'
,
[
'a'
,
'b'
,
'c|d'
],
'|'
,
2
)
test
(
'split'
,
'a|b|c|d'
,
[
'a'
,
'b'
,
'c|d'
],
'|'
,
2
)
test
(
'split'
,
'a b c d'
,
[
'a'
,
'b c d'
],
None
,
1
)
test
(
'split'
,
'a b c d'
,
[
'a'
,
'b'
,
'c d'
],
None
,
2
)
test
(
'split'
,
'a b c d'
,
[
'a'
,
'b'
,
'c'
,
'd'
],
None
,
3
)
test
(
'split'
,
'a b c d'
,
[
'a'
,
'b'
,
'c'
,
'd'
],
None
,
4
)
test
(
'split'
,
'a b c d'
,
[
'a'
,
'b'
,
'c'
,
'd'
],
None
,
0
)
test
(
'split'
,
'a b c d'
,
[
'a'
,
'b'
,
'c d'
],
None
,
2
)
# join now works with any sequence type
# join now works with any sequence type
class
Sequence
:
class
Sequence
:
...
@@ -67,6 +73,15 @@ test('rstrip', ' hello ', ' hello')
...
@@ -67,6 +73,15 @@ test('rstrip', ' hello ', ' hello')
test
(
'swapcase'
,
'HeLLo cOmpUteRs'
,
'hEllO CoMPuTErS'
)
test
(
'swapcase'
,
'HeLLo cOmpUteRs'
,
'hEllO CoMPuTErS'
)
test
(
'translate'
,
'xyzabcdef'
,
'xyzxyz'
,
transtable
,
'def'
)
test
(
'translate'
,
'xyzabcdef'
,
'xyzxyz'
,
transtable
,
'def'
)
test
(
'replace'
,
'one!two!three!'
,
'one@two!three!'
,
'!'
,
'@'
,
1
)
test
(
'replace'
,
'one!two!three!'
,
'one@two@three!'
,
'!'
,
'@'
,
2
)
test
(
'replace'
,
'one!two!three!'
,
'one@two@three@'
,
'!'
,
'@'
,
3
)
test
(
'replace'
,
'one!two!three!'
,
'one@two@three@'
,
'!'
,
'@'
,
4
)
test
(
'replace'
,
'one!two!three!'
,
'one@two@three@'
,
'!'
,
'@'
,
0
)
test
(
'replace'
,
'one!two!three!'
,
'one@two@three@'
,
'!'
,
'@'
)
test
(
'replace'
,
'one!two!three!'
,
'one!two!three!'
,
'x'
,
'@'
)
test
(
'replace'
,
'one!two!three!'
,
'one!two!three!'
,
'x'
,
'@'
,
2
)
strop
.
whitespace
strop
.
whitespace
strop
.
lowercase
strop
.
lowercase
strop
.
uppercase
strop
.
uppercase
Lib/dos-8x3/test_tim.py
View file @
b978d18f
...
@@ -8,7 +8,7 @@ if time.ctime(t) <> time.asctime(time.localtime(t)):
...
@@ -8,7 +8,7 @@ if time.ctime(t) <> time.asctime(time.localtime(t)):
print
'time.ctime(t) <> time.asctime(time.localtime(t))'
print
'time.ctime(t) <> time.asctime(time.localtime(t))'
time
.
daylight
time
.
daylight
if
int
(
time
.
mktime
(
time
.
localtime
(
t
)))
<>
int
(
t
):
if
long
(
time
.
mktime
(
time
.
localtime
(
t
)))
<>
long
(
t
):
print
'time.mktime(time.localtime(t)) <> t'
print
'time.mktime(time.localtime(t)) <> t'
time
.
sleep
(
1.2
)
time
.
sleep
(
1.2
)
...
...
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