blob: 9deb9a4ca0b7d9f4b0b12246d705226495257c83 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
'encoding UTF-8 Do not remove or change this line!
'**************************************************************************
'* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
'*
'* Copyright 2008 by Sun Microsystems, Inc.
'*
'* OpenOffice.org - a multi-platform office productivity suite
'*
'* $RCSfile: apicalls.inc,v $
'*
'* $Revision: 1.1 $
'*
'* last change: $Author: jsi $ $Date: 2008-06-16 12:19:05 $
'*
'* This file is part of OpenOffice.org.
'*
'* OpenOffice.org is free software: you can redistribute it and/or modify
'* it under the terms of the GNU Lesser General Public License version 3
'* only, as published by the Free Software Foundation.
'*
'* OpenOffice.org is distributed in the hope that it will be useful,
'* but WITHOUT ANY WARRANTY; without even the implied warranty of
'* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
'* GNU Lesser General Public License version 3 for more details
'* (a copy is included in the LICENSE file that accompanied this code).
'*
'* You should have received a copy of the GNU Lesser General Public License
'* version 3 along with OpenOffice.org. If not, see
'* <http://www.openoffice.org/license.html>
'* for a copy of the LGPLv3 License.
'*
'/******************************************************************************
'*
'* owner : joerg.skottke@sun.com
'*
'* short description : Various calls to the API
'*
'\******************************************************************************
function hGetFileLocationAPI() as string
'///<h3>Get the location of the current file from API - experimental, do not use</h3>
dim oUnoConnect as object
dim oUnoService as object
dim oDocument as object
dim cDocument as string
const CFN = "hGetFileLocationAPI::"
oUnoConnect = GetUNOApp
if ( isNull( oUnoConnect ) ) then
warnlog( CFN & "No UNO connection established" )
else
oUnoService = oUnoConnect.createInstance( "com.sun.star.frame.Desktop" )
if ( isNull( oUnoService ) ) then
warnlog( CFN & "No UNO Service available" )
else
oDocument = oUnoService.getCurrentComponent()
if ( isNull( oDocument ) ) then
warnlog( CFN & "No current component available" )
else
if ( oDocument.hasLocation() ) then
cDocument = oDocument.getLocation()
hGetFileLocationAPI() = cDocument
printlog( CFN & cDocument )
else
warnlog( "Document has no storage location" )
hGetFileLocationAPI() = ""
endif
endif
endif
endif
end function
'*******************************************************************************
function hGetDocTypeAPI() as string
'///<h3>Get the current document via API - experimental, do not use</h3>
dim oUnoConnect as object
dim oUnoService as object
dim oDocument as object
dim cDocument as string
const CFN = "hGetDocTypeAPI::"
oUnoConnect = GetUNOApp
if ( isNull( oUnoConnect ) ) then
warnlog( CFN & "No UNO connection established" )
else
oUnoService = oUnoConnect.createInstance( "com.sun.star.frame.Desktop" )
if ( isNull( oUnoService ) ) then
warnlog( CFN & "No UNO Service available" )
else
oDocument = oUnoService.getCurrentComponent()
if ( isNull( oDocument ) ) then
warnlog( CFN & "No current component available" )
else
if ( oDocument.SupportsService( "com.sun.star.sheet.SpreadsheetDocument" ) )then
hGetDoctypeAPI() = "CALC"
elseif( oDocument.SupportsService( "com.sun.star.text.TextDocument" ) ) then
hGetDocTypeAPI() = "WRITER"
elseif( oDocument.SupportsService( "com.sun.star.drawing.DrawingDocument" ) ) then
hGetDocTypeAPI() = "DRAW"
elseif( oDocument.SupportsService( "com.sun.star.formula.FormulaProperties" ) ) then
hGetDocTypeAPI() = "MATH"
elseif( oDocument.SupportsService("com.sun.star.presentation.PresentationDocument") ) then
hGetDocTypeAPI() = "IMPRESS"
else
warnlog( "Unknown document type" )
hGetDocTypeAPI() = ""
endif
endif
endif
endif
end function
|