aboutsummaryrefslogtreecommitdiffstats
path: root/framework/src/ant/apache-ant-1.9.6/src/main/org/apache/tools/ant/taskdefs/optional/native2ascii/DefaultNative2Ascii.java
blob: 3cd52afe5b5c44320bfbec180221a0be519384f8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*
 *  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;
}