From 86519253879e53e0209c4e96f0c7f09f3ee81da6 Mon Sep 17 00:00:00 2001 From: Talley Lambert Date: Sun, 7 Jul 2024 12:31:53 -0400 Subject: [PATCH] minor refactor --- src/useq/_position.py | 18 ++++++------------ 1 file changed, 6 insertions(+), 12 deletions(-) diff --git a/src/useq/_position.py b/src/useq/_position.py index 2f0008fd..ecf4b87c 100644 --- a/src/useq/_position.py +++ b/src/useq/_position.py @@ -1,13 +1,4 @@ -from typing import ( - TYPE_CHECKING, - ClassVar, - Generic, - Iterator, - Literal, - Optional, - SupportsIndex, - TypeVar, -) +from typing import TYPE_CHECKING, Generic, Iterator, Optional, SupportsIndex, TypeVar from pydantic import Field @@ -110,7 +101,7 @@ def num_positions(self) -> int: raise NotImplementedError("This method must be implemented by subclasses.") -class RelativePosition(PositionBase, _MultiPointPlan): +class RelativePosition(PositionBase, _MultiPointPlan["RelativePosition"]): """A relative position in 3D space. Relative positions also support `fov_width` and `fov_height` attributes, and can @@ -120,7 +111,10 @@ class RelativePosition(PositionBase, _MultiPointPlan): x: float = 0 y: float = 0 z: float = 0 - is_relative: ClassVar[Literal[True]] = True + + @property + def is_relative(self) -> bool: + return True def __iter__(self) -> Iterator["RelativePosition"]: # type: ignore [override] yield self