You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@pig.apache.org by da...@apache.org on 2014/10/30 18:27:19 UTC
svn commit: r1635556 -
/pig/branches/branch-0.14/src/org/apache/pig/backend/hadoop/hbase/TableSplitComparable.java
Author: daijy
Date: Thu Oct 30 17:27:19 2014
New Revision: 1635556
URL: http://svn.apache.org/r1635556
Log:
PIG-2495: Using merge JOIN from a HBaseStorage produces an error
Added:
pig/branches/branch-0.14/src/org/apache/pig/backend/hadoop/hbase/TableSplitComparable.java
Added: pig/branches/branch-0.14/src/org/apache/pig/backend/hadoop/hbase/TableSplitComparable.java
URL: http://svn.apache.org/viewvc/pig/branches/branch-0.14/src/org/apache/pig/backend/hadoop/hbase/TableSplitComparable.java?rev=1635556&view=auto
==============================================================================
--- pig/branches/branch-0.14/src/org/apache/pig/backend/hadoop/hbase/TableSplitComparable.java (added)
+++ pig/branches/branch-0.14/src/org/apache/pig/backend/hadoop/hbase/TableSplitComparable.java Thu Oct 30 17:27:19 2014
@@ -0,0 +1,88 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with this
+ * work for additional information regarding copyright ownership. The ASF
+ * licenses this file to you 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.
+ */
+package org.apache.pig.backend.hadoop.hbase;
+
+import java.io.DataInput;
+import java.io.DataOutput;
+import java.io.IOException;
+
+import org.apache.hadoop.io.WritableComparable;
+import org.apache.hadoop.hbase.mapreduce.TableSplit;
+
+public class TableSplitComparable implements WritableComparable<TableSplit> {
+
+ TableSplit tsplit;
+
+ // need a default constructor to be able to de-serialize using just the Writable interface
+ public TableSplitComparable() {
+ tsplit = new TableSplit();
+ }
+
+ public TableSplitComparable(TableSplit tsplit) {
+ this.tsplit = tsplit;
+ }
+
+ @Override
+ public void readFields(DataInput in) throws IOException {
+ tsplit.readFields(in);
+ }
+
+ @Override
+ public void write(DataOutput out) throws IOException {
+ tsplit.write(out);
+ }
+
+ @Override
+ public int compareTo(TableSplit split) {
+ return tsplit.compareTo((TableSplit) split);
+ }
+
+ @Override
+ public String toString() {
+ return "TableSplitComparable : " + tsplit.toString();
+ }
+
+ /* (non-Javadoc)
+ * @see java.lang.Object#hashCode()
+ */
+ @Override
+ public int hashCode() {
+ return ((tsplit == null) ? 0 : tsplit.hashCode());
+ }
+
+ /* (non-Javadoc)
+ * @see java.lang.Object#equals(java.lang.Object)
+ */
+ @Override
+ public boolean equals(Object obj) {
+ if (this == obj)
+ return true;
+ if (obj == null)
+ return false;
+ if (getClass() != obj.getClass())
+ return false;
+ TableSplitComparable other = (TableSplitComparable) obj;
+ if (tsplit == null) {
+ if (other.tsplit != null)
+ return false;
+ } else if (!tsplit.equals(other.tsplit)) {
+ return false;
+ }
+ return true;
+ }
+
+}