lensfun  0.3.99.0
Classes | Enumerations | Functions | Variables
Database functions

Create, destroy and search database for objects. More...

Classes

struct  lfDatabase
 A lens database object. More...
 

Enumerations

enum  { LF_SEARCH_LOOSE = 1 , LF_SEARCH_SORT_AND_UNIQUIFY = 2 }
 Flags controlling the behavior of database searches. More...
 

Functions

lfDatabaself_db_create (void)
 Create a new empty database object. More...
 
void lf_db_destroy (lfDatabase *db)
 Destroy the database object. More...
 
long int lf_db_read_timestamp (const char *dirname)
 
lfError lf_db_load (lfDatabase *db)
 
lfError lf_db_load_path (lfDatabase *db, const char *pathname)
 
lfError lf_db_load_str (lfDatabase *db, const char *xml, size_t data_size)
 
lfError lf_db_save_all (const lfDatabase *db, const char *filename)
 
lfError lf_db_save_str (const lfDatabase *db, char **xml, size_t *data_size)
 
const lfCamera ** lf_db_find_cameras (const lfDatabase *db, const char *maker, const char *model)
 
const lfCamera ** lf_db_find_cameras_ext (const lfDatabase *db, const char *maker, const char *model, int sflags)
 
const lfCamera *const * lf_db_get_cameras (lfDatabase *db)
 
const lfLens ** lf_db_find_lenses (const lfDatabase *db, const lfCamera *camera, const char *maker, const char *lens, int sflags)
 
const lfLens *const * lf_db_get_lenses (lfDatabase *db)
 
const lfMountlf_db_find_mount (const lfDatabase *db, const char *mount)
 
const char * lf_db_mount_name (const lfDatabase *db, const char *mount)
 
const lfMount *const * lf_db_get_mounts (lfDatabase *db)
 

Variables

const char *const lf_db_system_location
 
const char *const lf_db_system_updates_location
 
const char *const lf_db_user_location
 
const char *const lf_db_user_updates_location
 

Detailed Description

Create, destroy and search database for objects.

Enumeration Type Documentation

◆ anonymous enum

anonymous enum

Flags controlling the behavior of database searches.

Enumerator
LF_SEARCH_LOOSE 

This flag selects a looser search algorithm resulting in more results (still sorted by score).

If it is not present, all results where at least one of the input words is missing will be discarded.

LF_SEARCH_SORT_AND_UNIQUIFY 

This flag makes Lensfun to sort the results by focal length, and remove all double lens names.

If a lens has entries for different crop factors/aspect ratios, the only best match is included into the result. This is meant to be used to create a list presented to the user to pick a lens. Or, to lookup a lens for which you know maker and model exactly, and to check whether the result list really contains only one element.

Function Documentation

◆ lf_db_create()

lfDatabase* lf_db_create ( void  )

Create a new empty database object.

Usually the application will want to do this at startup, after which it would be a good idea to call lf_db_load().

Returns
A new empty database object.
See also
lfDatabase::lfDatabase

◆ lf_db_destroy()

void lf_db_destroy ( lfDatabase db)

Destroy the database object.

This is the only way to correctly destroy the database object.

Parameters
dbThe database to destroy.
See also
lfDatabase::~lfDatabase
Examples
example.c.

◆ lf_db_find_cameras()

const lfCamera** lf_db_find_cameras ( const lfDatabase db,
const char *  maker,
const char *  model 
)

◆ lf_db_find_cameras_ext()

const lfCamera** lf_db_find_cameras_ext ( const lfDatabase db,
const char *  maker,
const char *  model,
int  sflags 
)

◆ lf_db_find_lenses()

const lfLens** lf_db_find_lenses ( const lfDatabase db,
const lfCamera camera,
const char *  maker,
const char *  lens,
int  sflags 
)
See also
lfDatabase::FindLenses(const lfCamera *, const char *, const char *)

◆ lf_db_find_mount()

const lfMount* lf_db_find_mount ( const lfDatabase db,
const char *  mount 
)

◆ lf_db_get_cameras()

const lfCamera* const* lf_db_get_cameras ( lfDatabase db)

◆ lf_db_get_lenses()

const lfLens* const* lf_db_get_lenses ( lfDatabase db)
See also
lfDatabase::GetLenses
Examples
example.c.

◆ lf_db_get_mounts()

const lfMount* const* lf_db_get_mounts ( lfDatabase db)
See also
lfDatabase::GetMounts
Examples
example.c.

◆ lf_db_load()

lfError lf_db_load ( lfDatabase db)
See also
lfDatabase::Load()
Examples
example.c.

◆ lf_db_load_path()

lfError lf_db_load_path ( lfDatabase db,
const char *  pathname 
)

◆ lf_db_load_str()

lfError lf_db_load_str ( lfDatabase db,
const char *  xml,
size_t  data_size 
)

◆ lf_db_mount_name()

const char* lf_db_mount_name ( const lfDatabase db,
const char *  mount 
)
See also
lfDatabase::MountName
Examples
example.c, and tfun.cpp.

◆ lf_db_read_timestamp()

long int lf_db_read_timestamp ( const char *  dirname)

◆ lf_db_save_all()

lfError lf_db_save_all ( const lfDatabase db,
const char *  filename 
)
See also
lfDatabase::Save(const char *)

◆ lf_db_save_str()

lfError lf_db_save_str ( const lfDatabase db,
char **  xml,
size_t *  data_size 
)
See also
lfDatabase::Save(char*& xml, size_t& data_size)

Variable Documentation

◆ lf_db_system_location

const char* const lf_db_system_location
extern

◆ lf_db_system_updates_location

const char* const lf_db_system_updates_location
extern

◆ lf_db_user_location

const char* const lf_db_user_location
extern

◆ lf_db_user_updates_location

const char* const lf_db_user_updates_location
extern