Package org.harctoolbox.harchardware.ir
Class GirsClient<T extends ICommandLineDevice & IHarcHardware>
java.lang.Object
org.harctoolbox.harchardware.ir.GirsClient<T>
- Type Parameters:
- T-
- All Implemented Interfaces:
- Closeable,- AutoCloseable,- ICommandLineDevice,- IHarcHardware,- ICapture,- IIrReader,- IIrSenderStop,- IRawIrSender,- IRawIrSenderRepeat,- IReceive,- IRemoteCommandIrSender,- ITransmitter
public class GirsClient<T extends ICommandLineDevice & IHarcHardware>
extends Object
implements IHarcHardware, IReceive, IRawIrSender, IRawIrSenderRepeat, IRemoteCommandIrSender, IIrSenderStop, ITransmitter, ICapture, ICommandLineDevice, Closeable
- 
Field SummaryFieldsFields inherited from interface org.harctoolbox.harchardware.ir.IIrReaderDEFAULT_BEGIN_TIMEOUT, DEFAULT_CAPTURE_MAXSIZE, DEFAULT_ENDING_TIMEOUTFields inherited from interface org.harctoolbox.harchardware.ir.IRawIrSenderrepeatMaxFields inherited from interface org.harctoolbox.harchardware.ir.IRemoteCommandIrSenderrepeatMax
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionorg.harctoolbox.ircore.ModulatedIrSequencecapture()Listens to the device and returns a sequence.voidclose()static StringvoidString[]getCommands(String remote) Returns an array of command names for the remote given in the argument.intintlonggetParameter(String parameterName) String[]Returns an array of "remote" names.Returns a default Transmitter for the device.getTransmitter(String connector) Parses the String argument, and returns a transmitter accordingly.String[]Return possible name of transmitters, that are guaranteed to work with the getTransmitter(String).Returns the hardware version (not the version of the driver software).booleanbooleanbooleanbooleanisValid()Checks validity of an instance.static GirsClient<LocalSerialPortBuffered>newInstance(String portName, boolean verbose, Integer timeout) static GirsClient<TcpSocketPort>newInstance(InetAddress inetAddress, Integer portnumber, boolean verbose, Integer timeout) voidopen()Opens the device with previously set parameters.Reads a line of text.readString(boolean wait) Reads a line of text.booleanready()Tells whether this stream is ready to be read.org.harctoolbox.ircore.IrSequencereceive()Listens to the device and returns a sequence.voidreset()booleansendIr(org.harctoolbox.ircore.IrSignal irSignal, int count) booleansendIr(org.harctoolbox.ircore.IrSignal irSignal, int count, Transmitter transmitter) booleansendIrCommand(String remote, String command, int count, Transmitter transmitter) Sends the command to the hardware, to be sent count number of times.booleansendIrCommandRepeat(String remote, String command, Transmitter transmitter) Like sendIr, but sends the IR signal until stopped by stopIr.booleansendIrRepeat(org.harctoolbox.ircore.IrSignal irSignal, Transmitter transmitter) Like sendCcf, but continues the transmission until interrupted by a stopIr command.voidsendString(String cmd) Sends a command (a String) to the instance.voidsetBeginTimeout(int beginTimeout) voidsetCaptureMaxSize(int maxCaptureLength) voidsetDebug(int debug) Sets a debug parameter.voidsetEndingTimeout(int endingTimeout) voidsetFallbackFrequency(int fallbackFrequency) voidvoidsetLed(int led, boolean state) voidsetLineEnding(String lineEnding) voidsetParameter(String parameterName, int newValue) voidsetTimeout(int timeout) Deprecated.voidvoidsetUseReceiveForCapture(boolean val) voidsetVerbose(boolean verbose) Sets a verbosity flag, causing commands to be executed verbosely.booleanSignals the capturing device that it should stop capturing.booleanstopIr(Transmitter transmitter) Stops ongoing IR transmission.booleanSignals the receiving device that it should stop receiving.void
- 
Field Details- 
DEFAULT_BAUDpublic static final int DEFAULT_BAUD- See Also:
 
