Update git submodules
[LibreOffice.git] / registry / source / reflcnst.hxx
blob2c93a9cd22f28d17a20b7300d782392496828060
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #pragma once
22 #include <registry/types.hxx>
24 #include <string.h>
26 #define REGTYPE_IEEE_NATIVE 1
28 extern const sal_uInt32 magic;
29 extern const sal_uInt16 minorVersion;
30 extern const sal_uInt16 majorVersion;
32 #define OFFSET_MAGIC 0
33 #define OFFSET_SIZE static_cast<sal_uInt32>(OFFSET_MAGIC + sizeof(magic))
34 #define OFFSET_MINOR_VERSION static_cast<sal_uInt32>(OFFSET_SIZE + sizeof(sal_uInt32))
35 #define OFFSET_MAJOR_VERSION static_cast<sal_uInt32>(OFFSET_MINOR_VERSION + sizeof(minorVersion))
36 #define OFFSET_N_ENTRIES static_cast<sal_uInt32>(OFFSET_MAJOR_VERSION + sizeof(majorVersion))
37 #define OFFSET_TYPE_SOURCE static_cast<sal_uInt32>(OFFSET_N_ENTRIES + sizeof(sal_uInt16))
38 #define OFFSET_TYPE_CLASS static_cast<sal_uInt32>(OFFSET_TYPE_SOURCE + sizeof(sal_uInt16))
39 #define OFFSET_THIS_TYPE static_cast<sal_uInt32>(OFFSET_TYPE_CLASS + sizeof(sal_uInt16))
40 #define OFFSET_UIK static_cast<sal_uInt32>(OFFSET_THIS_TYPE + sizeof(sal_uInt16))
41 #define OFFSET_DOKU static_cast<sal_uInt32>(OFFSET_UIK + sizeof(sal_uInt16))
42 #define OFFSET_FILENAME static_cast<sal_uInt32>(OFFSET_DOKU + sizeof(sal_uInt16))
44 #define OFFSET_N_SUPERTYPES static_cast<sal_uInt32>(OFFSET_FILENAME + sizeof(sal_uInt16))
45 #define OFFSET_SUPERTYPES static_cast<sal_uInt32>(OFFSET_N_SUPERTYPES + sizeof(sal_uInt16))
47 #define OFFSET_CP_SIZE static_cast<sal_uInt32>(OFFSET_SUPERTYPES + sizeof(sal_uInt16))
48 #define OFFSET_CP static_cast<sal_uInt32>(OFFSET_CP_SIZE + sizeof(sal_uInt16))
50 #define CP_OFFSET_ENTRY_SIZE 0
51 #define CP_OFFSET_ENTRY_TAG static_cast<sal_uInt32>(CP_OFFSET_ENTRY_SIZE + sizeof(sal_uInt32))
52 #define CP_OFFSET_ENTRY_DATA static_cast<sal_uInt32>(CP_OFFSET_ENTRY_TAG + sizeof(sal_uInt16))
54 #define FIELD_OFFSET_ACCESS 0
55 #define FIELD_OFFSET_NAME static_cast<sal_uInt32>(FIELD_OFFSET_ACCESS + sizeof(sal_uInt16))
56 #define FIELD_OFFSET_TYPE static_cast<sal_uInt32>(FIELD_OFFSET_NAME + sizeof(sal_uInt16))
57 #define FIELD_OFFSET_VALUE static_cast<sal_uInt32>(FIELD_OFFSET_TYPE + sizeof(sal_uInt16))
58 #define FIELD_OFFSET_DOKU static_cast<sal_uInt32>(FIELD_OFFSET_VALUE + sizeof(sal_uInt16))
59 #define FIELD_OFFSET_FILENAME static_cast<sal_uInt32>(FIELD_OFFSET_DOKU + sizeof(sal_uInt16))
61 #define PARAM_OFFSET_TYPE 0
62 #define PARAM_OFFSET_MODE static_cast<sal_uInt32>(PARAM_OFFSET_TYPE + sizeof(sal_uInt16))
63 #define PARAM_OFFSET_NAME static_cast<sal_uInt32>(PARAM_OFFSET_MODE + sizeof(sal_uInt16))
65 #define METHOD_OFFSET_SIZE 0
66 #define METHOD_OFFSET_MODE static_cast<sal_uInt32>(METHOD_OFFSET_SIZE + sizeof(sal_uInt16))
67 #define METHOD_OFFSET_NAME static_cast<sal_uInt32>(METHOD_OFFSET_MODE + sizeof(sal_uInt16))
68 #define METHOD_OFFSET_RETURN static_cast<sal_uInt32>(METHOD_OFFSET_NAME + sizeof(sal_uInt16))
69 #define METHOD_OFFSET_DOKU static_cast<sal_uInt32>(METHOD_OFFSET_RETURN + sizeof(sal_uInt16))
70 #define METHOD_OFFSET_PARAM_COUNT static_cast<sal_uInt32>(METHOD_OFFSET_DOKU + sizeof(sal_uInt16))
72 #define REFERENCE_OFFSET_TYPE 0
73 #define REFERENCE_OFFSET_NAME static_cast<sal_uInt32>(REFERENCE_OFFSET_TYPE + sizeof(sal_uInt16))
74 #define REFERENCE_OFFSET_DOKU static_cast<sal_uInt32>(REFERENCE_OFFSET_NAME + sizeof(sal_uInt16))
75 #define REFERENCE_OFFSET_ACCESS static_cast<sal_uInt32>(REFERENCE_OFFSET_DOKU + sizeof(sal_uInt16))
77 enum CPInfoTag
79 CP_TAG_INVALID = RT_TYPE_NONE,
80 CP_TAG_CONST_BOOL = RT_TYPE_BOOL,
81 CP_TAG_CONST_BYTE = RT_TYPE_BYTE,
82 CP_TAG_CONST_INT16 = RT_TYPE_INT16,
83 CP_TAG_CONST_UINT16 = RT_TYPE_UINT16,
84 CP_TAG_CONST_INT32 = RT_TYPE_INT32,
85 CP_TAG_CONST_UINT32 = RT_TYPE_UINT32,
86 CP_TAG_CONST_INT64 = RT_TYPE_INT64,
87 CP_TAG_CONST_UINT64 = RT_TYPE_UINT64,
88 CP_TAG_CONST_FLOAT = RT_TYPE_FLOAT,
89 CP_TAG_CONST_DOUBLE = RT_TYPE_DOUBLE,
90 CP_TAG_CONST_STRING = RT_TYPE_STRING,
91 CP_TAG_UTF8_NAME
94 inline sal_uInt32 writeUINT16(sal_uInt8* buffer, sal_uInt16 v)
96 buffer[0] = static_cast<sal_uInt8>((v >> 8) & 0xFF);
97 buffer[1] = static_cast<sal_uInt8>((v >> 0) & 0xFF);
99 return sizeof(sal_uInt16);
102 inline sal_uInt32 readUINT16(const sal_uInt8* buffer, sal_uInt16& v)
104 //This is untainted data which comes from a controlled source
105 //so, using a byte-swapping pattern which coverity doesn't
106 //detect as such
107 //http://security.coverity.com/blog/2014/Apr/on-detecting-heartbleed-with-static-analysis.html
108 v = *buffer++; v <<= 8;
109 v |= *buffer;
110 return sizeof(sal_uInt16);
113 inline sal_uInt32 writeINT32(sal_uInt8* buffer, sal_Int32 v)
115 buffer[0] = static_cast<sal_uInt8>((v >> 24) & 0xFF);
116 buffer[1] = static_cast<sal_uInt8>((v >> 16) & 0xFF);
117 buffer[2] = static_cast<sal_uInt8>((v >> 8) & 0xFF);
118 buffer[3] = static_cast<sal_uInt8>((v >> 0) & 0xFF);
120 return sizeof(sal_Int32);
123 inline sal_uInt32 readINT32(const sal_uInt8* buffer, sal_Int32& v)
125 v = (
126 (buffer[0] << 24) |
127 (buffer[1] << 16) |
128 (buffer[2] << 8) |
129 (buffer[3] << 0)
132 return sizeof(sal_Int32);
135 inline sal_uInt32 writeUINT32(sal_uInt8* buffer, sal_uInt32 v)
137 buffer[0] = static_cast<sal_uInt8>((v >> 24) & 0xFF);
138 buffer[1] = static_cast<sal_uInt8>((v >> 16) & 0xFF);
139 buffer[2] = static_cast<sal_uInt8>((v >> 8) & 0xFF);
140 buffer[3] = static_cast<sal_uInt8>((v >> 0) & 0xFF);
142 return sizeof(sal_uInt32);
145 inline sal_uInt32 readUINT32(const sal_uInt8* buffer, sal_uInt32& v)
147 //This is untainted data which comes from a controlled source
148 //so, using a byte-swapping pattern which coverity doesn't
149 //detect as such
150 //http://security.coverity.com/blog/2014/Apr/on-detecting-heartbleed-with-static-analysis.html
151 v = *buffer++; v <<= 8;
152 v |= *buffer++; v <<= 8;
153 v |= *buffer++; v <<= 8;
154 v |= *buffer;
155 return sizeof(sal_uInt32);
158 inline sal_uInt32 writeUtf8(sal_uInt8* buffer, const char* v)
160 sal_uInt32 size = strlen(v) + 1;
162 memcpy(buffer, v, size);
164 return size;
167 inline sal_uInt32 readUtf8(const sal_uInt8* buffer, char* v, sal_uInt32 maxSize)
169 sal_uInt32 size = strlen(reinterpret_cast<const char*>(buffer)) + 1;
170 if(size > maxSize)
172 size = maxSize;
175 memcpy(v, buffer, size);
177 if (size == maxSize) v[size - 1] = '\0';
179 return size;
183 sal_uInt32 writeString(sal_uInt8* buffer, const sal_Unicode* v);
184 sal_uInt32 readString(const sal_uInt8* buffer, sal_Unicode* v, sal_uInt32 maxSize);
186 sal_uInt32 UINT16StringLen(const sal_uInt8* wstring);
188 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */