jaulib v1.3.0
Jau Support Library (C++, Java, ..)
IOStateFunc.java
Go to the documentation of this file.
1/**
2 * Author: Sven Gothel <sgothel@jausoft.com>
3 * Copyright (c) 2022-2023 Gothel Software e.K.
4 *
5 * Permission is hereby granted, free of charge, to any person obtaining
6 * a copy of this software and associated documentation files (the
7 * "Software"), to deal in the Software without restriction, including
8 * without limitation the rights to use, copy, modify, merge, publish,
9 * distribute, sublicense, and/or sell copies of the Software, and to
10 * permit persons to whom the Software is furnished to do so, subject to
11 * the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be
14 * included in all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
23 */
24package org.jau.io;
25
26/**
27 * Supporting std::basic_ios's iostate functionality for all ByteInStream implementations.
28 */
29public interface IOStateFunc {
30
31 /** Clears state flags by assignment to the given value. */
32 void clear(final IOState state);
33
34 /**
35 * Returns the current state flags.
36 *
37 * Method is marked `virtual` to allow implementations with asynchronous resources
38 * to determine or update the current iostate.
39 *
40 * Method is used throughout all query members and setstate(),
41 * hence they all will use the updated state from a potential override implementation.
42 */
44
45 /** Sets state flags, by keeping its previous bits. */
46 void setState(final IOState state);
47
48 /** Checks if no error nor eof() has occurred i.e. I/O operations are available. */
49 boolean good();
50
51 /** Checks if end-of-file has been reached. */
52 boolean eof();
53
54 /** Checks if an error has occurred. */
55 boolean fail();
56
57 /** Checks if a non-recoverable error has occurred. */
58 boolean bad();
59
60 /** Checks if a timeout (non-recoverable) has occurred. */
61 boolean timeout();
62}
Mimic std::ios_base::iostate for state functionality, see iostate_func.
Definition: IOState.java:33
Supporting std::basic_ios's iostate functionality for all ByteInStream implementations.
void clear(final IOState state)
Clears state flags by assignment to the given value.
boolean fail()
Checks if an error has occurred.
boolean bad()
Checks if a non-recoverable error has occurred.
void setState(final IOState state)
Sets state flags, by keeping its previous bits.
IOState rdState()
Returns the current state flags.
boolean good()
Checks if no error nor eof() has occurred i.e.
boolean timeout()
Checks if a timeout (non-recoverable) has occurred.
boolean eof()
Checks if end-of-file has been reached.