- 
DEFAULT_PORTpublic static final int DEFAULT_PORT- See Also:
 
 
- 
- 
Constructor Details- 
GirsClient- Throws:
- HarcHardwareException
- IOException
 
 
- 
- 
Method Details- 
newInstancepublic static GirsClient<TcpSocketPort> newInstance(InetAddress inetAddress, Integer portnumber, boolean verbose, Integer timeout) throws UnknownHostException, HarcHardwareException, IOException 
- 
newInstancepublic static GirsClient<LocalSerialPortBuffered> newInstance(String portName, boolean verbose, Integer timeout) throws IOException, HarcHardwareException - Throws:
- IOException
- HarcHardwareException
 
- 
expandIP
- 
setUseReceiveForCapture- Throws:
- HarcHardwareException
 
- 
setUseReceiveForCapturepublic void setUseReceiveForCapture()
- 
close- Specified by:
- closein interface- AutoCloseable
- Specified by:
- closein interface- Closeable
- Throws:
- IOException
 
- 
getVersionDescription copied from interface:IHarcHardwareReturns the hardware version (not the version of the driver software). May be null if no relevant information available.- Specified by:
- getVersionin interface- IHarcHardware
- Returns:
- Version string. Semantics can vary.
- Throws:
- IOException
 
- 
setVerbosepublic void setVerbose(boolean verbose) Description copied from interface:IHarcHardwareSets a verbosity flag, causing commands to be executed verbosely. Exact semantic depends on the implementation. Typically, all communication with the device is echoed to stderr.- Specified by:
- setVerbosein interface- IHarcHardware
- Parameters:
- verbose- on or off
 
- 
setDebugpublic void setDebug(int debug) Description copied from interface:IHarcHardwareSets a debug parameter. Exact semantic depends on the implementation.- Specified by:
- setDebugin interface- IHarcHardware
 
- 
setTimeoutDeprecated.Description copied from interface:IHarcHardwareSet timeout in milliseconds. Exact semantics may be dependent on the hardware.- Specified by:
- setTimeoutin interface- IHarcHardware
- Parameters:
- timeout- Timeout in milliseconds.
- Throws:
- IOException
- HarcHardwareException
 
- 
getBeginTimeout- Returns:
- the beginTimeout
 
- 
setBeginTimeout- Specified by:
- setBeginTimeoutin interface- IIrReader
- Parameters:
- beginTimeout- the beginTimeout to set
- Throws:
- IOException
- HarcHardwareException
 
- 
getMaxCaptureLengthpublic int getMaxCaptureLength()- Returns:
- the maxCaptureLength
 
- 
setCaptureMaxSize- Specified by:
- setCaptureMaxSizein interface- IIrReader
- Parameters:
- maxCaptureLength- the maxCaptureLength to set
- Throws:
- IOException
- HarcHardwareException
 
- 
getEndingTimeoutpublic int getEndingTimeout()- Returns:
- the endingTimeout
 
- 
setEndingTimeout- Specified by:
- setEndingTimeoutin interface- IIrReader
- Parameters:
- endingTimeout- the endingTimeout to set
- Throws:
- IOException
- HarcHardwareException
 
- 
setLineEnding- Parameters:
- lineEnding- the lineEnding to set
 
- 
isValidpublic boolean isValid()Description copied from interface:IHarcHardwareChecks validity of an instance. Exact meaning can vary.- Specified by:
- isValidin interface- IHarcHardware
- Returns:
- validity of the instance.
 
- 
getModules
- 
hasModule
- 
hasCaptureModulepublic boolean hasCaptureModule()
- 
hasTransmitModulepublic boolean hasTransmitModule()
- 
setFallbackFrequencypublic void setFallbackFrequency(int fallbackFrequency) - Parameters:
- fallbackFrequency- the fallbackFrequency to set
 
