from ....Internal.Core import Core
from ....Internal.CommandsGroup import CommandsGroup
from ....Internal import Conversions
from .... import enums
# noinspection PyPep8Naming,PyAttributeOutsideInit,SpellCheckingInspection
[docs]class ModeCls:
	"""Mode commands group definition. 1 total commands, 0 Subgroups, 1 group commands"""
	def __init__(self, core: Core, parent):
		self._core = core
		self._cmd_group = CommandsGroup("mode", core, parent)
[docs]	def set(self, mode: enums.IfGainMode) -> None:
		"""SCPI: SYSTem:IFGain:MODE \n
		Snippet: driver.system.ifGain.mode.set(mode = enums.IfGainMode.NORMal) \n
		Configures the internal IF gain settings in HP emulation mode due to the application needs. This setting is only taken
		into account for resolution bandwidth < 300 kHz and is only available if a HP language is selected using method RsFsw.
		System.Language.set. \n
			:param mode: NORMal | PULSe NORMal Optimized for high dynamic range, overload limit is close to reference level. PULSe Optimized for pulsed signals, overload limit up to 10 dB above reference level.
		"""
		param = Conversions.enum_scalar_to_str(mode, enums.IfGainMode)
		self._core.io.write(f'SYSTem:IFGain:MODE {param}') 
	# noinspection PyTypeChecker
[docs]	def get(self) -> enums.IfGainMode:
		"""SCPI: SYSTem:IFGain:MODE \n
		Snippet: value: enums.IfGainMode = driver.system.ifGain.mode.get() \n
		Configures the internal IF gain settings in HP emulation mode due to the application needs. This setting is only taken
		into account for resolution bandwidth < 300 kHz and is only available if a HP language is selected using method RsFsw.
		System.Language.set. \n
			:return: mode: NORMal | PULSe NORMal Optimized for high dynamic range, overload limit is close to reference level. PULSe Optimized for pulsed signals, overload limit up to 10 dB above reference level."""
		response = self._core.io.query_str(f'SYSTem:IFGain:MODE?')
		return Conversions.str_to_scalar_enum(response, enums.IfGainMode)