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