All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ocadotechnology.event.scheduling.ScheduledQueue Maven / Gradle / Ivy

There is a newer version: 16.6.21
Show newest version
/*
 * Copyright © 2017-2023 Ocado (Ocava)
 *
 * Licensed under the Apache License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.ocadotechnology.event.scheduling;

import java.util.PriorityQueue;

import javax.annotation.CheckForNull;

import com.ocadotechnology.time.TimeProvider;

public class ScheduledQueue {
    private final TimeProvider timeProvider;

    private final PriorityQueue queue = new PriorityQueue<>(15_000, Event.EVENT_COMPARATOR);

    public ScheduledQueue(TimeProvider timeProvider) {
        this.timeProvider = timeProvider;
    }

    public boolean add(Event e) {
        return queue.offer(e);
    }

    public void remove(Event event) {
        queue.remove(event);
    }

    // If there is a bin, this code is faster.  If not, we don't care about a small additional cost
    // (NB: offer(e) where e is the smallest element is O(1), not O(log n), ie is similar cost to peek)
    public @CheckForNull Event timedPoll() {
        Event e = queue.poll();
        if (e != null) {
            double now = timeProvider.getTime();
            if (e.time <= now) {
                return e;
            }
            queue.offer(e);
        }
        return null;
    }

    // If there is a bin, this code is faster.  If not, we don't care about a small additional cost
    // (NB: offer(e) where e is the smallest element is O(1), not O(log n), ie is similar cost to peek)
    public @CheckForNull Event timedPoll(double now) {
        Event e = queue.poll();
        if (e != null) {
            if (e.time <= now) {
                return e;
            }
            queue.offer(e);
        }
        return null;
    }

    public int size() {
        return queue.size();
    }

    public Event peek() {
        return queue.peek();
    }

    public boolean isEmpty() {
        return queue.isEmpty();
    }

    public boolean hasOnlyDaemonEvents() {
        return queue.stream().allMatch(Event::isDaemon);
    }

    public void addAll(Iterable eventsToAdd) {
        eventsToAdd.forEach(this::add);
    }

    public void removeAll(Iterable eventsToRemove) {
        eventsToRemove.forEach(this::remove);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy