/* model-info.h -- per model information objects and cache
* Copyright (C) 2010 SEIKO EPSON CORPORATION
*
* License: GPLv2+|iscan
* Authors: AVASYS CORPORATION
*
* This file is part of the SANE backend distributed with Image Scan!
*
* Image Scan!'s SANE backend 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 2 of the License or at your option any later version.
*
* This program 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 ought to have received a copy of the GNU General Public License
* along with this package. If not, see .
*
*
* Linking Image Scan!'s SANE backend statically or dynamically with
* other modules is making a combined work based on this SANE backend.
* Thus, the terms and conditions of the GNU General Public License
* cover the whole combination.
*
* As a special exception, the copyright holders of Image Scan!'s SANE
* backend give you permission to link Image Scan!'s SANE backend with
* SANE frontends that communicate with Image Scan!'s SANE backend
* solely through the SANE Application Programming Interface,
* regardless of the license terms of these SANE frontends, and to
* copy and distribute the resulting combined work under terms of your
* choice, provided that every copy of the combined work is
* accompanied by a complete copy of the source code of Image Scan!'s
* SANE backend (the version of Image Scan!'s SANE backend used to
* produce the combined work), being distributed under the terms of
* the GNU General Public License plus this exception. An independent
* module is a module which is not derived from or based on Image
* Scan!'s SANE backend.
*
* As a special exception, the copyright holders of Image Scan!'s SANE
* backend give you permission to link Image Scan!'s SANE backend with
* independent modules that communicate with Image Scan!'s SANE
* backend solely through the "Interpreter" interface, regardless of
* the license terms of these independent modules, and to copy and
* distribute the resulting combined work under terms of your choice,
* provided that every copy of the combined work is accompanied by a
* complete copy of the source code of Image Scan!'s SANE backend (the
* version of Image Scan!'s SANE backend used to produce the combined
* work), being distributed under the terms of the GNU General Public
* License plus this exception. An independent module is a module
* which is not derived from or based on Image Scan!'s SANE backend.
*
* Note that people who make modified versions of Image Scan!'s SANE
* backend are not obligated to grant special exceptions for their
* modified versions; it is their choice whether to do so. The GNU
* General Public License gives permission to release a modified
* version without this exception; this exception also makes it
* possible to release a modified version which carries forward this
* exception.
*/
#ifndef model_info_h_included
#define model_info_h_included
/*! \file
* \brief Model specific information.
*
* There is a fair bit of device information that does not change
* during the life-time of the device. The ESC/I scanner protocol
* provides support to query the device to get a significant part of
* this information. However, some of the information we would like
* to use is not available from the device. In addition, the device
* sometimes returns incorrect information.
*
* For a long time we have been working around this by putting the
* additional information and the corrections directly in our code.
* The model info support provided here implements a unified API to
* the device information allowing us to move it out of the code and
* into per model resource files.
*
* The API aims for on-demand, cached data retrieval. In order to
* support that, the sane_init() and sane_exit() functions need to
* handle cache initialisation and clean-up. They can do so through
* the model_info_cache_init() and model_cache_exit() functions.
*
* The sane_get_devices() and sane_open() functions can get access to
* per model information through the model_info_cache_get_info() API
* and use its return value in calls to the model info accessors. Of
* course, other SANE API entries may do so as well, though we cannot
* think of a good need for them to do so (as the information can be
* stored in the SANE_Handle during sane_open()).
*
* The number of model info accessors is still quite limited but we
* expect that to change when the implementation proceeds.
*
* There is also convenience API meant to make initialisation of the
* SANE_Device structure marginally less verbose.
*/
#include
#include
#include "defines.h"
#include "device.h"
#ifdef __cplusplus
extern "C"
{
#endif
struct ScanArea
{
SANE_Fixed width;
SANE_Fixed height;
};
typedef struct ScanArea scan_area_t;
/* Model info cache creation and destruction */
void * model_info_cache_init (const char *pkgdatadir, SANE_Status *status);
void * model_info_cache_exit (void *self);
/* Model info cache accessors */
const void * model_info_cache_get_info (const char *fw_name,
SANE_Status *status);
/* Model info cache convenience methods */
char * model_info_cache_get_model (const char *fw_name);
/* ?FIXME? add convenience methods for vendor and type? */
/* Model info accessors */
const char * model_info_get_name (const void *self);
const EpsonScanHard model_info_get_profile (const void *self);
bool model_info_customise_commands (const void *self, EpsonCmd cmd);
bool model_info_has_lock_commands (const void *self);
scan_area_t model_info_max_scan_area(const void *self, const char *option, const char *mode);
/* :FIXME: add more accessors */
#ifdef __cplusplus
} /* extern "C" */
#endif
#endif /* !defined (model_info_h_included) */