2023-01-28 23:09:19 +00:00
|
|
|
from logging import getLogger
|
2024-01-13 00:58:26 +00:00
|
|
|
from typing import Optional
|
2023-02-05 13:53:26 +00:00
|
|
|
|
2023-01-28 15:08:59 +00:00
|
|
|
from PIL import Image
|
|
|
|
|
2024-01-13 00:58:26 +00:00
|
|
|
from ..output import save_result
|
|
|
|
from ..params import ImageParams, SizeChart, StageParams
|
2023-02-26 05:49:39 +00:00
|
|
|
from ..server import ServerContext
|
2023-02-26 20:15:30 +00:00
|
|
|
from ..worker import WorkerContext
|
2023-11-18 23:18:23 +00:00
|
|
|
from .base import BaseStage
|
2023-11-19 00:08:38 +00:00
|
|
|
from .result import StageResult
|
2023-01-28 15:08:59 +00:00
|
|
|
|
2023-01-28 23:09:19 +00:00
|
|
|
logger = getLogger(__name__)
|
|
|
|
|
2023-01-28 15:08:59 +00:00
|
|
|
|
2023-07-02 23:21:21 +00:00
|
|
|
class PersistDiskStage(BaseStage):
|
2023-09-24 15:11:52 +00:00
|
|
|
max_tile = SizeChart.max
|
|
|
|
|
2023-07-01 12:10:53 +00:00
|
|
|
def run(
|
|
|
|
self,
|
2024-01-09 04:54:41 +00:00
|
|
|
worker: WorkerContext,
|
2023-07-01 12:10:53 +00:00
|
|
|
server: ServerContext,
|
|
|
|
_stage: StageParams,
|
|
|
|
params: ImageParams,
|
2023-11-19 00:08:38 +00:00
|
|
|
sources: StageResult,
|
2023-07-01 12:10:53 +00:00
|
|
|
*,
|
2023-09-11 04:06:00 +00:00
|
|
|
stage_source: Optional[Image.Image] = None,
|
2023-07-01 12:10:53 +00:00
|
|
|
**kwargs,
|
2023-11-19 00:08:38 +00:00
|
|
|
) -> StageResult:
|
2024-01-09 04:54:41 +00:00
|
|
|
logger.info("persisting %s images to disk", len(sources))
|
|
|
|
|
|
|
|
save_result(server, sources, worker.job)
|
2023-02-19 04:11:44 +00:00
|
|
|
|
2023-07-04 18:29:58 +00:00
|
|
|
return sources
|