- 
sendIrpublic boolean sendIr(org.harctoolbox.ircore.IrSignal irSignal, int count, Transmitter transmitter) throws IOException, HarcHardwareException - Specified by:
- sendIrin interface- IRawIrSender
- Returns:
- if false, command failed.
- Throws:
- IOException
- NoSuchTransmitterException
- HarcHardwareException
 
- 
sendIrpublic boolean sendIr(org.harctoolbox.ircore.IrSignal irSignal, int count) throws IOException, HarcHardwareException - Throws:
- IOException
- HarcHardwareException
 
- 
openDescription copied from interface:IHarcHardwareOpens the device with previously set parameters.- Specified by:
- openin interface- IHarcHardware
- Throws:
- IOException
- HarcHardwareException
 
- 
waitForpublic void waitFor(String goal, String areUThere, int delay, int tries) throws IOException, HarcHardwareException - Throws:
- IOException
- HarcHardwareException
 
- 
capturepublic org.harctoolbox.ircore.ModulatedIrSequence capture() throws IOException, HarcHardwareException, org.harctoolbox.ircore.OddSequenceLengthExceptionDescription copied from interface:ICaptureListens to the device and returns a sequence. Requires the device to be previously opened. Should itself neither open or close the device.- Specified by:
- capturein interface- ICapture
- Returns:
- Captured sequence, or null by timeout.
- Throws:
- IOException
- HarcHardwareException- if the device is not in valid/open state.
- org.harctoolbox.ircore.OddSequenceLengthException
 
- 
stopCapturepublic boolean stopCapture()Description copied from interface:ICaptureSignals the capturing device that it should stop capturing. May not be implemented in all hardware.- Specified by:
- stopCapturein interface- ICapture
- Returns:
- status
 
- 
receiveDescription copied from interface:IReceiveListens to the device and returns a sequence. Requires the device to be previously opened. Should itself neither open or close the device.- Specified by:
- receivein interface- IReceive
- Returns:
- Captured sequence, or null by timeout.
- Throws:
- HarcHardwareException- if the device is not in valid/open state.
- IOException
 
- 
stopReceivepublic boolean stopReceive()Description copied from interface:IReceiveSignals the receiving device that it should stop receiving. May not be implemented in all hardware.- Specified by:
- stopReceivein interface- IReceive
- Returns:
- status
 
- 
reset- Throws:
- IOException
- HarcHardwareException
 
- 
sendStringDescription copied from interface:ICommandLineDeviceSends a command (a String) to the instance.- Specified by:
- sendStringin interface- ICommandLineDevice
- Parameters:
- cmd- Command string to be sent.
- Throws:
- IOException
- HarcHardwareException
 
- 
readStringDescription copied from interface:ICommandLineDeviceReads a line of text. A line is considered to be terminated by any one of a line feed ('\n'), a carriage return ('\r'), or a carriage return followed immediately by a linefeed.- Specified by:
- readStringin interface- ICommandLineDevice
- Returns:
- A String containing the contents of the line, not including any line-termination characters, or null if no input available.
- Throws:
- IOException
 
- 
readStringDescription copied from interface:ICommandLineDeviceReads a line of text. A line is considered to be terminated by any one of a line feed ('\n'), a carriage return ('\r'), or a carriage return followed immediately by a linefeed.- Specified by:
- readStringin interface- ICommandLineDevice
- Parameters:
- wait- if true, wait until something arrives, otherwise return null if nothing there.
- Returns:
- A String containing the contents of the line, not including any line-termination characters, or null if no input available.
- Throws:
- IOException
 
- 
readyDescription copied from interface:ICommandLineDeviceTells whether this stream is ready to be read. A buffered character stream is ready if the buffer is not empty, or if the underlying character stream is ready.- Specified by:
- readyin interface- ICommandLineDevice
- Returns:
- True if the next read() is guaranteed not to block for input, false otherwise. Note that returning false does not guarantee that the next read will block.
- Throws:
- IOException- If an I/O error occurs
 
