/******************************************************************************* * Copyright (c) 2015-2021 MINRES Technologies GmbH and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * MINRES Technologies GmbH - initial API and implementation *******************************************************************************/ package com.minres.scviewer.database.vcd; import com.minres.scviewer.database.EventEntry; import com.minres.scviewer.database.EventList; import com.minres.scviewer.database.HierNode; import com.minres.scviewer.database.IEvent; import com.minres.scviewer.database.IEventList; import com.minres.scviewer.database.IWaveform; import com.minres.scviewer.database.WaveformType; public class VCDSignal extends HierNode implements IWaveform { private long id; private String fullName; private final int width; private IEventList values; public VCDSignal(String name) { this(0, name, 1); } public VCDSignal(int id, String name) { this(id,name,1); } public VCDSignal(int id, String name, int width) { super(name); fullName=name; this.id=id; this.width=width; this.values=new EventList(); } public VCDSignal(VCDSignal o, int id, String name) { super(name); fullName=name; this.id=id; this.width=o.width; this.values=o.values; } @Override public String getFullName() { return fullName; } public void setId(int id) { this.id=id; } @Override public long getId() { return id; } public void addSignalChange(Long time, T value){ values.put(time, value); } @Override public IEventList getEvents() { return values; } @Override public IEvent[] getEventsAtTime(long time) { return values.get(time); } @Override public IEvent[] getEventsBeforeTime(long time) { EventEntry e = values.floorEntry(time); if(e==null) return new IEvent[] {}; else return values.floorEntry(time).events; } @Override public boolean isSame(IWaveform other) { return( other instanceof VCDSignal && this.getId() == other.getId()); } @Override public WaveformType getType() { return WaveformType.SIGNAL; } @Override public int getRowCount() { return width; } @Override public String getKind() { return "signal"; } }