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

fiftyone.mobile.detection.entities.stream.Node Maven / Gradle / Ivy

The newest version!
package fiftyone.mobile.detection.entities.stream;

import fiftyone.mobile.detection.entities.NodeNumericIndex;
import fiftyone.mobile.detection.readers.BinaryReader;

/* *********************************************************************
 * This Source Code Form is copyright of 51Degrees Mobile Experts Limited. 
 * Copyright © 2014 51Degrees Mobile Experts Limited, 5 Charlotte Close,
 * Caversham, Reading, Berkshire, United Kingdom RG4 7BY
 * 
 * This Source Code Form is the subject of the following patent 
 * applications, owned by 51Degrees Mobile Experts Limited of 5 Charlotte
 * Close, Caversham, Reading, Berkshire, United Kingdom RG4 7BY: 
 * European Patent Application No. 13192291.6; and
 * United States Patent Application Nos. 14/085,223 and 14/085,301.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0.
 * 
 * If a copy of the MPL was not distributed with this file, You can obtain
 * one at http://mozilla.org/MPL/2.0/.
 * 
 * This Source Code Form is "Incompatible With Secondary Licenses", as
 * defined by the Mozilla Public License, v. 2.0.
 * ********************************************************************* */
/**
 * Represents a Entities.Node which can be used with the 
 * Stream data set. NumericChidren and RankedSignatureIndexes are not loaded
 * into memory when the entity is constructed, they're only loaded from the
 * data source when requested.
 */
public abstract class Node extends fiftyone.mobile.detection.entities.Node {
    /**
     * The position in the data set where the NumericChildren start.
     */
    protected final int numericChildrenPosition;
    /**
     * Pool used to load NumericChildren and RankedSignatureIndexes.
     */
    protected final Pool pool;

    /**
     * Constructs a new instance of Node.
     * @param dataSet The data set the node is contained within.
     * @param offset The offset in the data structure to the node.
     * @param reader Reader connected to the source data structure and 
     * positioned to start reading.
     */
    public Node(Dataset dataSet, int offset, BinaryReader reader) {
        super(dataSet, offset, reader);
        this.pool = dataSet.pool;
        this.numericChildrenPosition = reader.getPos();
        getNumericChildren();
    }
    
    /**
     * An array of all the numeric children.
     * @return array of all the numeric children.
     */
    @Override
    public final NodeNumericIndex[] getNumericChildren() {
        if(super.numericChildren == null) {
            synchronized(this) {
                if(super.numericChildren == null) {
                    BinaryReader reader = null;
                    try {
                        reader = pool.getReader();
                        reader.setPos(numericChildrenPosition);
                        super.numericChildren = readNodeNumericIndexes(dataSet, 
                                                reader, numericChildrenCount);
                    } catch(Exception ex) {
                        throw new Error("Cannot obtain numeric Children: "+ex);
                    } finally {
                        if (reader != null) {
                            pool.release(reader);
                        }
                    }
                }
            }
        }
        return numericChildren;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy