1*cdf0e10cSrcweir<?xml version="1.0" encoding="UTF-8"?>
2*cdf0e10cSrcweir<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3*cdf0e10cSrcweir<script:module xmlns:script="http://openoffice.org/2000/script" script:name="beans_XFastPropertySet" script:language="StarBasic">
4*cdf0e10cSrcweir
5*cdf0e10cSrcweir
6*cdf0e10cSrcweir'*************************************************************************
7*cdf0e10cSrcweir'
8*cdf0e10cSrcweir' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
9*cdf0e10cSrcweir'
10*cdf0e10cSrcweir' Copyright 2000, 2010 Oracle and/or its affiliates.
11*cdf0e10cSrcweir'
12*cdf0e10cSrcweir' OpenOffice.org - a multi-platform office productivity suite
13*cdf0e10cSrcweir'
14*cdf0e10cSrcweir' This file is part of OpenOffice.org.
15*cdf0e10cSrcweir'
16*cdf0e10cSrcweir' OpenOffice.org is free software: you can redistribute it and/or modify
17*cdf0e10cSrcweir' it under the terms of the GNU Lesser General Public License version 3
18*cdf0e10cSrcweir' only, as published by the Free Software Foundation.
19*cdf0e10cSrcweir'
20*cdf0e10cSrcweir' OpenOffice.org is distributed in the hope that it will be useful,
21*cdf0e10cSrcweir' but WITHOUT ANY WARRANTY; without even the implied warranty of
22*cdf0e10cSrcweir' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23*cdf0e10cSrcweir' GNU Lesser General Public License version 3 for more details
24*cdf0e10cSrcweir' (a copy is included in the LICENSE file that accompanied this code).
25*cdf0e10cSrcweir'
26*cdf0e10cSrcweir' You should have received a copy of the GNU Lesser General Public License
27*cdf0e10cSrcweir' version 3 along with OpenOffice.org.  If not, see
28*cdf0e10cSrcweir' <http://www.openoffice.org/license.html>
29*cdf0e10cSrcweir' for a copy of the LGPLv3 License.
30*cdf0e10cSrcweir'
31*cdf0e10cSrcweir'*************************************************************************
32*cdf0e10cSrcweir'*************************************************************************
33*cdf0e10cSrcweir
34*cdf0e10cSrcweir
35*cdf0e10cSrcweir
36*cdf0e10cSrcweir
37*cdf0e10cSrcweir
38*cdf0e10cSrcweirSub RunTest()
39*cdf0e10cSrcweir
40*cdf0e10cSrcweir'*************************************************************************
41*cdf0e10cSrcweir' INTERFACE:
42*cdf0e10cSrcweir' com.sun.star.beans.XFastPropertySet
43*cdf0e10cSrcweir'*************************************************************************
44*cdf0e10cSrcweirOn Error Goto ErrHndl
45*cdf0e10cSrcweir
46*cdf0e10cSrcweir    Dim bOK As Boolean
47*cdf0e10cSrcweir    Dim oPropertySetInfo As Object
48*cdf0e10cSrcweir    Dim oProperties As Variant
49*cdf0e10cSrcweir    Dim nIndex As Long, nHanlde As Long
50*cdf0e10cSrcweir    Dim nCount As Integer
51*cdf0e10cSrcweir    Dim vMemVal As Variant, vNewVal As Variant
52*cdf0e10cSrcweir    Dim bBoolean As Boolean
53*cdf0e10cSrcweir    Dim nInteger As Integer
54*cdf0e10cSrcweir    Dim nLong As Long
55*cdf0e10cSrcweir    Dim nSingle As Single
56*cdf0e10cSrcweir    Dim nDouble As Double
57*cdf0e10cSrcweir
58*cdf0e10cSrcweir    oPropertySetInfo = oObj.GetPropertySetInfo()
59*cdf0e10cSrcweir    oProperties = oPropertySetInfo.Properties
60*cdf0e10cSrcweir    nCount = uBound(oProperties)
61*cdf0e10cSrcweir
62*cdf0e10cSrcweir    nIndex = 0
63*cdf0e10cSrcweir    nMem = nIndex
64*cdf0e10cSrcweir    'find at first a Boolean Value, if not available a String Property
65*cdf0e10cSrcweir    While (NOT bFound) AND (nCount &gt;= nIndex)
66*cdf0e10cSrcweir        If VarType(oObj.getFastPropertyValue(oProperties(nIndex).Handle)) = 11 Then ' it is a Boolean Proerty
67*cdf0e10cSrcweir            bFound = true
68*cdf0e10cSrcweir            nMem = nIndex
69*cdf0e10cSrcweir        else
70*cdf0e10cSrcweir            If VarType(oObj.getFastPropertyValue(oProperties(nIndex).Handle)) = 8 Then ' it is a String Property
71*cdf0e10cSrcweir                nMem = nIndex
72*cdf0e10cSrcweir            end if
73*cdf0e10cSrcweir        end if
74*cdf0e10cSrcweir        nIndex = nIndex + 1
75*cdf0e10cSrcweir    Wend
76*cdf0e10cSrcweir    nIndex = nMem
77*cdf0e10cSrcweir    Out.Log("Property selected: '" + oProperties(nIndex).Name + "'")
78*cdf0e10cSrcweir
79*cdf0e10cSrcweir    'memory the old Value
80*cdf0e10cSrcweir    vMemVal = oObj.getFastPropertyValue(oProperties(nIndex).Handle)
81*cdf0e10cSrcweir    ' change the Value
82*cdf0e10cSrcweir    select case VarType(oObj.getFastPropertyValue(oProperties(nIndex).Handle)
83*cdf0e10cSrcweir        case 11 'boolean
84*cdf0e10cSrcweir            bBoolean = NOT oObj.getFastPropertyValue(oProperties(nIndex).Handle)
85*cdf0e10cSrcweir            vNewVal = bBoolean
86*cdf0e10cSrcweir        case 2 'integer
87*cdf0e10cSrcweir            nInteger = oObj.getFastPropertyValue(oProperties(nIndex).Handle) + 1
88*cdf0e10cSrcweir            vNewVal = nInteger
89*cdf0e10cSrcweir        case 3 'long
90*cdf0e10cSrcweir            nLong = oObj.getFastPropertyValue(oProperties(nIndex).Handle) + 1
91*cdf0e10cSrcweir            vNewVal = nLong
92*cdf0e10cSrcweir        case 4 'single
93*cdf0e10cSrcweir            nSingle = oObj.getFastPropertyValue(oProperties(nIndex).Handle) + 1
94*cdf0e10cSrcweir            vNewVal = nSingle
95*cdf0e10cSrcweir        case 5 'double
96*cdf0e10cSrcweir            nDouble = oObj.getFastPropertyValue(oProperties(nIndex).Handle) + 1
97*cdf0e10cSrcweir            vNewVal = nDouble
98*cdf0e10cSrcweir        case 8 'string
99*cdf0e10cSrcweir          vNewVal = oObj.getPropertyValue(oProperties(nIndex).Name) + cIfcShortName
100*cdf0e10cSrcweir    end select
101*cdf0e10cSrcweir
102*cdf0e10cSrcweir    nHandle = oProperties(nIndex).Handle
103*cdf0e10cSrcweir
104*cdf0e10cSrcweir    Test.StartMethod("getFastPropertyValue()")
105*cdf0e10cSrcweir    bOK = true
106*cdf0e10cSrcweir    bOK = bOK AND (vMemVal = oObj.getFastPropertyValue(nHandle))
107*cdf0e10cSrcweir    Test.MethodTested("getFastPropertyValue()", bOK)
108*cdf0e10cSrcweir
109*cdf0e10cSrcweir    Test.StartMethod("setFastPropertyValue()")
110*cdf0e10cSrcweir    bOK = true
111*cdf0e10cSrcweir    oObj.setFastPropertyValue(nHandle, vNewVal)
112*cdf0e10cSrcweir    bOK = bOK AND (vMemVal &lt;&gt; oObj.getFastPropertyValue(nHandle))
113*cdf0e10cSrcweir    Test.MethodTested("setFastPropertyValue()", bOK)
114*cdf0e10cSrcweir
115*cdf0e10cSrcweir
116*cdf0e10cSrcweirExit Sub
117*cdf0e10cSrcweirErrHndl:
118*cdf0e10cSrcweir    Test.Exception()
119*cdf0e10cSrcweir    bOK = false
120*cdf0e10cSrcweir    resume next
121*cdf0e10cSrcweirEnd Sub
122*cdf0e10cSrcweir</script:module>
123