# PyP6XER
# Copyright (C) 2020, 2021 Hassan Emam <hassan@constology.com>
#
# This file is part of PyP6XER.
#
# PyP6XER library is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License v2.1 as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# PyP6XER is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with PyP6XER. If not, see <https://www.gnu.org/licenses/old-licenses/lgpl-2.1.en.html>.
from xerparser.model.classes.udftype import UDFType
[docs]
class UDFTypes:
def __init__(self):
self._udftypes = []
[docs]
def add(self, params):
self._udftypes.append(UDFType(params))
[docs]
def get_tsv(self):
tsv = []
if len(self._udftypes) > 0:
tsv.append(['%T', 'UDFTYPE'])
tsv.append(['%F', 'udf_type_id', 'table_name', 'udf_type_name', 'udf_type_label', 'logical_data_type',
'super_flag', 'indicator_expression', 'summary_indicator_expression', 'export_flag'])
for udf in self._udftypes:
tsv.append(udf.get_tsv())
return tsv
[docs]
def find_by_id(self, id) -> UDFType:
obj = list(filter(lambda x: x.udf_type_id == id, self._udftypes))
if len(obj) > 0:
return obj[0]
return obj
@property
[docs]
def count(self):
return len(self._udftypes)
[docs]
def __len__(self):
return len(self._udftypes)
[docs]
def __iter__(self):
return self
[docs]
def __next__(self) -> UDFType:
if self.index >= len(self._udftypes):
raise StopIteration
idx = self.index
self.index += 1
return self._udftypes[idx]