Java tutorial
/* * Copyright 2012 LinkedIn Corp. * * 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. */ package azkaban.viewer.hdfs; import java.util.EnumSet; import java.util.Set; import java.io.IOException; import java.io.OutputStream; import java.io.PrintWriter; import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.fs.FileSystem; import org.apache.hadoop.fs.Path; import org.apache.hadoop.fs.permission.AccessControlException; import azkaban.viewer.hdfs.AzkabanSequenceFileReader; public abstract class SequenceFileViewer extends HdfsFileViewer { protected abstract Set<Capability> getCapabilities(AzkabanSequenceFileReader.Reader reader); protected abstract void displaySequenceFile(AzkabanSequenceFileReader.Reader reader, PrintWriter output, int startLine, int endLine) throws IOException; @Override public Set<Capability> getCapabilities(FileSystem fs, Path path) throws AccessControlException { Set<Capability> result = EnumSet.noneOf(Capability.class); AzkabanSequenceFileReader.Reader reader = null; try { reader = new AzkabanSequenceFileReader.Reader(fs, path, new Configuration()); result = getCapabilities(reader); } catch (AccessControlException e) { throw e; } catch (IOException e) { return EnumSet.noneOf(Capability.class); } finally { if (reader != null) { try { reader.close(); } catch (IOException e) { e.printStackTrace(); } } } return result; } @Override public void displayFile(FileSystem fs, Path file, OutputStream outputStream, int startLine, int endLine) throws IOException { AzkabanSequenceFileReader.Reader reader = null; PrintWriter writer = new PrintWriter(outputStream); try { reader = new AzkabanSequenceFileReader.Reader(fs, file, new Configuration()); displaySequenceFile(reader, writer, startLine, endLine); } catch (IOException e) { writer.write("Error opening sequence file " + e); throw e; } finally { if (reader != null) { reader.close(); } } } }