You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
105 lines
3.3 KiB
105 lines
3.3 KiB
3 weeks ago
|
diff --git a/pint/errors.py b/pint/errors.py
|
||
|
index 59d3b45..f080f52 100644
|
||
|
--- a/pint/errors.py
|
||
|
+++ b/pint/errors.py
|
||
|
@@ -81,12 +81,12 @@ class WithDefErr:
|
||
|
return DefinitionError(self.name, self.__class__, msg)
|
||
|
|
||
|
|
||
|
-@dataclass(frozen=False)
|
||
|
+@dataclass(frozen=True)
|
||
|
class PintError(Exception):
|
||
|
"""Base exception for all Pint errors."""
|
||
|
|
||
|
|
||
|
-@dataclass(frozen=False)
|
||
|
+@dataclass(frozen=True)
|
||
|
class DefinitionError(ValueError, PintError):
|
||
|
"""Raised when a definition is not properly constructed."""
|
||
|
|
||
|
@@ -102,7 +102,7 @@ class DefinitionError(ValueError, PintError):
|
||
|
return self.__class__, tuple(getattr(self, f.name) for f in fields(self))
|
||
|
|
||
|
|
||
|
-@dataclass(frozen=False)
|
||
|
+@dataclass(frozen=True)
|
||
|
class DefinitionSyntaxError(ValueError, PintError):
|
||
|
"""Raised when a textual definition has a syntax error."""
|
||
|
|
||
|
@@ -115,7 +115,7 @@ class DefinitionSyntaxError(ValueError, PintError):
|
||
|
return self.__class__, tuple(getattr(self, f.name) for f in fields(self))
|
||
|
|
||
|
|
||
|
-@dataclass(frozen=False)
|
||
|
+@dataclass(frozen=True)
|
||
|
class RedefinitionError(ValueError, PintError):
|
||
|
"""Raised when a unit or prefix is redefined."""
|
||
|
|
||
|
@@ -130,7 +130,7 @@ class RedefinitionError(ValueError, PintError):
|
||
|
return self.__class__, tuple(getattr(self, f.name) for f in fields(self))
|
||
|
|
||
|
|
||
|
-@dataclass(frozen=False)
|
||
|
+@dataclass(frozen=True)
|
||
|
class UndefinedUnitError(AttributeError, PintError):
|
||
|
"""Raised when the units are not defined in the unit registry."""
|
||
|
|
||
|
@@ -150,13 +150,13 @@ class UndefinedUnitError(AttributeError, PintError):
|
||
|
return self.__class__, tuple(getattr(self, f.name) for f in fields(self))
|
||
|
|
||
|
|
||
|
-@dataclass(frozen=False)
|
||
|
+@dataclass(frozen=True)
|
||
|
class PintTypeError(TypeError, PintError):
|
||
|
def __reduce__(self):
|
||
|
return self.__class__, tuple(getattr(self, f.name) for f in fields(self))
|
||
|
|
||
|
|
||
|
-@dataclass(frozen=False)
|
||
|
+@dataclass(frozen=True)
|
||
|
class DimensionalityError(PintTypeError):
|
||
|
"""Raised when trying to convert between incompatible units."""
|
||
|
|
||
|
@@ -183,7 +183,7 @@ class DimensionalityError(PintTypeError):
|
||
|
return self.__class__, tuple(getattr(self, f.name) for f in fields(self))
|
||
|
|
||
|
|
||
|
-@dataclass(frozen=False)
|
||
|
+@dataclass(frozen=True)
|
||
|
class OffsetUnitCalculusError(PintTypeError):
|
||
|
"""Raised on ambiguous operations with offset units."""
|
||
|
|
||
|
@@ -208,7 +208,7 @@ class OffsetUnitCalculusError(PintTypeError):
|
||
|
return self.__class__, tuple(getattr(self, f.name) for f in fields(self))
|
||
|
|
||
|
|
||
|
-@dataclass(frozen=False)
|
||
|
+@dataclass(frozen=True)
|
||
|
class LogarithmicUnitCalculusError(PintTypeError):
|
||
|
"""Raised on inappropriate operations with logarithmic units."""
|
||
|
|
||
|
@@ -233,7 +233,7 @@ class LogarithmicUnitCalculusError(PintTypeError):
|
||
|
return self.__class__, tuple(getattr(self, f.name) for f in fields(self))
|
||
|
|
||
|
|
||
|
-@dataclass(frozen=False)
|
||
|
+@dataclass(frozen=True)
|
||
|
class UnitStrippedWarning(UserWarning, PintError):
|
||
|
msg: str
|
||
|
|
||
|
@@ -241,13 +241,13 @@ class UnitStrippedWarning(UserWarning, PintError):
|
||
|
return self.__class__, tuple(getattr(self, f.name) for f in fields(self))
|
||
|
|
||
|
|
||
|
-@dataclass(frozen=False)
|
||
|
+@dataclass(frozen=True)
|
||
|
class UnexpectedScaleInContainer(Exception):
|
||
|
def __reduce__(self):
|
||
|
return self.__class__, tuple(getattr(self, f.name) for f in fields(self))
|
||
|
|
||
|
|
||
|
-@dataclass(frozen=False)
|
||
|
+@dataclass(frozen=True)
|
||
|
class UndefinedBehavior(UserWarning, PintError):
|
||
|
msg: str
|