/* * ============================================================================ * GNU General Public License * ============================================================================ * * Copyright (C) 2006-2011 Serotonin Software Technologies Inc. http://serotoninsoftware.com * @author Matthew Lohbihler * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 General Public License for more details. * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. * * When signing a commercial license with Serotonin Software Technologies Inc., * the following extension to GPL is made. A special exception to the GPL is * included to allow you to distribute a combined work that includes BAcnet4J * without being obliged to provide the source code for any proprietary components. */ package com.serotonin.bacnet4j.npdu.ip; import com.serotonin.bacnet4j.apdu.Segmentable; public class SegmentWindow { private int firstSequenceId; private final Segmentable[] segments; public SegmentWindow(int windowSize, int firstSequenceId) { this.firstSequenceId = firstSequenceId; segments = new Segmentable[windowSize]; } public Segmentable getSegment(int sequenceId) { return segments[sequenceId - firstSequenceId]; } public void setSegment(Segmentable segment) { segments[segment.getSequenceNumber() - firstSequenceId] = segment; } public boolean fitsInWindow(Segmentable segment) { int index = segment.getSequenceNumber() - firstSequenceId; if (index < 0 || index >= segments.length) return false; return true; } public boolean isEmpty() { for (int i = 0; i < segments.length; i++) { if (segments[i] != null) return false; } return true; } public boolean isFull() { for (int i = 0; i < segments.length; i++) { if (segments[i] == null) return false; } return true; } public void clear(int firstSequenceId) { this.firstSequenceId = firstSequenceId; for (int i = 0; i < segments.length; i++) segments[i] = null; } public boolean isLastSegment(int sequenceId) { return sequenceId == segments.length + firstSequenceId - 1; } }