// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef SYNC_SYNCABLE_SYNCABLE_COLUMNS_H_
#define SYNC_SYNCABLE_SYNCABLE_COLUMNS_H_
#include "sync/syncable/entry_kernel.h"
#include "sync/syncable/syncable_changes_version.h"
namespace syncer {
namespace syncable {
struct ColumnSpec {
const char* name;
const char* spec;
};
// Must be in exact same order as fields in entry_kernel.h.
static const ColumnSpec g_metas_columns[] = {
//////////////////////////////////////
// int64s
{"metahandle", "bigint primary key ON CONFLICT FAIL"},
{"base_version", "bigint default " CHANGES_VERSION_STRING},
{"server_version", "bigint default 0"},
// This is the item ID that we store for the embedding application.
{"local_external_id", "bigint default 0"},
{"transaction_version", "bigint default 0"},
// These timestamps are kept in the same format as that of the
// protocol (ms since Unix epoch).
{"mtime", "bigint default 0"},
{"server_mtime", "bigint default 0"},
{"ctime", "bigint default 0"},
{"server_ctime", "bigint default 0"},
//////////////////////////////////////
// Ids
{"id", "varchar(255) default \"r\""},
{"parent_id", "varchar(255) default \"r\""},
{"server_parent_id", "varchar(255) default \"r\""},
//////////////////////////////////////
// bits
{"is_unsynced", "bit default 0"},
{"is_unapplied_update", "bit default 0"},
{"is_del", "bit default 0"},
{"is_dir", "bit default 0"},
{"server_is_dir", "bit default 0"},
{"server_is_del", "bit default 0"},
//////////////////////////////////////
// Strings
{"non_unique_name", "varchar"},
{"server_non_unique_name", "varchar(255)"},
{"unique_server_tag", "varchar"},
{"unique_client_tag", "varchar"},
{"unique_bookmark_tag", "varchar"},
//////////////////////////////////////
// Blobs (serialized protos).
{"specifics", "blob"},
{"server_specifics", "blob"},
{"base_server_specifics", "blob"},
//////////////////////////////////////
// Blobs (positions).
{"server_unique_position", "blob"},
{"unique_position", "blob"},
//////////////////////////////////////
// AttachmentMetadata is a proto that contains all the metadata associated
// with an entry's attachments. Each entry has only one AttachmentMetadata
// proto. We store a single proto per entry (as opposed to one for each
// attachment) because it simplifies the database schema and implementation of
// DirectoryBackingStore.
{"attachment_metadata", "blob"},
{"server_attachment_metadata", "blob"}
};
// At least enforce that there are equal number of column names and fields.
COMPILE_ASSERT(arraysize(g_metas_columns) >= FIELD_COUNT, missing_column_name);
COMPILE_ASSERT(arraysize(g_metas_columns) <= FIELD_COUNT, extra_column_names);
static inline const char* ColumnName(int field) {
DCHECK(field < BEGIN_TEMPS);
return g_metas_columns[field].name;
}
} // namespace syncable
} // namespace syncer
#endif // SYNC_SYNCABLE_SYNCABLE_COLUMNS_H_