Add more comments.

This commit is contained in:
Epithumia 2013-12-22 19:21:01 +01:00
parent a950378ce7
commit 48d4ff5e97
2 changed files with 18 additions and 7 deletions

View file

@ -383,7 +383,7 @@ def dump(session, tables=[], directory=None, verbose=False, langs=['en']):
table_names = _get_table_names(metadata, tables) table_names = _get_table_names(metadata, tables)
table_names.sort() table_names.sort()
# Handle Oracle # Oracle fixery : read from short table names, dump long names
oranames = (session.connection().dialect.name == 'oracle') oranames = (session.connection().dialect.name == 'oracle')
if oranames: if oranames:
# Make a dictionary to match old<->new names # Make a dictionary to match old<->new names

View file

@ -3,28 +3,39 @@ from pokedex.db import metadata
### Helper functions for oracle ### Helper functions for oracle
def rewrite_long_table_names(): def rewrite_long_table_names():
"""Modifies the table names to disenvowel long table names. """Modifies the table names to disenvowel long table names.
Takes the metadata from memory or uses the imported one.
Returns a dictionary matching short names -> long names.
""" """
# Load table names from metadata
t_names = metadata.tables.keys() t_names = metadata.tables.keys()
table_names = list(t_names) table_names = list(t_names)
table_objs = [metadata.tables[name] for name in table_names] table_objs = [metadata.tables[name] for name in table_names]
# Prepare a dictionary to match old<->new names # Prepare a dictionary to match old<->new names
oradict = {} dictionary = {}
# Shorten table names, Oracle limits table and column names to 30 chars # Shorten table names, Oracle limits table and column names to 30 chars
for table in table_objs: for table in table_objs:
table._orginal_name = table.name[:] table._orginal_name = table.name[:]
oradict[table.name]=table._orginal_name dictionary[table.name]=table._orginal_name
if len(table._orginal_name) > 30: if len(table._orginal_name) > 30:
for letter in ['a', 'e', 'i', 'o', 'u', 'y']: for letter in ['a', 'e', 'i', 'o', 'u', 'y']:
table.name=table.name.replace(letter,'') table.name=table.name.replace(letter,'')
oradict[table.name]=table._orginal_name dictionary[table.name]=table._orginal_name
return oradict return dictionary
def restore_long_table_names(metadata,oradict): def restore_long_table_names(metadata,dictionary):
"""Modifies the table names to restore the long-naming. """Modifies the table names to restore the long-naming.
`metadata`
The metadata to restore.
`dictionary`
The dictionary matching short name -> long name.
""" """
for table in metadata.tables.values(): for table in metadata.tables.values():
table.name = oradict[table.name] table.name = dictionary[table.name]