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="sc_ScCellRangeObj" script:language="StarBasic"> 4cdf0e10cSrcweir 5cdf0e10cSrcweir 6cdf0e10cSrcweir'************************************************************************* 7cdf0e10cSrcweir' 8*5846f787SAndrew Rist' Licensed to the Apache Software Foundation (ASF) under one 9*5846f787SAndrew Rist' or more contributor license agreements. See the NOTICE file 10*5846f787SAndrew Rist' distributed with this work for additional information 11*5846f787SAndrew Rist' regarding copyright ownership. The ASF licenses this file 12*5846f787SAndrew Rist' to you under the Apache License, Version 2.0 (the 13*5846f787SAndrew Rist' "License"); you may not use this file except in compliance 14*5846f787SAndrew Rist' with the License. You may obtain a copy of the License at 15*5846f787SAndrew Rist' 16*5846f787SAndrew Rist' http://www.apache.org/licenses/LICENSE-2.0 17*5846f787SAndrew Rist' 18*5846f787SAndrew Rist' Unless required by applicable law or agreed to in writing, 19*5846f787SAndrew Rist' software distributed under the License is distributed on an 20*5846f787SAndrew Rist' "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 21*5846f787SAndrew Rist' KIND, either express or implied. See the License for the 22*5846f787SAndrew Rist' specific language governing permissions and limitations 23*5846f787SAndrew Rist' under the License. 24cdf0e10cSrcweir' 25cdf0e10cSrcweir'************************************************************************* 26cdf0e10cSrcweir 27cdf0e10cSrcweir 28cdf0e10cSrcweir 29*5846f787SAndrew Rist 30*5846f787SAndrew Rist 31cdf0e10cSrcweir' Be sure that all variables are dimensioned: 32cdf0e10cSrcweiroption explicit 33cdf0e10cSrcweir 34cdf0e10cSrcweir 35cdf0e10cSrcweir' REQUIRED VARIABLES for interface/service tests: 36cdf0e10cSrcweir 37cdf0e10cSrcweir'com.sun.star.sheet.XCellSeries 38cdf0e10cSrcweirGlobal aCellSeries(2) as Integer 39cdf0e10cSrcweir 40cdf0e10cSrcweir 41cdf0e10cSrcweir'Required for com.sun.star.chart.XChartData 42cdf0e10cSrcweirGlobal oCellToChange As Object 43cdf0e10cSrcweir 44cdf0e10cSrcweir' com.sun.star.sheet.XCellRangeData 45cdf0e10cSrcweirGlobal newData As Variant 46cdf0e10cSrcweir 47cdf0e10cSrcweirSub CreateObj() 48cdf0e10cSrcweir 49cdf0e10cSrcweir'************************************************************************* 50cdf0e10cSrcweir' COMPONENT: 51cdf0e10cSrcweir' sc.ScCellRangeObj 52cdf0e10cSrcweir'************************************************************************* 53cdf0e10cSrcweirOn Error Goto ErrHndl 54cdf0e10cSrcweir Dim oSheet, oRange As Object 55cdf0e10cSrcweir 56cdf0e10cSrcweir oDoc = utils.createDocument("scalc", cObjectName) 57cdf0e10cSrcweir oSheet = oDoc.Sheets(0) 58cdf0e10cSrcweir oCellToChange = oSheet.getCellByPosition(0, 0) 59cdf0e10cSrcweir oRange = oSheet.getCellRangeByPosition(0, 0, 10, 10) 60cdf0e10cSrcweir oObj = oRange 61cdf0e10cSrcweir 62cdf0e10cSrcweir aCellSeries(0) = 10 63cdf0e10cSrcweir aCellSeries(1) = 10 64cdf0e10cSrcweir 65cdf0e10cSrcweir 'Required for XCellRangeData 66cdf0e10cSrcweir newData = Array(_ 67cdf0e10cSrcweir Array(2.5, 5.0, 2.5, 5.0, 3.5, 8.7, 9.9, 0.3, 1.2, 3, 0),_ 68cdf0e10cSrcweir Array(4.0, 9.0, 3.5, 8.7, 9.9, 0.3, 1.2, 3, 0, 2.5, 5.0),_ 69cdf0e10cSrcweir Array(2.5, 3.5, 8.7, 9.9, 0.3, 1.2, 3, 0, 5.0, 2.5, 5.0),_ 70cdf0e10cSrcweir Array(4.0, 9.0, 2.5, 3.5, 8.7, 9.9, 0.3, 1.2, 3, 0, 5.0),_ 71cdf0e10cSrcweir Array(2.5, 5.0, 2.5, 5.0, 3.5, 8.7, 9.9, 0.3, 1.2, 3, 0),_ 72cdf0e10cSrcweir Array(4.0, 9.0, 3.5, 8.7, 9.9, 0.3, 1.2, 3, 0, 2.5, 5.0),_ 73cdf0e10cSrcweir Array(2.5, 3.5, 8.7, 9.9, 0.3, 1.2, 3, 0, 5.0, 2.5, 5.0),_ 74cdf0e10cSrcweir Array(4.0, 9.0, 2.5, 3.5, 8.7, 9.9, 0.3, 1.2, 3, 0, 5.0),_ 75cdf0e10cSrcweir Array(2.5, 5.0, 2.5, 5.0, 3.5, 8.7, 9.9, 0.3, 1.2, 3, 0),_ 76cdf0e10cSrcweir Array(4.0, 9.0, 3.5, 8.7, 9.9, 0.3, 1.2, 3, 0, 2.5, 5.0),_ 77cdf0e10cSrcweir Array(2.5, 3.5, 8.7, 9.9, 0.3, 1.2, 3, 0, 5.0, 2.5, 5.0)) 78cdf0e10cSrcweir 79cdf0e10cSrcweirExit Sub 80cdf0e10cSrcweirErrHndl: 81cdf0e10cSrcweir Test.Exception() 82cdf0e10cSrcweirEnd Sub 83cdf0e10cSrcweir 84cdf0e10cSrcweirFunction modifyDescriptor(descr As Variant) As Variant 85cdf0e10cSrcweirOn Error Goto ErrHndl 86cdf0e10cSrcweir Dim i As Integer, n as Integer 87cdf0e10cSrcweir Dim oCell As Object 88cdf0e10cSrcweir Dim vFields(0) as new com.sun.star.table.TableSortField 89cdf0e10cSrcweir 90cdf0e10cSrcweir for i = 0 to aCellSeries(0) - 1 91cdf0e10cSrcweir oCell = oObj.getCellByPosition(0, i) 92cdf0e10cSrcweir oCell.String = "" + (aCellSeries(0) - i) 93cdf0e10cSrcweir oCell.setFormula(aCellSeries(0) - i) 94cdf0e10cSrcweir next i 95cdf0e10cSrcweir 'ShowNameValuePair(descr) 96cdf0e10cSrcweir vFields(0).IsCaseSensitive = false 97cdf0e10cSrcweir vFields(0).IsAscending = true 98cdf0e10cSrcweir vFields(0).FieldType = com.sun.star.table.TableSortFieldType.ALPHANUMERIC 99cdf0e10cSrcweir for i = 0 to ubound(descr) 100cdf0e10cSrcweir if descr(i).Name = "IsSortColumns" then descr(i).Value = false 101cdf0e10cSrcweir if descr(i).Name = "SortFields" then descr(i).Value = vFields() 102cdf0e10cSrcweir next i 103cdf0e10cSrcweir 104cdf0e10cSrcweir modifyDescriptor() = descr 105cdf0e10cSrcweirExit Function 106cdf0e10cSrcweirErrHndl: 107cdf0e10cSrcweir Out.Log("Exception in ScCellRangeObj.modifyDescriptor() :") 108cdf0e10cSrcweir Test.Exception() 109cdf0e10cSrcweirend Function 110cdf0e10cSrcweir 111cdf0e10cSrcweirFunction checkSort() As Boolean 112cdf0e10cSrcweirOn Error Goto ErrHndl 113cdf0e10cSrcweir Dim i As Integer, oCell As Object 114cdf0e10cSrcweir Dim bOK As Boolean 115cdf0e10cSrcweir 116cdf0e10cSrcweir bOK = true 117cdf0e10cSrcweir for i = 0 to aCellSeries(0) - 1 118cdf0e10cSrcweir oCell = oObj.getCellByPosition(0,i) 119cdf0e10cSrcweir bOK = bOK AND oCell.String = "" + (i + 1) 120cdf0e10cSrcweir out.dbg(oCell.String + ":" + (i+1)) 121cdf0e10cSrcweir next i 122cdf0e10cSrcweir 123cdf0e10cSrcweir checkSort() = bOK 124cdf0e10cSrcweirExit Function 125cdf0e10cSrcweirErrHndl: 126cdf0e10cSrcweir Out.Log("Exception in ScCellRangeObj.checkSort() :") 127cdf0e10cSrcweir Test.Exception() 128cdf0e10cSrcweirend Function 129cdf0e10cSrcweir 130cdf0e10cSrcweir</script:module> 131