Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * 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.hadoop.hbase.regionserver;
 
 import java.util.List;
 import java.util.Map;
 
A MultiRowProcessor that performs multiple puts and deletes.
 
   Collection<byte[]> rowsToLock;
 
                             Collection<byte[]> rowsToLock) {
     this. = rowsToLock;
     this. = mutations;
   }
 
   @Override
   public Collection<byte[]> getRowsToLock() {
     return ;
   }
 
   @Override
   public boolean readOnly() {
     return false;
   }
   
   @Override
     return MultiRowMutationProcessorResponse.getDefaultInstance();
   }
 
   @Override
   public void process(long now,
                       HRegion region,
                       List<MutationmutationsToApply,
                       WALEdit walEditthrows IOException {
     byte[] byteNow = Bytes.toBytes(now);
     // Check mutations
     for (Mutation m : this.) {
       if (m instanceof Put) {
         Map<byte[], List<Cell>> familyMap = m.getFamilyCellMap();
         region.checkFamilies(familyMap.keySet());
         region.checkTimestamps(familyMapnow);
         region.updateKVTimestamps(familyMap.values(), byteNow);
       } else if (m instanceof Delete) {
         Delete d = (Deletem;
         region.prepareDelete(d);
         region.prepareDeleteTimestamps(dd.getFamilyCellMap(), byteNow);
       } else {
         throw new DoNotRetryIOException("Action must be Put or Delete. But was: "
             + m.getClass().getName());
       }
       mutationsToApply.add(m);
     }
     // Apply edits to a single WALEdit
     for (Mutation m : ) {
       for (List<Cellcells : m.getFamilyCellMap().values()) {
         boolean writeToWAL = m.getDurability() != .;
         for (Cell cell : cells) {
           KeyValue kv = KeyValueUtil.ensureKeyValue(cell);
          if (writeToWALwalEdit.add(kv);
        }
      }
    }
  }
  public void preProcess(HRegion regionWALEdit walEditthrows IOException {
    RegionCoprocessorHost coprocessorHost = region.getCoprocessorHost();
    if (coprocessorHost != null) {
      for (Mutation m : ) {
        if (m instanceof Put) {
          if (coprocessorHost.prePut((PutmwalEditm.getDurability())) {
            // by pass everything
            return;
          }
        } else if (m instanceof Delete) {
          Delete d = (Deletem;
          region.prepareDelete(d);
          if (coprocessorHost.preDelete(dwalEditd.getDurability())) {
            // by pass everything
            return;
          }
        }
      }
    }
  }
  public void preBatchMutate(HRegion regionWALEdit walEditthrows IOException {
    // TODO we should return back the status of this hook run to HRegion so that those Mutations
    // with OperationStatus as SUCCESS or FAILURE should not get applied to memstore.
    RegionCoprocessorHost coprocessorHost = region.getCoprocessorHost();
    OperationStatus[] opStatus = new OperationStatus[.size()];
    Arrays.fill(opStatus.);
    WALEdit[] walEditsFromCP = new WALEdit[.size()];
    if (coprocessorHost != null) {
          .toArray(new Mutation[.size()]), opStatuswalEditsFromCP, 0,
          .size());
      coprocessorHost.preBatchMutate();
    }
    // Apply edits to a single WALEdit
    for (int i = 0; i < .size(); i++) {
      if (opStatus[i] == .) {
        // Other OperationStatusCode means that Mutation is already succeeded or failed in CP hook
        // itself. No need to apply again to region
        if (walEditsFromCP[i] != null) {
          // Add the WALEdit created by CP hook
          for (KeyValue walKv : walEditsFromCP[i].getKeyValues()) {
            walEdit.add(walKv);
          }
        }
      }
    }
  }
  public void postBatchMutate(HRegion regionthrows IOException {
    RegionCoprocessorHost coprocessorHost = region.getCoprocessorHost();
    if (coprocessorHost != null) {
      assert  != null;
      // Use the same miniBatch state used to call the preBatchMutate()
      coprocessorHost.postBatchMutate();
    }
  }
  public void postProcess(HRegion regionWALEdit walEditboolean successthrows IOException {
    RegionCoprocessorHost coprocessorHost = region.getCoprocessorHost();
    if (coprocessorHost != null) {
      for (Mutation m : ) {
        if (m instanceof Put) {
          coprocessorHost.postPut((PutmwalEditm.getDurability());
        } else if (m instanceof Delete) {
          coprocessorHost.postDelete((DeletemwalEditm.getDurability());
        }
      }
      // At the end call the CP hook postBatchMutateIndispensably
      if ( != null) {
        // Directly calling this hook, with out calling pre/postBatchMutate() when Processor do a
        // read only process. Then no need to call this batch based CP hook also.
        coprocessorHost.postBatchMutateIndispensably(success);
      }
    }
  }
    return MultiRowMutationProcessorRequest.getDefaultInstance();
  }
    //nothing
  }
  public Durability useDurability() {
    // return true when at least one mutation requested a WAL flush (default)
    Durability durability = .;
    for (Mutation m : ) {
      if (m.getDurability().ordinal() > durability.ordinal()) {
        durability = m.getDurability();
      }
    }
    return durability;
  }
New to GrepCode? Check out our FAQ X