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