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="sheet_XSheetPageBreak" script:language="StarBasic">
4cdf0e10cSrcweir
5cdf0e10cSrcweir
6cdf0e10cSrcweir'*************************************************************************
7cdf0e10cSrcweir'
8*eebed415SAndrew Rist'  Licensed to the Apache Software Foundation (ASF) under one
9*eebed415SAndrew Rist'  or more contributor license agreements.  See the NOTICE file
10*eebed415SAndrew Rist'  distributed with this work for additional information
11*eebed415SAndrew Rist'  regarding copyright ownership.  The ASF licenses this file
12*eebed415SAndrew Rist'  to you under the Apache License, Version 2.0 (the
13*eebed415SAndrew Rist'  "License"); you may not use this file except in compliance
14*eebed415SAndrew Rist'  with the License.  You may obtain a copy of the License at
15*eebed415SAndrew Rist'
16*eebed415SAndrew Rist'    http://www.apache.org/licenses/LICENSE-2.0
17*eebed415SAndrew Rist'
18*eebed415SAndrew Rist'  Unless required by applicable law or agreed to in writing,
19*eebed415SAndrew Rist'  software distributed under the License is distributed on an
20*eebed415SAndrew Rist'  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21*eebed415SAndrew Rist'  KIND, either express or implied.  See the License for the
22*eebed415SAndrew Rist'  specific language governing permissions and limitations
23*eebed415SAndrew Rist'  under the License.
24cdf0e10cSrcweir'
25cdf0e10cSrcweir'*************************************************************************
26cdf0e10cSrcweir
27cdf0e10cSrcweir
28cdf0e10cSrcweir
29*eebed415SAndrew Rist
30*eebed415SAndrew Rist
31cdf0e10cSrcweir' Be sure that all variables are dimensioned:
32cdf0e10cSrcweiroption explicit
33cdf0e10cSrcweir
34cdf0e10cSrcweir
35cdf0e10cSrcweir
36cdf0e10cSrcweirSub RunTest()
37cdf0e10cSrcweir
38cdf0e10cSrcweir'*************************************************************************
39cdf0e10cSrcweir' INTERFACE:
40cdf0e10cSrcweir' com.sun.star.sheet.XSheetPageBreak
41cdf0e10cSrcweir'*************************************************************************
42cdf0e10cSrcweirOn Error Goto ErrHndl
43cdf0e10cSrcweir    Dim bOK As Boolean
44cdf0e10cSrcweir    Dim nColsBreaks As Integer
45cdf0e10cSrcweir    Dim nRowsBreaks As Integer
46cdf0e10cSrcweir    Dim oColumn As Object
47cdf0e10cSrcweir    Dim oRow As Object
48cdf0e10cSrcweir    Dim oPBs As Variant
49cdf0e10cSrcweir    Dim iRowsBefore As Integer
50cdf0e10cSrcweir    Dim iColsBefore As Integer
51cdf0e10cSrcweir
52cdf0e10cSrcweir    iColsBefore = ubound(oObj.getColumnPageBreaks()) - 1
53cdf0e10cSrcweir    iRowsBefore = ubound(oObj.getRowPageBreaks()) - 1
54cdf0e10cSrcweir
55cdf0e10cSrcweir    Out.Log("Before test: colBreaks: " &amp; iColsBefore &amp; _
56cdf0e10cSrcweir                        " rowBreaks: " &amp; iRowsBefore)
57cdf0e10cSrcweir
58cdf0e10cSrcweir    Out.Log("Inserting new PageBreaks.")
59cdf0e10cSrcweir    oColumn = oObj.Columns.getByIndex(5)
60cdf0e10cSrcweir    oColumn.SetPropertyValue("IsStartOfNewPage", true)
61cdf0e10cSrcweir    oRow = oObj.Rows.getByIndex(15)
62cdf0e10cSrcweir    oRow.SetPropertyValue("IsStartOfNewPage", true)
63cdf0e10cSrcweir
64cdf0e10cSrcweir    Test.StartMethod("getColumnPageBreaks()")
65cdf0e10cSrcweir    bOK = true
66cdf0e10cSrcweir    oPBs = oObj.getColumnPageBreaks()
67cdf0e10cSrcweir    nColsBreaks = uBound(oPBs)
68cdf0e10cSrcweir    Out.Log("There are " &amp; nColsBreaks &amp; " column breaks.")
69cdf0e10cSrcweir    bOK = bOK AND nColsBreaks &gt; 0
70cdf0e10cSrcweir    bOK = bOK AND oPBs(0).Position &gt;= 0
71cdf0e10cSrcweir    Test.MethodTested("getColumnPageBreaks()", bOK)
72cdf0e10cSrcweir
73cdf0e10cSrcweir    Test.StartMethod("getRowPageBreaks()")
74cdf0e10cSrcweir    bOK = true
75cdf0e10cSrcweir    oPBs = oObj.getRowPageBreaks()
76cdf0e10cSrcweir    nRowsBreaks = uBound(oPBs)
77cdf0e10cSrcweir    Out.Log("There are " &amp; nRowsBreaks &amp; " row breaks.")
78cdf0e10cSrcweir    bOK = bOK AND nRowsBreaks &gt; 0
79cdf0e10cSrcweir    bOK = bOK AND oPBs(0).Position &gt;= 0
80cdf0e10cSrcweir    Test.MethodTested("getRowPageBreaks()", bOK)
81cdf0e10cSrcweir
82cdf0e10cSrcweir    Test.StartMethod("removeAllManualPageBreaks()")
83cdf0e10cSrcweir    bOK = true
84cdf0e10cSrcweir    oObj.removeAllManualPageBreaks()
85cdf0e10cSrcweir    Out.Log("After test: colBreaks: " &amp; ubound(oObj.getColumnPageBreaks()) - 1 &amp; _
86cdf0e10cSrcweir                       " rowBreaks: " &amp; ubound(oObj.getRowPageBreaks()) - 1)
87cdf0e10cSrcweir
88cdf0e10cSrcweir    bOK = bOK AND ubound(oObj.getRowPageBreaks()) - 1 = iRowsBefore
89cdf0e10cSrcweir    bOK = bOK AND ubound(oObj.getColumnPageBreaks()) - 1= iColsBefore
90cdf0e10cSrcweir    Test.MethodTested("removeAllManualPageBreaks()", bOK)
91cdf0e10cSrcweir
92cdf0e10cSrcweirExit Sub
93cdf0e10cSrcweirErrHndl:
94cdf0e10cSrcweir    Test.Exception()
95cdf0e10cSrcweir    bOK = false
96cdf0e10cSrcweir    resume next
97cdf0e10cSrcweirEnd Sub
98cdf0e10cSrcweir</script:module>
99