/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright 2010 Oracle and/or its affiliates. All rights reserved.
*
* Oracle and Java are registered trademarks of Oracle and/or its affiliates.
* Other names may be trademarks of their respective owners.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common
* Development and Distribution License("CDDL") (collectively, the
* "License"). You may not use this file except in compliance with the
* License. You can obtain a copy of the License at
* http://www.netbeans.org/cddl-gplv2.html
* or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
* specific language governing permissions and limitations under the
* License. When distributing the software, include this License Header
* Notice in each file and include the License file at
* nbbuild/licenses/CDDL-GPL-2-CP. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the GPL Version 2 section of the License file that
* accompanied this code. If applicable, add the following below the
* License Header, with the fields enclosed by brackets [] replaced by
* your own identifying information:
* "Portions Copyrighted [year] [name of copyright owner]"
*
* If you wish your version of this file to be governed by only the CDDL
* or only the GPL Version 2, indicate your decision by adding
* "[Contributor] elects to include this software in this distribution
* under the [CDDL or GPL Version 2] license." If you do not indicate a
* single choice of license, a recipient has the option to distribute
* your version of this file under either the CDDL, the GPL Version 2 or
* to extend the choice of license to its licensees as provided above.
* However, if you add GPL Version 2 code and therefore, elected the GPL
* Version 2 license, then the option applies only if the new code is
* made subject to such option by the copyright holder.
*
* Contributor(s):
*
* Portions Copyrighted 2008 Sun Microsystems, Inc.
*/
package org.netbeans.modules.ruby.rubyproject;
import java.beans.PropertyChangeListener;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.swing.JComponent;
import org.netbeans.spi.options.AdvancedOption;
import org.netbeans.spi.options.OptionsPanelController;
import org.openide.util.HelpCtx;
import org.openide.util.Lookup;
import org.openide.util.NbBundle;
/**
* Option for enabling detailed logging.
*
* @author Erno Mononen
*/
public class RubyLoggingOption extends AdvancedOption {
private static final Logger RUBY_LOGGER = Logger.getLogger("org.netbeans.modules.ruby"); //NOI18N
private static final Logger YAML_LOGGER = Logger.getLogger("org.netbeans.modules.languages.yaml"); //NOI18N
private static final Logger EXECUTION_LOGGER = Logger.getLogger("org.netbeans.api.extexecution"); //NOI18N
private static final Logger DEBUGGER_LOGGER = Logger.getLogger("org.rubyforge.debugcommons"); //NOI18N
@Override
public String getDisplayName() {
return NbBundle.getMessage(RubyLoggingOption.class, "RubyLoggingOption.displayName.text");
}
@Override
public String getTooltip() {
return getDisplayName();
}
@Override
public OptionsPanelController create() {
return new Controller();
}
static void initLoggers () {
setIfHigher(RUBY_LOGGER, RubyLoggingSettings.getDefault().getLoggingLevel(RUBY_LOGGER));
setIfHigher(YAML_LOGGER, RubyLoggingSettings.getDefault().getLoggingLevel(YAML_LOGGER));
setIfHigher(EXECUTION_LOGGER, RubyLoggingSettings.getDefault().getLoggingLevel(EXECUTION_LOGGER));
setIfHigher(DEBUGGER_LOGGER, RubyLoggingSettings.getDefault().getLoggingLevel(DEBUGGER_LOGGER));
}
private static void setIfHigher(Logger logger, Level level) {
if (level == null) {
return;
}
if (logger.getLevel() == null || level.intValue() < logger.getLevel().intValue()) {
logger.setLevel(level);
}
}
private static final class Controller extends OptionsPanelController {
private final RubyLoggingOptionsPanel component = new RubyLoggingOptionsPanel();
@Override
public void update() {
Level debuggerLevel = DEBUGGER_LOGGER.getLevel();
Level rubyLevel = RUBY_LOGGER.getLevel();
boolean toggle = debuggerLevel != null && debuggerLevel.intValue() <= Level.FINEST.intValue();
component.setDebuggerLogging(toggle);
toggle = rubyLevel != null && rubyLevel.intValue() <= Level.FINE.intValue();
component.setStandardLogging(toggle);
}
@Override
public void applyChanges() {
setLevel(RUBY_LOGGER, Level.FINE, component.isStandardLoggingEnabled());
setLevel(YAML_LOGGER, Level.FINE, component.isStandardLoggingEnabled());
setLevel(EXECUTION_LOGGER, Level.FINE, component.isStandardLoggingEnabled());
setLevel(DEBUGGER_LOGGER, Level.FINEST, component.isDebuggerLoggingEnabled());
}
@Override
public void cancel() {
}
@Override
public boolean isValid() {
return true;
}
@Override
public boolean isChanged() {
//XXX
return false;
}
@Override
public JComponent getComponent(Lookup masterLookup) {
return component;
}
@Override
public HelpCtx getHelpCtx() {
return new HelpCtx(RubyLoggingOption.class);
}
@Override
public void addPropertyChangeListener(PropertyChangeListener l) {
}
@Override
public void removePropertyChangeListener(PropertyChangeListener l) {
}
private void setLevel(Logger logger, Level level, boolean selected) {
RubyLoggingSettings loggingSettings = RubyLoggingSettings.getDefault();
if (selected) {
Level original = logger.getLevel();
if (original == null || original.intValue() > level.intValue()) {
logger.setLevel(level);
loggingSettings.setLoggingLevel(logger, level);
}
} else {
logger.setLevel(null);
loggingSettings.setLoggingLevel(logger, null);
}
}
}
}