/**
* Copyright (C) 2009-2013 FoundationDB, LLC
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package com.foundationdb.server.store.format.tuple;
import com.foundationdb.ais.model.Group;
import com.foundationdb.ais.model.HasStorage;
import com.foundationdb.ais.protobuf.AISProtobuf.Storage;
import com.foundationdb.ais.protobuf.FDBProtobuf;
import com.foundationdb.server.store.format.StorageFormat;
import com.foundationdb.server.store.format.StorageFormatRegistry;
import com.foundationdb.sql.parser.StorageFormatNode;
public class TupleStorageFormat extends StorageFormat<TupleStorageDescription>
{
private final static String storageFormat = "tuple";
private TupleStorageFormat() {
}
public static void register(StorageFormatRegistry registry) {
registry.registerStorageFormat(FDBProtobuf.tupleUsage, storageFormat, TupleStorageDescription.class, new TupleStorageFormat());
}
public TupleStorageDescription readProtobuf(Storage pbStorage, HasStorage forObject, TupleStorageDescription storageDescription) {
if (storageDescription == null) {
storageDescription = new TupleStorageDescription(forObject, storageFormat);
}
storageDescription.setUsage(pbStorage.getExtension(FDBProtobuf.tupleUsage));
return storageDescription;
}
public TupleStorageDescription parseSQL(StorageFormatNode node, HasStorage forObject) {
TupleStorageDescription storageDescription = new TupleStorageDescription(forObject, storageFormat);
boolean keyOnly = true;
if (forObject instanceof Group) {
String keyOnlyOption = node.getOptions().get("key_only");
keyOnly = (keyOnlyOption != null) && Boolean.valueOf(keyOnlyOption);
}
storageDescription.setUsage(keyOnly ?
FDBProtobuf.TupleUsage.KEY_ONLY :
FDBProtobuf.TupleUsage.KEY_AND_ROW);
return storageDescription;
}
}