|
1 | | -# only import if running as a custom node |
2 | | -from .nodes.lora import NunchakuFluxLoraLoader |
3 | | -from .nodes.models import ( |
4 | | - NunchakuFluxDiTLoader, |
5 | | - NunchakuPulidApply, |
6 | | - NunchakuPulidLoader, |
7 | | - NunchakuTextEncoderLoader, |
8 | | - NunchakuTextEncoderLoaderV2, |
9 | | -) |
10 | | -from .nodes.preprocessors import FluxDepthPreprocessor |
11 | | -from .nodes.tools import NunchakuModelMerger |
| 1 | +import logging |
| 2 | +import os |
| 3 | + |
| 4 | +# Get log level from environment variable (default to INFO) |
| 5 | +log_level = os.getenv("LOG_LEVEL", "INFO").upper() |
| 6 | + |
| 7 | +# Configure logging |
| 8 | +logging.basicConfig(level=getattr(logging, log_level, logging.INFO), format="%(asctime)s - %(levelname)s - %(message)s") |
| 9 | +logger = logging.getLogger(__name__) |
| 10 | + |
| 11 | +logger.info("=" * 40 + " ComfyUI-nunchaku Initialization " + "=" * 40) |
| 12 | + |
| 13 | +from .utils import get_package_version, get_plugin_version, supported_versions |
| 14 | + |
| 15 | +nunchaku_full_version = get_package_version("nunchaku").split("+")[0].strip() |
| 16 | + |
| 17 | +logger.info(f"Nunchaku version: {nunchaku_full_version}") |
| 18 | +logger.info(f"ComfyUI-nunchaku version: {get_plugin_version()}") |
| 19 | + |
| 20 | +nunchaku_version = nunchaku_full_version.split("+")[0].strip() |
| 21 | +nunchaku_major_minor_patch_version = ".".join(nunchaku_version.split(".")[:3]) |
| 22 | +if f"v{nunchaku_major_minor_patch_version}" not in supported_versions: |
| 23 | + logger.warning( |
| 24 | + f"ComfyUI-nunchaku {get_plugin_version()} is not compatible with nunchaku {nunchaku_full_version}. " |
| 25 | + f"Please update nunchaku to a supported version in {supported_versions}." |
| 26 | + ) |
| 27 | + |
| 28 | +from .nodes.lora.flux import NunchakuFluxLoraLoader |
| 29 | +from .nodes.models.flux import NunchakuFluxDiTLoader |
12 | 30 |
|
13 | 31 | NODE_CLASS_MAPPINGS = { |
14 | 32 | "NunchakuFluxDiTLoader": NunchakuFluxDiTLoader, |
15 | | - "NunchakuTextEncoderLoader": NunchakuTextEncoderLoader, |
16 | | - "NunchakuTextEncoderLoaderV2": NunchakuTextEncoderLoaderV2, |
17 | 33 | "NunchakuFluxLoraLoader": NunchakuFluxLoraLoader, |
18 | | - "NunchakuDepthPreprocessor": FluxDepthPreprocessor, |
19 | | - "NunchakuPulidApply": NunchakuPulidApply, |
20 | | - "NunchakuPulidLoader": NunchakuPulidLoader, |
21 | | - "NunchakuModelMerger": NunchakuModelMerger, |
22 | 34 | } |
| 35 | + |
| 36 | +try: |
| 37 | + from .nodes.models.text_encoder import NunchakuTextEncoderLoader, NunchakuTextEncoderLoaderV2 |
| 38 | + |
| 39 | + NODE_CLASS_MAPPINGS["NunchakuTextEncoderLoader"] = NunchakuTextEncoderLoader |
| 40 | + NODE_CLASS_MAPPINGS["NunchakuTextEncoderLoaderV2"] = NunchakuTextEncoderLoaderV2 |
| 41 | +except ImportError: |
| 42 | + logger.exception("Optional nodes `NunchakuTextEncoderLoader` and `NunchakuTextEncoderLoaderV2` import failed:") |
| 43 | + |
| 44 | +try: |
| 45 | + from .nodes.preprocessors.depth import FluxDepthPreprocessor |
| 46 | + |
| 47 | + NODE_CLASS_MAPPINGS["NunchakuDepthPreprocessor"] = FluxDepthPreprocessor |
| 48 | +except ImportError: |
| 49 | + logger.exception("Optional node `NunchakuDepthPreprocessor` import failed:") |
| 50 | + |
| 51 | +try: |
| 52 | + from .nodes.models.pulid import NunchakuPulidApply, NunchakuPulidLoader |
| 53 | + |
| 54 | + NODE_CLASS_MAPPINGS["NunchakuPulidApply"] = NunchakuPulidApply |
| 55 | + NODE_CLASS_MAPPINGS["NunchakuPulidLoader"] = NunchakuPulidLoader |
| 56 | +except ImportError: |
| 57 | + logger.exception("Optional nodes `NunchakuPulidApply` and `NunchakuPulidLoader` import failed:") |
| 58 | + |
| 59 | +try: |
| 60 | + from .nodes.tools.merge_safetensors import NunchakuModelMerger |
| 61 | + |
| 62 | + NODE_CLASS_MAPPINGS["NunchakuModelMerger"] = NunchakuModelMerger |
| 63 | +except ImportError: |
| 64 | + logger.exception("Optional node `NunchakuModelMerger` import failed:") |
| 65 | + |
| 66 | +try: |
| 67 | + from .nodes.tools.installers import NunchakuWheelInstaller |
| 68 | + |
| 69 | + NODE_CLASS_MAPPINGS["NunchakuWheelInstaller"] = NunchakuWheelInstaller |
| 70 | +except ImportError: |
| 71 | + logger.exception("Optional node `NunchakuWheelInstaller` import failed:") |
| 72 | + |
23 | 73 | NODE_DISPLAY_NAME_MAPPINGS = {k: v.TITLE for k, v in NODE_CLASS_MAPPINGS.items()} |
24 | 74 | __all__ = ["NODE_CLASS_MAPPINGS", "NODE_DISPLAY_NAME_MAPPINGS"] |
| 75 | +logger.info("=" * (80 + len(" ComfyUI-nunchaku Initialization "))) |
0 commit comments