1*b1cdbd2cSJim Jagielski<?xml version="1.0" encoding="UTF-8"?>
2*b1cdbd2cSJim Jagielski<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3*b1cdbd2cSJim Jagielski<script:module xmlns:script="http://openoffice.org/2000/script" script:name="beans_XFastPropertySet" script:language="StarBasic">
4*b1cdbd2cSJim Jagielski
5*b1cdbd2cSJim Jagielski
6*b1cdbd2cSJim Jagielski'*************************************************************************
7*b1cdbd2cSJim Jagielski'
8*b1cdbd2cSJim Jagielski'  Licensed to the Apache Software Foundation (ASF) under one
9*b1cdbd2cSJim Jagielski'  or more contributor license agreements.  See the NOTICE file
10*b1cdbd2cSJim Jagielski'  distributed with this work for additional information
11*b1cdbd2cSJim Jagielski'  regarding copyright ownership.  The ASF licenses this file
12*b1cdbd2cSJim Jagielski'  to you under the Apache License, Version 2.0 (the
13*b1cdbd2cSJim Jagielski'  "License"); you may not use this file except in compliance
14*b1cdbd2cSJim Jagielski'  with the License.  You may obtain a copy of the License at
15*b1cdbd2cSJim Jagielski'
16*b1cdbd2cSJim Jagielski'    http://www.apache.org/licenses/LICENSE-2.0
17*b1cdbd2cSJim Jagielski'
18*b1cdbd2cSJim Jagielski'  Unless required by applicable law or agreed to in writing,
19*b1cdbd2cSJim Jagielski'  software distributed under the License is distributed on an
20*b1cdbd2cSJim Jagielski'  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21*b1cdbd2cSJim Jagielski'  KIND, either express or implied.  See the License for the
22*b1cdbd2cSJim Jagielski'  specific language governing permissions and limitations
23*b1cdbd2cSJim Jagielski'  under the License.
24*b1cdbd2cSJim Jagielski'
25*b1cdbd2cSJim Jagielski'*************************************************************************
26*b1cdbd2cSJim Jagielski
27*b1cdbd2cSJim Jagielski
28*b1cdbd2cSJim Jagielski
29*b1cdbd2cSJim Jagielski
30*b1cdbd2cSJim Jagielski
31*b1cdbd2cSJim Jagielski
32*b1cdbd2cSJim Jagielski
33*b1cdbd2cSJim JagielskiSub RunTest()
34*b1cdbd2cSJim Jagielski
35*b1cdbd2cSJim Jagielski'*************************************************************************
36*b1cdbd2cSJim Jagielski' INTERFACE:
37*b1cdbd2cSJim Jagielski' com.sun.star.beans.XFastPropertySet
38*b1cdbd2cSJim Jagielski'*************************************************************************
39*b1cdbd2cSJim JagielskiOn Error Goto ErrHndl
40*b1cdbd2cSJim Jagielski
41*b1cdbd2cSJim Jagielski    Dim bOK As Boolean
42*b1cdbd2cSJim Jagielski    Dim oPropertySetInfo As Object
43*b1cdbd2cSJim Jagielski    Dim oProperties As Variant
44*b1cdbd2cSJim Jagielski    Dim nIndex As Long, nHanlde As Long
45*b1cdbd2cSJim Jagielski    Dim nCount As Integer
46*b1cdbd2cSJim Jagielski    Dim vMemVal As Variant, vNewVal As Variant
47*b1cdbd2cSJim Jagielski    Dim bBoolean As Boolean
48*b1cdbd2cSJim Jagielski    Dim nInteger As Integer
49*b1cdbd2cSJim Jagielski    Dim nLong As Long
50*b1cdbd2cSJim Jagielski    Dim nSingle As Single
51*b1cdbd2cSJim Jagielski    Dim nDouble As Double
52*b1cdbd2cSJim Jagielski
53*b1cdbd2cSJim Jagielski    oPropertySetInfo = oObj.GetPropertySetInfo()
54*b1cdbd2cSJim Jagielski    oProperties = oPropertySetInfo.Properties
55*b1cdbd2cSJim Jagielski    nCount = uBound(oProperties)
56*b1cdbd2cSJim Jagielski
57*b1cdbd2cSJim Jagielski    nIndex = 0
58*b1cdbd2cSJim Jagielski    nMem = nIndex
59*b1cdbd2cSJim Jagielski    'find at first a Boolean Value, if not available a String Property
60*b1cdbd2cSJim Jagielski    While (NOT bFound) AND (nCount &gt;= nIndex)
61*b1cdbd2cSJim Jagielski        If VarType(oObj.getFastPropertyValue(oProperties(nIndex).Handle)) = 11 Then ' it is a Boolean Proerty
62*b1cdbd2cSJim Jagielski            bFound = true
63*b1cdbd2cSJim Jagielski            nMem = nIndex
64*b1cdbd2cSJim Jagielski        else
65*b1cdbd2cSJim Jagielski            If VarType(oObj.getFastPropertyValue(oProperties(nIndex).Handle)) = 8 Then ' it is a String Property
66*b1cdbd2cSJim Jagielski                nMem = nIndex
67*b1cdbd2cSJim Jagielski            end if
68*b1cdbd2cSJim Jagielski        end if
69*b1cdbd2cSJim Jagielski        nIndex = nIndex + 1
70*b1cdbd2cSJim Jagielski    Wend
71*b1cdbd2cSJim Jagielski    nIndex = nMem
72*b1cdbd2cSJim Jagielski    Out.Log("Property selected: '" + oProperties(nIndex).Name + "'")
73*b1cdbd2cSJim Jagielski
74*b1cdbd2cSJim Jagielski    'memory the old Value
75*b1cdbd2cSJim Jagielski    vMemVal = oObj.getFastPropertyValue(oProperties(nIndex).Handle)
76*b1cdbd2cSJim Jagielski    ' change the Value
77*b1cdbd2cSJim Jagielski    select case VarType(oObj.getFastPropertyValue(oProperties(nIndex).Handle)
78*b1cdbd2cSJim Jagielski        case 11 'boolean
79*b1cdbd2cSJim Jagielski            bBoolean = NOT oObj.getFastPropertyValue(oProperties(nIndex).Handle)
80*b1cdbd2cSJim Jagielski            vNewVal = bBoolean
81*b1cdbd2cSJim Jagielski        case 2 'integer
82*b1cdbd2cSJim Jagielski            nInteger = oObj.getFastPropertyValue(oProperties(nIndex).Handle) + 1
83*b1cdbd2cSJim Jagielski            vNewVal = nInteger
84*b1cdbd2cSJim Jagielski        case 3 'long
85*b1cdbd2cSJim Jagielski            nLong = oObj.getFastPropertyValue(oProperties(nIndex).Handle) + 1
86*b1cdbd2cSJim Jagielski            vNewVal = nLong
87*b1cdbd2cSJim Jagielski        case 4 'single
88*b1cdbd2cSJim Jagielski            nSingle = oObj.getFastPropertyValue(oProperties(nIndex).Handle) + 1
89*b1cdbd2cSJim Jagielski            vNewVal = nSingle
90*b1cdbd2cSJim Jagielski        case 5 'double
91*b1cdbd2cSJim Jagielski            nDouble = oObj.getFastPropertyValue(oProperties(nIndex).Handle) + 1
92*b1cdbd2cSJim Jagielski            vNewVal = nDouble
93*b1cdbd2cSJim Jagielski        case 8 'string
94*b1cdbd2cSJim Jagielski          vNewVal = oObj.getPropertyValue(oProperties(nIndex).Name) + cIfcShortName
95*b1cdbd2cSJim Jagielski    end select
96*b1cdbd2cSJim Jagielski
97*b1cdbd2cSJim Jagielski    nHandle = oProperties(nIndex).Handle
98*b1cdbd2cSJim Jagielski
99*b1cdbd2cSJim Jagielski    Test.StartMethod("getFastPropertyValue()")
100*b1cdbd2cSJim Jagielski    bOK = true
101*b1cdbd2cSJim Jagielski    bOK = bOK AND (vMemVal = oObj.getFastPropertyValue(nHandle))
102*b1cdbd2cSJim Jagielski    Test.MethodTested("getFastPropertyValue()", bOK)
103*b1cdbd2cSJim Jagielski
104*b1cdbd2cSJim Jagielski    Test.StartMethod("setFastPropertyValue()")
105*b1cdbd2cSJim Jagielski    bOK = true
106*b1cdbd2cSJim Jagielski    oObj.setFastPropertyValue(nHandle, vNewVal)
107*b1cdbd2cSJim Jagielski    bOK = bOK AND (vMemVal &lt;&gt; oObj.getFastPropertyValue(nHandle))
108*b1cdbd2cSJim Jagielski    Test.MethodTested("setFastPropertyValue()", bOK)
109*b1cdbd2cSJim Jagielski
110*b1cdbd2cSJim Jagielski
111*b1cdbd2cSJim JagielskiExit Sub
112*b1cdbd2cSJim JagielskiErrHndl:
113*b1cdbd2cSJim Jagielski    Test.Exception()
114*b1cdbd2cSJim Jagielski    bOK = false
115*b1cdbd2cSJim Jagielski    resume next
116*b1cdbd2cSJim JagielskiEnd Sub
117*b1cdbd2cSJim Jagielski</script:module>
118