From 919f6e9646ec436cb834f1b8017a117013057160 Mon Sep 17 00:00:00 2001 From: Mark McLoughlin Date: Tue, 16 Jul 2024 18:01:46 +0100 Subject: [PATCH] importblock: resolve circular import issue Fixes #147 importblock uses Pipeline, and the pipeline module defines: _block_types = { ... "ImportBlock": importblock.ImportBlock, which gives the following error: ``` src/instructlab/sdg/__init__.py:29: in from .importblock import ImportBlock src/instructlab/sdg/importblock.py:6: in from . import pipeline src/instructlab/sdg/pipeline.py:102: in "ImportBlock": importblock.ImportBlock, E AttributeError: partially initialized module 'src.instructlab.sdg.importblock' has no attribute 'ImportBlock' (most likely due to a circular import) ``` This fixes the issue, but it's not very satisfactory, so I've included a FIXME. Signed-off-by: Mark McLoughlin --- src/instructlab/sdg/importblock.py | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/src/instructlab/sdg/importblock.py b/src/instructlab/sdg/importblock.py index 8efb2550..c2e98b31 100644 --- a/src/instructlab/sdg/importblock.py +++ b/src/instructlab/sdg/importblock.py @@ -3,7 +3,6 @@ from datasets import Dataset # Local -from . import pipeline from .block import Block from .logger_config import setup_logger @@ -30,6 +29,21 @@ def __init__( """ super().__init__(ctx, pipe, block_name) self.path = path + + # FIXME: find a better fix for this circular import error: + # + # src/instructlab/sdg/__init__.py:29: in + # from .importblock import ImportBlock + # src/instructlab/sdg/importblock.py:6: in + # from . import pipeline + # src/instructlab/sdg/pipeline.py:102: in + # "ImportBlock": importblock.ImportBlock, + # E AttributeError: partially initialized module 'src.instructlab.sdg.importblock' has no attribute 'ImportBlock' (most likely due to a circular import) + # + # pylint: disable=C0415 + # Local + from . import pipeline + self.pipeline = pipeline.Pipeline.from_file(self.ctx, self.path) def generate(self, samples) -> Dataset: