Oyranos Color Management System API
Public Member Functions | Data Fields
oyOptions_s Struct Reference

generic Options More...

#include <oyOptions_s.h>

Inheritance diagram for oyOptions_s:
Inheritance graph
Collaboration diagram for oyOptions_s:
Collaboration graph

Public Member Functions

OYAPI oyOptions_s *OYEXPORT oyOptions_New (oyObject_s object)
 allocate a new Options object More...
 
OYAPI oyOptions_s *OYEXPORT oyOptions_Copy (oyOptions_s *options, oyObject_s object)
 copy or reference a Options object More...
 
OYAPI int OYEXPORT oyOptions_Release (oyOptions_s **options)
 release and possibly deallocate a oyOptions_s object More...
 
OYAPI int OYEXPORT oyOptions_MoveIn (oyOptions_s *list, oyOption_s **obj, int pos)
 add an element to a Options list More...
 
OYAPI int OYEXPORT oyOptions_ReleaseAt (oyOptions_s *list, int pos)
 release a element from a Options list More...
 
OYAPI oyOption_s *OYEXPORT oyOptions_Get (oyOptions_s *list, int pos)
 get a element of a Options list More...
 
OYAPI int OYEXPORT oyOptions_Count (oyOptions_s *list)
 count the elements in a Options list More...
 
OYAPI int OYEXPORT oyOptions_Clear (oyOptions_s *list)
 clear the elements in a Options list More...
 
OYAPI int OYEXPORT oyOptions_Sort (oyOptions_s *list, int32_t *rank_list)
 sort a list according to a rank_list More...
 
oyOptions_soyOptions_FromBoolean (oyOptions_s *set_a, oyOptions_s *set_b, oyBOOLEAN_e type, oyObject_s object)
 boolean operations on two sets of option More...
 
oyOptions_soyOptions_FromText (const char *text, uint32_t flags, oyObject_s object)
 deserialise a text file to oyOptions_s data More...
 
int oyOptions_Add (oyOptions_s *options, oyOption_s *option, int pos, oyObject_s object)
 add a element to a Options list More...
 
int oyOptions_Set (oyOptions_s *options, oyOption_s *option, int pos, oyObject_s object)
 set a element in a Options list More...
 
int oyOptions_SetOpts (oyOptions_s *list, oyOptions_s *add)
 set options in a Options list More...
 
int oyOptions_AppendOpts (oyOptions_s *list, oyOptions_s *append)
 Basic reference options from one list into an other. More...
 
int oyOptions_CopyFrom (oyOptions_s **list, oyOptions_s *from, oyBOOLEAN_e type, oyFILTER_REG_e fields, oyObject_s object)
 copy from one option set to an other option set More...
 
int oyOptions_Filter (oyOptions_s **add_list, int32_t *count, uint32_t flags, oyBOOLEAN_e type, const char *registration, oyOptions_s *src_list)
 filter options More...
 
const char * oyOptions_GetText (oyOptions_s *options, oyNAME_e type)
 dump options to text More...
 
int oyOptions_CountType (oyOptions_s *options, const char *registration, oyOBJECT_e type)
 search for options with special attributes More...
 
oyOption_soyOptions_Find (oyOptions_s *options, const char *registration)
 search for a certain option key More...
 
const char * oyOptions_FindString (oyOptions_s *options, const char *registration, const char *value)
 search for a certain option key and possibly value More...
 
int oyOptions_SetFromText (oyOptions_s **obj, const char *registration, const char *value, uint32_t flags)
 change a value More...
 
int oyOptions_FindInt (oyOptions_s *options, const char *registration, int pos, int32_t *result)
 get a value More...
 
int oyOptions_SetFromInt (oyOptions_s **obj, const char *registration, int32_t value, int pos, uint32_t flags)
 change a value More...
 
int oyOptions_FindDouble (oyOptions_s *options, const char *registration, int pos, double *result)
 get a value More...
 
int oyOptions_SetFromDouble (oyOptions_s **obj, const char *registration, double value, int pos, uint32_t flags)
 change a value More...
 
oyStruct_soyOptions_GetType (oyOptions_s *options, int pos, const char *registration, oyOBJECT_e type)
 select from options with special attribute More...
 
int oyOptions_MoveInStruct (oyOptions_s **obj, const char *registration, oyStruct_s **oy_struct, uint32_t flags)
 change a value More...
 
int oyOptions_SetFromData (oyOptions_s **options, const char *registration, oyPointer ptr, size_t size, uint32_t flags)
 set a data blob or plain pointer More...
 
int oyOptions_FindData (oyOptions_s *options, const char *registration, oyPointer *result, size_t *size, oyAlloc_f allocateFunc)
 get a value More...
 
int oyOptions_SetSource (oyOptions_s *options, oyOPTIONSOURCE_e source)
 set source attribute More...
 
OYAPI int OYEXPORT oyOptions_ObserverAdd (oyOptions_s *object, oyStruct_s *observer, oyStruct_s *user_data, oyObserver_Signal_f signalFunc)
 observe options and its elements More...
 
OYAPI int OYEXPORT oyOptions_ObserversDisable (oyOptions_s *object)
 disable signaling More...
 
OYAPI int OYEXPORT oyOptions_ObserversEnable (oyOptions_s *object)
 disable signaling More...
 
OYAPI int OYEXPORT oyOptions_SetDriverContext (oyOptions_s **options, oyPointer driver_context, const char *driver_context_type, size_t driver_context_size, oyObject_s object)
 set a device option from a given external context More...
 
oyOptions_soyOptions_ForFilter (const char *registration, const char *cmm, uint32_t flags, oyObject_s object)
 provide Oyranos behaviour settings More...
 
oyOptions_soyOptions_ForFilter_ (oyFilterCore_s_ *filter, uint32_t flags, oyObject_s object)
 Provide Oyranos behaviour settings. More...
 
OYAPI int OYEXPORT oyOptions_SaveToDB (oyOptions_s *options, const char *registration, char **new_reg, oyAlloc_f allocateFunc)
 store a oyOptions_s in DB More...
 
int oyOptions_DoFilter (oyOptions_s *opts, uint32_t flags, const char *filter_type)
 filter the options More...
 
- Public Member Functions inherited from oyStruct_s
const char * oyStruct_GetTextFromModule (oyStruct_s *obj, oyNAME_e name_type, uint32_t flags)
 get object infos from a module More...
 
const char * oyStruct_GetText (oyStruct_s *obj, oyNAME_e name_type, uint32_t flags)
 get a text dump More...
 

Data Fields

const oyOBJECT_e type_
 Type of object. More...
 
oyStruct_Copy_f copy
 Copy function. More...
 
oyStruct_Release_f release
 Release function. More...
 
oyObject_s oy_
 Oyranos internal object. More...
 
- Data Fields inherited from oyStruct_s
const oyOBJECT_e type_
 Type of object. More...
 
oyStruct_Copy_f copy
 Copy function. More...
 
oyStruct_Release_f release
 Release function. More...
 
oyObject_s oy_
 Oyranos internal object. More...
 

Detailed Description

generic Options

Options can be any flag or rendering intent and other informations needed to configure a process. The object contains a list of oyOption_s objects.

Note
This class holds a list of objects [list]
Version
Oyranos: x.x.x
Since
YYYY/MM/DD (Oyranos: x.x.x)
Date
YYYY/MM/DD

Member Function Documentation

◆ oyOptions_Add()

int oyOptions_Add ( oyOptions_s options,
oyOption_s option,
int  pos,
oyObject_s  object 
)

add a element to a Options list

Function oyOptions_Add

We must not add any already listed option. (oyFILTER_REG_TOP)

Adding a new element without any checks is as simple as following code:

*     tmp = oyOption_Copy( option, object );
*     oyOptions_MoveIn( options, &tmp, -1 ); 
Version
Oyranos: 0.1.9
Since
2008/11/17 (Oyranos: 0.1.9)
Date
2010/11/27

References oyFilterRegistrationToText().

Referenced by oyOptions_Filter().

◆ oyOptions_AppendOpts()

int oyOptions_AppendOpts ( oyOptions_s list,
oyOptions_s append 
)

Basic reference options from one list into an other.

Function oyOptions_AppendOpts

See also
oyOptions_MoveIn
Version
Oyranos:
Since
Date

References oyOptions_Count(), oyOptions_Get(), and oyOptions_MoveIn().

Referenced by oyConfig_s::oyConfig_Count(), oyConfig_s::oyConfig_Get(), and oyConfig_s::oyConfig_SaveToDB().

◆ oyOptions_Clear()

OYAPI int OYEXPORT oyOptions_Clear ( oyOptions_s list)

clear the elements in a Options list

Function oyOptions_Clear

Parameters
[in,out]listthe list
Returns
0 - success; otherwise - error
Version
Oyranos: 0.3.0
Since
2011/02/01 (Oyranos: 0.3.0)
Date
2011/02/01

References oyOBJECT_OPTIONS_S, and oyStructList_s::oyStructList_Clear().

Referenced by oyConfig_s::oyConfig_GetOptions(), and oyProfiles_s::oyProfiles_DeviceRank().

◆ oyOptions_Copy()

OYAPI oyOptions_s *OYEXPORT oyOptions_Copy ( oyOptions_s options,
oyObject_s  object 
)

copy or reference a Options object

Function oyOptions_Copy

The function is for copying and for referencing. The reference is the most often used way, which saves resourcs and time.

Parameters
[in]optionsOptions struct object
objectNULL - means reference, the optional object triggers a real copy

References oyOBJECT_OPTIONS_S.

Referenced by oyConfig_s::oyConfig_GetFromDB(), oyConfigs_s::oyConfigs_FromDeviceClass(), oyFilterGraph_s::oyFilterGraph_GetOptions(), oyFilterNode_s::oyFilterNode_GetOptions(), oyFilterNode_s::oyFilterNode_GetTags(), oyImage_s::oyImage_GetTags(), oyImage_s::oyImage_SetCritical(), and oyPixelAccess_s::oyPixelAccess_GetRequestQueue().

◆ oyOptions_CopyFrom()

int oyOptions_CopyFrom ( oyOptions_s **  list,
oyOptions_s from,
oyBOOLEAN_e  type,
oyFILTER_REG_e  fields,
oyObject_s  object 
)

copy from one option set to an other option set

Function oyOptions_CopyFrom

Parameters
[out]listtarget
[in]fromsource
typeboolean operation before copy
fieldsregistration fields of each option
objectthe optional object
Returns
0 - success; 1 - error; -1 issue
Version
Oyranos: 0.1.10
Since
2009/05/05 (Oyranos: 0.1.10)
Date
2009/10/25

References oyBOOLEAN_DIFFERENZ, oyBOOLEAN_INTERSECTION, oyBOOLEAN_SUBSTRACTION, oyBOOLEAN_UNION, oyFilterRegistrationMatch(), oyFilterRegistrationToText(), oyOption_s::oyOption_Release(), oyOptions_Count(), oyOptions_Get(), oyOptions_MoveIn(), oyOptions_New(), oyOptions_Release(), oyOptions_SetOpts(), oyStructList_s::oyStructList_New(), and oyStructList_s::oyStructList_Release().

Referenced by oyFilterPlug_s::oyFilterPlug_ResolveImage(), and oyImage_ToFile().

◆ oyOptions_Count()

OYAPI int OYEXPORT oyOptions_Count ( oyOptions_s list)

◆ oyOptions_CountType()

int oyOptions_CountType ( oyOptions_s options,
const char *  registration,
oyOBJECT_e  type 
)

search for options with special attributes

Function oyOptions_CountType

Version
Oyranos: 0.1.10
Since
2009/03/04 (Oyranos: 0.1.10)
Date
2009/03/04

References oyFilterRegistrationMatch(), oyOBJECT_OPTIONS_S, oyOption_s::oyOption_Release(), oyOptions_Count(), oyOptions_Get(), and oyVAL_STRUCT.

◆ oyOptions_DoFilter()

int oyOptions_DoFilter ( oyOptions_s opts,
uint32_t  flags,
const char *  filter_type 
)

filter the options

Function oyOptions_DoFilter

The returned options are read in from the Elektra settings and if thats not available from the inbuild defaults. The later can explicitely selected with oyOPTIONSOURCE_FILTER passed as flags argument. advanced options can be filtered out by adding oyOPTIONATTRIBUTE_ADVANCED.

Modules should handle the advanced options as well but shall normally not act upon them. The convention to set them zero, keeps them inactive.

On the front end side the CMM cache has to include them, as they will influence the hash sum generation. The question arrises, whether to include these options marked as non visible along the path or require the CMM cache code to check each time for them on cache lookup. The oyOption_s::flags is already in place. So we use it and do inclusion. Front end options can be filtered as they do not affect the CMM cache.

See also
oyOptions_Add
Parameters
optsthe options
[in]flagsfor inbuild defaults | oyOPTIONSOURCE_FILTER; for options marked as advanced | oyOPTIONATTRIBUTE_ADVANCED; for front end options | oyOPTIONATTRIBUTE_FRONT
filter_typethe type level from a registration
Returns
options
Version
Oyranos: 0.1.9
Since
2008/11/27 (Oyranos: 0.1.9)
Date
2008/11/27

References oyFILTER_REG_TYPE, oyFilterRegistrationToText(), oyOption_s::oyOption_GetRegistration(), oyOption_s::oyOption_SetFromText(), oyOPTIONATTRIBUTE_ADVANCED, oyOPTIONATTRIBUTE_FRONT, oyOptions_Count(), oyOptions_Get(), and oyOptions_New().

◆ oyOptions_Filter()

int oyOptions_Filter ( oyOptions_s **  add_list,
int32_t *  count,
uint32_t  flags,
oyBOOLEAN_e  type,
const char *  registration,
oyOptions_s src_list 
)

filter options

Function oyOptions_Filter

Each option added to the add_list is a cheaply linked one.

See also
oyOptions_Add
Parameters
[out]add_listthe options list to add to
[out]countthe number of matching options
[in]flagsfor inbuild defaults | oyOPTIONSOURCE_FILTER
[in]typesupport are oyBOOLEAN_INTERSECTION and oyBOOLEAN_DIFFERENZ
[in]registrationa registration which shall be matched
[in]src_listthe options to select from
Returns
0 - success; 1 - error
Version
Oyranos: 0.1.10
Since
2009/05/05 (Oyranos: 0.1.10)
Date
2009/05/05

