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.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 azkaban.viewer.hdfs.AzkabanSequenceFileReader; public abstract class HdfsSequenceFileViewer implements HdfsFileViewer { protected abstract boolean canReadFile(AzkabanSequenceFileReader.Reader reader) throws Exception; protected abstract void displaySequenceFile(AzkabanSequenceFileReader.Reader reader, PrintWriter output, int startLine, int endLine) throws IOException; public boolean canReadFile(FileSystem fs, Path file) { boolean result = false; AzkabanSequenceFileReader.Reader reader = null; try { reader = new AzkabanSequenceFileReader.Reader(fs, file, new Configuration()); result = canReadFile(reader); } catch (Exception e) { return false; } finally { if (reader != null) { try { reader.close(); } catch (IOException e) { } } } return result; } 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(); } } } }