/**
* jlibgamma — Display server abstraction layer for gamma ramp and Java
* Copyright © 2014 Mattias Andrée (maandree@member.fsf.org)
*
* This library is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This library 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this library. If not, see <http://www.gnu.org/licenses/>.
*/
package libgamma;
/**
* <p>
* Class of <tt>libgamma</tt> exceptions including
* native system exceptions.
* </p>
* <p>
* The class contains constants with <tt>libgamma</tt> error
* codes. It does however not contain system error codes.
* </p>
*/
@SuppressWarnings("serial")
public class LibgammaException extends Exception
{
/**
* Type initialiser.
*/
static
{
Libgamma.initialise();
}
/**
* This error code is never used. It is only provided
* so you know its error code if you plan to iterate
* over all <tt>libgamma</tt> error codes.
*/
public static final int LIBGAMMA_ERRNO_SET = -1;
/**
* The selected adjustment method does not exist
* or has been excluded at compile-time.
*/
public static final int LIBGAMMA_NO_SUCH_ADJUSTMENT_METHOD = -2;
/**
* The selected site does not exist.
*/
public static final int LIBGAMMA_NO_SUCH_SITE = -3;
/**
* The selected partition does not exist.
*/
public static final int LIBGAMMA_NO_SUCH_PARTITION = -4;
/**
* The selected CRTC does not exist.
*/
public static final int LIBGAMMA_NO_SUCH_CRTC = -5;
/**
* Counter overflowed when counting the number
* of available items.
*/
public static final int LIBGAMMA_IMPOSSIBLE_AMOUNT = -6;
/**
* The selected connector is disabled, it does
* not have a CRTC.
*/
public static final int LIBGAMMA_CONNECTOR_DISABLED = -7;
/**
* The selected CRTC could not be opened,
* reason unknown.
*/
public static final int LIBGAMMA_OPEN_CRTC_FAILED = -8;
/**
* The CRTC information field is not supported
* by the adjustment method.
*/
public static final int LIBGAMMA_CRTC_INFO_NOT_SUPPORTED = -9;
/**
* Failed to read the current gamma ramps for
* the selected CRTC, reason unknown.
*/
public static final int LIBGAMMA_GAMMA_RAMP_READ_FAILED = -10;
/**
* Failed to write the current gamma ramps for
* the selected CRTC, reason unknown.
*/
public static final int LIBGAMMA_GAMMA_RAMP_WRITE_FAILED = -11;
/**
* The specified ramp sizes does not match the
* ramps sizes returned by the adjustment methods
* in response to the query/command.
*/
public static final int LIBGAMMA_GAMMA_RAMP_SIZE_CHANGED = -12;
/**
* The specified ramp sizes are not identical
* which is required by the adjustment method.
* (Only returned in debug mode.)
*/
public static final int LIBGAMMA_MIXED_GAMMA_RAMP_SIZE = -13;
/**
* The specified ramp sizes are not supported
* by the adjustment method.
* (Only returned in debug mode.)
*/
public static final int LIBGAMMA_WRONG_GAMMA_RAMP_SIZE = -14;
/**
* The adjustment method reported that the gamma
* ramps size is 1, or perhaps even zero or negative.
*/
public static final int LIBGAMMA_SINGLETON_GAMMA_RAMP = -15;
/**
* The adjustment method failed to list
* available CRTC:s, reason unknown.
*/
public static final int LIBGAMMA_LIST_CRTCS_FAILED = -16;
/**
* Failed to acquire mode resources from the
* adjustment method.
*/
public static final int LIBGAMMA_ACQUIRING_MODE_RESOURCES_FAILED = -17;
/**
* The adjustment method reported that a negative
* number of partitions exists in the site.
*/
public static final int LIBGAMMA_NEGATIVE_PARTITION_COUNT = -18;
/**
* The adjustment method reported that a negative
* number of CRTC:s exists in the partition.
*/
public static final int LIBGAMMA_NEGATIVE_CRTC_COUNT = -19;
/**
* Device cannot be access becauses of
* insufficient permissions.
*/
public static final int LIBGAMMA_DEVICE_RESTRICTED = -20;
/**
* Device cannot be access, reason unknown.
*/
public static final int LIBGAMMA_DEVICE_ACCESS_FAILED = -21;
/**
* Device cannot be access, membership of the
* {@link #group_gid} (named by {@link #group_name}
* (can be {@code null}, if so <tt>errno</tt> may have
* been set to tell why)) is required.
*/
public static final int LIBGAMMA_DEVICE_REQUIRE_GROUP = -22;
/**
* The graphics card appear to have been removed.
*/
public static final int LIBGAMMA_GRAPHICS_CARD_REMOVED = -23;
/**
* The state of the requested information is unknown.
*/
public static final int LIBGAMMA_STATE_UNKNOWN = -24;
/**
* Failed to determine which connector the
* CRTC belongs to.
*/
public static final int LIBGAMMA_CONNECTOR_UNKNOWN = -25;
/**
* The detected connector type is not listed
* in this library and has to be updated.
*/
public static final int LIBGAMMA_CONNECTOR_TYPE_NOT_RECOGNISED = -26;
/**
* The detected subpixel order is not listed
* in this library and has to be updated.
*/
public static final int LIBGAMMA_SUBPIXEL_ORDER_NOT_RECOGNISED = -27;
/**
* The length of the EDID does not match that
* of any supported EDID structure revision.
*/
public static final int LIBGAMMA_EDID_LENGTH_UNSUPPORTED = -28;
/**
* The magic number in the EDID does not match
* that of any supported EDID structure revision.
*/
public static final int LIBGAMMA_EDID_WRONG_MAGIC_NUMBER = -29;
/**
* The EDID structure revision used by the
* mointor is not supported.
*/
public static final int LIBGAMMA_EDID_REVISION_UNSUPPORTED = -30;
/**
* The gamma characteristics field in the EDID
* is left unspecified.
* (This could be considered a non-error.)
*/
public static final int LIBGAMMA_GAMMA_NOT_SPECIFIED = -31;
/**
* The checksum in the EDID is incorrect, all
* request information has been provided
* by you cannot count on it.
*/
public static final int LIBGAMMA_EDID_CHECKSUM_ERROR = -32;
/**
* Both of the errors {@link #LIBGAMMA_GAMMA_NOT_SPECIFIED}
* and {@link #LIBGAMMA_EDID_CHECKSUM_ERROR} have occurred.
*/
public static final int LIBGAMMA_GAMMA_NOT_SPECIFIED_AND_EDID_CHECKSUM_ERROR = -33;
/**
* Failed to query the gamma ramps size from the
* adjustment method, reason unknown.
*/
public static final int LIBGAMMA_GAMMA_RAMPS_SIZE_QUERY_FAILED = -34;
/**
* The selected partition could not be opened,
* reason unknown.
*/
public static final int LIBGAMMA_OPEN_PARTITION_FAILED = -35;
/**
* The selected site could not be opened,
* reason unknown.
*/
public static final int LIBGAMMA_OPEN_SITE_FAILED = -36;
/**
* Failed to query the adjustment method for
* its protocol version, reason unknown.
*/
public static final int LIBGAMMA_PROTOCOL_VERSION_QUERY_FAILED = -37;
/**
* The adjustment method's version of its
* protocol is not supported.
*/
public static final int LIBGAMMA_PROTOCOL_VERSION_NOT_SUPPORTED = -38;
/**
* The adjustment method failed to list
* available partitions, reason unknown.
*/
public static final int LIBGAMMA_LIST_PARTITIONS_FAILED = -39;
/**
* Partition exists by index, but the partition
* at that index does not exist.
*/
public static final int LIBGAMMA_NULL_PARTITION = -40;
/**
* There is not mointor connected to the
* connector of the selected CRTC.
*/
public static final int LIBGAMMA_NOT_CONNECTED = -41;
/**
* Data extraction from a reply from the
* adjustment method failed, reason unknown.
*/
public static final int LIBGAMMA_REPLY_VALUE_EXTRACTION_FAILED = -42;
/**
* No EDID property was found on the output.
*/
public static final int LIBGAMMA_EDID_NOT_FOUND = -43;
/**
* Failed to list properties on the output,
* reason unknown.
*/
public static final int LIBGAMMA_LIST_PROPERTIES_FAILED = -44;
/**
* Failed to query a property's value from
* the output, reason unknown.
*/
public static final int LIBGAMMA_PROPERTY_VALUE_QUERY_FAILED = -45;
/**
* A request for information on an output
* failed, reason unknown.
*/
public static final int LIBGAMMA_OUTPUT_INFORMATION_QUERY_FAILED = -46;
/**
* The number of the libgamma error with the
* lowest number. If this is lower than the
* number your program thinks it should be sould
* update your program for new errors.
*/
public static final int LIBGAMMA_ERROR_MIN = -46;
/**
* Constructor.
*
* @param error_code The error code.
*/
public LibgammaException(int error_code)
{
this.error_code = error_code;
if (error_code == LIBGAMMA_DEVICE_REQUIRE_GROUP)
{ this.group_gid = libgamma_group_gid();
this.group_name = libgamma_group_name();
}
else
{ this.group_gid = 0;
this.group_name = null;
}
if (error_code < 0)
this.string = name_of_error(error_code);
else
this.string = strerror(error_code);
}
/**
* The error code.
* Cannot be {@link #LIBGAMMA_ERRNO_SET}.
*/
public final int error_code;
/**
* Group that the user needs to be a member of if
* {@link #error_code} is {@link #LIBGAMMA_DEVICE_REQUIRE_GROUP}.
*/
public final int group_gid;
/**
* Group that the user needs to be a member of if
* {@link #error_code} is {@link #LIBGAMMA_DEVICE_REQUIRE_GROUP},
* {@code null} if the name of the group {@link #group_gid}
* cannot be determined.
*/
public final String group_name;
/**
* Name of textual description of the error.
*/
public final String string;
/**
* {@inheritDoc}
*/
@Override
public String toString()
{
return this.string;
}
/**
* Returns the name of the definition associated with
* a <tt>libgamma</tt> error code.
*
* @param value The error code.
* @return The name of the definition associated with the error code,
* {@code null} if the error code does not exist.
*/
public static native String name_of_error(int value);
/**
* Return the value of a <tt>libgamma</tt> error definition
* refered to by name.
*
* @param name The name of the definition associated with the error code.
* @return The error code, zero if the name is {@code null}
* or does not refer to a <tt>libgamma</tt> error.
*/
public static native int value_of_error(String name);
/**
* Acquire the value that should go to {@link #group_gid}.
*
* @return The value that should go to {@link #group_gid}.
*/
private static native int libgamma_group_gid();
/**
* Acquire the value that should go to {@link #group_name}.
*
* @return The value that should go to {@link #group_name}.
*/
private static native String libgamma_group_name();
/**
* Get a textual description of a system error code.
*
* @param error_code The error code.
* @return A textual description of the error code.
*/
private static native String strerror(int error_code);
}