Source code for mxcubecore.HardwareObjects.mockup.ShutterMockup
#
# Project name: MXCuBE
# https://github.com/mxcube
#
# This file is part of MXCuBE software.
#
# MXCuBE is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# MXCuBE is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with MXCuBE. If not, see <http://www.gnu.org/licenses/>.
"""Mockup shutter implementation"""
from enum import (
Enum,
unique,
)
from mxcubecore.BaseHardwareObjects import HardwareObjectState
from mxcubecore.HardwareObjects.abstract.AbstractShutter import AbstractShutter
from mxcubecore.HardwareObjects.mockup.ActuatorMockup import ActuatorMockup
[docs]@unique
class ShutterStates(Enum):
"""Shutter states definitions."""
OPEN = HardwareObjectState.READY, 6
CLOSED = HardwareObjectState.READY, 7
MOVING = HardwareObjectState.BUSY, 8
DISABLED = HardwareObjectState.WARNING, 9
AUTOMATIC = HardwareObjectState.READY, 10
[docs]class ShutterMockup(AbstractShutter, ActuatorMockup):
"""
ShutterMockup for simulating a simple open/close shutter.
Fake some of the states of the shutter to correspong to values.
"""
SPECIFIC_STATES = ShutterStates
[docs] def init(self):
"""Initialisation"""
super().init()
self._initialise_values()
self.update_value(self.VALUES.CLOSED)
self.update_state(self.STATES.READY)
def _initialise_values(self):
"""Add additional, known in advance states to VALUES"""
values_dict = {item.name: item.value for item in self.VALUES}
values_dict.update(
{
"MOVING": "In Motion",
"UNUSABLE": "Temporarily not controlled",
}
)
self.VALUES = Enum("ValueEnum", values_dict)