Source code for xerparser.model.udftypes

# 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):
[docs] self.index = 0
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]