1<?xml version="1.0" encoding="UTF-8"?>
2<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3<script:module xmlns:script="http://openoffice.org/2000/script" script:name="fwl_FilterFactory" script:language="StarBasic">
4
5
6'*************************************************************************
7'
8'  Licensed to the Apache Software Foundation (ASF) under one
9'  or more contributor license agreements.  See the NOTICE file
10'  distributed with this work for additional information
11'  regarding copyright ownership.  The ASF licenses this file
12'  to you under the Apache License, Version 2.0 (the
13'  "License"); you may not use this file except in compliance
14'  with the License.  You may obtain a copy of the License at
15'
16'    http://www.apache.org/licenses/LICENSE-2.0
17'
18'  Unless required by applicable law or agreed to in writing,
19'  software distributed under the License is distributed on an
20'  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21'  KIND, either express or implied.  See the License for the
22'  specific language governing permissions and limitations
23'  under the License.
24'
25'*************************************************************************
26
27
28
29
30
31' Be sure that all variables are dimensioned:
32option explicit
33
34
35' REQUIRED VARIABLES for interface/service tests:
36
37'Required for lang.XMultiServiceFactory
38Global cServiceName As String
39Global bCreateInstanceWithoutArguments As Boolean
40Global aArguments() As Variant
41
42
43Sub CreateObj()
44
45'*************************************************************************
46' COMPONENT:
47' fwl.FilterFactory
48'*************************************************************************
49On Error Goto ErrHndl
50
51    oObj = createUnoService("com.sun.star.comp.framework.FilterFactory")
52
53    Dim filterNames() As Variant
54    filterNames = oObj.getElementNames()
55
56    Dim i As Integer
57    Dim filterType As String
58    Dim filterProps As Object
59    Dim filterImpl As String
60    Dim filName As String
61    for i = 0 to ubound(filterNames)
62        filterProps = oObj.getByName(filterNames(i))
63        filterImpl = getPropertyValue(filterProps, "FilterService")
64        if Not isNULL(filterImpl) and len(filterImpl) > 0 then
65            filterType = getPropertyValue(filterProps, "Type")
66            Out.log("Found filter '" + filterNames(i) + "', type: " + _
67                filterType + ", service name: '" + filterImpl + "'")
68            cServiceName = filterType
69            bCreateInstanceWithoutArguments = false
70            Dim args(0) As new com.sun.star.beans.PropertyValue
71            args(0).Name = "FilterName"
72            args(0).Value = filterNames(i)
73        endif
74    next i
75Exit Sub
76ErrHndl:
77    Test.Exception()
78End Sub
79
80Function getPropertyValue(byVal props As Variant, propName As String) As String
81    Dim i As Integer
82    for i = 0 to ubound(props)
83        if props(i).Name = propName then
84            getPropertyValue = props(i).Value
85            exit function
86        endif
87    next i
88End Function
89</script:module>
90