summaryrefslogtreecommitdiff
path: root/scripting/examples/basic/SearchAndReplace.xba
blob: fb7c60bd4f22cfd4c88294d0fe3fb9f2e6cbb72e (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
123
124
125
126
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
<!--
 * This file is part of the LibreOffice project.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 *
 * This file incorporates work covered by the following license notice:
 *
 *   Licensed to the Apache Software Foundation (ASF) under one or more
 *   contributor license agreements. See the NOTICE file distributed
 *   with this work for additional information regarding copyright
 *   ownership. The ASF licenses this file to you under the Apache
 *   License, Version 2.0 (the "License"); you may not use this file
 *   except in compliance with the License. You may obtain a copy of
 *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
-->
<script:module xmlns:script="http://openoffice.org/2000/script" script:name="SearchAndReplace" script:language="StarBasic">&apos; ***
&apos; SearchAndReplace basic script
&apos; Uses a user interface to search and replace the specified strings
&apos;
&apos; author        Neil Montgomery
&apos; created       August 12, 2002
&apos; ***


&apos; Main subprocedure to start script
Sub Main
 dialogShow()
End Sub


&apos; Global reference to the dialog object
Dim oDialog as Object


&apos; Uses the loadDialog subprocedure to load and execute the dialog box
Sub dialogShow
 oDialog = loadDialog(&quot;Standard&quot;,&quot;SearchAndReplaceDialog&quot;)
 oDialog.execute()
End Sub



&apos; ***
&apos; Loads the dialog from the dialog library
&apos;
&apos; param Libname         the library name where dialog is stored
&apos; param  DialogName     the name of the dialog
&apos; param         oLibContainer   library container to hold the loaded dialog library (optional)
&apos; return        runtime dialog object
&apos; ***
Function loadDialog(Libname as String, DialogName as String, Optional oLibContainer)
 Dim oLib as Object
 Dim oLibDialog as Object
 Dim oRuntimeDialog as Object
 
 If isMissing(oLibContainer ) then
  oLibContainer = DialogLibraries
 End If
 oLibContainer.loadLibrary(LibName)
 oLib = oLibContainer.getByName(Libname)
 oLibDialog = oLib.getByName(DialogName)
 oRuntimeDialog = createUnoDialog(oLibDialog)
 loadDialog() = oRuntimeDialog
End Function



&apos; ***
&apos; Creates a connection to the current document.
&apos; Gets the search and replace keys from the dialog and replaces all
&apos; instances of the search key with the replace key. 
&apos;
&apos; ***
Sub getInfoFromDialog
 Dim oDocument As Object
 Dim oSearch As Object
 Dim oFound As Object
 Dim oFoundCursor As Object
 Dim oSearchText as Object
 Dim oReplaceText as Object
 
 &apos; Create a document object for the current document then create text and
 &apos; cursor objects
 oDocument = StarDesktop.ActiveFrame.Controller.Model
 oSearch = oDocument.createSearchDescriptor

 &apos; Replace all instances of the search string with the replavce string
 oSearch.SearchString = getSearchKey()
 oSearch.ReplaceString = getReplaceKey()
 oDocument.replaceAll(oSearch)
End Sub


&apos; ***
&apos; Gets the search key string from the dialog
&apos;
&apos; returns	string 		representing the search key
&apos; ***
Function getSearchKey() as String
 Dim sSearch As String

 &apos; Get the search key from the dialog
 oSearchText = oDialog.GetControl(&quot;SearchKeyTextBox&quot;)
 sSearch = oSearchText.Text
 getSearchKey = sSearch
End Function



&apos; ***
&apos; Gets the replace key string from the dialog 
&apos;
&apos; returns 	string		representing the replace key
&apos; ***
Function getReplaceKey() as String
 Dim sReplace As String

 &apos; Get the replace key from the dialog
 oReplaceText = oDialog.GetControl(&quot;ReplaceKeyTextBox&quot;)
 sReplace = oReplaceText.Text
 getReplaceKey = sReplace
End Function</script:module>