1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/* *********************************************************************
* This Original Work is copyright of 51 Degrees Mobile Experts Limited.
* Copyright 2022 51 Degrees Mobile Experts Limited, Davidson House,
* Forbury Square, Reading, Berkshire, United Kingdom RG1 3EU.
*
* This Original Work is licensed under the European Union Public Licence
* (EUPL) v.1.2 and is subject to its terms as set out below.
*
* If a copy of the EUPL was not distributed with this file, You can obtain
* one at https://opensource.org/licenses/EUPL-1.2.
*
* The 'Compatible Licences' set out in the Appendix to the EUPL (as may be
* amended by the European Commission) shall be deemed incompatible for
* the purposes of the Work and the provisions of the compatibility
* clause in Article 5 of the EUPL shall not apply.
*
* If using the Work as, or as part of, a network application, by
* including the attribution notice(s) required under Article 5 of the EUPL
* in the end user terms of the application under an appropriate heading,
* such notice(s) shall fulfill the requirements of that article.
* ********************************************************************* */
/**
* @ingroup FiftyOneDegreesDeviceDetection
* @defgroup FiftyOneDegreesDataSetDeviceDetection Data Set
*
* A device detection specific data file initialised in a structure.
*
* ## Introduction
*
* Data set structure extending #fiftyoneDegreesDataSetBase type with device
* detection specific elements. This adds the unique index of the User-Agent
* header and extends base methods to handle the specific data set type.
*
* For further info see @link FiftyOneDegreesDataSet @endlink
*
* @{
*/
/**
* Device detection data set structure which contains the 'must have's for all
* device detection data sets.
*/
typedef struct fiftyone_degrees_dataset_device_detection_t fiftyoneDegreesDataSetDeviceDetection;
/**
* @copydoc fiftyoneDegreesDataSetRelease
*/
void ;
/**
* @copydoc fiftyoneDegreesDataSetFree
*/
void ;
/**
* @copydoc fiftyoneDegreesDataSetGet
*/
fiftyoneDegreesDataSetDeviceDetection*
;
/**
* Initialise the header and properties using the
* #fiftyoneDegreesDataSetInitProperties and #fiftyoneDegreesDataSetInitHeaders
* methods, set the index of the User-Agent header and initialise the override
* properties.
* @param dataSet pointer to the pre allocated data set to be initialised
* @param properties the properties which should be initialised in the data set
* @param state pointer to data which is needed by get methods
* @param getPropertyMethod method used to retrieve the name of a property at
* a specified index from the data set
* @param getHeaderMethod method used to retrieve the unique id and name of a
* header at a specified index from the data set
* @param overridesFilter pointer to a filter method which determines whether
* or not a property is eligible to be overridden
* @param getEvidencePropertiesMethod method used to populate the list of
* evidence required for a property in the data set
* @return the status associated with the header initialisation. Any value
* other than #FIFTYONE_DEGREES_STATUS_SUCCESS means the headers were not
* initialised correctly
*/
fiftyoneDegreesStatusCode
;
/**
* @copydoc fiftyoneDegreesDataSetReset
*/
void ;
/**
* @}
*/