/**
* $Id: echo.java 88 2008-11-27 17:06:00Z daldei $
* $Date: 2008-11-27 12:06:00 -0500 (Thu, 27 Nov 2008) $
*
*/
package org.xmlsh.builtin.commands;
import java.io.ByteArrayOutputStream;
import java.util.List;
import org.apache.logging.log4j.Level;
import org.apache.logging.log4j.Logger;
import org.xmlsh.core.BuiltinCommand;
import org.xmlsh.core.Options;
import org.xmlsh.core.XValue;
import org.xmlsh.util.Util;
public class log extends BuiltinCommand {
@Override
public int run(List<XValue> args) throws Exception {
Options opts = new Options("c=class:,p=priority:");
opts.parse(args);
String sClass = opts.getOptString("c", log.class.getName());
String sLevel = opts.getOptString("p", "info");
Level level = parseLevel(sLevel);
args = opts.getRemainingArgs();
/*
* Serialize all output into a single string
*
*/
ByteArrayOutputStream out = new ByteArrayOutputStream();
args = Util.expandSequences(args);
boolean bFirst = true;
for(XValue arg : args) {
if(!bFirst)
out.write(' ');
bFirst = false;
arg.serialize(out, getSerializeOpts());
}
out.flush();
Logger logger = org.apache.logging.log4j.LogManager.getLogger(sClass);
logger.log(level, out.toString(getSerializeOpts().getOutputTextEncoding()));
return 0;
}
private Level parseLevel(String sLevel) {
return Level.toLevel(sLevel);
}
}
//
//
// Copyright (C) 2008-2014 David A. Lee.
//
// The contents of this file are subject to the "Simplified BSD License" (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.opensource.org/licenses/bsd-license.php
//
// Software distributed under the License is distributed on an "AS IS" basis,
// WITHOUT WARRANTY OF ANY KIND, either express or implied.
// See the License for the specific language governing rights and limitations
// under the License.
//
// The Original Code is: all this file.
//
// The Initial Developer of the Original Code is David A. Lee
//
// Portions created by (your name) are Copyright (C) (your legal entity). All
// Rights Reserved.
//
// Contributor(s): none.
//