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