package com.linkedin.databus2.schemas; /* * * Copyright 2013 LinkedIn Corp. All rights reserved * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * */ /** * Represents a logical object to uniquely identify a schema * Given a databusSourceName and a version, there must exist a unique schema * i.e., given (EspressoDB.IdNamePair,1) => unique schema * @author pganti * */ public class VersionedTableSchemaLookup { private String _databusSourceName; private int _version; public VersionedTableSchemaLookup(String databusSourceName, int version) { super(); _databusSourceName = databusSourceName; _version = version; } public String getDatabusSourceName() { return _databusSourceName; } public int getVersion() { return _version; } @Override public String toString() { return "(" + getDatabusSourceName() + "," + getVersion() + ")"; } @Override public boolean equals(Object o) { if (null == o || ! (o instanceof VersionedTableSchemaLookup)) return false; VersionedTableSchemaLookup other = (VersionedTableSchemaLookup)o; return _databusSourceName.equals(other.getDatabusSourceName()) && _version == other.getVersion(); } @Override public int hashCode() { return _databusSourceName.hashCode() << 16 + _version; } }