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

com.datatorrent.stram.plan.physical.StatsRevisions Maven / Gradle / Ivy

There is a newer version: 3.7.0
Show newest version
/**
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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.datatorrent.stram.plan.physical;

import java.io.Serializable;
import java.util.Arrays;
import java.util.IdentityHashMap;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * MVCC store for single writer and multiple readers of consistent revisions.
 * All values are managed in arrays and referenced through an index map.
 * Fields can be added, but not removed.
 *
 * @since 0.9.3
 */
public class StatsRevisions implements Serializable
{
  private final IdentityHashMap longsIndex = new IdentityHashMap<>();
  private transient ThreadLocal VERSION = new ThreadLocal<>();
  private Revision current = new Revision();

  public VersionedLong newVersionedLong()
  {
    VersionedLong vl = new VersionedLong(longsIndex.size());
    longsIndex.put(vl, vl.index);
    return vl;
  }

  private class Revision implements Serializable
  {
    private static final long serialVersionUID = 201401131642L;
    Object[] refs;
    long[] longs;
    double[] doubles;

    private Revision()
    {
      refs = new Object[0];
      longs = new long[0];
      doubles = new double[0];
    }

    private Revision(Revision other)
    {
      refs = Arrays.copyOf(other.refs, other.refs.length);
      longs = Arrays.copyOf(other.longs, other.longs.length);
      doubles = Arrays.copyOf(other.doubles, other.doubles.length);
    }

  }

  public class VersionedLong implements Serializable
  {
    private static final long serialVersionUID = 201401131642L;
    private final int index;

    private VersionedLong(int index)
    {
      this.index = index;
    }

    public long get()
    {
      Revision v = VERSION.get();
      if (v == null) {
        v = current;
      }
      if (index < v.longs.length) {
        return v.longs[index];
      }
      // revision did not have key
      return 0;
    }

    public void set(long val)
    {
      Revision v = VERSION.get();
      if (v == null || v == current) {
        throw new AssertionError("Cannot modify readonly state.");
      }
      if (index >= v.longs.length) {
        // grow array
        long[] newArray = new long[index + 10];
        System.arraycopy(v.longs, 0, newArray, 0, v.longs.length);
        v.longs = newArray;
      }
      v.longs[index] = val;
    }

    public void add(long val)
    {
      set(get() + val);
    }

    @Override
    public String toString()
    {
      return Long.toString(get());
    }

  }

  public void checkout()
  {
    Revision v = new Revision(current);
    VERSION.set(v);
  }

  public void commit()
  {
    //LOG.debug("commit " + this);
    Revision v = VERSION.get();
    current = v;
    VERSION.remove();
  }

  @SuppressWarnings("unused")
  private static final Logger LOG = LoggerFactory.getLogger(StatsRevisions.class);
  private static final long serialVersionUID = 201401131642L;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy