You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

JetFormat.java 40KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148
  1. /*
  2. Copyright (c) 2005 Health Market Science, Inc.
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. http://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. */
  13. package com.healthmarketscience.jackcess.impl;
  14. import java.io.IOException;
  15. import java.nio.ByteBuffer;
  16. import java.nio.channels.FileChannel;
  17. import java.nio.charset.Charset;
  18. import java.nio.charset.StandardCharsets;
  19. import java.util.Collections;
  20. import java.util.EnumSet;
  21. import java.util.HashMap;
  22. import java.util.Map;
  23. import java.util.Set;
  24. import com.healthmarketscience.jackcess.DataType;
  25. import com.healthmarketscience.jackcess.Database;
  26. /**
  27. * Encapsulates constants describing a specific version of the Access Jet format
  28. * @author Tim McCune
  29. */
  30. public abstract class JetFormat {
  31. /** Maximum size of a record minus OLE objects and Memo fields */
  32. public static final int MAX_RECORD_SIZE = 1900; //2kb minus some overhead
  33. /** the "unit" size for text fields */
  34. public static final short TEXT_FIELD_UNIT_SIZE = 2;
  35. /** Maximum size of a text field */
  36. public static final short TEXT_FIELD_MAX_LENGTH = 255 * TEXT_FIELD_UNIT_SIZE;
  37. public enum CodecType {
  38. NONE, JET, MSISAM, OFFICE;
  39. }
  40. /** Offset in the file that holds the byte describing the Jet format
  41. version */
  42. private static final int OFFSET_VERSION = 20;
  43. /** Version code for Jet version 3 */
  44. private static final byte CODE_VERSION_3 = 0x0;
  45. /** Version code for Jet version 4 */
  46. private static final byte CODE_VERSION_4 = 0x1;
  47. /** Version code for Jet version 12.0 */
  48. private static final byte CODE_VERSION_12 = 0x2;
  49. /** Version code for Jet version 14.0 */
  50. private static final byte CODE_VERSION_14 = 0x3;
  51. /** Version code for Jet version 16.0 */
  52. private static final byte CODE_VERSION_16 = 0x5;
  53. /** Version code for Jet version 17.0 */
  54. private static final byte CODE_VERSION_17 = 0x6;
  55. /** location of the engine name in the header */
  56. public static final int OFFSET_ENGINE_NAME = 0x4;
  57. /** length of the engine name in the header */
  58. public static final int LENGTH_ENGINE_NAME = 0xF;
  59. /** amount of initial data to be read to determine database type */
  60. private static final int HEADER_LENGTH = 21;
  61. private final static byte[] MSISAM_ENGINE = new byte[] {
  62. 'M', 'S', 'I', 'S', 'A', 'M', ' ', 'D', 'a', 't', 'a', 'b', 'a', 's', 'e'
  63. };
  64. /** mask used to obfuscate the db header */
  65. private static final byte[] BASE_HEADER_MASK = new byte[]{
  66. (byte)0xB5, (byte)0x6F, (byte)0x03, (byte)0x62, (byte)0x61, (byte)0x08,
  67. (byte)0xC2, (byte)0x55, (byte)0xEB, (byte)0xA9, (byte)0x67, (byte)0x72,
  68. (byte)0x43, (byte)0x3F, (byte)0x00, (byte)0x9C, (byte)0x7A, (byte)0x9F,
  69. (byte)0x90, (byte)0xFF, (byte)0x80, (byte)0x9A, (byte)0x31, (byte)0xC5,
  70. (byte)0x79, (byte)0xBA, (byte)0xED, (byte)0x30, (byte)0xBC, (byte)0xDF,
  71. (byte)0xCC, (byte)0x9D, (byte)0x63, (byte)0xD9, (byte)0xE4, (byte)0xC3,
  72. (byte)0x7B, (byte)0x42, (byte)0xFB, (byte)0x8A, (byte)0xBC, (byte)0x4E,
  73. (byte)0x86, (byte)0xFB, (byte)0xEC, (byte)0x37, (byte)0x5D, (byte)0x44,
  74. (byte)0x9C, (byte)0xFA, (byte)0xC6, (byte)0x5E, (byte)0x28, (byte)0xE6,
  75. (byte)0x13, (byte)0xB6, (byte)0x8A, (byte)0x60, (byte)0x54, (byte)0x94,
  76. (byte)0x7B, (byte)0x36, (byte)0xF5, (byte)0x72, (byte)0xDF, (byte)0xB1,
  77. (byte)0x77, (byte)0xF4, (byte)0x13, (byte)0x43, (byte)0xCF, (byte)0xAF,
  78. (byte)0xB1, (byte)0x33, (byte)0x34, (byte)0x61, (byte)0x79, (byte)0x5B,
  79. (byte)0x92, (byte)0xB5, (byte)0x7C, (byte)0x2A, (byte)0x05, (byte)0xF1,
  80. (byte)0x7C, (byte)0x99, (byte)0x01, (byte)0x1B, (byte)0x98, (byte)0xFD,
  81. (byte)0x12, (byte)0x4F, (byte)0x4A, (byte)0x94, (byte)0x6C, (byte)0x3E,
  82. (byte)0x60, (byte)0x26, (byte)0x5F, (byte)0x95, (byte)0xF8, (byte)0xD0,
  83. (byte)0x89, (byte)0x24, (byte)0x85, (byte)0x67, (byte)0xC6, (byte)0x1F,
  84. (byte)0x27, (byte)0x44, (byte)0xD2, (byte)0xEE, (byte)0xCF, (byte)0x65,
  85. (byte)0xED, (byte)0xFF, (byte)0x07, (byte)0xC7, (byte)0x46, (byte)0xA1,
  86. (byte)0x78, (byte)0x16, (byte)0x0C, (byte)0xED, (byte)0xE9, (byte)0x2D,
  87. (byte)0x62, (byte)0xD4};
  88. /** value of the "AccessVersion" property for access 2000 dbs:
  89. {@code "08.50"} */
  90. private static final String ACCESS_VERSION_2000 = "08.50";
  91. /** value of the "AccessVersion" property for access 2002/2003 dbs
  92. {@code "09.50"} */
  93. private static final String ACCESS_VERSION_2003 = "09.50";
  94. /** known intro bytes for property maps */
  95. static final byte[][] PROPERTY_MAP_TYPES = {
  96. new byte[]{'M', 'R', '2', '\0'}, // access 2000+
  97. new byte[]{'K', 'K', 'D', '\0'}}; // access 97
  98. // use nested inner class to avoid problematic static init loops
  99. private static final class PossibleFileFormats {
  100. private static final Map<String,Database.FileFormat> POSSIBLE_VERSION_3 =
  101. Collections.singletonMap((String)null, Database.FileFormat.V1997);
  102. private static final Map<String,Database.FileFormat> POSSIBLE_VERSION_4 =
  103. new HashMap<String,Database.FileFormat>();
  104. private static final Map<String,Database.FileFormat> POSSIBLE_VERSION_12 =
  105. Collections.singletonMap((String)null, Database.FileFormat.V2007);
  106. private static final Map<String,Database.FileFormat> POSSIBLE_VERSION_14 =
  107. Collections.singletonMap((String)null, Database.FileFormat.V2010);
  108. private static final Map<String,Database.FileFormat> POSSIBLE_VERSION_16 =
  109. Collections.singletonMap((String)null, Database.FileFormat.V2016);
  110. private static final Map<String,Database.FileFormat> POSSIBLE_VERSION_17 =
  111. Collections.singletonMap((String)null, Database.FileFormat.V2019);
  112. private static final Map<String,Database.FileFormat> POSSIBLE_VERSION_MSISAM =
  113. Collections.singletonMap((String)null, Database.FileFormat.MSISAM);
  114. static {
  115. POSSIBLE_VERSION_4.put(ACCESS_VERSION_2000, Database.FileFormat.V2000);
  116. POSSIBLE_VERSION_4.put(ACCESS_VERSION_2003, Database.FileFormat.V2003);
  117. POSSIBLE_VERSION_4.put(null, Database.FileFormat.GENERIC_JET4);
  118. }
  119. }
  120. /** calculated types supported in version 14 */
  121. private static final Set<DataType> V14_CALC_TYPES =
  122. EnumSet.of(DataType.BOOLEAN, DataType.BYTE, DataType.INT, DataType.LONG,
  123. DataType.FLOAT, DataType.DOUBLE, DataType.GUID,
  124. DataType.SHORT_DATE_TIME, DataType.MONEY, DataType.NUMERIC,
  125. DataType.TEXT, DataType.MEMO);
  126. /** calculated types supported in version 16 */
  127. private static final Set<DataType> V16_CALC_TYPES = EnumSet.of(DataType.BIG_INT);
  128. static {
  129. V16_CALC_TYPES.addAll(V14_CALC_TYPES);
  130. }
  131. /** the JetFormat constants for the Jet database version "3" */
  132. public static final JetFormat VERSION_3 = new Jet3Format();
  133. /** the JetFormat constants for the Jet database version "4" */
  134. public static final JetFormat VERSION_4 = new Jet4Format();
  135. /** the JetFormat constants for the MSISAM database */
  136. public static final JetFormat VERSION_MSISAM = new MSISAMFormat();
  137. /** the JetFormat constants for the Jet database version "12.0" */
  138. public static final JetFormat VERSION_12 = new Jet12Format();
  139. /** the JetFormat constants for the Jet database version "14.0" */
  140. public static final JetFormat VERSION_14 = new Jet14Format();
  141. /** the JetFormat constants for the Jet database version "16.0" */
  142. public static final JetFormat VERSION_16 = new Jet16Format();
  143. /** the JetFormat constants for the Jet database version "17.0" */
  144. public static final JetFormat VERSION_17 = new Jet17Format();
  145. //These constants are populated by this class's constructor. They can't be
  146. //populated by the subclass's constructor because they are final, and Java
  147. //doesn't allow this; hence all the abstract defineXXX() methods.
  148. /** the name of this format */
  149. private final String _name;
  150. /** the read/write mode of this format */
  151. public final boolean READ_ONLY;
  152. /** whether or not we can use indexes in this format */
  153. public final boolean INDEXES_SUPPORTED;
  154. /** type of page encoding supported */
  155. public final CodecType CODEC_TYPE;
  156. /** Database page size in bytes */
  157. public final int PAGE_SIZE;
  158. public final long MAX_DATABASE_SIZE;
  159. public final int MAX_ROW_SIZE;
  160. public final int DATA_PAGE_INITIAL_FREE_SPACE;
  161. public final int OFFSET_MASKED_HEADER;
  162. public final byte[] HEADER_MASK;
  163. public final int OFFSET_HEADER_DATE;
  164. public final int OFFSET_PASSWORD;
  165. public final int SIZE_PASSWORD;
  166. public final int OFFSET_SORT_ORDER;
  167. public final int SIZE_SORT_ORDER;
  168. public final int OFFSET_CODE_PAGE;
  169. public final int OFFSET_ENCODING_KEY;
  170. public final int OFFSET_NEXT_TABLE_DEF_PAGE;
  171. public final int OFFSET_NUM_ROWS;
  172. public final int OFFSET_NEXT_AUTO_NUMBER;
  173. public final int OFFSET_NEXT_COMPLEX_AUTO_NUMBER;
  174. public final int OFFSET_TABLE_TYPE;
  175. public final int OFFSET_MAX_COLS;
  176. public final int OFFSET_NUM_VAR_COLS;
  177. public final int OFFSET_NUM_COLS;
  178. public final int OFFSET_NUM_INDEX_SLOTS;
  179. public final int OFFSET_NUM_INDEXES;
  180. public final int OFFSET_OWNED_PAGES;
  181. public final int OFFSET_FREE_SPACE_PAGES;
  182. public final int OFFSET_INDEX_DEF_BLOCK;
  183. public final int SIZE_INDEX_COLUMN_BLOCK;
  184. public final int SIZE_INDEX_INFO_BLOCK;
  185. public final int OFFSET_COLUMN_TYPE;
  186. public final int OFFSET_COLUMN_NUMBER;
  187. public final int OFFSET_COLUMN_PRECISION;
  188. public final int OFFSET_COLUMN_SCALE;
  189. public final int OFFSET_COLUMN_SORT_ORDER;
  190. public final int OFFSET_COLUMN_CODE_PAGE;
  191. public final int OFFSET_COLUMN_COMPLEX_ID;
  192. public final int OFFSET_COLUMN_FLAGS;
  193. public final int OFFSET_COLUMN_EXT_FLAGS;
  194. public final int OFFSET_COLUMN_LENGTH;
  195. public final int OFFSET_COLUMN_VARIABLE_TABLE_INDEX;
  196. public final int OFFSET_COLUMN_FIXED_DATA_OFFSET;
  197. public final int OFFSET_COLUMN_FIXED_DATA_ROW_OFFSET;
  198. public final int OFFSET_TABLE_DEF_LOCATION;
  199. public final int OFFSET_ROW_START;
  200. public final int OFFSET_USAGE_MAP_START;
  201. public final int OFFSET_USAGE_MAP_PAGE_DATA;
  202. public final int OFFSET_REFERENCE_MAP_PAGE_NUMBERS;
  203. public final int OFFSET_FREE_SPACE;
  204. public final int OFFSET_NUM_ROWS_ON_DATA_PAGE;
  205. public final int MAX_NUM_ROWS_ON_DATA_PAGE;
  206. public final int OFFSET_INDEX_COMPRESSED_BYTE_COUNT;
  207. public final int OFFSET_INDEX_ENTRY_MASK;
  208. public final int OFFSET_PREV_INDEX_PAGE;
  209. public final int OFFSET_NEXT_INDEX_PAGE;
  210. public final int OFFSET_CHILD_TAIL_INDEX_PAGE;
  211. public final int SIZE_INDEX_DEFINITION;
  212. public final int SIZE_COLUMN_HEADER;
  213. public final int SIZE_ROW_LOCATION;
  214. public final int SIZE_LONG_VALUE_DEF;
  215. public final int MAX_INLINE_LONG_VALUE_SIZE;
  216. public final int MAX_LONG_VALUE_ROW_SIZE;
  217. public final int MAX_COMPRESSED_UNICODE_SIZE;
  218. public final int SIZE_TDEF_HEADER;
  219. public final int SIZE_TDEF_TRAILER;
  220. public final int SIZE_COLUMN_DEF_BLOCK;
  221. public final int SIZE_INDEX_ENTRY_MASK;
  222. public final int SKIP_BEFORE_INDEX_FLAGS;
  223. public final int SKIP_AFTER_INDEX_FLAGS;
  224. public final int SKIP_BEFORE_INDEX_SLOT;
  225. public final int SKIP_AFTER_INDEX_SLOT;
  226. public final int SKIP_BEFORE_INDEX;
  227. public final int SIZE_NAME_LENGTH;
  228. public final int SIZE_ROW_COLUMN_COUNT;
  229. public final int SIZE_ROW_VAR_COL_OFFSET;
  230. public final int USAGE_MAP_TABLE_BYTE_LENGTH;
  231. public final int MAX_COLUMNS_PER_TABLE;
  232. public final int MAX_INDEXES_PER_TABLE;
  233. public final int MAX_TABLE_NAME_LENGTH;
  234. public final int MAX_COLUMN_NAME_LENGTH;
  235. public final int MAX_INDEX_NAME_LENGTH;
  236. public final boolean LEGACY_NUMERIC_INDEXES;
  237. public final Charset CHARSET;
  238. public final ColumnImpl.SortOrder DEFAULT_SORT_ORDER;
  239. public final byte[] PROPERTY_MAP_TYPE;
  240. public final int SIZE_TEXT_FIELD_UNIT;
  241. /**
  242. * @param channel the database file.
  243. * @return The Jet Format represented in the passed-in file
  244. * @throws IOException if the database file format is unsupported.
  245. */
  246. public static JetFormat getFormat(FileChannel channel) throws IOException {
  247. ByteBuffer buffer = ByteBuffer.allocate(HEADER_LENGTH);
  248. int bytesRead = channel.read(buffer, 0L);
  249. if(bytesRead < HEADER_LENGTH) {
  250. throw new IOException("Empty database file");
  251. }
  252. buffer.flip();
  253. byte version = buffer.get(OFFSET_VERSION);
  254. if (version == CODE_VERSION_3) {
  255. return VERSION_3;
  256. } else if (version == CODE_VERSION_4) {
  257. if(ByteUtil.matchesRange(buffer, OFFSET_ENGINE_NAME, MSISAM_ENGINE)) {
  258. return VERSION_MSISAM;
  259. }
  260. return VERSION_4;
  261. } else if (version == CODE_VERSION_12) {
  262. return VERSION_12;
  263. } else if (version == CODE_VERSION_14) {
  264. return VERSION_14;
  265. } else if (version == CODE_VERSION_16) {
  266. return VERSION_16;
  267. } else if (version == CODE_VERSION_17) {
  268. return VERSION_17;
  269. }
  270. throw new IOException("Unsupported " +
  271. ((version < CODE_VERSION_3) ? "older" : "newer") +
  272. " version: " + version);
  273. }
  274. private JetFormat(String name) {
  275. _name = name;
  276. READ_ONLY = defineReadOnly();
  277. INDEXES_SUPPORTED = defineIndexesSupported();
  278. CODEC_TYPE = defineCodecType();
  279. PAGE_SIZE = definePageSize();
  280. MAX_DATABASE_SIZE = defineMaxDatabaseSize();
  281. MAX_ROW_SIZE = defineMaxRowSize();
  282. DATA_PAGE_INITIAL_FREE_SPACE = defineDataPageInitialFreeSpace();
  283. OFFSET_MASKED_HEADER = defineOffsetMaskedHeader();
  284. HEADER_MASK = defineHeaderMask();
  285. OFFSET_HEADER_DATE = defineOffsetHeaderDate();
  286. OFFSET_PASSWORD = defineOffsetPassword();
  287. SIZE_PASSWORD = defineSizePassword();
  288. OFFSET_SORT_ORDER = defineOffsetSortOrder();
  289. SIZE_SORT_ORDER = defineSizeSortOrder();
  290. OFFSET_CODE_PAGE = defineOffsetCodePage();
  291. OFFSET_ENCODING_KEY = defineOffsetEncodingKey();
  292. OFFSET_NEXT_TABLE_DEF_PAGE = defineOffsetNextTableDefPage();
  293. OFFSET_NUM_ROWS = defineOffsetNumRows();
  294. OFFSET_NEXT_AUTO_NUMBER = defineOffsetNextAutoNumber();
  295. OFFSET_NEXT_COMPLEX_AUTO_NUMBER = defineOffsetNextComplexAutoNumber();
  296. OFFSET_TABLE_TYPE = defineOffsetTableType();
  297. OFFSET_MAX_COLS = defineOffsetMaxCols();
  298. OFFSET_NUM_VAR_COLS = defineOffsetNumVarCols();
  299. OFFSET_NUM_COLS = defineOffsetNumCols();
  300. OFFSET_NUM_INDEX_SLOTS = defineOffsetNumIndexSlots();
  301. OFFSET_NUM_INDEXES = defineOffsetNumIndexes();
  302. OFFSET_OWNED_PAGES = defineOffsetOwnedPages();
  303. OFFSET_FREE_SPACE_PAGES = defineOffsetFreeSpacePages();
  304. OFFSET_INDEX_DEF_BLOCK = defineOffsetIndexDefBlock();
  305. SIZE_INDEX_COLUMN_BLOCK = defineSizeIndexColumnBlock();
  306. SIZE_INDEX_INFO_BLOCK = defineSizeIndexInfoBlock();
  307. OFFSET_COLUMN_TYPE = defineOffsetColumnType();
  308. OFFSET_COLUMN_NUMBER = defineOffsetColumnNumber();
  309. OFFSET_COLUMN_PRECISION = defineOffsetColumnPrecision();
  310. OFFSET_COLUMN_SCALE = defineOffsetColumnScale();
  311. OFFSET_COLUMN_SORT_ORDER = defineOffsetColumnSortOrder();
  312. OFFSET_COLUMN_CODE_PAGE = defineOffsetColumnCodePage();
  313. OFFSET_COLUMN_COMPLEX_ID = defineOffsetColumnComplexId();
  314. OFFSET_COLUMN_FLAGS = defineOffsetColumnFlags();
  315. OFFSET_COLUMN_EXT_FLAGS = defineOffsetColumnExtFlags();
  316. OFFSET_COLUMN_LENGTH = defineOffsetColumnLength();
  317. OFFSET_COLUMN_VARIABLE_TABLE_INDEX = defineOffsetColumnVariableTableIndex();
  318. OFFSET_COLUMN_FIXED_DATA_OFFSET = defineOffsetColumnFixedDataOffset();
  319. OFFSET_COLUMN_FIXED_DATA_ROW_OFFSET = defineOffsetColumnFixedDataRowOffset();
  320. OFFSET_TABLE_DEF_LOCATION = defineOffsetTableDefLocation();
  321. OFFSET_ROW_START = defineOffsetRowStart();
  322. OFFSET_USAGE_MAP_START = defineOffsetUsageMapStart();
  323. OFFSET_USAGE_MAP_PAGE_DATA = defineOffsetUsageMapPageData();
  324. OFFSET_REFERENCE_MAP_PAGE_NUMBERS = defineOffsetReferenceMapPageNumbers();
  325. OFFSET_FREE_SPACE = defineOffsetFreeSpace();
  326. OFFSET_NUM_ROWS_ON_DATA_PAGE = defineOffsetNumRowsOnDataPage();
  327. MAX_NUM_ROWS_ON_DATA_PAGE = defineMaxNumRowsOnDataPage();
  328. OFFSET_INDEX_COMPRESSED_BYTE_COUNT = defineOffsetIndexCompressedByteCount();
  329. OFFSET_INDEX_ENTRY_MASK = defineOffsetIndexEntryMask();
  330. OFFSET_PREV_INDEX_PAGE = defineOffsetPrevIndexPage();
  331. OFFSET_NEXT_INDEX_PAGE = defineOffsetNextIndexPage();
  332. OFFSET_CHILD_TAIL_INDEX_PAGE = defineOffsetChildTailIndexPage();
  333. SIZE_INDEX_DEFINITION = defineSizeIndexDefinition();
  334. SIZE_COLUMN_HEADER = defineSizeColumnHeader();
  335. SIZE_ROW_LOCATION = defineSizeRowLocation();
  336. SIZE_LONG_VALUE_DEF = defineSizeLongValueDef();
  337. MAX_INLINE_LONG_VALUE_SIZE = defineMaxInlineLongValueSize();
  338. MAX_LONG_VALUE_ROW_SIZE = defineMaxLongValueRowSize();
  339. MAX_COMPRESSED_UNICODE_SIZE = defineMaxCompressedUnicodeSize();
  340. SIZE_TDEF_HEADER = defineSizeTdefHeader();
  341. SIZE_TDEF_TRAILER = defineSizeTdefTrailer();
  342. SIZE_COLUMN_DEF_BLOCK = defineSizeColumnDefBlock();
  343. SIZE_INDEX_ENTRY_MASK = defineSizeIndexEntryMask();
  344. SKIP_BEFORE_INDEX_FLAGS = defineSkipBeforeIndexFlags();
  345. SKIP_AFTER_INDEX_FLAGS = defineSkipAfterIndexFlags();
  346. SKIP_BEFORE_INDEX_SLOT = defineSkipBeforeIndexSlot();
  347. SKIP_AFTER_INDEX_SLOT = defineSkipAfterIndexSlot();
  348. SKIP_BEFORE_INDEX = defineSkipBeforeIndex();
  349. SIZE_NAME_LENGTH = defineSizeNameLength();
  350. SIZE_ROW_COLUMN_COUNT = defineSizeRowColumnCount();
  351. SIZE_ROW_VAR_COL_OFFSET = defineSizeRowVarColOffset();
  352. USAGE_MAP_TABLE_BYTE_LENGTH = defineUsageMapTableByteLength();
  353. MAX_COLUMNS_PER_TABLE = defineMaxColumnsPerTable();
  354. MAX_INDEXES_PER_TABLE = defineMaxIndexesPerTable();
  355. MAX_TABLE_NAME_LENGTH = defineMaxTableNameLength();
  356. MAX_COLUMN_NAME_LENGTH = defineMaxColumnNameLength();
  357. MAX_INDEX_NAME_LENGTH = defineMaxIndexNameLength();
  358. LEGACY_NUMERIC_INDEXES = defineLegacyNumericIndexes();
  359. CHARSET = defineCharset();
  360. DEFAULT_SORT_ORDER = defineDefaultSortOrder();
  361. PROPERTY_MAP_TYPE = definePropMapType();
  362. SIZE_TEXT_FIELD_UNIT = defineSizeTextFieldUnit();
  363. }
  364. protected abstract boolean defineReadOnly();
  365. protected abstract boolean defineIndexesSupported();
  366. protected abstract CodecType defineCodecType();
  367. protected abstract int definePageSize();
  368. protected abstract long defineMaxDatabaseSize();
  369. protected abstract int defineMaxRowSize();
  370. protected abstract int defineDataPageInitialFreeSpace();
  371. protected abstract int defineOffsetMaskedHeader();
  372. protected abstract byte[] defineHeaderMask();
  373. protected abstract int defineOffsetHeaderDate();
  374. protected abstract int defineOffsetPassword();
  375. protected abstract int defineSizePassword();
  376. protected abstract int defineOffsetSortOrder();
  377. protected abstract int defineSizeSortOrder();
  378. protected abstract int defineOffsetCodePage();
  379. protected abstract int defineOffsetEncodingKey();
  380. protected abstract int defineOffsetNextTableDefPage();
  381. protected abstract int defineOffsetNumRows();
  382. protected abstract int defineOffsetNextAutoNumber();
  383. protected abstract int defineOffsetNextComplexAutoNumber();
  384. protected abstract int defineOffsetTableType();
  385. protected abstract int defineOffsetMaxCols();
  386. protected abstract int defineOffsetNumVarCols();
  387. protected abstract int defineOffsetNumCols();
  388. protected abstract int defineOffsetNumIndexSlots();
  389. protected abstract int defineOffsetNumIndexes();
  390. protected abstract int defineOffsetOwnedPages();
  391. protected abstract int defineOffsetFreeSpacePages();
  392. protected abstract int defineOffsetIndexDefBlock();
  393. protected abstract int defineSizeIndexColumnBlock();
  394. protected abstract int defineSizeIndexInfoBlock();
  395. protected abstract int defineOffsetColumnType();
  396. protected abstract int defineOffsetColumnNumber();
  397. protected abstract int defineOffsetColumnPrecision();
  398. protected abstract int defineOffsetColumnScale();
  399. protected abstract int defineOffsetColumnSortOrder();
  400. protected abstract int defineOffsetColumnCodePage();
  401. protected abstract int defineOffsetColumnComplexId();
  402. protected abstract int defineOffsetColumnFlags();
  403. protected abstract int defineOffsetColumnExtFlags();
  404. protected abstract int defineOffsetColumnLength();
  405. protected abstract int defineOffsetColumnVariableTableIndex();
  406. protected abstract int defineOffsetColumnFixedDataOffset();
  407. protected abstract int defineOffsetColumnFixedDataRowOffset();
  408. protected abstract int defineOffsetTableDefLocation();
  409. protected abstract int defineOffsetRowStart();
  410. protected abstract int defineOffsetUsageMapStart();
  411. protected abstract int defineOffsetUsageMapPageData();
  412. protected abstract int defineOffsetReferenceMapPageNumbers();
  413. protected abstract int defineOffsetFreeSpace();
  414. protected abstract int defineOffsetNumRowsOnDataPage();
  415. protected abstract int defineMaxNumRowsOnDataPage();
  416. protected abstract int defineOffsetIndexCompressedByteCount();
  417. protected abstract int defineOffsetIndexEntryMask();
  418. protected abstract int defineOffsetPrevIndexPage();
  419. protected abstract int defineOffsetNextIndexPage();
  420. protected abstract int defineOffsetChildTailIndexPage();
  421. protected abstract int defineSizeIndexDefinition();
  422. protected abstract int defineSizeColumnHeader();
  423. protected abstract int defineSizeRowLocation();
  424. protected abstract int defineSizeLongValueDef();
  425. protected abstract int defineMaxInlineLongValueSize();
  426. protected abstract int defineMaxLongValueRowSize();
  427. protected abstract int defineMaxCompressedUnicodeSize();
  428. protected abstract int defineSizeTdefHeader();
  429. protected abstract int defineSizeTdefTrailer();
  430. protected abstract int defineSizeColumnDefBlock();
  431. protected abstract int defineSizeIndexEntryMask();
  432. protected abstract int defineSkipBeforeIndexFlags();
  433. protected abstract int defineSkipAfterIndexFlags();
  434. protected abstract int defineSkipBeforeIndexSlot();
  435. protected abstract int defineSkipAfterIndexSlot();
  436. protected abstract int defineSkipBeforeIndex();
  437. protected abstract int defineSizeNameLength();
  438. protected abstract int defineSizeRowColumnCount();
  439. protected abstract int defineSizeRowVarColOffset();
  440. protected abstract int defineUsageMapTableByteLength();
  441. protected abstract int defineMaxColumnsPerTable();
  442. protected abstract int defineMaxIndexesPerTable();
  443. protected abstract int defineMaxTableNameLength();
  444. protected abstract int defineMaxColumnNameLength();
  445. protected abstract int defineMaxIndexNameLength();
  446. protected abstract Charset defineCharset();
  447. protected abstract ColumnImpl.SortOrder defineDefaultSortOrder();
  448. protected abstract byte[] definePropMapType();
  449. protected abstract int defineSizeTextFieldUnit();
  450. protected abstract boolean defineLegacyNumericIndexes();
  451. protected abstract Map<String,Database.FileFormat> getPossibleFileFormats();
  452. public abstract boolean isSupportedDataType(DataType type);
  453. public abstract boolean isSupportedCalculatedDataType(DataType type);
  454. @Override
  455. public String toString() {
  456. return _name;
  457. }
  458. private static class Jet3Format extends JetFormat {
  459. private Jet3Format() {
  460. super("VERSION_3");
  461. }
  462. @Override
  463. protected boolean defineReadOnly() { return true; }
  464. @Override
  465. protected boolean defineIndexesSupported() { return true; }
  466. @Override
  467. protected CodecType defineCodecType() {
  468. return CodecType.JET;
  469. }
  470. @Override
  471. protected int definePageSize() { return 2048; }
  472. @Override
  473. protected long defineMaxDatabaseSize() {
  474. return (1L * 1024L * 1024L * 1024L);
  475. }
  476. @Override
  477. protected int defineMaxRowSize() { return 2012; }
  478. @Override
  479. protected int defineDataPageInitialFreeSpace() { return PAGE_SIZE - 14; }
  480. @Override
  481. protected int defineOffsetMaskedHeader() { return 24; }
  482. @Override
  483. protected byte[] defineHeaderMask() {
  484. return ByteUtil.copyOf(BASE_HEADER_MASK, BASE_HEADER_MASK.length - 2);
  485. }
  486. @Override
  487. protected int defineOffsetHeaderDate() { return -1; }
  488. @Override
  489. protected int defineOffsetPassword() { return 66; }
  490. @Override
  491. protected int defineSizePassword() { return 20; }
  492. @Override
  493. protected int defineOffsetSortOrder() { return 58; }
  494. @Override
  495. protected int defineSizeSortOrder() { return 2; }
  496. @Override
  497. protected int defineOffsetCodePage() { return 60; }
  498. @Override
  499. protected int defineOffsetEncodingKey() { return 62; }
  500. @Override
  501. protected int defineOffsetNextTableDefPage() { return 4; }
  502. @Override
  503. protected int defineOffsetNumRows() { return 12; }
  504. @Override
  505. protected int defineOffsetNextAutoNumber() { return 20; }
  506. @Override
  507. protected int defineOffsetNextComplexAutoNumber() { return -1; }
  508. @Override
  509. protected int defineOffsetTableType() { return 20; }
  510. @Override
  511. protected int defineOffsetMaxCols() { return 21; }
  512. @Override
  513. protected int defineOffsetNumVarCols() { return 23; }
  514. @Override
  515. protected int defineOffsetNumCols() { return 25; }
  516. @Override
  517. protected int defineOffsetNumIndexSlots() { return 27; }
  518. @Override
  519. protected int defineOffsetNumIndexes() { return 31; }
  520. @Override
  521. protected int defineOffsetOwnedPages() { return 35; }
  522. @Override
  523. protected int defineOffsetFreeSpacePages() { return 39; }
  524. @Override
  525. protected int defineOffsetIndexDefBlock() { return 43; }
  526. @Override
  527. protected int defineSizeIndexColumnBlock() { return 39; }
  528. @Override
  529. protected int defineSizeIndexInfoBlock() { return 20; }
  530. @Override
  531. protected int defineOffsetColumnType() { return 0; }
  532. @Override
  533. protected int defineOffsetColumnNumber() { return 1; }
  534. @Override
  535. protected int defineOffsetColumnPrecision() { return 11; }
  536. @Override
  537. protected int defineOffsetColumnScale() { return 12; }
  538. @Override
  539. protected int defineOffsetColumnSortOrder() { return 9; }
  540. @Override
  541. protected int defineOffsetColumnCodePage() { return 11; }
  542. @Override
  543. protected int defineOffsetColumnComplexId() { return -1; }
  544. @Override
  545. protected int defineOffsetColumnFlags() { return 13; }
  546. @Override
  547. protected int defineOffsetColumnExtFlags() { return -1; }
  548. @Override
  549. protected int defineOffsetColumnLength() { return 16; }
  550. @Override
  551. protected int defineOffsetColumnVariableTableIndex() { return 3; }
  552. @Override
  553. protected int defineOffsetColumnFixedDataOffset() { return 14; }
  554. @Override
  555. protected int defineOffsetColumnFixedDataRowOffset() { return 1; }
  556. @Override
  557. protected int defineOffsetTableDefLocation() { return 4; }
  558. @Override
  559. protected int defineOffsetRowStart() { return 10; }
  560. @Override
  561. protected int defineOffsetUsageMapStart() { return 5; }
  562. @Override
  563. protected int defineOffsetUsageMapPageData() { return 4; }
  564. @Override
  565. protected int defineOffsetReferenceMapPageNumbers() { return 1; }
  566. @Override
  567. protected int defineOffsetFreeSpace() { return 2; }
  568. @Override
  569. protected int defineOffsetNumRowsOnDataPage() { return 8; }
  570. @Override
  571. protected int defineMaxNumRowsOnDataPage() { return 255; }
  572. @Override
  573. protected int defineOffsetIndexCompressedByteCount() { return 20; }
  574. @Override
  575. protected int defineOffsetIndexEntryMask() { return 22; }
  576. @Override
  577. protected int defineOffsetPrevIndexPage() { return 8; }
  578. @Override
  579. protected int defineOffsetNextIndexPage() { return 12; }
  580. @Override
  581. protected int defineOffsetChildTailIndexPage() { return 16; }
  582. @Override
  583. protected int defineSizeIndexDefinition() { return 8; }
  584. @Override
  585. protected int defineSizeColumnHeader() { return 18; }
  586. @Override
  587. protected int defineSizeRowLocation() { return 2; }
  588. @Override
  589. protected int defineSizeLongValueDef() { return 12; }
  590. @Override
  591. protected int defineMaxInlineLongValueSize() { return 64; }
  592. @Override
  593. protected int defineMaxLongValueRowSize() { return 2032; }
  594. @Override
  595. protected int defineMaxCompressedUnicodeSize() { return 1024; }
  596. @Override
  597. protected int defineSizeTdefHeader() { return 43; }
  598. @Override
  599. protected int defineSizeTdefTrailer() { return 2; }
  600. @Override
  601. protected int defineSizeColumnDefBlock() { return 25; }
  602. @Override
  603. protected int defineSizeIndexEntryMask() { return 226; }
  604. @Override
  605. protected int defineSkipBeforeIndexFlags() { return 0; }
  606. @Override
  607. protected int defineSkipAfterIndexFlags() { return 0; }
  608. @Override
  609. protected int defineSkipBeforeIndexSlot() { return 0; }
  610. @Override
  611. protected int defineSkipAfterIndexSlot() { return 0; }
  612. @Override
  613. protected int defineSkipBeforeIndex() { return 0; }
  614. @Override
  615. protected int defineSizeNameLength() { return 1; }
  616. @Override
  617. protected int defineSizeRowColumnCount() { return 1; }
  618. @Override
  619. protected int defineSizeRowVarColOffset() { return 1; }
  620. @Override
  621. protected int defineUsageMapTableByteLength() { return 128; }
  622. @Override
  623. protected int defineMaxColumnsPerTable() { return 255; }
  624. @Override
  625. protected int defineMaxIndexesPerTable() { return 32; }
  626. @Override
  627. protected int defineMaxTableNameLength() { return 64; }
  628. @Override
  629. protected int defineMaxColumnNameLength() { return 64; }
  630. @Override
  631. protected int defineMaxIndexNameLength() { return 64; }
  632. @Override
  633. protected boolean defineLegacyNumericIndexes() { return true; }
  634. @Override
  635. protected Charset defineCharset() { return Charset.defaultCharset(); }
  636. @Override
  637. protected ColumnImpl.SortOrder defineDefaultSortOrder() {
  638. return ColumnImpl.GENERAL_97_SORT_ORDER;
  639. }
  640. @Override
  641. protected byte[] definePropMapType() {
  642. return PROPERTY_MAP_TYPES[1];
  643. }
  644. @Override
  645. protected int defineSizeTextFieldUnit() { return 1; }
  646. @Override
  647. protected Map<String,Database.FileFormat> getPossibleFileFormats()
  648. {
  649. return PossibleFileFormats.POSSIBLE_VERSION_3;
  650. }
  651. @Override
  652. public boolean isSupportedDataType(DataType type) {
  653. return ((type != DataType.COMPLEX_TYPE) &&
  654. (type != DataType.BIG_INT));
  655. }
  656. @Override
  657. public boolean isSupportedCalculatedDataType(DataType type) {
  658. return false;
  659. }
  660. }
  661. private static class Jet4Format extends JetFormat {
  662. private Jet4Format() {
  663. this("VERSION_4");
  664. }
  665. private Jet4Format(String name) {
  666. super(name);
  667. }
  668. @Override
  669. protected boolean defineReadOnly() { return false; }
  670. @Override
  671. protected boolean defineIndexesSupported() { return true; }
  672. @Override
  673. protected CodecType defineCodecType() {
  674. return CodecType.JET;
  675. }
  676. @Override
  677. protected int definePageSize() { return 4096; }
  678. @Override
  679. protected long defineMaxDatabaseSize() {
  680. return (2L * 1024L * 1024L * 1024L);
  681. }
  682. @Override
  683. protected int defineMaxRowSize() { return 4060; }
  684. @Override
  685. protected int defineDataPageInitialFreeSpace() { return PAGE_SIZE - 14; }
  686. @Override
  687. protected int defineOffsetMaskedHeader() { return 24; }
  688. @Override
  689. protected byte[] defineHeaderMask() { return BASE_HEADER_MASK; }
  690. @Override
  691. protected int defineOffsetHeaderDate() { return 114; }
  692. @Override
  693. protected int defineOffsetPassword() { return 66; }
  694. @Override
  695. protected int defineSizePassword() { return 40; }
  696. @Override
  697. protected int defineOffsetSortOrder() { return 110; }
  698. @Override
  699. protected int defineSizeSortOrder() { return 4; }
  700. @Override
  701. protected int defineOffsetCodePage() { return 60; }
  702. @Override
  703. protected int defineOffsetEncodingKey() { return 62; }
  704. @Override
  705. protected int defineOffsetNextTableDefPage() { return 4; }
  706. @Override
  707. protected int defineOffsetNumRows() { return 16; }
  708. @Override
  709. protected int defineOffsetNextAutoNumber() { return 20; }
  710. @Override
  711. protected int defineOffsetNextComplexAutoNumber() { return -1; }
  712. @Override
  713. protected int defineOffsetTableType() { return 40; }
  714. @Override
  715. protected int defineOffsetMaxCols() { return 41; }
  716. @Override
  717. protected int defineOffsetNumVarCols() { return 43; }
  718. @Override
  719. protected int defineOffsetNumCols() { return 45; }
  720. @Override
  721. protected int defineOffsetNumIndexSlots() { return 47; }
  722. @Override
  723. protected int defineOffsetNumIndexes() { return 51; }
  724. @Override
  725. protected int defineOffsetOwnedPages() { return 55; }
  726. @Override
  727. protected int defineOffsetFreeSpacePages() { return 59; }
  728. @Override
  729. protected int defineOffsetIndexDefBlock() { return 63; }
  730. @Override
  731. protected int defineSizeIndexColumnBlock() { return 52; }
  732. @Override
  733. protected int defineSizeIndexInfoBlock() { return 28; }
  734. @Override
  735. protected int defineOffsetColumnType() { return 0; }
  736. @Override
  737. protected int defineOffsetColumnNumber() { return 5; }
  738. @Override
  739. protected int defineOffsetColumnPrecision() { return 11; }
  740. @Override
  741. protected int defineOffsetColumnScale() { return 12; }
  742. @Override
  743. protected int defineOffsetColumnSortOrder() { return 11; }
  744. @Override
  745. protected int defineOffsetColumnCodePage() { return -1; }
  746. @Override
  747. protected int defineOffsetColumnComplexId() { return -1; }
  748. @Override
  749. protected int defineOffsetColumnFlags() { return 15; }
  750. @Override
  751. protected int defineOffsetColumnExtFlags() { return 16; }
  752. @Override
  753. protected int defineOffsetColumnLength() { return 23; }
  754. @Override
  755. protected int defineOffsetColumnVariableTableIndex() { return 7; }
  756. @Override
  757. protected int defineOffsetColumnFixedDataOffset() { return 21; }
  758. @Override
  759. protected int defineOffsetColumnFixedDataRowOffset() { return 2; }
  760. @Override
  761. protected int defineOffsetTableDefLocation() { return 4; }
  762. @Override
  763. protected int defineOffsetRowStart() { return 14; }
  764. @Override
  765. protected int defineOffsetUsageMapStart() { return 5; }
  766. @Override
  767. protected int defineOffsetUsageMapPageData() { return 4; }
  768. @Override
  769. protected int defineOffsetReferenceMapPageNumbers() { return 1; }
  770. @Override
  771. protected int defineOffsetFreeSpace() { return 2; }
  772. @Override
  773. protected int defineOffsetNumRowsOnDataPage() { return 12; }
  774. @Override
  775. protected int defineMaxNumRowsOnDataPage() { return 255; }
  776. @Override
  777. protected int defineOffsetIndexCompressedByteCount() { return 24; }
  778. @Override
  779. protected int defineOffsetIndexEntryMask() { return 27; }
  780. @Override
  781. protected int defineOffsetPrevIndexPage() { return 12; }
  782. @Override
  783. protected int defineOffsetNextIndexPage() { return 16; }
  784. @Override
  785. protected int defineOffsetChildTailIndexPage() { return 20; }
  786. @Override
  787. protected int defineSizeIndexDefinition() { return 12; }
  788. @Override
  789. protected int defineSizeColumnHeader() { return 25; }
  790. @Override
  791. protected int defineSizeRowLocation() { return 2; }
  792. @Override
  793. protected int defineSizeLongValueDef() { return 12; }
  794. @Override
  795. protected int defineMaxInlineLongValueSize() { return 64; }
  796. @Override
  797. protected int defineMaxLongValueRowSize() { return 4076; }
  798. @Override
  799. protected int defineMaxCompressedUnicodeSize() { return 1024; }
  800. @Override
  801. protected int defineSizeTdefHeader() { return 63; }
  802. @Override
  803. protected int defineSizeTdefTrailer() { return 2; }
  804. @Override
  805. protected int defineSizeColumnDefBlock() { return 25; }
  806. @Override
  807. protected int defineSizeIndexEntryMask() { return 453; }
  808. @Override
  809. protected int defineSkipBeforeIndexFlags() { return 4; }
  810. @Override
  811. protected int defineSkipAfterIndexFlags() { return 5; }
  812. @Override
  813. protected int defineSkipBeforeIndexSlot() { return 4; }
  814. @Override
  815. protected int defineSkipAfterIndexSlot() { return 4; }
  816. @Override
  817. protected int defineSkipBeforeIndex() { return 4; }
  818. @Override
  819. protected int defineSizeNameLength() { return 2; }
  820. @Override
  821. protected int defineSizeRowColumnCount() { return 2; }
  822. @Override
  823. protected int defineSizeRowVarColOffset() { return 2; }
  824. @Override
  825. protected int defineUsageMapTableByteLength() { return 64; }
  826. @Override
  827. protected int defineMaxColumnsPerTable() { return 255; }
  828. @Override
  829. protected int defineMaxIndexesPerTable() { return 32; }
  830. @Override
  831. protected int defineMaxTableNameLength() { return 64; }
  832. @Override
  833. protected int defineMaxColumnNameLength() { return 64; }
  834. @Override
  835. protected int defineMaxIndexNameLength() { return 64; }
  836. @Override
  837. protected boolean defineLegacyNumericIndexes() { return true; }
  838. @Override
  839. protected Charset defineCharset() { return StandardCharsets.UTF_16LE; }
  840. @Override
  841. protected ColumnImpl.SortOrder defineDefaultSortOrder() {
  842. return ColumnImpl.GENERAL_LEGACY_SORT_ORDER;
  843. }
  844. @Override
  845. protected byte[] definePropMapType() {
  846. return PROPERTY_MAP_TYPES[0];
  847. }
  848. @Override
  849. protected int defineSizeTextFieldUnit() { return TEXT_FIELD_UNIT_SIZE; }
  850. @Override
  851. protected Map<String,Database.FileFormat> getPossibleFileFormats()
  852. {
  853. return PossibleFileFormats.POSSIBLE_VERSION_4;
  854. }
  855. @Override
  856. public boolean isSupportedDataType(DataType type) {
  857. return ((type != DataType.COMPLEX_TYPE) &&
  858. (type != DataType.BIG_INT));
  859. }
  860. @Override
  861. public boolean isSupportedCalculatedDataType(DataType type) {
  862. return false;
  863. }
  864. }
  865. private static final class MSISAMFormat extends Jet4Format {
  866. private MSISAMFormat() {
  867. super("MSISAM");
  868. }
  869. @Override
  870. protected CodecType defineCodecType() {
  871. return CodecType.MSISAM;
  872. }
  873. @Override
  874. protected Map<String,Database.FileFormat> getPossibleFileFormats()
  875. {
  876. return PossibleFileFormats.POSSIBLE_VERSION_MSISAM;
  877. }
  878. }
  879. private static class Jet12Format extends Jet4Format {
  880. private Jet12Format() {
  881. super("VERSION_12");
  882. }
  883. private Jet12Format(String name) {
  884. super(name);
  885. }
  886. @Override
  887. protected CodecType defineCodecType() {
  888. return CodecType.OFFICE;
  889. }
  890. @Override
  891. protected boolean defineLegacyNumericIndexes() { return false; }
  892. @Override
  893. protected Map<String,Database.FileFormat> getPossibleFileFormats() {
  894. return PossibleFileFormats.POSSIBLE_VERSION_12;
  895. }
  896. @Override
  897. protected int defineOffsetNextComplexAutoNumber() { return 28; }
  898. @Override
  899. protected int defineOffsetColumnComplexId() { return 11; }
  900. @Override
  901. public boolean isSupportedDataType(DataType type) {
  902. return (type != DataType.BIG_INT);
  903. }
  904. @Override
  905. public boolean isSupportedCalculatedDataType(DataType type) {
  906. return false;
  907. }
  908. }
  909. private static class Jet14Format extends Jet12Format {
  910. private Jet14Format() {
  911. super("VERSION_14");
  912. }
  913. private Jet14Format(String name) {
  914. super(name);
  915. }
  916. @Override
  917. protected ColumnImpl.SortOrder defineDefaultSortOrder() {
  918. return ColumnImpl.GENERAL_SORT_ORDER;
  919. }
  920. @Override
  921. protected byte[] definePropMapType() {
  922. return PROPERTY_MAP_TYPES[0];
  923. }
  924. @Override
  925. protected Map<String,Database.FileFormat> getPossibleFileFormats() {
  926. return PossibleFileFormats.POSSIBLE_VERSION_14;
  927. }
  928. @Override
  929. public boolean isSupportedCalculatedDataType(DataType type) {
  930. return V14_CALC_TYPES.contains(type);
  931. }
  932. }
  933. private static class Jet16Format extends Jet14Format {
  934. private Jet16Format() {
  935. super("VERSION_16");
  936. }
  937. private Jet16Format(String name) {
  938. super(name);
  939. }
  940. @Override
  941. public boolean isSupportedDataType(DataType type) {
  942. return true;
  943. }
  944. @Override
  945. protected Map<String,Database.FileFormat> getPossibleFileFormats() {
  946. return PossibleFileFormats.POSSIBLE_VERSION_16;
  947. }
  948. @Override
  949. public boolean isSupportedCalculatedDataType(DataType type) {
  950. return V16_CALC_TYPES.contains(type);
  951. }
  952. }
  953. private static final class Jet17Format extends Jet16Format {
  954. private Jet17Format() {
  955. super("VERSION_17");
  956. }
  957. @Override
  958. public boolean isSupportedDataType(DataType type) {
  959. return true;
  960. }
  961. @Override
  962. protected Map<String,Database.FileFormat> getPossibleFileFormats() {
  963. return PossibleFileFormats.POSSIBLE_VERSION_17;
  964. }
  965. }
  966. }