Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Z
Zope
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
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
Zope
Commits
28dacc89
Commit
28dacc89
authored
Jul 12, 1998
by
Jim Fulton
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Redid way SQL aliases are handled.
parent
c12872d4
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
34 additions
and
7 deletions
+34
-7
lib/python/Shared/DC/ZRDB/RDB.py
lib/python/Shared/DC/ZRDB/RDB.py
+19
-4
lib/python/Shared/DC/ZRDB/Results.py
lib/python/Shared/DC/ZRDB/Results.py
+15
-3
No files found.
lib/python/Shared/DC/ZRDB/RDB.py
View file @
28dacc89
...
...
@@ -11,8 +11,8 @@
__doc__
=
'''Class for reading RDB files
$Id: RDB.py,v 1.1
7 1998/07/12 15:58:57
jim Exp $'''
__version__
=
'$Revision: 1.1
7
$'
[
11
:
-
2
]
$Id: RDB.py,v 1.1
8 1998/07/12 16:46:40
jim Exp $'''
__version__
=
'$Revision: 1.1
8
$'
[
11
:
-
2
]
import
regex
,
regsub
from
string
import
split
,
strip
,
lower
,
upper
,
atof
,
atoi
,
atol
,
find
,
join
...
...
@@ -41,6 +41,10 @@ Parsers={'n': atof,
record_classes
=
{}
class
SQLAlias
(
ExtensionClass
.
Base
):
def
__init__
(
self
,
name
):
self
.
_n
=
name
def
__of__
(
self
,
parent
):
return
getattr
(
parent
,
self
.
_n
)
class
NoBrains
:
pass
class
DatabaseResults
:
...
...
@@ -63,6 +67,7 @@ class DatabaseResults:
self
.
_names
=
names
=
split
(
line
,
'
\
t
'
)
if
not
names
:
raise
ValueError
,
'No column names'
aliases
=
[]
self
.
_schema
=
schema
=
{}
i
=
0
for
name
in
names
:
...
...
@@ -72,8 +77,10 @@ class DatabaseResults:
if
schema
.
has_key
(
name
):
raise
ValueError
,
'Duplicate column name, %s'
%
name
schema
[
name
]
=
i
schema
[
lower
(
name
)]
=
i
schema
[
upper
(
name
)]
=
i
n
=
lower
(
name
)
if
n
!=
name
:
aliases
.
append
((
n
,
SQLAlias
(
name
)))
n
=
upper
(
name
)
if
n
!=
name
:
aliases
.
append
((
n
,
SQLAlias
(
name
)))
i
=
i
+
1
self
.
_nv
=
nv
=
len
(
names
)
...
...
@@ -130,6 +137,11 @@ class DatabaseResults:
setattr(r,k,getattr(Record,k))
record_classes[names,brains]=r
# Add SQL Aliases
d=r.__dict__
for k, v in aliases:
if not hasattr(r,k): d[k]=v
if hasattr(brains, '
__init__
'):
binit=brains.__init__
if hasattr(binit,'
im_func
'): binit=binit.im_func
...
...
@@ -200,6 +212,9 @@ File=DatabaseResults
##############################################################################
#
# $Log: RDB.py,v $
# Revision 1.18 1998/07/12 16:46:40 jim
# Redid way SQL aliases are handled.
#
# Revision 1.17 1998/07/12 15:58:57 jim
# Made row data attributes case-insensitive.
#
...
...
lib/python/Shared/DC/ZRDB/Results.py
View file @
28dacc89
import
ExtensionClass
from
string
import
strip
,
lower
,
upper
from
Acquisition
import
Implicit
from
Record
import
Record
record_classes
=
{}
class
SQLAlias
(
ExtensionClass
.
Base
):
def
__init__
(
self
,
name
):
self
.
_n
=
name
def
__of__
(
self
,
parent
):
return
getattr
(
parent
,
self
.
_n
)
class
NoBrains
:
pass
class
Results
:
...
...
@@ -20,6 +24,7 @@ class Results:
self
.
_names
=
names
=
[]
self
.
_schema
=
schema
=
{}
self
.
_data_dictionary
=
dd
=
{}
aliases
=
[]
i
=
0
for
item
in
items
:
name
=
item
[
'name'
]
...
...
@@ -29,8 +34,10 @@ class Results:
if
schema
.
has_key
(
name
):
raise
ValueError
,
'Duplicate column name, %s'
%
name
schema
[
name
]
=
i
schema
[
lower
(
name
)]
=
i
schema
[
upper
(
name
)]
=
i
n
=
lower
(
name
)
if
n
!=
name
:
aliases
.
append
((
n
,
SQLAlias
(
name
)))
n
=
upper
(
name
)
if
n
!=
name
:
aliases
.
append
((
n
,
SQLAlias
(
name
)))
dd
[
name
]
=
item
names
.
append
(
name
)
i
=
i
+
1
...
...
@@ -50,6 +57,11 @@ class Results:
setattr
(
r
,
k
,
getattr
(
Record
,
k
))
record_classes
[
names
,
brains
]
=
r
# Add SQL Aliases
d
=
r
.
__dict__
for
k
,
v
in
aliases
:
if
not
hasattr
(
r
,
k
):
d
[
k
]
=
v
if
hasattr
(
brains
,
'__init__'
):
binit
=
brains
.
__init__
if
hasattr
(
binit
,
'im_func'
):
binit
=
binit
.
im_func
...
...
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