Make relation immutable

This commit is contained in:
Salvo 'LtWorf' Tomaselli 2020-08-13 10:44:39 +02:00
parent 76509e249b
commit be9fdd2e84
No known key found for this signature in database
GPG Key ID: B3A7CF0C801886CF
2 changed files with 10 additions and 34 deletions

View File

@ -1,4 +1,5 @@
3.0 3.0
- Relations now use frozenset internally and are immutable
- Refactored parser to use better typing - Refactored parser to use better typing
- Refactored and fixed some optimizations - Refactored and fixed some optimizations
- Added more test cases - Added more test cases

View File

@ -34,8 +34,7 @@ __all__ = [
] ]
class Relation: class Relation(NamedTuple):
''' '''
This object defines a relation (as a group of consistent tuples) and operations. This object defines a relation (as a group of consistent tuples) and operations.
@ -58,41 +57,17 @@ class Relation:
An empty relation needs a header, and can be filled using the insert() An empty relation needs a header, and can be filled using the insert()
method. method.
''' '''
def __hash__(self): header: 'Header'
raise NotImplementedError() content: FrozenSet[tuple]
def __init__(self, filename: Optional[Union[str, Path]] = None) -> None: @staticmethod
self._readonly = False def load(filename: Union[str, Path]) -> 'Relation':
self.content: Set[tuple] = set()
if filename is None: # Empty relation
self.header = Header([])
return
with open(filename) as fp: with open(filename) as fp:
reader = csv.reader(fp) # Creating a csv reader reader = csv.reader(fp) # Creating a csv reader
self.header = Header(next(reader)) # read 1st line header = Header(next(reader)) # read 1st line
iterator = ((self.insert(i) for i in reader)) #FIXME load properly
deque(iterator, maxlen=0) content = frozenset((tuple(i) for i in reader))
return Relation(header, content)
def _make_duplicate(self, copy: 'Relation') -> None:
'''Flag that the relation "copy" is pointing
to the same set as this relation.'''
self._readonly = True
copy._readonly = True
def _make_writable(self, copy_content: bool = True) -> None:
'''If this relation is marked as readonly, this
method will copy the content to make it writable too
if copy_content is set to false, the caller must
separately copy the content.'''
if self._readonly:
self._readonly = False
if copy_content:
self.content = set(self.content)
def __iter__(self): def __iter__(self):
return iter(self.content) return iter(self.content)