/* * * Copyright 2002-2004 The Ant-Contrib project * * 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 net.sf.antcontrib.cpptasks.openwatcom; import java.util.Vector; import net.sf.antcontrib.cpptasks.types.LibraryTypeEnum; /** * A add-in class for OpenWatcom processors. * * */ public final class OpenWatcomProcessor { /** * Adds warning command line options. * * @param args Vector list of options * @param level int value of WarningLevelEnum */ public static void addWarningSwitch(final Vector args, final int level) { switch (level) { case 0: args.addElement("/w0"); break; case 1: args.addElement("/w1"); break; case 2: break; case 3: args.addElement("/w2"); break; case 4: args.addElement("/w3"); break; case 5: args.addElement("/we"); break; default: args.addElement("/w1"); break; } } /** * Gets command line option to read from an option file. * * @param cmdFile String file name for option file * @return String Command line option */ public static String getCommandFileSwitch(final String cmdFile) { StringBuffer buf = new StringBuffer("@"); if (cmdFile.indexOf(' ') >= 0) { buf.append('\"'); buf.append(cmdFile.replace('/', '\\')); buf.append('\"'); } else { buf.append(cmdFile); } return buf.toString(); } /** * Creates a command line option to define a preprocessor macro. * * @param buffer StringBuffer destination buffer * @param define String parameter to define * @param value String value, may be null */ public static void getDefineSwitch(final StringBuffer buffer, final String define, final String value) { buffer.append("/d"); buffer.append(define); if (value != null && value.length() > 0) { buffer.append('='); buffer.append(value); } } /** * Create a command line option to add a directory to the include path. * @param includeDir String directory * @return String command line option */ public static String getIncludeDirSwitch(final String includeDir) { return "/i=" + includeDir.replace('/', '\\'); } /** * Builds command line options to specify the output file names. * * @param outPath String path to output file * @return String[] command line options */ public static String[] getOutputFileSwitch(final String outPath) { StringBuffer buf = new StringBuffer("/fo="); if (outPath.indexOf(' ') >= 0) { buf.append('\"'); buf.append(outPath); buf.append('\"'); } else { buf.append(outPath); } String[] retval = new String[] { buf.toString()}; return retval; } /** * Get file selectors for specified libraries. * @param libnames library names * @param libType library type * @return file selectors */ public static String[] getLibraryPatterns(final String[] libnames, final LibraryTypeEnum libType) { StringBuffer buf = new StringBuffer(); String[] patterns = new String[libnames.length]; for (int i = 0; i < libnames.length; i++) { buf.setLength(0); buf.append(libnames[i]); buf.append(".lib"); patterns[i] = buf.toString(); } return patterns; } /** * Builds a command line option to undefine a preprocessor macro. * @param buffer StringBuffer destination * @param define String macro to be undefined */ public static void getUndefineSwitch(final StringBuffer buffer, final String define) { buffer.append("/u"); buffer.append(define); } /** * Gets whether processor tratement of file names is case-sensitive. * @return boolean true if case sensitive */ public static boolean isCaseSensitive() { return false; } /** * Private constructor. */ private OpenWatcomProcessor() { } }