1<?xml version="1.0" encoding="UTF-8"?> 2<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd"> 3<script:module xmlns:script="http://openoffice.org/2000/script" script:name="sheet_XRecentFunctions" script:language="StarBasic"> 4 5 6'************************************************************************* 7' 8' Licensed to the Apache Software Foundation (ASF) under one 9' or more contributor license agreements. See the NOTICE file 10' distributed with this work for additional information 11' regarding copyright ownership. The ASF licenses this file 12' to you under the Apache License, Version 2.0 (the 13' "License"); you may not use this file except in compliance 14' with the License. You may obtain a copy of the License at 15' 16' http://www.apache.org/licenses/LICENSE-2.0 17' 18' Unless required by applicable law or agreed to in writing, 19' software distributed under the License is distributed on an 20' "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 21' KIND, either express or implied. See the License for the 22' specific language governing permissions and limitations 23' under the License. 24' 25'************************************************************************* 26 27 28 29 30 31' Be sure that all variables are dimensioned: 32option explicit 33 34'************************************************************************* 35' This Interface/Service test depends on the following GLOBAL variables, 36' which must be specified in the object creation: 37 38' - Global AllFunctions As Variant 39 40'************************************************************************* 41 42 43 44 45 46 47Sub RunTest() 48 49'************************************************************************* 50' INTERFACE: 51' com.sun.star.sheet.XRecentFunctions 52'************************************************************************* 53On Error Goto ErrHndl 54 Dim bOK As Boolean 55 Dim recentFunctions As Variant 56 Dim i, j As Integer 57 Dim props As Variant 58 59 60 Test.StartMethod("getRecentFunctionIds()") 61 bOK = true 62 recentFunctions = oObj.getRecentFunctionIds() 63 bOK = bOK AND NOT isNULL(recentFunctions) 64 bOK = bOK AND ubound(recentFunctions) <= oObj.getMaxRecentFunctions 65 for i = 0 to ubound(recentFunctions) - 1 66 for j = i + 1 to ubound(recentFunctions) 67 if recentFunctions(i) = recentFunctions(j) then bOK = false 68 next j 69 next i 70 Test.MethodTested("getRecentFunctionIds()", bOK) 71 72 Test.StartMethod("setRecentFunctionIds()") 73 bOK = true 74 Dim Max As Integer 75 Max = oObj.getMaxRecentFunctions 76 Dim newList(Max) As Integer 77 78 for i = 0 to ubound(newList()) 79 props = AllFunctions.getByIndex(i) 80 for j = 0 to ubound(props()) 81 if props(j).Name = "Id" then 82 newList(i) = props(j).Value 83 exit for 84 end if 85 next j 86 next i 87 88 oObj.setRecentFunctionIds(newList()) 89 bOK = bOK AND (Max = oObj.getMaxRecentFunctions) 90 Test.MethodTested("setRecentFunctionIds()", bOK) 91 92 Test.StartMethod("getMaxRecentFunctions()") 93 bOK = true 94 Max = oObj.getMaxRecentFunctions 95 Out.Log("MaxRecentFunctions = " & Max) 96 bOK = bOK AND Max > 0 97 Test.MethodTested("getMaxRecentFunctions()", bOK) 98 99Exit Sub 100ErrHndl: 101 Test.Exception() 102 bOK = false 103 resume next 104End Sub 105</script:module> 106