blob: ed9f8f35bb70d1b9272a7a265c0c5ef2b9cb80d9 [file] [log] [blame]
/*
* 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.tools.ant.taskdefs.optional.native2ascii;
import java.io.File;
import org.apache.tools.ant.BuildException;
import org.apache.tools.ant.ProjectComponent;
import org.apache.tools.ant.taskdefs.optional.Native2Ascii;
import org.apache.tools.ant.types.Commandline;
/**
* encapsulates the handling common to diffent Native2Asciiadapter
* implementations.
*
* @since Ant 1.6.3
*/
public abstract class DefaultNative2Ascii implements Native2AsciiAdapter {
/** No-arg constructor. */
public DefaultNative2Ascii() {
}
/**
* Splits the task into setting up the command line switches
* @param args the native 2 ascii arguments.
* @param srcFile the source file.
* @param destFile the destination file.
* @return run if the conversion was successful.
* @throws BuildException if there is a problem.
* (delegated to {@link #setup setup}), adding the file names
* (delegated to {@link #addFiles addFiles}) and running the tool
* (delegated to {@link #run run}).
*/
public final boolean convert(Native2Ascii args, File srcFile,
File destFile) throws BuildException {
Commandline cmd = new Commandline();
setup(cmd, args);
addFiles(cmd, args, srcFile, destFile);
return run(cmd, args);
}
/**
* Sets up the initial command line.
*
* <p>only the -encoding argument and nested arg elements get
* handled here.</p>
*
* @param cmd Command line to add to
* @param args provides the user-setting and access to Ant's
* logging system.
* @throws BuildException if there was a problem.
*/
protected void setup(Commandline cmd, Native2Ascii args)
throws BuildException {
if (args.getEncoding() != null) {
cmd.createArgument().setValue("-encoding");
cmd.createArgument().setValue(args.getEncoding());
}
cmd.addArguments(args.getCurrentArgs());
}
/**
* Adds source and dest files to the command line.
*
* <p>This implementation adds them without any leading
* qualifiers, source first.</p>
*
* @param cmd Command line to add to
* @param log provides access to Ant's logging system.
* @param src the source file
* @param dest the destination file
* @throws BuildException if there was a problem.
*/
protected void addFiles(Commandline cmd, ProjectComponent log, File src,
File dest) throws BuildException {
cmd.createArgument().setFile(src);
cmd.createArgument().setFile(dest);
}
/**
* Executes the command.
*
* @param cmd Command line to execute
* @param log provides access to Ant's logging system.
* @return whether execution was successful
* @throws BuildException if there was a problem.
*/
protected abstract boolean run(Commandline cmd, ProjectComponent log)
throws BuildException;
}