References oyBOOLEAN_DIFFERENZ, oyBOOLEAN_INTERSECTION, oyBOOLEAN_UNION, oyFilterRegistrationMatch(), oyOBJECT_OPTIONS_S, oyOption_s::oyOption_Release(), oyOptions_Add(), oyOptions_Count(), oyOptions_Get(), oyOptions_New(), oyOPTIONSOURCE_DATA, oyOPTIONSOURCE_FILTER, and oyOPTIONSOURCE_USER.

Referenced by oyFilterNode_s::oyFilterNode_GetOptions(), oyFilterPlug_s::oyFilterPlug_ResolveImage(), and oyPixelAccess_s::oyPixelAccess_Create().

◆ oyOptions_Find()

oyOption_s * oyOptions_Find ( oyOptions_s options,
const char *  registration 
)

search for a certain option key

Function oyOptions_Find

This function returns the first found option for a given key. The key is represented by a registrations option level.

Parameters
optionsset of options
registrationregistration or key
Returns
a matching options
Version
Oyranos: 0.1.9
Since
2008/11/05 (Oyranos: 0.1.9)
Date
2009/04/13

References oyFilterRegistrationMatch(), oyOBJECT_OPTIONS_S, oyOption_s::oyOption_Release(), oyOptions_Count(), and oyOptions_Get().

Referenced by oyConfig_s::oyConfig_Find(), oyConfig_s::oyConfig_Has(), oyFilterGraph_s::oyFilterGraph_PrepareContexts(), oyOptions_FindData(), oyOptions_FindDouble(), oyOptions_FindInt(), oyOptions_FindString(), oyOptions_MoveInStruct(), oyOptions_SetFromData(), oyOptions_SetFromDouble(), oyOptions_SetFromInt(), oyOptions_SetFromText(), oyObserver_s::oyStruct_DisableSignalSend(), and oyObserver_s::oyStruct_EnableSignalSend().

◆ oyOptions_FindData()

int oyOptions_FindData ( oyOptions_s options,
const char *  registration,
oyPointer *  result,
size_t *  size,
oyAlloc_f  allocateFunc 
)

get a value

Function oyOptions_FindData

Parameters
optionsthe options list or set to manipulate
registrationthe options registration name, e.g. "org/my_org/openicc/my_app/my_opt" or simply a key, e.g. "my_opt"
[out]resultthe data; With size == zero, the pointer is static and owned somewhere else. With size set, the pointer is owned my
  • the caller.
[out]sizethe data size
[in]allocateFuncuser allocator
Returns
0 - option exists, is of correct type, holds a value; -1 - not found; 1 - error
Version
Oyranos: 0.1.10
Since
2009/11/07 (Oyranos: 0.1.10)
Date
2009/11/07

References oyOBJECT_OPTION_S, oyOBJECT_OPTIONS_S, oyOption_s::oyOption_GetData(), oyOption_s::oyOption_Release(), oyOptions_Find(), oyVAL_STRUCT, and oyOption_s::type_.

◆ oyOptions_FindDouble()

int oyOptions_FindDouble ( oyOptions_s options,
const char *  registration,
int  pos,
double *  result 
)

get a value

Function oyOptions_FindDouble

Parameters
optionsthe options list or set to manipulate
registrationthe options registration name, e.g. "org/my_org/openicc/my_app/my_opt" or simple key, e.g. "my_opt"
resultthe double
posthe value position
Returns
0 - option exists, is of correct type, holds a value at the position; -1 - not found; 1 - error
Version
Oyranos: 0.1.10
Since
2009/05/04 (Oyranos: 0.1.10)
Date
2009/09/10

References oyOBJECT_OPTION_S, oyOBJECT_OPTIONS_S, oyOptions_Find(), and oyVAL_DOUBLE.

◆ oyOptions_FindInt()

int oyOptions_FindInt ( oyOptions_s options,
const char *  registration,
int  pos,
int32_t *  result 
)

get a value

Function oyOptions_FindInt

Parameters
optionsthe options list or set to manipulate
registrationthe options registration name, e.g. "org/my_org/openicc/my_app/my_opt" or simple key, e.g. "my_opt"
posthe values position in a possible list
resultthe integer
Returns
0 - option exists, is of correct type, holds a value at the position; -1 - not found; 1 - error
Version
Oyranos: 0.1.10
Since
2009/05/04 (Oyranos: 0.1.10)
Date
2009/05/04

References oyOBJECT_OPTION_S, oyOBJECT_OPTIONS_S, oyOptions_Find(), and oyOption_s::type_.

Referenced by oyDeviceFromJSON(), oyFilterPlug_s::oyFilterPlug_ResolveImage(), and oyConfig_s::oyRankMapFromJSON().

◆ oyOptions_FindString()

const char * oyOptions_FindString ( oyOptions_s options,
const char *  registration,
const char *  value 
)

search for a certain option key and possibly value

Function oyOptions_FindString

This function returns the first found value for a given key. The key is represented by the oyOption_s::name::nick The returned string is valid along the livetime of the particular option value.

Version
Oyranos: 0.1.9
Since
2008/10/07 (Oyranos: 0.1.8)
Date
2009/04/13

References oyOBJECT_OPTION_S, oyOBJECT_OPTIONS_S, and oyOptions_Find().

Referenced by oyConfig_s::oyConfig_FindString(), oyConfigs_s::oyConfigs_FromDeviceClass(), oyDeviceFromJSON(), oyDeviceGetInfo(), oyDeviceToJSON(), oyFilterGraph_s::oyFilterGraph_CountNodes(), oyFilterGraph_s::oyFilterGraph_GetNode(), oyProfile_s::oyProfile_AddDevice(), oyProfile_FromTaxiDB(), oyProfile_Install(), and oyConfig_s::oyRankMapToJSON().

◆ oyOptions_ForFilter()

oyOptions_s * oyOptions_ForFilter ( const char *  registration,
const char *  cmm,
uint32_t  flags,
oyObject_s  object 
)

provide Oyranos behaviour settings

Function oyOptions_ForFilter

The returned options are read in from the Elektra settings and if thats not available from the inbuild defaults. The later can explicitely selected with oyOPTIONSOURCE_FILTER passed as flags argument. The key names map to the registration and XML syntax.

To obtain all advanced front end options from a meta module use:

*  flags = oyOPTIONATTRIBUTE_ADVANCED |
*          oyOPTIONATTRIBUTE_FRONT |
*          OY_SELECT_COMMON 
See also
OY_SELECT_FILTER OY_SELECT_COMMON oyOPTIONATTRIBUTE_e
Parameters
[in]registrationthe filter registration to search for
[in]cmma CMM to match
[in]flagsfor inbuild defaults | oyOPTIONSOURCE_FILTER; for options marked as advanced | oyOPTIONATTRIBUTE_ADVANCED | OY_SELECT_FILTER | OY_SELECT_COMMON
objectthe optional object
Returns
the options
Version
Oyranos: 0.3.0
Since
2008/10/08 (Oyranos: 0.1.8)
Date
2011/01/29

◆ oyOptions_ForFilter_()

oyOptions_s * oyOptions_ForFilter_ ( oyFilterCore_s_ *  filter,
uint32_t  flags,
oyObject_s  object 
)

Provide Oyranos behaviour settings.

Function oyOptions_ForFilter_

References OY_SELECT_COMMON, OY_SELECT_FILTER, oyFILTER_REG_TYPE, oyFilterRegistrationToText(), and oyOptions_New().

Referenced by oyFilterNode_s::oyFilterNode_GetOptions().

◆ oyOptions_FromBoolean()

oyOptions_s * oyOptions_FromBoolean ( oyOptions_s set_a,
oyOptions_s set_b,
oyBOOLEAN_e  type,
oyObject_s  object 
)

boolean operations on two sets of option

Function oyOptions_FromBoolean

See also
oyOptions_Add
Parameters
[in]set_aoptions set A
[in]set_boptions set B
[in]typethe operation to perform
objectthe optional object
Version
Oyranos: 0.1.8
Since
2008/06/28 (Oyranos: 0.1.8)
Date
2008/06/28

References oyFILTER_REG_OPTION, oyFilterRegistrationToText(), oyOptions_Count(), and oyOptions_Get().

◆ oyOptions_FromText()

oyOptions_s * oyOptions_FromText ( const char *  text,
uint32_t  flags,
oyObject_s  object 
)

deserialise a text file to oyOptions_s data

Function oyOptions_FromText

This function is based on libxml2.

Parameters
[in]textthe text to process
[in]flagsfor future use
objectthe optional object
Returns
the data
Version
Oyranos: 0.1.9
Since
2008/11/17 (Oyranos: 0.1.9)
Date
2008/11/17

References oyOptions_New().

Referenced by oyOptions_SetDriverContext().

◆ oyOptions_Get()

OYAPI oyOption_s *OYEXPORT oyOptions_Get ( oyOptions_s list,
int  pos 
)

◆ oyOptions_GetText()

const char * oyOptions_GetText ( oyOptions_s options,
oyNAME_e  type 
)

dump options to text

Function oyOptions_GetText

The type argument should select the following string in return:

  • oyNAME_NAME - a readable XFORMS data model
  • oyNAME_NICK - the hash ID
  • oyNAME_DESCRIPTION - option registration name with key and without value
