/* * Created on Oct 25, 2006 Copyright (C) 2001-6, Anthony Harrison anh23@pitt.edu * (jactr.org) This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of the License, * or (at your option) any later version. This library is distributed in the * hope that it will be useful, but WITHOUT ANY WARRANTY; without even the * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See * the GNU Lesser General Public License for more details. You should have * received a copy of the GNU Lesser General Public License along with this * library; if not, write to the Free Software Foundation, Inc., 59 Temple * Place, Suite 330, Boston, MA 02111-1307 USA */ package org.jactr.core.module.declarative.four.learning; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.jactr.core.chunk.IChunk; import org.jactr.core.chunk.event.IChunkListener; import org.jactr.core.event.IParameterEvent; import org.jactr.core.module.declarative.event.DeclarativeModuleEvent; import org.jactr.core.module.declarative.event.IDeclarativeModuleListener; /** * this listener is just to attach the ChunkListener to newly created chunks so * that we can add and remove links * * @author developer */ public class DeclarativeModuleListener implements IDeclarativeModuleListener { /** * logger definition */ static private final Log LOGGER = LogFactory .getLog(DeclarativeModuleListener.class); DefaultDeclarativeLearningModule4 _learningModule; IChunkListener _chunkListener; public DeclarativeModuleListener(DefaultDeclarativeLearningModule4 learning) { _learningModule = learning; _chunkListener = createChunkListener(); } protected IChunkListener createChunkListener() { return new ChunkListener(); } protected IDeclarativeLearningModule4 getLearningModule() { return _learningModule; } public void chunkAdded(DeclarativeModuleEvent dme) { /* * and we remove the listener at encoding */ dme.getChunk().removeListener(_chunkListener); if (LOGGER.isDebugEnabled()) LOGGER.debug("Removed chunk listener " + dme.getChunk()); } public void chunkCreated(DeclarativeModuleEvent dme) { IChunk chunk = dme.getChunk(); // attach to the chunk.. we need to know all changes to the contents of this // chunk if (LOGGER.isDebugEnabled()) LOGGER.debug("New chunk created, attaching listener to " + chunk); chunk.addListener(_chunkListener, _learningModule.getExecutor()); } public void chunkTypeAdded(DeclarativeModuleEvent dme) { } public void chunkTypeCreated(DeclarativeModuleEvent dme) { // set the chunk base level activation equation.. } public void chunkTypesMerged(DeclarativeModuleEvent dme) { } public void chunksMerged(DeclarativeModuleEvent dme) { /* * and we remove the listener at encoding */ for (IChunk chunk : dme.getChunks()) { chunk.removeListener(_chunkListener); if (LOGGER.isDebugEnabled()) LOGGER.debug("Removed chunk listener " +chunk); } } @SuppressWarnings("unchecked") public void parameterChanged(IParameterEvent pe) { } }