You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@uima.apache.org by sc...@apache.org on 2007/05/21 23:28:44 UTC
svn commit: r540307 -
/incubator/uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/cas/impl/CASMetadata.java
Author: schor
Date: Mon May 21 14:28:44 2007
New Revision: 540307
URL: http://svn.apache.org/viewvc?view=rev&rev=540307
Log:
[UIMA-409] new class holds CAS metadata, incl ref to typesystem and FSClassRegistry instances
Added:
incubator/uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/cas/impl/CASMetadata.java
Added: incubator/uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/cas/impl/CASMetadata.java
URL: http://svn.apache.org/viewvc/incubator/uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/cas/impl/CASMetadata.java?view=auto&rev=540307
==============================================================================
--- incubator/uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/cas/impl/CASMetadata.java (added)
+++ incubator/uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/cas/impl/CASMetadata.java Mon May 21 14:28:44 2007
@@ -0,0 +1,164 @@
+/*
+ * 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 org.apache.uima.cas.impl;
+
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.List;
+import java.util.Vector;
+
+import org.apache.uima.cas.CAS;
+import org.apache.uima.cas.Feature;
+import org.apache.uima.cas.Type;
+
+/**
+ * Internal class that holds "meta" information about a CAS
+ * This object is shared by all CASes that have the same typeSystemImpl.
+ *
+ * It is accessible to classes in the cas.impl package, only.
+ */
+
+class CASMetadata {
+
+ final TypeSystemImpl ts;
+ final FSClassRegistry fsClassRegistry;
+
+
+ // ///////////////////////////////////////////////////////
+ // Data structures for type checking and feature encoding
+
+ // For each feature, what the offset from the start of the FS is.
+ // That is, this will always be a number > 0. If you have the
+ // address a of a structure of type t, then you can get the value of
+ // feature f by getting (the value of) a+featureOffset[f] from the
+ // heap. If f is not appropriate for t, anything can happen
+ // (including an ArrayIndexOutOfBoundsException).
+ int[] featureOffset;
+
+ // For each type, how large structures of that type are. This will
+ // also be > 0 for each type (since you need to store the type at a
+ // minimum.
+ int[] fsSpaceReq;
+
+ // For each type, remember if it's a regular type that can be created
+ // with CAS.createFS() or not. Exceptions are built-in types float, int and
+ // string, as well as arrays.
+ boolean[] creatableType;
+
+ // ///////////////////////////////////////////////////////
+ // Properties of types.
+
+ // Those types can not be created with CAS.createFS().
+ private static String[] nonCreatableTypes = { CAS.TYPE_NAME_INTEGER, CAS.TYPE_NAME_FLOAT,
+ CAS.TYPE_NAME_STRING, CAS.TYPE_NAME_ARRAY_BASE, CAS.TYPE_NAME_FS_ARRAY,
+ CAS.TYPE_NAME_INTEGER_ARRAY, CAS.TYPE_NAME_FLOAT_ARRAY, CAS.TYPE_NAME_STRING_ARRAY,
+ CAS.TYPE_NAME_SOFA, CAS.TYPE_NAME_BYTE, CAS.TYPE_NAME_BYTE_ARRAY, CAS.TYPE_NAME_BOOLEAN,
+ CAS.TYPE_NAME_BOOLEAN_ARRAY, CAS.TYPE_NAME_SHORT, CAS.TYPE_NAME_SHORT_ARRAY,
+ CAS.TYPE_NAME_LONG, CAS.TYPE_NAME_LONG_ARRAY, CAS.TYPE_NAME_DOUBLE,
+ CAS.TYPE_NAME_DOUBLE_ARRAY };
+
+
+
+ CASMetadata(TypeSystemImpl ts, FSClassRegistry fsClassRegistry) {
+ this.ts = ts;
+ this.fsClassRegistry = fsClassRegistry;
+ }
+
+ CASMetadata(TypeSystemImpl ts) {
+ this.ts = ts;
+ this.fsClassRegistry = new FSClassRegistry(ts);
+ }
+
+
+ // called when type system is "committed"
+ // - all types are known
+ // - no new types will be added
+ // -- exception: array types
+ void setupFeaturesAndCreatableTypes() {
+ // Compute feature offsets.
+ computeFeatureOffsets();
+ // Compute FS space requirements.
+ final int numTypes = ts.getNumberOfTypes();
+ this.fsSpaceReq = new int[numTypes + 1];
+ for (int i = 1; i <= numTypes; i++) {
+ this.fsSpaceReq[i] = ts.getAppropriateFeatures(i).length + 1;
+ }
+ // Initialize the non-creatable types info.
+ initCreatableTypeTable();
+ }
+
+ // Compute the feature offsets
+ private final void computeFeatureOffsets() {
+ final int numFeats = ts.getNumberOfFeatures();
+ this.featureOffset = new int[numFeats + 1];
+ Type startType = ts.getTopType();
+ // Recursively compute the offsets, starting at the top. Initial offset
+ // is 0.
+ computeFeatureOffsets(startType, 0);
+ }
+
+ // Compute the offsets for features of a type. The offset parameter
+ // specifies
+ // how many offset values have already been used.
+ private final void computeFeatureOffsets(Type t, int offset) {
+ // Find all features for which the input type is the domain type.
+ List allFeats = t.getFeatures();
+ ArrayList introFeats = new ArrayList();
+ final int numAllFeats = allFeats.size();
+ Feature feat;
+ for (int i = 0; i < numAllFeats; i++) {
+ feat = (Feature) allFeats.get(i);
+ if (feat.getDomain() == t) {
+ introFeats.add(feat);
+ }
+ }
+ // For each feature for which the input type is the domain, assign an
+ // offset
+ // arbitrarily, starting with the input offset + 1.
+ int featCode;
+ final int numFeats = introFeats.size();
+ for (int i = 0; i < numFeats; i++) {
+ featCode = ((FeatureImpl) introFeats.get(i)).getCode();
+ this.featureOffset[featCode] = offset + 1 + i;
+ }
+ // Call routine recursively for all subtypes. Increment input offset by
+ // number of features introduced on this type.
+ Vector immediateSubtypes = ts.getDirectlySubsumedTypes(t);
+ final int numTypes = immediateSubtypes.size();
+ for (int i = 0; i < numTypes; i++) {
+ computeFeatureOffsets((Type) immediateSubtypes.get(i), offset + numFeats);
+ }
+ }
+
+ private void initCreatableTypeTable() {
+ this.creatableType = new boolean[ts.getTypeArraySize()];
+ Arrays.fill(this.creatableType, true);
+ int typeCode;
+ for (int i = 0; i < nonCreatableTypes.length; i++) {
+ typeCode = ((TypeImpl) ts.getType(nonCreatableTypes[i])).getCode();
+ for (int subType = ts.getSmallestType(); subType < this.creatableType.length; subType++) {
+ if (ts.subsumes(typeCode, subType)) {
+ this.creatableType[subType] = false;
+ }
+ }
+ }
+ }
+
+}