Todo:
streamline output and group, avoid writing all levels for each key
Parameters
[in,out]optionsthe option
typeoyNAME_NICK is equal to an ID
Returns
the text
Version
Oyranos: 0.3.3
Since
2008/11/25 (Oyranos: 0.1.9)
Date
2011/10/31

References oyNAME_NAME, oyOption_s::oyOption_Release(), oyOptions_Count(), and oyOptions_Get().

Referenced by oyContextCollectData_(), and oyOption_s::oyOption_GetText().

◆ oyOptions_GetType()

oyStruct_s * oyOptions_GetType ( oyOptions_s options,
int  pos,
const char *  registration,
oyOBJECT_e  type 
)

select from options with special attribute

Function oyOptions_GetType

Version
Oyranos: 0.1.10
Since
2009/03/04 (Oyranos: 0.1.10)
Date
2009/03/04

References oyStruct_s::copy, oyFilterRegistrationMatch(), oyOBJECT_OPTIONS_S, oyOption_s::oyOption_Release(), oyOptions_Count(), oyOptions_Get(), and oyVAL_STRUCT.

Referenced by oyImage_s::oyImage_CreateForDisplay().

◆ oyOptions_MoveIn()

OYAPI int OYEXPORT oyOptions_MoveIn ( oyOptions_s list,
oyOption_s **  obj,
int  pos 
)

add an element to a Options list

Function oyOptions_MoveIn

Parameters
[in]listlist
[in,out]objlist element
posposition
Version
Oyranos: 0.1.10
Since
2010/07/05 (Oyranos: 0.1.10)
Date
2010/07/05

References oyOBJECT_OPTION_S, oyOBJECT_OPTIONS_S, oyObserver_s::oyStruct_IsObserved(), oyObserver_s::oyStruct_ObserverAdd(), oyStructList_s::oyStructList_Create(), oyStructList_s::oyStructList_MoveIn(), and oyOption_s::type_.

Referenced by oyOptions_AppendOpts(), oyOptions_CopyFrom(), oyOptions_Set(), and oyOptions_SetDriverContext().

◆ oyOptions_MoveInStruct()

int oyOptions_MoveInStruct ( oyOptions_s **  obj,
const char *  registration,
oyStruct_s **  oy_struct,
uint32_t  flags 
)

change a value

Function oyOptions_MoveInStruct

Parameters
objthe options list or set to manipulate
registrationthe options registration name, e.g. "org/my_org/openicc/my_app/my_opt"
oy_structthe Oyranos style object to move in
flagscan be OY_CREATE_NEW for a new option, or OY_ADD_ALWAYS
Version
Oyranos: 0.1.10
Since
2009/03/05 (Oyranos: 0.1.10)
Date
2009/03/05

Add a new option if the OY_CREATE_NEW flag is present.

References oyOBJECT_OPTIONS_S, oyOptions_Find(), oyOptions_New(), and type_.

◆ oyOptions_New()

OYAPI oyOptions_s *OYEXPORT oyOptions_New ( oyObject_s  object)

◆ oyOptions_ObserverAdd()

OYAPI int OYEXPORT oyOptions_ObserverAdd ( oyOptions_s object,
oyStruct_s observer,
oyStruct_s user_data,
oyObserver_Signal_f  signalFunc 
)

observe options and its elements

Function oyOptions_ObserverAdd

Parameters
[in]objectthe options
[in]observerthe in observation intereressted object
[in]user_dataadditional static informations
[in]signalFuncthe signal handler
Returns
0 - fine; 1 - error
Version
Oyranos: 0.1.10
Since
2009/10/28 (Oyranos: 0.1.10)
Date
2009/10/28

Referenced by oyFilterNode_s::oyFilterNode_GetOptions().

◆ oyOptions_ObserversDisable()

OYAPI int OYEXPORT oyOptions_ObserversDisable ( oyOptions_s object)

disable signaling

Function oyOptions_ObserversDisable

Parameters
[in]objectthe options
Returns
0 - fine; 1 - error
Version
Oyranos: 0.1.10
Since
2010/04/07 (Oyranos: 0.1.10)
Date
2010/04/07

References oyOption_s::oyOption_Release(), oyOptions_Count(), oyOptions_Get(), and oyObserver_s::oyStruct_DisableSignalSend().

◆ oyOptions_ObserversEnable()

OYAPI int OYEXPORT oyOptions_ObserversEnable ( oyOptions_s object)

disable signaling

Function oyOptions_ObserversEnable

Parameters
[in]objectthe options
Returns
0 - fine; 1 - error
Version
Oyranos: 0.1.10
Since
2010/04/07 (Oyranos: 0.1.10)
Date
2010/04/07

References oyOption_s::oyOption_Release(), oyOptions_Count(), oyOptions_Get(), and oyObserver_s::oyStruct_EnableSignalSend().

◆ oyOptions_Release()

OYAPI int OYEXPORT oyOptions_Release ( oyOptions_s **  options)

◆ oyOptions_ReleaseAt()

OYAPI int OYEXPORT oyOptions_ReleaseAt ( oyOptions_s list,
int  pos 
)

release a element from a Options list

Function oyOptions_ReleaseAt

Parameters
[in,out]listthe list
posposition
Version
Oyranos: 0.1.10
Since
2010/07/05 (Oyranos: 0.1.10)
Date
2010/07/05

References oyOBJECT_OPTIONS_S, oyStructList_s::oyStructList_GetParentObjType(), and oyStructList_s::oyStructList_ReleaseAt().

◆ oyOptions_SaveToDB()

OYAPI int OYEXPORT oyOptions_SaveToDB ( oyOptions_s options,
const char *  registration,
char **  new_reg,
oyAlloc_f  allocateFunc 
)

store a oyOptions_s in DB

Function oyOptions_SaveToDB

Parameters
[in]optionsthe options
[in]registrationthe registration
[out]new_regthe new registration; optional
[in]allocthe user allocator for new_reg; optional
Returns
0 - good, 1 >= error
Version
Oyranos: 0.3.0
Since
2009/02/08 (Oyranos: 0.1.10)
Date
2011/01/29

References OY_SLASH, oyFilterRegistrationToText(), oyOption_s::oyOption_GetRegistration(), oyOptions_Count(), and oyOptions_Get().

Referenced by oyConfig_s::oyConfig_SaveToDB().

◆ oyOptions_Set()

int oyOptions_Set ( oyOptions_s options,
oyOption_s option,
int  pos,
oyObject_s  object 
)

set a element in a Options list

Function oyOptions_Set

Already listed options are replaced by the new option. A option new to the existing set will be referenced if no object argument is given.

Adding a new element without any checks is as simple as following code:

*     tmp = oyOption_Copy( option, object );
*     oyOptions_MoveIn( options, &tmp, -1 ); 
Version
Oyranos: 0.1.10
Since
2009/10/25 (Oyranos: 0.1.10)
Date
2009/10/25

References oyFilterRegistrationMatchKey(), oyOption_s::oyOption_Copy(), oyOption_s::oyOption_Release(), oyOptions_Count(), oyOptions_Get(), and oyOptions_MoveIn().

Referenced by oyOptions_SetOpts().

◆ oyOptions_SetDriverContext()

OYAPI int OYEXPORT oyOptions_SetDriverContext ( oyOptions_s **  options,
oyPointer  driver_context,
const char *  driver_context_type,
size_t  driver_context_size,
oyObject_s  object 
)

set a device option from a given external context

Function oyOptions_SetDriverContext

The options will be created in case they do not exist. The driver_context_type accepts "xml". The data in driver_context will be converted to a options set following the Oyranos options XML schemes with the help oyOptions_FromText(). Any other pointer will be converted to a oyBlob_s object. The name of that object will come from driver_context_type.

Parameters
[in,out]optionsoptions for the device
[in]driver_contextdriver context
[in]driver_context_type"xml" or something related to the driver
[in]driver_context_sizesize of driver_context
[in]objecta optional object
Returns
1 - error; 0 - success; -1 - otherwise
Version
Oyranos: 0.1.10
Since
2009/05/18 (Oyranos: 0.1.10)
Date
2009/05/18

References oyFilterRegistrationMatch(), oyOBJECT_OPTIONS_S, oyOption_s::oyOption_FromRegistration(), oyOption_s::oyOption_MoveInStruct(), oyOption_s::oyOption_SetFromData(), oyOptions_FromText(), oyOptions_MoveIn(), oyOptions_New(), and oyOptions_Release().

◆ oyOptions_SetFromData()

int oyOptions_SetFromData ( oyOptions_s **  options,
const char *  registration,
oyPointer  ptr,
size_t  size,
uint32_t  flags 
)

set a data blob or plain pointer

Function oyOptions_SetFromData

Parameters
optionsthe options list or set to manipulate
registrationthe options registration name, e.g. "org/my_org/openicc/my_app/my_opt"
ptrthe pointer
sizethe pointer size
flagscan be OY_CREATE_NEW for a new option, or OY_ADD_ALWAYS
Returns
0 - success; 1 - error
Version
Oyranos: 0.1.10
Since
2009/11/07 (Oyranos: 0.1.10)
Date
2009/11/07

Add a new option if the OY_CREATE_NEW flag is present.

References oyOBJECT_OPTIONS_S, oyOptions_Find(), and oyOptions_New().

◆ oyOptions_SetFromDouble()

int oyOptions_SetFromDouble ( oyOptions_s **  obj,
const char *  registration,
double  value,
int  pos,
uint32_t  flags 
)

change a value

Function oyOptions_SetFromDouble

Parameters
objthe options list or set to manipulate
registrationthe options registration name, e.g. "org/my_org/openicc/my_app/my_opt"
valuethe value to set
posthe position in a value list
flagscan be OY_CREATE_NEW for a new option, OY_STRING_LIST or OY_ADD_ALWAYS
Returns
0 - success; 1 - error
Version
Oyranos: 0.1.10
Since
2009/05/04 (Oyranos: 0.1.10)
Date
2009/09/10

Add a new option if the OY_CREATE_NEW flag is present.

References oyOBJECT_OPTIONS_S, oyOptions_Find(), and oyOptions_New().

◆ oyOptions_SetFromInt()

int oyOptions_SetFromInt ( oyOptions_s **  obj,
const char *  registration,
int32_t  value,
int  pos,
uint32_t  flags 
)

change a value

Function oyOptions_SetFromInt

Parameters
objthe options list or set to manipulate
registrationthe options registration name, e.g. "org/my_org/openicc/my_app/my_opt"
valuethe value to set
posthe position in a value list
flagscan be OY_CREATE_NEW for a new option, OY_STRING_LIST or OY_ADD_ALWAYS
Returns
0 - success; 1 - error
Version
Oyranos: 0.1.10
Since
2009/05/04 (Oyranos: 0.1.10)
Date
2009/05/04

Add a new option if the OY_CREATE_NEW flag is present.

References oyOBJECT_OPTIONS_S, oyOptions_Find(), and oyOptions_New().

◆ oyOptions_SetFromText()

int oyOptions_SetFromText ( oyOptions_s **  obj,
const char *  registration,
const char *  value,
uint32_t  flags 
)

change a value

Function oyOptions_SetFromText

Parameters
objthe options list or set to manipulate
registrationthe options registration name, e.g. "org/my_org/openicc/my_app/my_opt"
valuethe value to set
flagscan be OY_CREATE_NEW for a new option, OY_STRING_LIST or OY_ADD_ALWAYS
Version
Oyranos: 0.3.0
Since
2008/11/27 (Oyranos: 0.1.9)
Date
2011/03/15

Add a new option if the OY_CREATE_NEW flag is present.

Flags are passed on to oyOption_SetFromText, e.g. OY_STRING_LIST.

References oyOBJECT_OPTIONS_S, oyOptions_Find(), oyOptions_New(), and type_.

Referenced by oyConfig_s::oyConfig_AddDBData(), oyDeviceGetInfo(), oyDeviceProfileFromDB(), oyDeviceSelectSimiliar(), oyDeviceSetProfile(), oyDeviceUnset(), oyImage_s::oyImage_CreateForDisplay(), oyImage_FromFile(), and oyImage_ToFile().

◆ oyOptions_SetOpts()

int oyOptions_SetOpts ( oyOptions_s list,
oyOptions_s add 
)

set options in a Options list

Function oyOptions_SetOpts

Already listed options are replaced by the new options.

See also
oyOptions_Set It will use copying.
Version
Oyranos: 0.1.10
Since
2009/10/25 (Oyranos: 0.1.10)
Date
2009/10/25

References oy_, oyOption_s::oyOption_Release(), oyOptions_Count(), oyOptions_Get(), and oyOptions_Set().

Referenced by oyOptions_CopyFrom().

◆ oyOptions_SetSource()

int oyOptions_SetSource ( oyOptions_s options,
oyOPTIONSOURCE_e  source 
)

set source attribute

Function oyOptions_SetSource

Parameters
optionsthe options list or set to manipulate
sourcethe options new source attribute
Version
Oyranos: 0.1.10
Since
2009/01/27 (Oyranos: 0.1.9)
Date
2009/01/27

References oyOBJECT_OPTIONS_S, oyOption_s::oyOption_Release(), oyOptions_Count(), oyOptions_Get(), and type_.

◆ oyOptions_Sort()

OYAPI int OYEXPORT oyOptions_Sort ( oyOptions_s list,
int32_t *  rank_list 
)

sort a list according to a rank_list

Function oyOptions_Sort

Version
Oyranos: 0.3.0
Since
2011/02/01 (Oyranos: 0.3.0)
Date
2011/02/01

References oyOBJECT_OPTIONS_S, and oyStructList_s::oyStructList_Sort().

Field Documentation

◆ copy

oyStruct_Copy_f oyOptions_s::copy

Copy function.

◆ oy_

oyObject_s oyOptions_s::oy_

Oyranos internal object.

Features name and hash. Do not change during object life time.

Referenced by oyImage_s::oyImage_SetCritical(), and oyOptions_SetOpts().

◆ release

oyStruct_Release_f oyOptions_s::release

Release function.

◆ type_

const oyOBJECT_e oyOptions_s::type_

Type of object.

The struct type tells Oyranos how to interprete hidden fields.

Referenced by oyOptions_MoveInStruct(), oyOptions_SetFromText(), and oyOptions_SetSource().