#!/usr/bin/env python3 # -*- coding: utf-8 -*- # # Copyright (C) 1998-2026 Stephane Galland # # This program is free library; you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as # published by the Free Software Foundation; either version 3 of the # License, or any later version. # # This library 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 # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public # License along with this library; see the file COPYING. If not, # write to the Free Software Foundation, Inc., 59 Temple Place - Suite # 330, Boston, MA 02111-1307, USA. """ Readers of "transdef" files. """ import abc from abc import ABC from autolatex2.config.configobj import Config from autolatex2.translator.readers.transdefline import TransdefLine class AbstractTransdefReader(ABC): """ Abstract implementation of a "transdef" reader. """ def __init__(self, configuration : Config): """ Constructor. :param configuration: the global configuration. :type configuration: Config """ self.__configuration : Config = configuration @property def configuration(self) -> Config: """ Replies the configuration. :return: the configuration. :rtype: Config """ return self.__configuration @configuration.setter def configuration(self, c : Config): """ Change the configuration. :param c: the configuration. :type c: Config """ self.__configuration = c @abc.abstractmethod def read_translator_file(self, filename : str) -> dict[str,TransdefLine]: """ Read the translator file. The replied value is the set of keys read from the transdef file. Each value is a TransdefLine. :param filename: the name of the file to read. :type filename: str :rtype: dict[str,TransdefLine] """ raise NotImplementedError()