blob: 760507361557f3a5b43f3f1230e445f924515a7f (
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
|
'encoding UTF-8 Do not remove or change this line!
'**************************************************************************
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* 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
|