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