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="table_XCellRange" 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' You can only get ranges within your
36*b1cdbd2cSJim Jagielski' object-range. That means is your object-range
37*b1cdbd2cSJim Jagielski' is (A1:C3) you can get only a range within
38*b1cdbd2cSJim Jagielski' (A1:C3).
39*b1cdbd2cSJim Jagielski
40*b1cdbd2cSJim Jagielski'*************************************************************************
41*b1cdbd2cSJim Jagielski
42*b1cdbd2cSJim Jagielski
43*b1cdbd2cSJim Jagielski
44*b1cdbd2cSJim Jagielski
45*b1cdbd2cSJim Jagielski
46*b1cdbd2cSJim JagielskiSub RunTest()
47*b1cdbd2cSJim Jagielski
48*b1cdbd2cSJim Jagielski'*************************************************************************
49*b1cdbd2cSJim Jagielski' INTERFACE:
50*b1cdbd2cSJim Jagielski' com.sun.star.table.XCellRange
51*b1cdbd2cSJim Jagielski'*************************************************************************
52*b1cdbd2cSJim JagielskiOn Error Goto ErrHndl
53*b1cdbd2cSJim Jagielski    Dim bOK As Boolean
54*b1cdbd2cSJim Jagielski
55*b1cdbd2cSJim Jagielski    Dim oCell As Object
56*b1cdbd2cSJim Jagielski    Dim oCellRange As Object
57*b1cdbd2cSJim Jagielski    Dim oCellRange1 As Object
58*b1cdbd2cSJim Jagielski    Dim bSupport As Boolean
59*b1cdbd2cSJim Jagielski    Dim oAddress As Object
60*b1cdbd2cSJim Jagielski    Dim nSCol As Long, nECol As Long
61*b1cdbd2cSJim Jagielski    Dim nSRow As Long, nERow As Long
62*b1cdbd2cSJim Jagielski    Dim nCol As Long, nRow As Long
63*b1cdbd2cSJim Jagielski    Dim cSCol As String, cECol As String
64*b1cdbd2cSJim Jagielski
65*b1cdbd2cSJim Jagielski    bOK = true
66*b1cdbd2cSJim Jagielski    'does the object support this service? If yes, the object is a range itself.
67*b1cdbd2cSJim Jagielski    'So we must look for the range address to be get a valid range
68*b1cdbd2cSJim Jagielski    if hasUnoInterfaces( oObj, "com.sun.star.sheet.XCellRangeAddressable" ) then
69*b1cdbd2cSJim Jagielski        Out.Log("Object supports com.sun.star.sheet.XCellRangeAddressable")
70*b1cdbd2cSJim Jagielski        bSupport = true
71*b1cdbd2cSJim Jagielski        oAddress = oObj.getRangeAddress()
72*b1cdbd2cSJim Jagielski        nSCol = oAddress.StartColumn
73*b1cdbd2cSJim Jagielski        nECol = oAddress.EndColumn
74*b1cdbd2cSJim Jagielski        nSRow = oAddress.StartRow
75*b1cdbd2cSJim Jagielski        nERow = oAddress.EndRow
76*b1cdbd2cSJim Jagielski        nCol = nECol - nSCol
77*b1cdbd2cSJim Jagielski        nRow = nERow - nSRow
78*b1cdbd2cSJim Jagielski    else
79*b1cdbd2cSJim Jagielski        bSupport = false
80*b1cdbd2cSJim Jagielski        nCol = 1
81*b1cdbd2cSJim Jagielski        nRow = 1
82*b1cdbd2cSJim Jagielski    end if
83*b1cdbd2cSJim Jagielski
84*b1cdbd2cSJim Jagielski    Test.StartMethod("getCellByPosition()")
85*b1cdbd2cSJim Jagielski    bOK = true
86*b1cdbd2cSJim Jagielski    Out.Log("try to getCellByPosition(" + nCol + "," + nRow + ")")
87*b1cdbd2cSJim Jagielski    oCell = oObj.getCellByPosition(nCol, nRow)
88*b1cdbd2cSJim Jagielski    bOK = bOK AND hasUnoInterfaces( oCell, "com.sun.star.table.XCell" )
89*b1cdbd2cSJim Jagielski    Test.MethodTested("getCellByPosition()", bOK)
90*b1cdbd2cSJim Jagielski
91*b1cdbd2cSJim Jagielski    Test.StartMethod("getCellRangeByPosition()")
92*b1cdbd2cSJim Jagielski    bOK = true
93*b1cdbd2cSJim Jagielski    Out.Log("try to getCellRangeByPosition(0,0," + nCol + "," + nRow + ")")
94*b1cdbd2cSJim Jagielski    oCellRange = oObj.getCellRangeByPosition(0, 0, nCol, nRow)
95*b1cdbd2cSJim Jagielski    bOK = bOK AND hasUnoInterfaces( oCellRange, "com.sun.star.table.XCellRange" )
96*b1cdbd2cSJim Jagielski    Test.MethodTested("getCellRangeByPosition()", bOK)
97*b1cdbd2cSJim Jagielski
98*b1cdbd2cSJim Jagielski    Test.StartMethod("getCellRangeByName()")
99*b1cdbd2cSJim Jagielski    bOK = true
100*b1cdbd2cSJim Jagielski    if bSupport then
101*b1cdbd2cSJim Jagielski        oAddress = oObj.getRangeAddress()
102*b1cdbd2cSJim Jagielski        nSCol = oAddress.StartColumn
103*b1cdbd2cSJim Jagielski        nECol = oAddress.EndColumn
104*b1cdbd2cSJim Jagielski        nSRow = oAddress.StartRow
105*b1cdbd2cSJim Jagielski        nERow = oAddress.EndRow
106*b1cdbd2cSJim Jagielski        cSCol = getCharacter(nSCol)
107*b1cdbd2cSJim Jagielski        cECol = getCharacter(nECol)
108*b1cdbd2cSJim Jagielski    else
109*b1cdbd2cSJim Jagielski        nSRow = 0
110*b1cdbd2cSJim Jagielski        nERow = 2
111*b1cdbd2cSJim Jagielski        cSCol = "A"
112*b1cdbd2cSJim Jagielski        cECol = "C"
113*b1cdbd2cSJim Jagielski    end if
114*b1cdbd2cSJim Jagielski    Out.Log("Try to getCellRangeByName(""" + cSCol + (nSRow + 1) + ":" + cECol + (nERow + 1) + """)")
115*b1cdbd2cSJim Jagielski    oCellRange1 = oObj.getCellRangeByName("" + cSCol + (nSRow + 1) + ":" + cECol + (nERow + 1))
116*b1cdbd2cSJim Jagielski    bOK = bOK AND hasUnoInterfaces( oCellRange1, "com.sun.star.table.XCellRange" )
117*b1cdbd2cSJim Jagielski    Test.MethodTested("getCellRangeByName()", bOK)
118*b1cdbd2cSJim Jagielski
119*b1cdbd2cSJim JagielskiExit Sub
120*b1cdbd2cSJim JagielskiErrHndl:
121*b1cdbd2cSJim Jagielski    Test.Exception()
122*b1cdbd2cSJim Jagielski    bOK = false
123*b1cdbd2cSJim Jagielski    resume next
124*b1cdbd2cSJim JagielskiEnd Sub
125*b1cdbd2cSJim JagielskiFunction getCharacter( nCol as Integer) as String
126*b1cdbd2cSJim Jagielski    Dim Char As String
127*b1cdbd2cSJim Jagielski    Dim nNum As Integer
128*b1cdbd2cSJim Jagielski    nNum = nCol
129*b1cdbd2cSJim Jagielski    Char = ""
130*b1cdbd2cSJim Jagielski    if (nNum - 26) &gt; 0 Then
131*b1cdbd2cSJim Jagielski        Char = Chr((nNum mod 26)+65)
132*b1cdbd2cSJim Jagielski        nNum = Int((nNum - 26)/ 26)
133*b1cdbd2cSJim Jagielski    end if
134*b1cdbd2cSJim Jagielski    Char = Chr(nNum + 65) + Char
135*b1cdbd2cSJim Jagielski    getCharacter = Char
136*b1cdbd2cSJim JagielskiEnd Function
137*b1cdbd2cSJim Jagielski</script:module>
138