com.pi4j.io.IO Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pi4j-core Show documentation
Show all versions of pi4j-core Show documentation
Pi4J Java API & Runtime Library
The newest version!
package com.pi4j.io;
/*-
* #%L
* **********************************************************************
* ORGANIZATION : Pi4J
* PROJECT : Pi4J :: LIBRARY :: Java Library (CORE)
* FILENAME : IO.java
*
* This file is part of the Pi4J project. More information about
* this project can be found here: https://pi4j.com/
* **********************************************************************
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* #L%
*/
import com.pi4j.common.Describable;
import com.pi4j.common.Identity;
import com.pi4j.common.Lifecycle;
import com.pi4j.provider.Provider;
/**
* IO interface.
*
* @author Robert Savage (http://www.savagehomeautomation.com)
* @version $Id: $Id
*/
public interface IO
extends Describable, Lifecycle, Identity {
/**
* config.
*
* @return a CONFIG_TYPE object.
*/
CONFIG_TYPE config();
/**
* type.
*
* @return a {@link com.pi4j.io.IOType} object.
*/
default IOType type() { return IOType.getByIOClass(this.getClass()); }
// TODO :: RECONCILE IDENTITY PROPERTIES BETWEEN IO INSTANCE AND UNDERLYING CONFIG; PROBABLY NEED TO REMOVE THESE SETTERS
/**
* name.
*
* @param name a {@link java.lang.String} object.
* @return a IO_TYPE object.
*/
IO_TYPE name(String name);
/**
* description.
*
* @param description a {@link java.lang.String} object.
* @return a IO_TYPE object.
*/
IO_TYPE description(String description);
/**
* provider.
*
* @return a PROVIDER_TYPE object.
*/
PROVIDER_TYPE provider();
}