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_XNamedRanges" 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 36cdf0e10cSrcweirSub RunTest() 37cdf0e10cSrcweir 38cdf0e10cSrcweir'************************************************************************* 39cdf0e10cSrcweir' INTERFACE: 40cdf0e10cSrcweir' com.sun.star.sheet.XNamedRanges 41cdf0e10cSrcweir'************************************************************************* 42cdf0e10cSrcweirOn Error Goto ErrHndl 43cdf0e10cSrcweir Dim bOK As Boolean 44cdf0e10cSrcweir Dim count As Integer 45cdf0e10cSrcweir Dim outRange As New com.sun.star.table.CellAddress 46cdf0e10cSrcweir Dim range As New com.sun.star.table.CellRangeAddress 47cdf0e10cSrcweir Dim i As Integer 48cdf0e10cSrcweir 49cdf0e10cSrcweir Test.StartMethod("addNewByName()") 50cdf0e10cSrcweir bOK = true 51cdf0e10cSrcweir outRange.Sheet = 0 52cdf0e10cSrcweir outRange.Row = 1 53cdf0e10cSrcweir outRange.Column = 1 54cdf0e10cSrcweir count = oObj.Count 55cdf0e10cSrcweir oObj.addNewByName(cIfcShortName, "T4:Y7", outRange, 0) 56cdf0e10cSrcweir bOK = bOK AND oObj.count = count + 1 57cdf0e10cSrcweir bOK = bOK AND oObj.hasByName(cIfcShortName) 58cdf0e10cSrcweir Test.MethodTested("addNewByName()", bOK) 59cdf0e10cSrcweir 60cdf0e10cSrcweir Test.StartMethod("addNewFromTitles()") 61cdf0e10cSrcweir bOK = true 62cdf0e10cSrcweir count = oObj.count 63cdf0e10cSrcweir 64cdf0e10cSrcweir range.Sheet = 0 65cdf0e10cSrcweir range.StartRow = 1 66cdf0e10cSrcweir range.StartColumn = 2 67cdf0e10cSrcweir range.EndRow = 3 68cdf0e10cSrcweir range.EndColumn = 4 69cdf0e10cSrcweir 70cdf0e10cSrcweir for i = 1 to 5 71cdf0e10cSrcweir oDoc.Sheets(0).getCellByPosition(i, 1).String = "Col" & i 72cdf0e10cSrcweir next i 73cdf0e10cSrcweir 74cdf0e10cSrcweir oObj.addNewFromTitles(range, com.sun.star.sheet.Border.TOP) 75cdf0e10cSrcweir 76cdf0e10cSrcweir bOK = bOK AND (oObj.count = count + 3) 77cdf0e10cSrcweir 78cdf0e10cSrcweir bOK = bOK AND NOT oObj.hasByName("Col1") 79cdf0e10cSrcweir bOK = bOK AND oObj.hasByName("Col2") 80cdf0e10cSrcweir bOK = bOK AND oObj.hasByName("Col3") 81cdf0e10cSrcweir bOK = bOK AND oObj.hasByName("Col4") 82cdf0e10cSrcweir bOK = bOK AND NOT oObj.hasByName("Col5") 83cdf0e10cSrcweir Test.MethodTested("addNewFromTitles()", bOK) 84cdf0e10cSrcweir 85cdf0e10cSrcweir Test.StartMethod("removeByName()") 86cdf0e10cSrcweir bOK = true 87cdf0e10cSrcweir count = oObj.Count 88cdf0e10cSrcweir oObj.removeByName(cIfcShortName) 89cdf0e10cSrcweir bOK = bOK AND (count = oObj.count + 1) 90cdf0e10cSrcweir bOK = bOK AND NOT oObj.hasByName(cIfcShortName) 91cdf0e10cSrcweir Test.MethodTested("removeByName()", bOK) 92cdf0e10cSrcweir 93cdf0e10cSrcweir Test.StartMethod("outputList()") 94cdf0e10cSrcweir bOK = true 95cdf0e10cSrcweir outRange.Sheet = 0 96cdf0e10cSrcweir outRange.Row = 5 97cdf0e10cSrcweir outRange.Column = 5 98cdf0e10cSrcweir 99cdf0e10cSrcweir count = oObj.count 100cdf0e10cSrcweir for i = 4 to 5 + count 101cdf0e10cSrcweir oDoc.Sheets(0).getCellByPosition(5, i).String = "a" 102cdf0e10cSrcweir oDoc.Sheets(0).getCellByPosition(6, i).String = "b" 103cdf0e10cSrcweir next i 104cdf0e10cSrcweir 105cdf0e10cSrcweir oObj.outputList(outRange) 106cdf0e10cSrcweir 107cdf0e10cSrcweir bOK = bOK AND oDoc.Sheets(0).getCellByPosition(5, 4).String = "a" 108cdf0e10cSrcweir bOK = bOK AND oDoc.Sheets(0).getCellByPosition(6, 4).String = "b" 109cdf0e10cSrcweir bOK = bOK AND oDoc.Sheets(0).getCellByPosition(5, 5 + count).String = "a" 110cdf0e10cSrcweir bOK = bOK AND oDoc.Sheets(0).getCellByPosition(6, 5 + count).String = "b" 111cdf0e10cSrcweir 112cdf0e10cSrcweir for i = 5 to 4 + count 113cdf0e10cSrcweir bOK = bOK AND oDoc.Sheets(0).getCellByPosition(5, i).String <> "a" 114cdf0e10cSrcweir bOK = bOK AND oDoc.Sheets(0).getCellByPosition(6, i).String <> "b" 115cdf0e10cSrcweir bOK = bOK AND oObj.hasByName(oDoc.Sheets(0).getCellByPosition(5, i).String) 116cdf0e10cSrcweir next i 117cdf0e10cSrcweir 118cdf0e10cSrcweir Test.MethodTested("outputList()", bOK) 119cdf0e10cSrcweir 120cdf0e10cSrcweirExit Sub 121cdf0e10cSrcweirErrHndl: 122cdf0e10cSrcweir Test.Exception() 123cdf0e10cSrcweir bOK = false 124cdf0e10cSrcweir resume next 125cdf0e10cSrcweirEnd Sub 126cdf0e10cSrcweir</script:module> 127