src.com.ibm.as400.vaccess.FileEventSupport Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jt400 Show documentation
Show all versions of jt400 Show documentation
The Open Source version of the IBM Toolbox for Java
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: FileEventSupport.java
//
// The source code contained herein is licensed under the IBM Public License
// Version 1.0, which has been approved by the Open Source Initiative.
// Copyright (C) 1997-2000 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.vaccess;
import com.ibm.as400.access.FileEvent;
import com.ibm.as400.access.FileListener;
import java.util.Vector;
/**
The FileEventSupport class represents a list of FileListeners.
This is also a FileListener and will dispatch all file events.
**/
class FileEventSupport
implements FileListener
{
private static final String copyright = "Copyright (C) 1997-2000 International Business Machines Corporation and others.";
// Private data.
private transient FileListener[] listeners_ = new FileListener[0]; // For speed.
private transient Vector listenersV_ = new Vector ();
private Object source_;
/**
Constructs a FileEventSupport object.
@param source The source of the events.
**/
public FileEventSupport (Object source)
{
source_ = source;
}
/**
Adds a listener.
@param listener The listener.
**/
public void addFileListener(FileListener listener) {
if (listener == null)
throw new NullPointerException("listener");
synchronized (this) {
listenersV_.addElement(listener);
listeners_ = new FileListener[listenersV_.size()];
listenersV_.copyInto(listeners_);
}
}
/**
Processes a file closed event.
@param event The event.
**/
public void fileClosed (FileEvent event)
{
fireFileClosed ();
}
/**
Processes a file created event.
@param event The event.
**/
public void fileCreated (FileEvent event)
{
fireFileCreated ();
}
/**
Processes a file deleted event.
@param event The event.
**/
public void fileDeleted (FileEvent event)
{
fireFileDeleted ();
}
/**
Processes a file modified event.
@param event The event.
**/
public void fileModified (FileEvent event)
{
fireFileModified ();
}
/**
Processes a file open event.
@param event The event.
**/
public void fileOpened (FileEvent event)
{
fireFileOpened ();
}
/**
Fires a file closed event.
**/
public void fireFileClosed ()
{
synchronized (listeners_) {
for (int i = 0; i < listeners_.length; ++i)
listeners_[i].fileClosed (new FileEvent (source_, FileEvent.FILE_CLOSED));
}
}
/**
Fires a file created event.
**/
public void fireFileCreated ()
{
synchronized (listeners_) {
for (int i = 0; i < listeners_.length; ++i)
listeners_[i].fileCreated (new FileEvent (source_, FileEvent.FILE_CREATED));
}
}
/**
Fires a file deleted event.
**/
public void fireFileDeleted ()
{
synchronized (listeners_) {
for (int i = 0; i < listeners_.length; ++i)
listeners_[i].fileClosed (new FileEvent (source_, FileEvent.FILE_DELETED));
}
}
/**
Fires a file modified event.
**/
public void fireFileModified ()
{
synchronized (listeners_) {
for (int i = 0; i < listeners_.length; ++i)
listeners_[i].fileClosed (new FileEvent (source_, FileEvent.FILE_MODIFIED));
}
}
/**
Fires a file open event.
**/
public void fireFileOpened ()
{
synchronized (listeners_) {
for (int i = 0; i < listeners_.length; ++i)
listeners_[i].fileClosed (new FileEvent (source_, FileEvent.FILE_OPENED));
}
}
/**
Removes a listener.
@param listener The listener.
**/
public void removeFileListener(FileListener listener) {
if (listener == null)
throw new NullPointerException("listener");
synchronized (this) {
if (listenersV_.removeElement(listener)) {
listeners_ = new FileListener[listenersV_.size()];
listenersV_.copyInto(listeners_);
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy