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

swim.system.lane.DemandMapLaneModel Maven / Gradle / Ivy

The newest version!
// Copyright 2015-2024 Nstream, inc.
//
// 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 swim.system.lane;

import java.util.Iterator;
import swim.api.warp.WarpUplink;
import swim.collections.FingerTrieSeq;
import swim.structure.Record;
import swim.structure.Value;
import swim.system.LaneModel;
import swim.system.LaneView;
import swim.system.WarpBinding;
import swim.system.warp.WarpLaneModel;

public class DemandMapLaneModel extends WarpLaneModel, DemandMapLaneUplink> {

  public DemandMapLaneModel() {
    // nop
  }

  @Override
  public String laneType() {
    return "map";
  }

  @Override
  protected DemandMapLaneUplink createWarpUplink(WarpBinding link) {
    return new DemandMapLaneUplink(this, link, this.createUplinkAddress(link));
  }

  @Override
  protected void didOpenLaneView(DemandMapLaneView view) {
    view.setLaneBinding(this);
  }

  @SuppressWarnings("unchecked")
  void cueDownKey(Value key) {
    FingerTrieSeq uplinks;
    do {
      uplinks = (FingerTrieSeq) LaneModel.UPLINKS.get(this);
      for (int i = 0, n = uplinks.size(); i < n; i += 1) {
        uplinks.get(i).cueDownKey(key);
      }
    } while (uplinks != LaneModel.UPLINKS.get(this));
  }

  void remove(Value key) {
    this.sendDown(Record.create(1).attr("remove", Record.create(1).slot("key", key)));
  }

  Value nextDownCue(Value key, WarpUplink uplink) {
    final Object views = LaneModel.VIEWS.get(this);
    if (views instanceof DemandMapLaneView) {
      return ((DemandMapLaneView) views).nextDownCue(key, uplink);
    } else if (views instanceof LaneView[]) {
      final LaneView[] viewArray = (LaneView[]) views;
      for (int i = 0, n = viewArray.length; i < n; i += 1) {
        final Value value = ((DemandMapLaneView) viewArray[i]).nextDownCue(key, uplink);
        if (value != null) {
          return value;
        }
      }
    }
    return null;
  }

  Iterator syncKeys(WarpUplink uplink) {
    final Object views = LaneModel.VIEWS.get(this);
    if (views instanceof DemandMapLaneView) {
      return ((DemandMapLaneView) views).syncKeys(uplink);
    } else if (views instanceof LaneView[]) {
      final LaneView[] viewArray = (LaneView[]) views;
      for (int i = 0, n = viewArray.length; i < n; i += 1) {
        final Iterator iterator = ((DemandMapLaneView) viewArray[i]).syncKeys(uplink);
        if (iterator != null) {
          return iterator;
        }
      }
    }
    return null;
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy