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

com.sun.jna.platform.win32.OaIdl Maven / Gradle / Ivy

There is a newer version: 1.2.2.1-jre17
Show newest version
/*
 * The contents of this file is dual-licensed under 2
 * alternative Open Source/Free licenses: LGPL 2.1 or later and
 * Apache License 2.0. (starting with JNA version 4.0.0).
 *
 * You can freely decide which license you want to apply to
 * the project.
 *
 * You may obtain a copy of the LGPL License at:
 *
 * http://www.gnu.org/licenses/licenses.html
 *
 * A copy is also included in the downloadable source code package
 * containing JNA, in file "LGPL2.1".
 *
 * You may obtain a copy of the Apache License at:
 *
 * http://www.apache.org/licenses/
 *
 * A copy is also included in the downloadable source code package
 * containing JNA, in file "AL2.0".
 */
package com.sun.jna.platform.win32;

import java.util.List;

import com.sun.jna.IntegerType;
import com.sun.jna.Memory;
import com.sun.jna.NativeLong;
import com.sun.jna.Pointer;
import com.sun.jna.Structure;
import com.sun.jna.Structure.FieldOrder;
import com.sun.jna.Union;
import com.sun.jna.platform.win32.BaseTSD.ULONG_PTR;
import com.sun.jna.platform.win32.COM.COMUtils;
import com.sun.jna.platform.win32.COM.Dispatch;
import com.sun.jna.platform.win32.Guid.GUID;
import com.sun.jna.platform.win32.Variant.VARIANT;
import com.sun.jna.platform.win32.Variant.VariantArg;
import com.sun.jna.platform.win32.WTypes.BSTR;
import com.sun.jna.platform.win32.WTypes.LPOLESTR;
import com.sun.jna.platform.win32.WTypes.VARTYPE;
import com.sun.jna.platform.win32.WinDef.BYTE;
import com.sun.jna.platform.win32.WinDef.DWORD;
import com.sun.jna.platform.win32.WinDef.DWORDByReference;
import com.sun.jna.platform.win32.WinDef.LCID;
import com.sun.jna.platform.win32.WinDef.LONG;
import com.sun.jna.platform.win32.WinDef.LONGLONG;
import com.sun.jna.platform.win32.WinDef.PVOID;
import com.sun.jna.platform.win32.WinDef.SCODE;
import com.sun.jna.platform.win32.WinDef.SHORT;
import com.sun.jna.platform.win32.WinDef.ULONG;
import com.sun.jna.platform.win32.WinDef.ULONGLONG;
import com.sun.jna.platform.win32.WinDef.USHORT;
import com.sun.jna.platform.win32.WinDef.WORD;
import com.sun.jna.platform.win32.COM.TypeComp;
import com.sun.jna.platform.win32.COM.Unknown;
import static com.sun.jna.platform.win32.Variant.VT_BOOL;
import static com.sun.jna.platform.win32.Variant.VT_BSTR;
import static com.sun.jna.platform.win32.Variant.VT_CY;
import static com.sun.jna.platform.win32.Variant.VT_DATE;
import static com.sun.jna.platform.win32.Variant.VT_DECIMAL;
import static com.sun.jna.platform.win32.Variant.VT_DISPATCH;
import static com.sun.jna.platform.win32.Variant.VT_ERROR;
import static com.sun.jna.platform.win32.Variant.VT_I1;
import static com.sun.jna.platform.win32.Variant.VT_I2;
import static com.sun.jna.platform.win32.Variant.VT_I4;
import static com.sun.jna.platform.win32.Variant.VT_INT;
import static com.sun.jna.platform.win32.Variant.VT_R4;
import static com.sun.jna.platform.win32.Variant.VT_R8;
import static com.sun.jna.platform.win32.Variant.VT_RECORD;
import static com.sun.jna.platform.win32.Variant.VT_UI1;
import static com.sun.jna.platform.win32.Variant.VT_UI2;
import static com.sun.jna.platform.win32.Variant.VT_UI4;
import static com.sun.jna.platform.win32.Variant.VT_UINT;
import static com.sun.jna.platform.win32.Variant.VT_UNKNOWN;
import static com.sun.jna.platform.win32.Variant.VT_VARIANT;
import com.sun.jna.ptr.ByReference;
import com.sun.jna.ptr.PointerByReference;
import java.io.Closeable;
import java.util.Date;

/**
 * The Interface OaIdl.
 */
public interface OaIdl {

    // The DATE Type is defined in localtime and the java Date type always contains
    // a a timezone offset, so the difference has to be calculated and can't be
    // predetermined
    public static final long DATE_OFFSET = new Date(1899 - 1900, 12 - 1, 30, 0, 0, 0).getTime();

    /**
     * The Class EXCEPINFO.
     */
    @FieldOrder({"wCode", "wReserved", "bstrSource", "bstrDescription",
        "bstrHelpFile", "dwHelpContext", "pvReserved", "pfnDeferredFillIn",
        "scode"})
    public static class EXCEPINFO extends Structure {

        /**
         * The Class ByReference.
         */
        public static class ByReference extends EXCEPINFO implements
                Structure.ByReference {
        }

        /** The w code. */
        public WORD wCode;

        /** The w reserved. */
        public WORD wReserved;

        /** The bstr source. */
        public BSTR bstrSource;

        /** The bstr description. */
        public BSTR bstrDescription;

        /** The bstr help file. */
        public BSTR bstrHelpFile;

        /** The dw help context. */
        public DWORD dwHelpContext;

        /** The pv reserved. */
        public PVOID pvReserved;

        /** The pfn deferred fill in. */
        public EXCEPINFO.ByReference pfnDeferredFillIn;

        /** The scode. */
        public SCODE scode;

        /**
         * Instantiates a new excepinfo.
         */
        public EXCEPINFO() {
            super();
        }

        /**
         * Instantiates a new excepinfo.
         *
         * @param p
         *            the p
         */
        public EXCEPINFO(Pointer p) {
            super(p);
        }
    }

    public static class VARIANT_BOOL extends IntegerType {
        private static final long serialVersionUID = 1L;
        public static final int SIZE = 2;

        public VARIANT_BOOL() {
            this(0);
        }

        public VARIANT_BOOL(long value) {
            super(2, value);
        }

        public VARIANT_BOOL(boolean value) {
            this(value ? 0xFFFF : 0x0000);
        }

        public boolean booleanValue() {
            return shortValue() != 0x0000;
        }
    }

    public static class _VARIANT_BOOL extends VARIANT_BOOL {
        private static final long serialVersionUID = 1L;

        public _VARIANT_BOOL() {
            this(0);
        }

        public _VARIANT_BOOL(long value) {
            super(value);
        }
    }

    public static class VARIANT_BOOLByReference extends ByReference {
        public VARIANT_BOOLByReference() {
            this(new VARIANT_BOOL(0));
        }

        public VARIANT_BOOLByReference(VARIANT_BOOL value) {
            super(VARIANT_BOOL.SIZE);
            setValue(value);
        }

        public void setValue(VARIANT_BOOL value) {
            getPointer().setShort(0, value.shortValue());
        }

        public VARIANT_BOOL getValue() {
            return new VARIANT_BOOL(getPointer().getShort(0));
        }
    }

    public static class _VARIANT_BOOLByReference extends ByReference {
        public _VARIANT_BOOLByReference() {
            this(new VARIANT_BOOL(0));
        }

        public _VARIANT_BOOLByReference(VARIANT_BOOL value) {
            super(VARIANT_BOOL.SIZE);
            setValue(value);
        }

        public void setValue(VARIANT_BOOL value) {
            getPointer().setShort(0, value.shortValue());
        }

        public VARIANT_BOOL getValue() {
            return new VARIANT_BOOL(getPointer().getShort(0));
        }
    }

    @FieldOrder({"date"})
    public static class DATE extends Structure {
        private final static long MICRO_SECONDS_PER_DAY = 24L * 60L * 60L * 1000L;

        public static class ByReference extends DATE implements
                Structure.ByReference {
        }

        public double date;

        public DATE() {
            super();
        }

        public DATE(double date) {
            this.date = date;
        }

        public DATE(Date javaDate) {
            setFromJavaDate(javaDate);
        }

        public Date getAsJavaDate() {
            long days = (((long) this.date) * MICRO_SECONDS_PER_DAY) + DATE_OFFSET;
            double timePart = 24 * Math.abs(this.date - ((long) this.date));
            int hours = (int) timePart;
            timePart = 60 * (timePart - ((int) timePart));
            int minutes = (int) timePart;
            timePart = 60 * (timePart - ((int) timePart));
            int seconds = (int) timePart;
            timePart = 1000 * (timePart - ((int) timePart));
            int milliseconds = (int) timePart;

            Date baseDate = new Date(days);
            baseDate.setHours(hours);
            baseDate.setMinutes(minutes);
            baseDate.setSeconds(seconds);
            baseDate.setTime(baseDate.getTime() + milliseconds);
            return baseDate;
        }

        public void setFromJavaDate(Date javaDate) {
            double msSinceOrigin = javaDate.getTime() - DATE_OFFSET;
            double daysAsFract = msSinceOrigin / MICRO_SECONDS_PER_DAY;

            Date dayDate = new Date(javaDate.getTime());
            dayDate.setHours(0);
            dayDate.setMinutes(0);
            dayDate.setSeconds(0);
            dayDate.setTime(dayDate.getTime() / 1000 * 1000); // Clear milliseconds

            double integralPart = Math.floor(daysAsFract);
            double fractionalPart = Math.signum(daysAsFract) * ((javaDate.getTime() - dayDate.getTime()) / (24d * 60 * 60 * 1000));

            this.date = integralPart + fractionalPart;
        }
    }

    /**
     * The Class DISPID.
     */
    public static class DISPID extends LONG {
        private static final long serialVersionUID = 1L;

        public DISPID() {
            this(0);
        }

        public DISPID(int value) {
            super(value);
        }
    }

    public static class DISPIDByReference extends ByReference {
        public DISPIDByReference() {
            this(new DISPID(0));
        }

        public DISPIDByReference(DISPID value) {
            super(DISPID.SIZE);
            setValue(value);
        }

        public void setValue(DISPID value) {
            getPointer().setInt(0, value.intValue());
        }

        public DISPID getValue() {
            return new DISPID(getPointer().getInt(0));
        }
    }

    public static class MEMBERID extends DISPID {
        private static final long serialVersionUID = 1L;

        public MEMBERID() {
            this(0);
        }

        public MEMBERID(int value) {
            super(value);
        }
    }

    public static class MEMBERIDByReference extends ByReference {
        public MEMBERIDByReference() {
            this(new MEMBERID(0));
        }

        public MEMBERIDByReference(MEMBERID value) {
            super(MEMBERID.SIZE);
            setValue(value);
        }

        public void setValue(MEMBERID value) {
            getPointer().setInt(0, value.intValue());
        }

        public MEMBERID getValue() {
            return new MEMBERID(getPointer().getInt(0));
        }
    }

    // The Collect property. You use this property if the method you are calling
    // through Invoke is an accessor function.
    /** The Constant DISPID_COLLECT. */
    public final static DISPID DISPID_COLLECT = new DISPID(-8);

    // The C++ constructor function for the object.
    /** The Constant DISPID_CONSTRUCTOR. */
    public final static DISPID DISPID_CONSTRUCTOR = new DISPID(-6);

    // The C++ destructor function for the object.
    /** The Constant DISPID_DESTRUCTOR. */
    public final static DISPID DISPID_DESTRUCTOR = new DISPID(-7);

    // The Evaluate method. This method is implicitly invoked when the ActiveX
    // client encloses the arguments in square brackets. For example, the
    // following two lines are equivalent:
    /** The Constant DISPID_EVALUATE. */
    public final static DISPID DISPID_EVALUATE = new DISPID(-5);

    // The _NewEnum property. This special, restricted property is required for
    // collection objects. It returns an enumerator object that supports
    // IEnumVARIANT, and should have the restricted attribute specified.
    /** The Constant DISPID_NEWENUM. */
    public final static DISPID DISPID_NEWENUM = new DISPID(-4);

    // The parameter that receives the value of an assignment in a PROPERTYPUT.
    /** The Constant DISPID_PROPERTYPUT. */
    public final static DISPID DISPID_PROPERTYPUT = new DISPID(-3);

    // The value returned by IDispatch::GetIDsOfNames to indicate that a member
    // or parameter name was not found.
    /** The Constant DISPID_UNKNOWN. */
    public final static DISPID DISPID_UNKNOWN = new DISPID(-1);

    // The default member for the object. This property or method is invoked
    // when an ActiveX client specifies the object name without a property or
    // method.
    /** The Constant DISPID_VALUE. */
    public final static DISPID DISPID_VALUE = new DISPID(0);

    public final static MEMBERID MEMBERID_NIL = new MEMBERID(
            DISPID_UNKNOWN.intValue());

    /** An array that is allocated on the stack. */
    public final static int FADF_AUTO = 0x0001;

    /** An array that is statically allocated. */
    public final static int FADF_STATIC = 0x0002;

    /** An array that is embedded in a structure. */
    public final static int FADF_EMBEDDED = 0x0004;

