Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  package org.apache.helix.manager.zk;
  
  /*
   * 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.
  */
 
 import java.util.List;
 import java.util.Map;
 import java.util.Set;
 
 
 public abstract class Cache<T> {
   final ReadWriteLock _lock;
 
   public Cache() {
      = new ReentrantReadWriteLock();
      = new ConcurrentHashMap<StringZNode>();
   }
 
   public void addToParentChildSet(String parentPathString childName) {
     ZNode znode = .get(parentPath);
     if (znode != null) {
       znode.addChild(childName);
     }
   }
 
   public void addToParentChildSet(String parentPathList<StringchildNames) {
     if (childNames != null && !childNames.isEmpty()) {
       ZNode znode = .get(parentPath);
       if (znode != null) {
         znode.addChildren(childNames);
       }
     }
   }
 
   public void removeFromParentChildSet(String parentPathString name) {
     ZNode zNode = .get(parentPath);
     if (zNode != null) {
       zNode.removeChild(name);
     }
   }
 
   public boolean exists(String path) {
     return .containsKey(path);
   }
 
   public ZNode get(String path) {
     try {
       .readLock().lock();
       return .get(path);
     } finally {
       .readLock().unlock();
     }
   }
 
   public void lockWrite() {
     .writeLock().lock();
   }
 
   public void unlockWrite() {
     .writeLock().unlock();
   }
 
   public void lockRead() {
     .readLock().lock();
   }
 
   public void unlockRead() {
     .readLock().unlock();
   }
 
   public void purgeRecursive(String path) {
     try {
       .writeLock().lock();
 
       String parentPath = HelixUtil.getZkParentPath(path);
       String name = HelixUtil.getZkName(path);
      removeFromParentChildSet(parentPathname);
      ZNode znode = .remove(path);
      if (znode != null) {
        // recursively remove children nodes
        Set<StringchildNames = znode.getChildSet();
        for (String childName : childNames) {
          String childPath = path + "/" + childName;
          purgeRecursive(childPath);
        }
      }
    } finally {
      .writeLock().unlock();
    }
  }
  public void reset() {
    try {
      .writeLock().lock();
      .clear();
    } finally {
      .writeLock().unlock();
    }
  }
  public abstract void update(String path, T dataStat stat);
  public abstract void updateRecursive(String path);
  // debug
  public Map<StringZNodegetCache() {
    return ;
  }
New to GrepCode? Check out our FAQ X