- 
flushInput- Specified by:
- flushInputin interface- ICommandLineDevice
- Throws:
- IOException
 
- 
getTransmitterDescription copied from interface:IRawIrSenderReturns a default Transmitter for the device. May be null if the device ignores the Transmitter argument in sendIr.- Specified by:
- getTransmitterin interface- IRawIrSender
- Specified by:
- getTransmitterin interface- IRemoteCommandIrSender
- Specified by:
- getTransmitterin interface- ITransmitter
- Returns:
- Transmitter
 
- 
stopIrDescription copied from interface:IIrSenderStopStops ongoing IR transmission.- Specified by:
- stopIrin interface- IIrSenderStop
- Returns:
- if false, command failed.
- Throws:
- NoSuchTransmitterException
- IOException
 
- 
getTransmitterDescription copied from interface:ITransmitterParses the String argument, and returns a transmitter accordingly. Syntax and semantics may vary.- Specified by:
- getTransmitterin interface- ITransmitter
- Parameters:
- connector- String describing desired port. Syntax is dependent on the implementing class.
- Returns:
- Transmitter
- Throws:
- NoSuchTransmitterException
 
- 
getTransmitterNamesDescription copied from interface:ITransmitterReturn possible name of transmitters, that are guaranteed to work with the getTransmitter(String). This may be generated by inquiring the device, producing correct result, or it may be some static function, describing transmitters not necessarily present on the actually deployed device.- Specified by:
- getTransmitterNamesin interface- ITransmitter
- Returns:
- Array of strings that are guaranteed to work with the getTransmitter(String)
 
- 
sendIrRepeatpublic boolean sendIrRepeat(org.harctoolbox.ircore.IrSignal irSignal, Transmitter transmitter) throws NoSuchTransmitterException, IOException Description copied from interface:IRawIrSenderRepeatLike sendCcf, but continues the transmission until interrupted by a stopIr command. Particular implementations, or hardware, might limit the number of transmissions, though.- Specified by:
- sendIrRepeatin interface- IRawIrSenderRepeat
- Returns:
- if false, command failed.
- Throws:
- NoSuchTransmitterException
- IOException
 
- 
getRemotesDescription copied from interface:IRemoteCommandIrSenderReturns an array of "remote" names.- Specified by:
- getRemotesin interface- IRemoteCommandIrSender
- Returns:
- Throws:
- IOException
 
- 
getCommandsDescription copied from interface:IRemoteCommandIrSenderReturns an array of command names for the remote given in the argument.- Specified by:
- getCommandsin interface- IRemoteCommandIrSender
- Parameters:
- remote- The "remote" to search in
- Returns:
- Throws:
- IOException
 
- 
sendIrCommandpublic boolean sendIrCommand(String remote, String command, int count, Transmitter transmitter) throws IOException, NoSuchTransmitterException Description copied from interface:IRemoteCommandIrSenderSends the command to the hardware, to be sent count number of times.- Specified by:
- sendIrCommandin interface- IRemoteCommandIrSender
- count- Number of times to repeat the command
- Returns:
- success
- Throws:
- IOException
- NoSuchTransmitterException
 
- 
sendIrCommandRepeatpublic boolean sendIrCommandRepeat(String remote, String command, Transmitter transmitter) throws IOException, NoSuchTransmitterException Description copied from interface:IRemoteCommandIrSenderLike sendIr, but sends the IR signal until stopped by stopIr. An implementation, or a hardware, may limit the number of repeats though.- Specified by:
- sendIrCommandRepeatin interface- IRemoteCommandIrSender
- Returns:
- Throws:
- IOException
- NoSuchTransmitterException
 
- 
setLed- Throws:
- IOException
- HarcHardwareException
 
- 
setLcd- Throws:
- IOException
- HarcHardwareException
 
- 
getParameter- Throws:
- IOException
- HarcHardwareException
 
- 
setParameterpublic void setParameter(String parameterName, int newValue) throws IOException, HarcHardwareException - Throws:
- IOException
- HarcHardwareException
 
 
-