1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef __com_sun_star_sheet_XExternalSheetCache_idl__
21 #define __com_sun_star_sheet_XExternalSheetCache_idl__
23 #include
<com
/sun
/star
/lang
/IllegalArgumentException.idl
>
25 module com
{ module sun
{ module star
{ module sheet
{
27 /** Primary interface for the com::sun::star::sheet::ExternalSheetCache service.
29 @see com::sun::star::sheet::ExternalSheetCache
33 interface XExternalSheetCache
35 /** It sets a cached value for a specified cell position. The value is expected
36 to be either of type string or of type double. No
37 other data types are supported.
39 @param nRow row position (0-based)
40 @param nColumn column position (0-based)
41 @param aValue cell value to be cached
43 void setCellValue
( [in] long nColumn
, [in] long nRow
, [in] any aValue
)
44 raises
(com
::sun
::star
::lang
::IllegalArgumentException
);
46 /** It retrieves a cached value from a specified cell position. The cached
47 value can be either string or double.
49 @return any cached cell value
51 any getCellValue
( [in] long nColumn
, [in] long nRow
)
52 raises
(com
::sun
::star
::lang
::IllegalArgumentException
);
54 /** It returns a list of all row numbers where a cached cell or cells exist.
55 The row numbers are sorted in ascending order.
57 @return sequence<long> list of all row numbers with cached cell(s)
59 sequence
< long > getAllRows
();
61 /** Given a row number, this method returns a list of all columns numbers
62 that store cached cell values in that row. The column numbers are
63 sorted in ascending order.
65 @return sequence<long> list of all columns numbers with cached cell values
67 sequence
< long > getAllColumns
( [in] long nRow
)
68 raises
(com
::sun
::star
::lang
::IllegalArgumentException
);
71 /** Index corresponding to this instance of an external sheet cache for
72 usage in formula tokens.
74 <p>This index to the external sheet cache is expected in the
75 SingleReference::Sheet member if it is part of an
76 external reference token.
78 <p>Each external sheet cache has a unique index value inside the
79 ExternalDocLink instance.</p>
82 @see ExternalReference
84 [attribute
, readonly] long TokenIndex
;
92 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */