📄 safearray.java
字号:
/*
* Copyright (c) 1999-2004 Sourceforge JACOB Project.
* All rights reserved. Originator: Dan Adler (http://danadler.com).
* Get more information about JACOB at http://sourceforge.net/projects/jacob-project
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
package com.jacob.com;
/**
* This creates an array wrapper around Variant objects(?). This supports 1, 2
* and n-dimensional arrays. It exists in this form because n-dimensional arrays
* were a later addition.
*/
public class SafeArray extends JacobObject {
/** The super secret int that is actually the pointer to windows memory */
int m_pV = 0;
/**
* Constructor. Why does this exist? Yeah, someone will post on sourceforge
* about this comment.
*
*/
public SafeArray() {
}
/**
* Constructor.
*
* @param vt
* type of array
*/
public SafeArray(int vt) {
init(vt, new int[] { 0 }, new int[] { -1 });
}
/**
* Constructor for a single dimensional array whose lower bounds is 0 and
* whose upper bound is specified as a parameter
*
* @param vt
* type of the array
* @param celems
* length of the array
*/
public SafeArray(int vt, int celems) {
init(vt, new int[] { 0 }, new int[] { celems });
}
/**
* Creates a two dimensional SafeArray whose base indexes are 0.
*
* @param vt
* Type of the array
* @param celems1
* length of the array in first dimension
* @param celems2
* length of the array in second dimension
*/
public SafeArray(int vt, int celems1, int celems2) {
init(vt, new int[] { 0, 0 }, new int[] { celems1, celems2 });
}
/**
* Constructor with support for N-dimensional array support
* <p>
* You create an N-D SafeArray by: SafeArray sa = new
* SafeArray(Variant.VariantVariant, new int[] {0,0,0,0}, new int[]
* {4,4,4,4}); Where the 1st array is lower bounds and 2nd has the lengths
* of each dimension *
*
* @param vt
* @param lbounds
* @param celems
*/
public SafeArray(int vt, int lbounds[], int celems[]) {
init(vt, lbounds, celems);
}
/**
* convert a string to a VT_UI1 array
*
* @param s
* source string
*/
public SafeArray(String s) {
char[] ca = s.toCharArray();
init(Variant.VariantByte, new int[] { 0 }, new int[] { ca.length });
fromCharArray(ca);
}
/**
* convert a VT_UI1 array to string
*
* @return variant byte as a string
*/
public String asString() {
if (getvt() != Variant.VariantByte) {
return null;
}
char ja[] = toCharArray();
return new String(ja);
}
public native Object clone();
/**
* now private so only this object can access. Was: call this to explicitly
* release the com object before gc
*
*/
private native void destroy();
/**
* {@inheritDoc}
*/
protected void finalize() {
safeRelease();
}
/**
* populate the safe array from the passed in array of data
*
* @param ja
*/
public native void fromBooleanArray(boolean ja[]);
/**
* populate the safe array from the passed in array of data
*
* @param ja
*/
public native void fromByteArray(byte ja[]);
/**
* populate the safe array from the passed in array of data
*
* @param ja
*/
public native void fromCharArray(char ja[]);
/**
* populate the safe array from the passed in array of data
*
* @param ja
*/
public native void fromDoubleArray(double ja[]);
/**
* populate the safe array from the passed in array of data
*
* @param ja
*/
public native void fromFloatArray(float ja[]);
/**
* populate the safe array from the passed in array of data
*
* @param ja
*/
public native void fromIntArray(int ja[]);
/**
* populate the safe array from the passed in array of data
*
* @param ja
*/
public native void fromLongArray(long ja[]);
/**
* populate the safe array from the passed in array of data
*
* @param ja
*/
public native void fromShortArray(short ja[]);
/**
* populate the safe array from the passed in array of data
*
* @param ja
*/
public native void fromStringArray(String ja[]);
/**
* populate the safe array from the passed in array of data
*
* @param ja
*/
public native void fromVariantArray(Variant ja[]);
/**
* boolean access
*
* @param sa_idx
* @return boolean representation
*/
public native boolean getBoolean(int sa_idx);
/**
* get boolean value from N-dimensional array
*
* @param indices -
* length must equal Dimension of SafeArray
* @return the value at the specified location
*/
public native boolean getBoolean(int indices[]);
/**
* boolean access
*
* @param sa_idx1
* @param sa_idx2
* @return boolean representation
*/
public native boolean getBoolean(int sa_idx1, int sa_idx2);
/**
* boolean access
*
* @param sa_idx
* @param nelems
* @param ja
* @param ja_start
*/
public native void getBooleans(int sa_idx, int nelems, boolean ja[],
int ja_start);
/**
* byte access
*
* @param sa_idx
* @return byte representaton
*/
public native byte getByte(int sa_idx);
/**
* get byte value from N-dimensional array
*
* @param indices -
* length must equal Dimension of SafeArray
* @return the value at the specified location
*/
public native byte getByte(int indices[]);
/**
* byte access
*
* @param sa_idx1
* @param sa_idx2
* @return byte representation
*/
public native byte getByte(int sa_idx1, int sa_idx2);
/**
* Fills byte array from contents of this array
*
* @param sa_idx
* @param nelems
* @param ja
* @param ja_start
*/
public native void getBytes(int sa_idx, int nelems, byte ja[], int ja_start);
/**
* char access
*
* @param sa_idx
* @return single character rpeesentation
*/
public native char getChar(int sa_idx);
/**
* get char value from N-dimensional array
*
* @param indices -
* length must equal Dimension of SafeArray
* @return the value at the specified location
*/
public native char getChar(int indices[]);
/**
* char access
*
* @param sa_idx1
* @param sa_idx2
* @return single character representation
*/
public native char getChar(int sa_idx1, int sa_idx2);
/**
* char access
*
* @param sa_idx
* @param nelems
* @param ja
* @param ja_start
*/
public native void getChars(int sa_idx, int nelems, char ja[], int ja_start);
/**
* double access
*
* @param sa_idx
* @return double stored in array
*/
public native double getDouble(int sa_idx);
/**
* get double value from N-dimensional array
*
* @param indices -
* length must equal Dimension of SafeArray
* @return the value at the specified location
*/
public native double getDouble(int indices[]);
/**
* double access
*
* @param sa_idx1
* @param sa_idx2
* @return double stored in array
*/
public native double getDouble(int sa_idx1, int sa_idx2);
/**
* double access
*
* @param sa_idx
* @param nelems
* @param ja
* @param ja_start
*/
public native void getDoubles(int sa_idx, int nelems, double ja[],
int ja_start);
/**
* @return the size of each element?
*/
public native int getElemSize();
/**
* @return The ??features of the array?
*/
public native int getFeatures();
/**
* float access
*
* @param sa_idx
* @return float held in array at location
*/
public native float getFloat(int sa_idx);
/**
* get float value from N-dimensional array
*
* @param indices -
* length must equal Dimension of SafeArray
* @return the value at the specified location
*/
public native float getFloat(int indices[]);
/**
* float access
*
* @param sa_idx1
* @param sa_idx2
* @return float held in array at location
*/
public native float getFloat(int sa_idx1, int sa_idx2);
/**
* float access
*
* @param sa_idx
* @param nelems
* @param ja
* @param ja_start
*/
public native void getFloats(int sa_idx, int nelems, float ja[],
int ja_start);
/**
* get int from an single dimensional array
*
* @param sa_idx
* array index
* @return int stored in array
*/
public native int getInt(int sa_idx);
/**
* get int value from N-dimensional array
*
* @param indices -
* length must equal Dimension of SafeArray
* @return the value at the specified location
*/
public native int getInt(int indices[]);
/**
* get int from 2 dimensional array
*
* @param sa_idx1
* array index first dimension
* @param sa_idx2
* array index of second dimension
* @return int stored in array
*/
public native int getInt(int sa_idx1, int sa_idx2);
/**
* retrieves a group of ints from a single dimensional array
*
* @param sa_idx
* the index in the array to start the get
* @param nelems
* number of elements to retrieve
* @param ja
* the structure to be filled with the ints
* @param ja_start
* the start point in the java int array to start filling
*/
public native void getInts(int sa_idx, int nelems, int ja[], int ja_start);
/**
* get int from an single dimensional array
*
* @param sa_idx
* array index
* @return long stored in array
*/
public native long getLong(int sa_idx);
/**
* get long value from N-dimensional array
*
* @param indices -
* length must equal Dimension of SafeArray
* @return the value at the specified location
*/
public native long getLong(int indices[]);
/**
* get long from 2 dimensional array
*
* @param sa_idx1
* array index first dimension
* @param sa_idx2
* array index of second dimension
* @return long stored in array
*/
public native long getLong(int sa_idx1, int sa_idx2);
/**
* retrieves a group of longs from a single dimensional array
*
* @param sa_idx
* the index in the array to start the get
* @param nelems
* number of elements to retrieve
* @param ja
* the structure to be filled with the longs
* @param ja_start
* the start point in the java longs array to start filling
*/
public native void getLongs(int sa_idx, int nelems, long ja[], int ja_start);
/**
* @return The lower bounds of the array?
*/
public native int getLBound();
/**
* @param dim
* the dimension we are checking in a multidimensional array
* @return The lower bounds of the array?
*/
public native int getLBound(int dim);
/**
* @return The number of dimensions in this array
*/
public native int getNumDim();
/**
* not implemented.
*
* @return 0
*/
public int getNumLocks() {
return 0;
}
/**
* short access
*
* @param sa_idx
* @return short stored in array
*/
public native short getShort(int sa_idx);
/**
* get short value from N-dimensional array
*
* @param indices -
* length must equal Dimension of SafeArray
* @return the value at the specified location
*/
public native short getShort(int indices[]);
/**
* short access
*
* @param sa_idx1
* @param sa_idx2
* @return short stored in array
*/
public native short getShort(int sa_idx1, int sa_idx2);
/**
* short access
*
* @param sa_idx
* @param nelems
* @param ja
* @param ja_start
*/
public native void getShorts(int sa_idx, int nelems, short ja[],
int ja_start);
/**
* string access
*
* @param sa_idx
* @return String stored in array
*
*/
public native String getString(int sa_idx);
/**
* get String value from N-dimensional array
*
* @param indices -
* length must equal Dimension of SafeArray
* @return the value at the specified location
*/
public native String getString(int indices[]);
/**
* string access
*
* @param sa_idx1
* @param sa_idx2
* @return String stored in array
*/
public native String getString(int sa_idx1, int sa_idx2);
/**
* string access
*
* @param sa_idx
* @param nelems
* @param ja
* @param ja_start
*/
public native void getStrings(int sa_idx, int nelems, String ja[],
int ja_start);
/**
* @return The upper bounds of the array?
*/
public native int getUBound();
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -