Add more typing info

This commit is contained in:
Salvo 'LtWorf' Tomaselli 2018-04-22 00:29:37 +02:00
parent 9101cee7ab
commit 7b471709c4
No known key found for this signature in database
GPG Key ID: B3A7CF0C801886CF

View File

@ -1,5 +1,5 @@
# Relational # Relational
# Copyright (C) 2009-2017 Salvo "LtWorf" Tomaselli # Copyright (C) 2009-2018 Salvo "LtWorf" Tomaselli
# #
# Relational is free software: you can redistribute it and/or modify # Relational is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by # it under the terms of the GNU General Public License as published by
@ -127,7 +127,7 @@ def recoursive_scan(function, node, rels=None):
return changes return changes
def duplicated_select(n): def duplicated_select(n: parser.Node) -> int:
'''This function locates and deletes things like '''This function locates and deletes things like
σ a ( σ a(C)) and the ones like σ a ( σ b(C)) σ a ( σ a(C)) and the ones like σ a ( σ b(C))
replacing the 1st one with a single select and replacing the 1st one with a single select and
@ -150,7 +150,7 @@ def duplicated_select(n):
return changes + recoursive_scan(duplicated_select, n) return changes + recoursive_scan(duplicated_select, n)
def futile_union_intersection_subtraction(n): def futile_union_intersection_subtraction(n: parser.Node) -> int:
'''This function locates things like r r, and replaces them with r. '''This function locates things like r r, and replaces them with r.
R R --> R R R --> R
R R --> R R R --> R
@ -208,7 +208,7 @@ def futile_union_intersection_subtraction(n):
return changes + recoursive_scan(futile_union_intersection_subtraction, n) return changes + recoursive_scan(futile_union_intersection_subtraction, n)
def down_to_unions_subtractions_intersections(n): def down_to_unions_subtractions_intersections(n: parser.Node) -> int:
'''This funcion locates things like σ i==2 (c d), where the union '''This funcion locates things like σ i==2 (c d), where the union
can be a subtraction and an intersection and replaces them with can be a subtraction and an intersection and replaces them with
σ i==2 (c) σ i==2(d). σ i==2 (c) σ i==2(d).
@ -239,7 +239,7 @@ def down_to_unions_subtractions_intersections(n):
return changes + recoursive_scan(down_to_unions_subtractions_intersections, n) return changes + recoursive_scan(down_to_unions_subtractions_intersections, n)
def duplicated_projection(n): def duplicated_projection(n: parser.Node) -> int:
'''This function locates thing like π i ( π j (R)) and replaces '''This function locates thing like π i ( π j (R)) and replaces
them with π i (R)''' them with π i (R)'''
changes = 0 changes = 0
@ -251,7 +251,7 @@ def duplicated_projection(n):
return changes + recoursive_scan(duplicated_projection, n) return changes + recoursive_scan(duplicated_projection, n)
def selection_inside_projection(n): def selection_inside_projection(n: parser.Node) -> int:
'''This function locates things like σ j (π k(R)) and '''This function locates things like σ j (π k(R)) and
converts them into π k(σ j (R))''' converts them into π k(σ j (R))'''
changes = 0 changes = 0
@ -267,7 +267,7 @@ def selection_inside_projection(n):
return changes + recoursive_scan(selection_inside_projection, n) return changes + recoursive_scan(selection_inside_projection, n)
def swap_union_renames(n): def swap_union_renames(n: parser.Node) -> int:
'''This function locates things like '''This function locates things like
ρ ab(R) ρ ab(Q) ρ ab(R) ρ ab(Q)
and replaces them with and replaces them with
@ -305,7 +305,7 @@ def swap_union_renames(n):
return changes + recoursive_scan(swap_union_renames, n) return changes + recoursive_scan(swap_union_renames, n)
def futile_renames(n): def futile_renames(n: parser.Node) -> int:
'''This function purges renames like id->id''' '''This function purges renames like id->id'''
changes = 0 changes = 0
@ -333,7 +333,7 @@ def futile_renames(n):
return changes + recoursive_scan(futile_renames, n) return changes + recoursive_scan(futile_renames, n)
def subsequent_renames(n): def subsequent_renames(n: parser.Node) -> int:
'''This function removes redoundant subsequent renames joining them into one''' '''This function removes redoundant subsequent renames joining them into one'''
'''Purges renames like id->id Since it's needed to be performed BEFORE this one '''Purges renames like id->id Since it's needed to be performed BEFORE this one
@ -411,7 +411,7 @@ def tokenize_select(expression):
return l return l
def swap_rename_projection(n): def swap_rename_projection(n: parser.Node) -> int:
'''This function locates things like π k(ρ j(R)) '''This function locates things like π k(ρ j(R))
and replaces them with ρ j(π k(R)). and replaces them with ρ j(π k(R)).
This will let rename work on a hopefully smaller set This will let rename work on a hopefully smaller set
@ -453,7 +453,7 @@ def swap_rename_projection(n):
return changes + recoursive_scan(swap_rename_projection, n) return changes + recoursive_scan(swap_rename_projection, n)
def swap_rename_select(n): def swap_rename_select(n: parser.Node) -> int:
'''This function locates things like σ k(ρ j(R)) and replaces '''This function locates things like σ k(ρ j(R)) and replaces
them with ρ j(σ k(R)). Renaming the attributes used in the them with ρ j(σ k(R)). Renaming the attributes used in the
selection, so the operation is still valid.''' selection, so the operation is still valid.'''
@ -490,7 +490,7 @@ def swap_rename_select(n):
return changes + recoursive_scan(swap_rename_select, n) return changes + recoursive_scan(swap_rename_select, n)
def select_union_intersect_subtract(n): def select_union_intersect_subtract(n: parser.Node) -> int:
'''This function locates things like σ i(a) σ q(a) '''This function locates things like σ i(a) σ q(a)
and replaces them with σ (i OR q) (a) and replaces them with σ (i OR q) (a)
Removing a O() operation like the union''' Removing a O() operation like the union'''
@ -530,7 +530,7 @@ def select_union_intersect_subtract(n):
return changes + recoursive_scan(select_union_intersect_subtract, n) return changes + recoursive_scan(select_union_intersect_subtract, n)
def union_and_product(n): def union_and_product(n: parser.Node) -> int:
''' '''
A * B A * C = A * (B C) A * B A * C = A * (B C)
Same thing with inner join Same thing with inner join
@ -696,7 +696,7 @@ def selection_and_product(n, rels):
return changes + recoursive_scan(selection_and_product, n, rels) return changes + recoursive_scan(selection_and_product, n, rels)
def useless_projection(n, rels): def useless_projection(n, rels) -> int:
''' '''
Removes projections that are over all the fields Removes projections that are over all the fields
''' '''