    /** An array that may not be resized or reallocated. */
    public final static int FADF_FIXEDSIZE = 0x0010;

    /**
     * An array that contains records. When set, there will be a pointer to the
     * IRecordInfo interface at negative offset 4 in the array descriptor.
     */
    public final static int FADF_RECORD = 0x0020;

    /**
     * An array that has an IID identifying interface. When set, there will be a
     * GUID at negative offset 16 in the safe array descriptor. Flag is set only
     * when FADF_DISPATCH or FADF_UNKNOWN is also set.
     */
    public final static int FADF_HAVEIID = 0x0040;

    /**
     * An array that has a variant type. The variant type can be retrieved with
     * SafeArrayGetVartype.
     */
    public final static int FADF_HAVEVARTYPE = 0x0080;

    /** An array of BSTRs. */
    public final static int FADF_BSTR = 0x0100;

    /** An array of IUnknown*. */
    public final static int FADF_UNKNOWN = 0x0200;

    /** An array of IDispatch*. */
    public final static int FADF_DISPATCH = 0x0400;

    /** An array of VARIANTs. */
    public final static int FADF_VARIANT = 0x0800;

    /** Bits reserved for future use. */
    public final static int FADF_RESERVED = 0xF008;

    @FieldOrder({"value"})
    public static class TYPEKIND extends Structure {
        public static class ByReference extends TYPEKIND implements
                Structure.ByReference {
            public ByReference() {

            }

            public ByReference(int value) {
                super(value);
            }

            public ByReference(TYPEKIND typekind) {
                super(typekind.getPointer());
                value = typekind.value;
            }
        }

        public int value;

        public TYPEKIND() {
            super();
        }

        public TYPEKIND(int value) {
            this.value = value;
        }

        public TYPEKIND(Pointer pointer) {
            super(pointer);
            this.read();
        }

        // / native declaration : line 4
        public static final int TKIND_ENUM = 0;
        // / native declaration : line 5
        public static final int TKIND_RECORD = TYPEKIND.TKIND_ENUM + 1;
        // / native declaration : line 6
        public static final int TKIND_MODULE = TYPEKIND.TKIND_RECORD + 1;
        // / native declaration : line 7
        public static final int TKIND_INTERFACE = TYPEKIND.TKIND_MODULE + 1;
        // / native declaration : line 8
        public static final int TKIND_DISPATCH = TYPEKIND.TKIND_INTERFACE + 1;
        // / native declaration : line 9
        public static final int TKIND_COCLASS = TYPEKIND.TKIND_DISPATCH + 1;
        // / native declaration : line 10
        public static final int TKIND_ALIAS = TYPEKIND.TKIND_COCLASS + 1;
        // / native declaration : line 11
        public static final int TKIND_UNION = TYPEKIND.TKIND_ALIAS + 1;
        // / native declaration : line 12
        public static final int TKIND_MAX = TYPEKIND.TKIND_UNION + 1;
    }

    @FieldOrder({"value"})
    public static class DESCKIND extends Structure {
        public static class ByReference extends DESCKIND implements
                Structure.ByReference {
        }

        public int value;

        public DESCKIND() {
            super();
        }

        public DESCKIND(int value) {
            this.value = value;
        }

        public DESCKIND(Pointer pointer) {
            super(pointer);
            this.read();
        }

        // / native declaration : line 4
        public static final int DESCKIND_NONE = 0;
        // / native declaration : line 5
        public static final int DESCKIND_FUNCDESC = DESCKIND.DESCKIND_NONE + 1;
        // / native declaration : line 6
        public static final int DESCKIND_VARDESC = DESCKIND.DESCKIND_FUNCDESC + 1;
        // / native declaration : line 7
        public static final int DESCKIND_TYPECOMP = DESCKIND.DESCKIND_VARDESC + 1;
        // / native declaration : line 8
        public static final int DESCKIND_IMPLICITAPPOBJ = DESCKIND.DESCKIND_TYPECOMP + 1;
        // / native declaration : line 9
        public static final int DESCKIND_MAX = DESCKIND.DESCKIND_IMPLICITAPPOBJ + 1;
    }

