X-Git-Url: https://gitweb.fperrin.net/?a=blobdiff_plain;f=tim%2Fprune%2FUpdateMessageBroker.java;h=337fc27967712542addcde896b07568558058d03;hb=140e9d165f85c3d4f0435a311e091209313faa2a;hp=417d05547aa9b54e8bf3f7b09c0d11d2edae0f8d;hpb=d3679d647d57c2ee7376ddbf6def2d5b23c04307;p=GpsPrune.git diff --git a/tim/prune/UpdateMessageBroker.java b/tim/prune/UpdateMessageBroker.java index 417d055..337fc27 100644 --- a/tim/prune/UpdateMessageBroker.java +++ b/tim/prune/UpdateMessageBroker.java @@ -4,28 +4,18 @@ package tim.prune; * Class responsible for distributing update information * to all registered listeners */ -public class UpdateMessageBroker +public abstract class UpdateMessageBroker { - private DataSubscriber[] _subscribers; - private int _subscriberNum = 0; - private static final int MAXIMUM_NUMBER_SUBSCRIBERS = 4; - - - /** - * Constructor - * @param inTrack Track object - */ - public UpdateMessageBroker() - { - _subscribers = new DataSubscriber[MAXIMUM_NUMBER_SUBSCRIBERS]; - } + private static final int MAXIMUM_NUMBER_SUBSCRIBERS = 6; + private static DataSubscriber[] _subscribers = new DataSubscriber[MAXIMUM_NUMBER_SUBSCRIBERS]; + private static int _subscriberNum = 0; /** * Add a data subscriber to the list * @param inSub DataSubscriber to add */ - public void addSubscriber(DataSubscriber inSub) + public static void addSubscriber(DataSubscriber inSub) { _subscribers[_subscriberNum] = inSub; _subscriberNum++; @@ -36,7 +26,7 @@ public class UpdateMessageBroker * Send a message to all subscribers that * the data has been updated */ - public void informSubscribers() + public static void informSubscribers() { informSubscribers(DataSubscriber.ALL); } @@ -46,8 +36,9 @@ public class UpdateMessageBroker * Send message to all subscribers * @param inChange Change that occurred */ - public void informSubscribers(byte inChange) + public static void informSubscribers(byte inChange) { + // TODO: Launch separate thread so that whatever caused the inform can finish for (int i=0; i<_subscribers.length; i++) { if (_subscribers[i] != null) @@ -56,4 +47,19 @@ public class UpdateMessageBroker } } } + + /** + * Send message to all subscribers + * @param inMessage message to display informing of action completed + */ + public static void informSubscribers(String inMessage) + { + for (int i=0; i<_subscribers.length; i++) + { + if (_subscribers[i] != null) + { + _subscribers[i].actionCompleted(inMessage); + } + } + } }