    /**
     * Implementation of SAFEARRAY. Implements Closable, which in this case
     * delegates to destroy, to free native memory on close.
     *
     * 

VARTYPE for the SAFEARRAY can be:

* *
    *
  • VT_BOOL
  • *
  • VT_BSTR
  • *
  • VT_CY
  • *
  • VT_DATE
  • *
  • VT_DECIMAL
  • *
  • VT_DISPATCH
  • *
  • VT_ERROR
  • *
  • VT_I1
  • *
  • VT_I2
  • *
  • VT_I4
  • *
  • VT_INT
  • *
  • VT_R4
  • *
  • VT_R8
  • *
  • VT_RECORD
  • *
  • VT_UI1
  • *
  • VT_UI2
  • *
  • VT_UI4
  • *
  • VT_UINT
  • *
  • VT_UNKNOWN
  • *
  • VT_VARIANT
  • *
* *

General comment: All indices in the helper methods use java int.

* *

The native type for the indices is LONG, which is defined as:

* *
A 32-bit signed integer. The range is �2147483648 through 2147483647 decimal.
*/ @FieldOrder({"cDims", "fFeatures", "cbElements", "cLocks", "pvData", "rgsabound"}) public static class SAFEARRAY extends Structure implements Closeable { public static class ByReference extends SAFEARRAY implements Structure.ByReference { } public USHORT cDims; public USHORT fFeatures; public ULONG cbElements; public ULONG cLocks; public PVOID pvData; /** The rgsabound. */ public SAFEARRAYBOUND[] rgsabound = { new SAFEARRAYBOUND() }; public SAFEARRAY() { super(); } public SAFEARRAY(Pointer pointer) { super(pointer); this.read(); } @Override public void read() { super.read(); if(cDims.intValue() > 0) { rgsabound = (SAFEARRAYBOUND[]) rgsabound[0].toArray(cDims.intValue()); } else { rgsabound = new SAFEARRAYBOUND[]{ new SAFEARRAYBOUND() }; } } /** * Create a SAFEARRAY with supplied VARIANT as element type. * *

* This helper creates a basic SAFEARRAY with a base type of VT_VARIANT. * The array will have as many dimensions as parameters are passed in. * The lowerbound for each dimension is set to zero, the count to the * parameter value.

* * @param size array of dimension size * @return SAFEARRAYWrapper or {@code NULL} if creation fails. */ public static SAFEARRAY.ByReference createSafeArray(int... size) { return createSafeArray(new WTypes.VARTYPE(Variant.VT_VARIANT), size); } /** * Create a SAFEARRAY with supplied element type. * *

* The array will have as many dimensions as parameters are passed in. * The lowerbound for each dimension is set to zero, the count to the * parameter value.

* * @param vartype type of array contents (see Variant.VT_* constants) * @param size array of dimension size * @return SAFEARRAYWrapper or {@code NULL} if creation fails. */ public static SAFEARRAY.ByReference createSafeArray(VARTYPE vartype, int... size) { OaIdl.SAFEARRAYBOUND[] rgsabound = (OaIdl.SAFEARRAYBOUND[]) new OaIdl.SAFEARRAYBOUND().toArray(size.length); for (int i = 0; i < size.length; i++) { rgsabound[i].lLbound = new WinDef.LONG(0); rgsabound[i].cElements = new WinDef.ULONG(size[size.length - i - 1]); } SAFEARRAY.ByReference data = OleAuto.INSTANCE.SafeArrayCreate(vartype, new WinDef.UINT(size.length), rgsabound); return data; } /** * Set value at {@code indices} in {@code array} to arg. * *

* The supplied argument is copied into the array. If the value is no * longer needed, it needs to be freed if not handled automatically.

* * @param indices the index, order follows java/C convention * @param arg the arg */ public void putElement(Object arg, int... indices) { WinDef.LONG[] paramIndices = new WinDef.LONG[indices.length]; for (int i = 0; i < indices.length; i++) { paramIndices[i] = new WinDef.LONG(indices[indices.length - i - 1]); } WinNT.HRESULT hr; Memory mem; switch (getVarType().intValue()) { case VT_BOOL: mem = new Memory(2); if(arg instanceof Boolean) { mem.setShort(0, (short) (((Boolean) arg) ? 0xFFFF : 0) ); } else { mem.setShort(0, (short) (((Number) arg).intValue() > 0 ? 0xFFFF : 0)); } hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, mem); COMUtils.checkRC(hr); break; case VT_UI1: case VT_I1: mem = new Memory(1); mem.setByte(0, ((Number) arg).byteValue()); hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, mem); COMUtils.checkRC(hr); break; case VT_UI2: case VT_I2: mem = new Memory(2); mem.setShort(0, ((Number) arg).shortValue()); hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, mem); COMUtils.checkRC(hr); break; case VT_UI4: case VT_UINT: case VT_I4: case VT_INT: mem = new Memory(4); mem.setInt(0, ((Number) arg).intValue()); hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, mem); COMUtils.checkRC(hr); break; case VT_ERROR: mem = new Memory(4); mem.setInt(0, ((Number) arg).intValue()); hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, mem); COMUtils.checkRC(hr); break; case VT_R4: mem = new Memory(4); mem.setFloat(0, ((Number) arg).floatValue()); hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, mem); COMUtils.checkRC(hr); break; case VT_R8: mem = new Memory(8); mem.setDouble(0, ((Number) arg).doubleValue()); hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, mem); COMUtils.checkRC(hr); break; case VT_DATE: mem = new Memory(8); mem.setDouble(0, ((DATE) arg).date); hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, mem); COMUtils.checkRC(hr); break; case VT_BSTR: if(arg instanceof String) { BSTR bstr = OleAuto.INSTANCE.SysAllocString((String) arg); hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, bstr.getPointer()); OleAuto.INSTANCE.SysFreeString(bstr); COMUtils.checkRC(hr); } else { hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, ((BSTR) arg).getPointer()); COMUtils.checkRC(hr); } break; case VT_VARIANT: hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, ((VARIANT) arg).getPointer()); COMUtils.checkRC(hr); break; case VT_UNKNOWN: hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, ((Unknown) arg).getPointer()); COMUtils.checkRC(hr); break; case VT_DISPATCH: hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, ((Dispatch) arg).getPointer()); COMUtils.checkRC(hr); break; case VT_CY: hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, ((CURRENCY) arg).getPointer()); COMUtils.checkRC(hr); break; case VT_DECIMAL: hr = OleAuto.INSTANCE.SafeArrayPutElement(this, paramIndices, ((DECIMAL) arg).getPointer()); COMUtils.checkRC(hr); break; case VT_RECORD: default: throw new IllegalStateException("Can't parse array content - type not supported: " + getVarType().intValue()); } } /** * Retrieve the value at the referenced index from the SAFEARRAY. * *

The function creates a copy of the value. The values are * allocated with native functions and need to be freed accordingly.

* * @param indices the index, order follows java/C convention * @return the variant */ public Object getElement(int... indices) { WinDef.LONG[] paramIndices = new WinDef.LONG[indices.length]; for (int i = 0; i < indices.length; i++) { paramIndices[i] = new WinDef.LONG(indices[indices.length - i - 1]); } Object result; WinNT.HRESULT hr; Memory mem; PointerByReference pbr; switch (getVarType().intValue()) { case VT_BOOL: mem = new Memory(2); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, mem); COMUtils.checkRC(hr); result = mem.getShort(0) != 0; break; case VT_UI1: case VT_I1: mem = new Memory(1); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, mem); COMUtils.checkRC(hr); result = mem.getByte(0); break; case VT_UI2: case VT_I2: mem = new Memory(2); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, mem); COMUtils.checkRC(hr); result = mem.getShort(0); break; case VT_UI4: case VT_UINT: case VT_I4: case VT_INT: mem = new Memory(4); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, mem); COMUtils.checkRC(hr); result = mem.getInt(0); break; case VT_ERROR: mem = new Memory(4); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, mem); COMUtils.checkRC(hr); result = new SCODE(mem.getInt(0)); break; case VT_R4: mem = new Memory(4); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, mem); COMUtils.checkRC(hr); result = mem.getFloat(0); break; case VT_R8: mem = new Memory(8); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, mem); COMUtils.checkRC(hr); result = mem.getDouble(0); break; case VT_DATE: mem = new Memory(8); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, mem); COMUtils.checkRC(hr); result = new DATE(mem.getDouble(0)); break; case VT_BSTR: pbr = new PointerByReference(); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, pbr.getPointer()); COMUtils.checkRC(hr); BSTR bstr = new BSTR(pbr.getValue()); result = bstr.getValue(); OleAuto.INSTANCE.SysFreeString(bstr); break; case VT_VARIANT: VARIANT holder = new Variant.VARIANT(); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, holder.getPointer()); COMUtils.checkRC(hr); result = holder; break; case VT_UNKNOWN: pbr = new PointerByReference(); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, pbr.getPointer()); COMUtils.checkRC(hr); result = new Unknown(pbr.getValue()); break; case VT_DISPATCH: pbr = new PointerByReference(); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, pbr.getPointer()); COMUtils.checkRC(hr); result = new Dispatch(pbr.getValue()); break; case VT_CY: CURRENCY currency = new CURRENCY(); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, currency.getPointer()); COMUtils.checkRC(hr); result = currency; break; case VT_DECIMAL: DECIMAL decimal = new DECIMAL(); hr = OleAuto.INSTANCE.SafeArrayGetElement(this, paramIndices, decimal.getPointer()); COMUtils.checkRC(hr); result = decimal; break; case VT_RECORD: default: throw new IllegalStateException("Can't parse array content - type not supported: " + getVarType().intValue()); } return result; } /** * Retrieve pointer to data element from array. * *

* Caller is responsible for (un)locking the array via * {@link OleAuto#SafeArrayLock} and {@link OleAuto#SafeArrayUnlock} or * the helper methods: {@link SAFEARRAY#lock} and * {@link SAFEARRAY#unlock}.

* * @param indices the index, order follows java/C convention * @return the pointer to the data element */ public Pointer ptrOfIndex(int... indices) { WinDef.LONG[] paramIndices = new WinDef.LONG[indices.length]; for (int i = 0; i < indices.length; i++) { paramIndices[i] = new WinDef.LONG(indices[indices.length - i - 1]); } PointerByReference pbr = new PointerByReference(); WinNT.HRESULT hr = OleAuto.INSTANCE.SafeArrayPtrOfIndex(this, paramIndices, pbr); COMUtils.checkRC(hr); return pbr.getValue(); } /** * Destroy the underlying SAFEARRAY and free memory */ public void destroy() { WinNT.HRESULT res = OleAuto.INSTANCE.SafeArrayDestroy(this); COMUtils.checkRC(res); } /** * Implemented to satisfy Closeable interface, delegates to destroy. */ public void close() { destroy(); } /** * Retrieve lower bound for the selected dimension. * *

As in the all the accessor functions, that index is converted to * java conventions.

* * @param dimension zerobased index * @return lower bound for the selected dimension */ public int getLBound(int dimension) { int targetDimension = getDimensionCount() - dimension; WinDef.LONGByReference bound = new WinDef.LONGByReference(); WinNT.HRESULT res = OleAuto.INSTANCE.SafeArrayGetLBound(this, new WinDef.UINT(targetDimension), bound); COMUtils.checkRC(res); return bound.getValue().intValue(); } /** * Retrieve upper bound for the selected dimension. * *

As in the all the accessor functions, that index is converted to * java conventions.

* * @param dimension zerobased index * @return upper bound for the selected dimension */ public int getUBound(int dimension) { int targetDimension = getDimensionCount() - dimension; WinDef.LONGByReference bound = new WinDef.LONGByReference(); WinNT.HRESULT res = OleAuto.INSTANCE.SafeArrayGetUBound(this, new WinDef.UINT(targetDimension), bound); COMUtils.checkRC(res); return bound.getValue().intValue(); } /** * Return number of dimensions of the SAFEARRAY * * @return number of dimensions of the SAFEARRAY */ public int getDimensionCount() { return OleAuto.INSTANCE.SafeArrayGetDim(this).intValue(); } /** * Lock array and retrieve pointer to data * * @return Pointer to arraydata */ public Pointer accessData() { PointerByReference pbr = new PointerByReference(); WinNT.HRESULT hr = OleAuto.INSTANCE.SafeArrayAccessData(this, pbr); COMUtils.checkRC(hr); return pbr.getValue(); } /** * Unlock array and invalidate the pointer retrieved via * SafeArrayAccessData */ public void unaccessData() { WinNT.HRESULT hr = OleAuto.INSTANCE.SafeArrayUnaccessData(this); COMUtils.checkRC(hr); } /** * Increments the lock count of an array, and places a pointer to the * array data in pvData of the array descriptor. */ public void lock() { WinNT.HRESULT res = OleAuto.INSTANCE.SafeArrayLock(this); COMUtils.checkRC(res); } /** * Decrements the lock count of an array so it can be freed or resized */ public void unlock() { WinNT.HRESULT res = OleAuto.INSTANCE.SafeArrayUnlock(this); COMUtils.checkRC(res); } /** * Changes the right-most (least significant) bound of the specified * safe array. * * @param cElements * @param lLbound */ public void redim(int cElements, int lLbound) { WinNT.HRESULT res = OleAuto.INSTANCE.SafeArrayRedim(this, new OaIdl.SAFEARRAYBOUND(cElements, lLbound)); COMUtils.checkRC(res); } /** * Return VARTYPE of the SAFEARRAY * * @return VARTYPE of the SAFEARRAY */ public VARTYPE getVarType() { WTypes.VARTYPEByReference resultHolder = new WTypes.VARTYPEByReference(); WinNT.HRESULT res = OleAuto.INSTANCE.SafeArrayGetVartype(this, resultHolder); COMUtils.checkRC(res); return resultHolder.getValue(); } /** * Get size of one element in bytes * * @return element size in bytes */ public long getElemsize() { return OleAuto.INSTANCE.SafeArrayGetElemsize(this).longValue(); } } @FieldOrder({"pSAFEARRAY"}) public static class SAFEARRAYByReference extends Structure implements Structure.ByReference { public SAFEARRAYByReference() { } public SAFEARRAYByReference(Pointer p) { super(p); read(); } public SAFEARRAYByReference(SAFEARRAY.ByReference safeArray) { pSAFEARRAY = safeArray; } public SAFEARRAY.ByReference pSAFEARRAY; } @FieldOrder({"cElements", "lLbound"}) public static class SAFEARRAYBOUND extends Structure { public static class ByReference extends SAFEARRAYBOUND implements Structure.ByReference { } public ULONG cElements; public LONG lLbound; public SAFEARRAYBOUND() { super(); } public SAFEARRAYBOUND(Pointer pointer) { super(pointer); this.read(); } public SAFEARRAYBOUND(int cElements, int lLbound) { this.cElements = new ULONG(cElements); this.lLbound = new LONG(lLbound); this.write(); } } public static class CURRENCY extends Union { public static class ByReference extends CURRENCY implements Structure.ByReference { }; public _CURRENCY currency; public LONGLONG int64; public CURRENCY() { super(); } public CURRENCY(Pointer pointer) { super(pointer); this.read(); } @FieldOrder({"Lo", "Hi"}) public static class _CURRENCY extends Structure { public ULONG Lo; public LONG Hi; public _CURRENCY() { super(); } public _CURRENCY(Pointer pointer) { super(pointer); this.read(); } } } @FieldOrder({"wReserved", "decimal1", "Hi32", "decimal2"}) public static class DECIMAL extends Structure { public static class ByReference extends DECIMAL implements Structure.ByReference { }; public static class _DECIMAL1 extends Union { public USHORT signscale; public _DECIMAL1_DECIMAL decimal1_DECIMAL; public _DECIMAL1() { this.setType("signscale"); } public _DECIMAL1(Pointer pointer) { super(pointer); this.setType("signscale"); this.read(); } @FieldOrder({"scale", "sign"}) public static class _DECIMAL1_DECIMAL extends Structure { public BYTE scale; public BYTE sign; public _DECIMAL1_DECIMAL() { super(); } public _DECIMAL1_DECIMAL(Pointer pointer) { super(pointer); } } } public static class _DECIMAL2 extends Union { public ULONGLONG Lo64; public _DECIMAL2_DECIMAL decimal2_DECIMAL; public _DECIMAL2() { this.setType("Lo64"); } public _DECIMAL2(Pointer pointer) { super(pointer); this.setType("Lo64"); this.read(); } @FieldOrder({"Lo32", "Mid32"}) public static class _DECIMAL2_DECIMAL extends Structure { public BYTE Lo32; public BYTE Mid32; public _DECIMAL2_DECIMAL() { super(); } public _DECIMAL2_DECIMAL(Pointer pointer) { super(pointer); } } } public short wReserved; public _DECIMAL1 decimal1; public NativeLong Hi32; public _DECIMAL2 decimal2; public DECIMAL() { super(); } public DECIMAL(Pointer pointer) { super(pointer); } } @FieldOrder({"value"}) public static class SYSKIND extends Structure { public static class ByReference extends SYSKIND implements Structure.ByReference { } public int value; public SYSKIND() { super(); } public SYSKIND(int value) { this.value = value; } public SYSKIND(Pointer pointer) { super(pointer); this.read(); } public static final int SYS_WIN16 = 0; public static final int SYS_WIN32 = SYSKIND.SYS_WIN16 + 1; public static final int SYS_MAC = SYSKIND.SYS_WIN32 + 1; public static final int SYS_WIN64 = SYSKIND.SYS_MAC + 1; } @FieldOrder({"value"}) public static class LIBFLAGS extends Structure { public static class ByReference extends LIBFLAGS implements Structure.ByReference { } public int value; public LIBFLAGS() { super(); } public LIBFLAGS(int value) { this.value = value; } public LIBFLAGS(Pointer pointer) { super(pointer); this.read(); } public static final int LIBFLAG_FRESTRICTED = 0x1; public static final int LIBFLAG_FCONTROL = 0x2; public static final int LIBFLAG_FHIDDEN = 0x4; public static final int LIBFLAG_FHASDISKIMAGE = 0x8; }; @FieldOrder({"guid", "lcid", "syskind", "wMajorVerNum", "wMinorVerNum", "wLibFlags"}) public static class TLIBATTR extends Structure { public static class ByReference extends TLIBATTR implements Structure.ByReference { public ByReference() { super(); } public ByReference(Pointer pointer) { super(pointer); this.read(); } } public GUID guid; public LCID lcid; public SYSKIND syskind; public WORD wMajorVerNum; public WORD wMinorVerNum; public WORD wLibFlags; public TLIBATTR() { super(); } public TLIBATTR(Pointer pointer) { super(pointer); this.read(); } } public static class BINDPTR extends Union { public static class ByReference extends BINDPTR implements Structure.ByReference { }; // / C type : FUNCDESC* public FUNCDESC lpfuncdesc; // / C type : VARDESC* public VARDESC lpvardesc; // / C type : ITypeComp* public TypeComp lptcomp; public BINDPTR() { super(); } // / @param lpvardesc C type : VARDESC* public BINDPTR(VARDESC lpvardesc) { super(); this.lpvardesc = lpvardesc; setType(VARDESC.class); } // / @param lptcomp C type : ITypeComp* public BINDPTR(TypeComp lptcomp) { super(); this.lptcomp = lptcomp; setType(TypeComp.class); } // / @param lpfuncdesc C type : FUNCDESC* public BINDPTR(FUNCDESC lpfuncdesc) { super(); this.lpfuncdesc = lpfuncdesc; setType(FUNCDESC.class); } } @FieldOrder({"memid", "lprgscode", "lprgelemdescParam", "funckind", "invkind", "callconv", "cParams", "cParamsOpt", "oVft", "cScodes", "elemdescFunc", "wFuncFlags"}) public static class FUNCDESC extends Structure { public static class ByReference extends FUNCDESC implements Structure.ByReference { }; public MEMBERID memid; public ScodeArg.ByReference lprgscode; public ElemDescArg.ByReference lprgelemdescParam; public FUNCKIND funckind; public INVOKEKIND invkind; public CALLCONV callconv; public SHORT cParams; public SHORT cParamsOpt; public SHORT oVft; public SHORT cScodes; public ELEMDESC elemdescFunc; public WORD wFuncFlags; public FUNCDESC() { super(); } public FUNCDESC(Pointer pointer) { super(pointer); this.read(); if (this.cParams.shortValue() > 1) { this.lprgelemdescParam.elemDescArg = new ELEMDESC[this.cParams .shortValue()]; this.lprgelemdescParam.read(); } } } @FieldOrder({"elemDescArg"}) public static class ElemDescArg extends Structure { public static class ByReference extends ElemDescArg implements Structure.ByReference { } public ELEMDESC[] elemDescArg = { new ELEMDESC() }; public ElemDescArg() { super(); } public ElemDescArg(Pointer pointer) { super(pointer); this.read(); } } @FieldOrder({"scodeArg"}) public static class ScodeArg extends Structure { public static class ByReference extends ScodeArg implements Structure.ByReference { } public SCODE[] scodeArg = { new SCODE() }; public ScodeArg() { super(); } public ScodeArg(Pointer pointer) { super(pointer); this.read(); } } @FieldOrder({"memid", "lpstrSchema", "_vardesc", "elemdescVar", "wVarFlags", "varkind"}) public class VARDESC extends Structure { public static class ByReference extends VARDESC implements Structure.ByReference { }; // / C type : MEMBERID public MEMBERID memid; // / C type : LPOLESTR public LPOLESTR lpstrSchema; /** * [switch_is][switch_type]
* C type : _VARDESC_union */ public _VARDESC _vardesc; // / C type : ELEMDESC public ELEMDESC elemdescVar; public WORD wVarFlags; // / C type : VARKIND public VARKIND varkind; // / native declaration : line 6 // / native declaration : line 6 public static class _VARDESC extends Union { public static class ByReference extends _VARDESC implements Structure.ByReference { }; // / [case()] public NativeLong oInst; /** * [case()]
* C type : VARIANT* */ public VARIANT.ByReference lpvarValue; public _VARDESC() { setType("lpvarValue"); this.read(); } public _VARDESC(Pointer pointer) { super(pointer); setType("lpvarValue"); this.read(); } /** * @param lpvarValue * [case()]
* C type : VARIANT* */ public _VARDESC(VARIANT.ByReference lpvarValue) { this.lpvarValue = lpvarValue; setType("lpvarValue"); } // / @param oInst [case()] public _VARDESC(NativeLong oInst) { this.oInst = oInst; setType("oInst"); } }; public VARDESC() { super(); } public VARDESC(Pointer pointer) { super(pointer); this._vardesc.setType("lpvarValue"); this.read(); } } @FieldOrder({"tdesc", "_elemdesc"}) public static class ELEMDESC extends Structure { public static class ByReference extends ELEMDESC implements Structure.ByReference { }; /** * the type of the element
* C type : TYPEDESC */ public TYPEDESC tdesc; // / C type : DUMMYUNIONNAMEUnion public _ELEMDESC _elemdesc; // / native declaration : line 4 // / native declaration : line 4 public static class _ELEMDESC extends Union { public static class ByReference extends _ELEMDESC implements Structure.ByReference { }; /** * info for remoting the element
* C type : IDLDESC */ public IDLDESC idldesc; /** * info about the parameter
* C type : PARAMDESC */ public PARAMDESC paramdesc; public _ELEMDESC() { } public _ELEMDESC(Pointer pointer) { super(pointer); setType("paramdesc"); this.read(); } /** * @param paramdesc * info about the parameter
* C type : PARAMDESC */ public _ELEMDESC(PARAMDESC paramdesc) { this.paramdesc = paramdesc; setType("paramdesc"); } /** * @param idldesc * info for remoting the element
* C type : IDLDESC */ public _ELEMDESC(IDLDESC idldesc) { this.idldesc = idldesc; setType("idldesc"); } }; public ELEMDESC() { super(); } public ELEMDESC(Pointer pointer) { super(pointer); this.read(); } } @FieldOrder({"value"}) public static class FUNCKIND extends Structure { public static class ByReference extends FUNCKIND implements Structure.ByReference { }; // / native declaration : line 20 public static final int FUNC_VIRTUAL = 0; // / native declaration : line 21 public static final int FUNC_PUREVIRTUAL = FUNC_VIRTUAL + 1; // / native declaration : line 22 public static final int FUNC_NONVIRTUAL = FUNC_PUREVIRTUAL + 1; // / native declaration : line 23 public static final int FUNC_STATIC = FUNC_NONVIRTUAL + 1; // / native declaration : line 24 public static final int FUNC_DISPATCH = FUNC_STATIC + 1; public int value; public FUNCKIND() { super(); } public FUNCKIND(int value) { this.value = value; } } @FieldOrder({"value"}) public static class INVOKEKIND extends Structure { public static class ByReference extends INVOKEKIND implements Structure.ByReference { } // / native declaration : line 30 public static final INVOKEKIND INVOKE_FUNC = new INVOKEKIND(1); // / native declaration : line 31 public static final INVOKEKIND INVOKE_PROPERTYGET = new INVOKEKIND(2); // / native declaration : line 32 public static final INVOKEKIND INVOKE_PROPERTYPUT = new INVOKEKIND(4); // / native declaration : line 33 public static final INVOKEKIND INVOKE_PROPERTYPUTREF = new INVOKEKIND(8); public int value; public INVOKEKIND() { super(); } public INVOKEKIND(int value) { this.value = value; } } @FieldOrder({"value"}) public static class CALLCONV extends Structure { public static class ByReference extends CALLCONV implements Structure.ByReference { } // / native declaration : line 4 public static final int CC_FASTCALL = 0; // / native declaration : line 5 public static final int CC_CDECL = 1; // / native declaration : line 6 public static final int CC_MSCPASCAL = CALLCONV.CC_CDECL + 1; // / native declaration : line 7 public static final int CC_PASCAL = CALLCONV.CC_MSCPASCAL; // / native declaration : line 8 public static final int CC_MACPASCAL = CALLCONV.CC_PASCAL + 1; // / native declaration : line 9 public static final int CC_STDCALL = CALLCONV.CC_MACPASCAL + 1; // / native declaration : line 10 public static final int CC_FPFASTCALL = CALLCONV.CC_STDCALL + 1; // / native declaration : line 11 public static final int CC_SYSCALL = CALLCONV.CC_FPFASTCALL + 1; // / native declaration : line 12 public static final int CC_MPWCDECL = CALLCONV.CC_SYSCALL + 1; // / native declaration : line 13 public static final int CC_MPWPASCAL = CALLCONV.CC_MPWCDECL + 1; // / native declaration : line 14 public static final int CC_MAX = CALLCONV.CC_MPWPASCAL + 1; public int value; public CALLCONV() { } public CALLCONV(int value) { this.value = value; } } @FieldOrder({"value"}) public static class VARKIND extends Structure { public static class ByReference extends VARKIND implements Structure.ByReference { }; // / native declaration : line 4 public static final int VAR_PERINSTANCE = 0; // / native declaration : line 5 public static final int VAR_STATIC = VAR_PERINSTANCE + 1; // / native declaration : line 6 public static final int VAR_CONST = VAR_STATIC + 1; // / native declaration : line 7 public static final int VAR_DISPATCH = VAR_CONST + 1; public int value; public VARKIND() { super(); } public VARKIND(int value) { this.value = value; } } @FieldOrder({"_typedesc", "vt"}) public static class TYPEDESC extends Structure { public static class ByReference extends TYPEDESC implements Structure.ByReference { }; public static class _TYPEDESC extends Union { /** * [case()]
* C type : tagTYPEDESC* */ public TYPEDESC.ByReference lptdesc; /** * [case()]
* C type : tagARRAYDESC* */ public ARRAYDESC.ByReference lpadesc; /** * [case()]
* C type : HREFTYPE */ public HREFTYPE hreftype; public _TYPEDESC() { this.setType("hreftype"); this.read(); } public _TYPEDESC(Pointer pointer) { super(pointer); this.setType("hreftype"); this.read(); } public TYPEDESC.ByReference getLptdesc() { this.setType("lptdesc"); this.read(); return this.lptdesc; } public ARRAYDESC.ByReference getLpadesc() { this.setType("lpadesc"); this.read(); return this.lpadesc; } public HREFTYPE getHreftype() { this.setType("hreftype"); this.read(); return this.hreftype; } }; public _TYPEDESC _typedesc; public VARTYPE vt; public TYPEDESC() { this.read(); } public TYPEDESC(Pointer pointer) { super(pointer); this.read(); } public TYPEDESC(_TYPEDESC _typedesc, VARTYPE vt) { this._typedesc = _typedesc; this.vt = vt; } } @FieldOrder({"dwReserved", "wIDLFlags"}) public static class IDLDESC extends Structure { public static class ByReference extends IDLDESC implements Structure.ByReference { public ByReference() { super(); } public ByReference(IDLDESC idldesc) { super(idldesc.dwReserved, idldesc.wIDLFlags); } }; // / C type : ULONG_PTR public ULONG_PTR dwReserved; public USHORT wIDLFlags; public IDLDESC() { super(); } public IDLDESC(Pointer pointer) { super(pointer); this.read(); } // / @param dwReserved C type : ULONG_PTR public IDLDESC(ULONG_PTR dwReserved, USHORT wIDLFlags) { this.dwReserved = dwReserved; this.wIDLFlags = wIDLFlags; } } @FieldOrder({"tdescElem", "cDims", "rgbounds"}) public class ARRAYDESC extends Structure { // / C type : TYPEDESC public TYPEDESC tdescElem; public short cDims; /** * [size_is]
* C type : SAFEARRAYBOUND[1] */ public SAFEARRAYBOUND[] rgbounds = { new SAFEARRAYBOUND() }; public ARRAYDESC() { super(); } public ARRAYDESC(Pointer pointer) { super(pointer); this.read(); } /** * @param tdescElem * C type : TYPEDESC
* @param cDims dimensions * @param rgbounds * [size_is]
* C type : SAFEARRAYBOUND[1] */ public ARRAYDESC(TYPEDESC tdescElem, short cDims, SAFEARRAYBOUND rgbounds[]) { this.tdescElem = tdescElem; this.cDims = cDims; if (rgbounds.length != this.rgbounds.length) throw new IllegalArgumentException("Wrong array size !"); this.rgbounds = rgbounds; } public static class ByReference extends ARRAYDESC implements Structure.ByReference { }; } @FieldOrder({"pparamdescex", "wParamFlags"}) public static class PARAMDESC extends Structure { public static class ByReference extends PARAMDESC implements Structure.ByReference { } // replaced PARAMDESCEX.ByReference with Pointer // because of JNA 4 has a problem with ByReference public Pointer pparamdescex; public USHORT wParamFlags; public PARAMDESC() { super(); } public PARAMDESC(Pointer pointer) { super(pointer); this.read(); } } @FieldOrder({"cBytes", "varDefaultValue"}) public static class PARAMDESCEX extends Structure { public static class ByReference extends PARAMDESCEX implements Structure.ByReference { }; public ULONG cBytes; public VariantArg varDefaultValue; public PARAMDESCEX() { super(); } public PARAMDESCEX(Pointer pointer) { super(pointer); this.read(); } } public static class HREFTYPE extends DWORD { private static final long serialVersionUID = 1L; public HREFTYPE() { super(); } public HREFTYPE(long value) { super(value); } } public static class HREFTYPEByReference extends DWORDByReference { public HREFTYPEByReference() { this(new HREFTYPE(0)); } public HREFTYPEByReference(DWORD value) { super(value); } public void setValue(HREFTYPE value) { getPointer().setInt(0, value.intValue()); } @Override public HREFTYPE getValue() { return new HREFTYPE(getPointer().getInt(0)); } } @FieldOrder({"guid", "lcid", "dwReserved", "memidConstructor", "memidDestructor", "lpstrSchema", "cbSizeInstance", "typekind", "cFuncs", "cVars", "cImplTypes", "cbSizeVft", "cbAlignment", "wTypeFlags", "wMajorVerNum", "wMinorVerNum", "tdescAlias", "idldescType"}) public class TYPEATTR extends Structure { public static class ByReference extends TYPEATTR implements Structure.ByReference { }; // / C type : GUID public GUID guid; // / C type : LCID public LCID lcid; public DWORD dwReserved; // / C type : MEMBERID public MEMBERID memidConstructor; // / C type : MEMBERID public MEMBERID memidDestructor; // / C type : LPOLESTR public LPOLESTR lpstrSchema; public ULONG cbSizeInstance; // / C type : TYPEKIND public TYPEKIND typekind; public WORD cFuncs; public WORD cVars; public WORD cImplTypes; public WORD cbSizeVft; public WORD cbAlignment; // The type flags. See TYPEFLAGS_... public WORD wTypeFlags; public WORD wMajorVerNum; public WORD wMinorVerNum; // / C type : TYPEDESC public TYPEDESC tdescAlias; // / C type : IDLDESC public IDLDESC idldescType; public TYPEATTR() { super(); } public TYPEATTR(Pointer pointer) { super(pointer); this.read(); } /** * A type description that describes an Application object. */ public final static int TYPEFLAGS_FAPPOBJECT = 0x1; /** * Instances of the type can be created by ITypeInfo::CreateInstance. */ public final static int TYPEFLAGS_FCANCREATE = 0x2; /** * The type is licensed. */ public final static int TYPEFLAGS_FLICENSED = 0x4; /** * The type is predefined. The client application should automatically create a single instance of the object * that has this attribute. The name of the variable that points to the object is the same as the class name of * the object. */ public final static int TYPEFLAGS_FPREDECLID = 0x8; /** * The type should not be displayed to browsers. */ public final static int TYPEFLAGS_FHIDDEN = 0x10; /** * The type is a control from which other types will be derived, and should not be displayed to users. */ public final static int TYPEFLAGS_FCONTROL = 0x20; /** * The interface supplies both IDispatch and VTBL binding. */ public final static int TYPEFLAGS_FDUAL = 0x40; /** * The interface cannot add members at run time. */ public final static int TYPEFLAGS_FNONEXTENSIBLE = 0x80; /** * The types used in the interface are fully compatible with Automation, including VTBL binding support. Setting * dual on an interface sets this flag in addition to TYPEFLAG_FDUAL. Not allowed on dispinterfaces. */ public final static int TYPEFLAGS_FOLEAUTOMATION = 0x100; /** * Should not be accessible from macro languages. This flag is intended for system-level types or types that * type browsers should not display. */ public final static int TYPEFLAGS_FRESTRICTED = 0x200; /** * The class supports aggregation. */ public final static int TYPEFLAGS_FAGGREGATABLE = 0x400; /** * The type is replaceable. */ public final static int TYPEFLAGS_FREPLACEABLE = 0x800; /** * Indicates that the interface derives from IDispatch, either directly or indirectly. This flag is computed. * There is no Object Description Language for the flag. */ public final static int TYPEFLAGS_FDISPATCHABLE = 0x1000; /** * The type has reverse binding. */ public final static int TYPEFLAGS_FREVERSEBIND = 0x2000; /** * Interfaces can be marked with this flag to indicate that they will be using a proxy/stub dynamic link * library. This flag specifies that the typelib proxy should not be unregistered when the typelib is * unregistered. */ public final static int TYPEFLAGS_FPROXY = 0x4000; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy