xref: /trunk/main/helpcontent2/source/text/sbasic/shared/03090201.xhp (revision 17fc61f3a15bef512c3b3b900ca61de59fe4462d)
1cdf0e10cSrcweir<?xml version="1.0" encoding="UTF-8"?>
2cdf0e10cSrcweir
3d33d0967SAndrew Rist<!--***********************************************************
4cdf0e10cSrcweir *
5d33d0967SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one
6d33d0967SAndrew Rist * or more contributor license agreements.  See the NOTICE file
7d33d0967SAndrew Rist * distributed with this work for additional information
8d33d0967SAndrew Rist * regarding copyright ownership.  The ASF licenses this file
9d33d0967SAndrew Rist * to you under the Apache License, Version 2.0 (the
10d33d0967SAndrew Rist * "License"); you may not use this file except in compliance
11d33d0967SAndrew Rist * with the License.  You may obtain a copy of the License at
12cdf0e10cSrcweir *
13d33d0967SAndrew Rist *   http://www.apache.org/licenses/LICENSE-2.0
14cdf0e10cSrcweir *
15d33d0967SAndrew Rist * Unless required by applicable law or agreed to in writing,
16d33d0967SAndrew Rist * software distributed under the License is distributed on an
17d33d0967SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
18d33d0967SAndrew Rist * KIND, either express or implied.  See the License for the
19d33d0967SAndrew Rist * specific language governing permissions and limitations
20d33d0967SAndrew Rist * under the License.
21cdf0e10cSrcweir *
22d33d0967SAndrew Rist ***********************************************************-->
23d33d0967SAndrew Rist
24cdf0e10cSrcweir<helpdocument version="1.0">
25cdf0e10cSrcweir<meta>
26cdf0e10cSrcweir<topic id="textsbasicshared03090201xml" indexer="include" status="PUBLISH">
27cdf0e10cSrcweir<title id="tit" xml-lang="en-US">Do...Loop Statement [Runtime]</title>
28cdf0e10cSrcweir<filename>/text/sbasic/shared/03090201.xhp</filename>
29cdf0e10cSrcweir</topic>
30cdf0e10cSrcweir</meta>
31cdf0e10cSrcweir<body>
32cdf0e10cSrcweir<section id="doloop">
33c5ffc49bSmseidel<bookmark xml-lang="en-US" branch="index" id="bm_id3156116">
34c5ffc49bSmseidel<bookmark_value>Do...Loop statement</bookmark_value>
35cdf0e10cSrcweir<bookmark_value>While; Do loop</bookmark_value>
36cdf0e10cSrcweir<bookmark_value>Until</bookmark_value>
37cdf0e10cSrcweir<bookmark_value>loops</bookmark_value>
38cdf0e10cSrcweir</bookmark>
39*17fc61f3Smseidel<paragraph role="heading" id="hd_id3156116" xml-lang="en-US" level="1" l10n="U"><link href="text/sbasic/shared/03090201.xhp" name="Do...Loop Statement [Runtime]">Do...Loop Statement [Runtime]</link></paragraph>
40*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3109850" xml-lang="en-US" l10n="U">Repeats the statements between the Do and the Loop statement while the condition is True or until the condition becomes True.</paragraph>
41cdf0e10cSrcweir</section>
42*17fc61f3Smseidel<paragraph role="heading" id="hd_id3149119" xml-lang="en-US" level="2" l10n="U">Syntax</paragraph>
43*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3155150" xml-lang="en-US" l10n="U">Do [{While | Until} condition = True]</paragraph>
44*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3154422" xml-lang="en-US" l10n="U">statement block</paragraph>
45*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3150789" xml-lang="en-US" l10n="U">[Exit Do]</paragraph>
46*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3155805" xml-lang="en-US" l10n="U">statement block</paragraph>
47*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3145090" xml-lang="en-US" l10n="U">Loop</paragraph>
48*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3154749" xml-lang="en-US" l10n="U">or</paragraph>
49*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3150503" xml-lang="en-US" l10n="U">Do</paragraph>
50*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3149762" xml-lang="en-US" l10n="U">statement block</paragraph>
51*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3150984" xml-lang="en-US" l10n="U">[Exit Do]</paragraph>
52*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3143228" xml-lang="en-US" l10n="U">statement block</paragraph>
53*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3149235" xml-lang="en-US" l10n="U">Loop [{While | Until} condition = True]</paragraph>
54*17fc61f3Smseidel<paragraph role="heading" id="hd_id3156024" xml-lang="en-US" level="2" l10n="U">Parameters/Elements</paragraph>
55*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3156344" xml-lang="en-US" l10n="U"><emph>Condition:</emph> A comparison, numeric or string expression, that evaluates either True or False.</paragraph>
56*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3149669" xml-lang="en-US" l10n="U"><emph>Statement block:</emph> Statements that you want to repeat while or until the condition is True.</paragraph>
57*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3150791" xml-lang="en-US" l10n="U">The <emph>Do...Loop</emph> statement executes a loop as long as, or until, a certain condition is True. The condition for exiting the loop must be entered following either the <emph>Do</emph> or the <emph>Loop</emph> statement. The following examples are valid combinations:</paragraph>
58*17fc61f3Smseidel<paragraph role="heading" id="hd_id3154366" xml-lang="en-US" level="2" l10n="U">Syntax</paragraph>
59*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3145171" xml-lang="en-US" l10n="U">Do While condition = True</paragraph>
60*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3149203" xml-lang="en-US" l10n="U">...statement block</paragraph>
61*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3125864" xml-lang="en-US" l10n="U">Loop</paragraph>
62*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3154124" xml-lang="en-US" l10n="U">The statement block between the Do While and the Loop statements is repeated so long as the condition is true.</paragraph>
63*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3153968" xml-lang="en-US" l10n="U">Do Until condition = True</paragraph>
64*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3154909" xml-lang="en-US" l10n="U">...statement block</paragraph>
65*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3159151" xml-lang="en-US" l10n="U">Loop</paragraph>
66*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3150440" xml-lang="en-US" l10n="U">The statement block between the Do Until and the Loop statements is repeated if the condition so long as the condition is false.</paragraph>
67*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3153952" xml-lang="en-US" l10n="U">Do</paragraph>
68*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3147349" xml-lang="en-US" l10n="U">...statement block</paragraph>
69*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3159153" xml-lang="en-US" l10n="U">Loop While condition = True</paragraph>
70*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3146985" xml-lang="en-US" l10n="U">The statement block between the Do and the Loop statements repeats so long as the condition is true.</paragraph>
71*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3150488" xml-lang="en-US" l10n="U">Do</paragraph>
72*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3153189" xml-lang="en-US" l10n="U">...statement block</paragraph>
73*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3155411" xml-lang="en-US" l10n="U">Loop Until condition = True</paragraph>
74*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3151117" xml-lang="en-US" l10n="U">The statement block between the Do and the Loop statements repeats until the condition is true.</paragraph>
75*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3149484" xml-lang="en-US" l10n="U">Use the <emph>Exit Do</emph> statement to unconditionally end the loop. You can add this statement anywhere in a <emph>Do</emph>...<emph>Loop</emph> statement. You can also define an exit condition using the <emph>If...Then</emph> structure as follows:</paragraph>
76*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3149262" xml-lang="en-US" l10n="U">Do...</paragraph>
77*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3149298" xml-lang="en-US" l10n="U">statements</paragraph>
78*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3145646" xml-lang="en-US" l10n="U">If condition = True Then Exit Do</paragraph>
79*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3154490" xml-lang="en-US" l10n="U">statements</paragraph>
80*17fc61f3Smseidel<paragraph role="paragraph" id="par_id3153159" xml-lang="en-US" l10n="U">Loop...</paragraph>
81*17fc61f3Smseidel<paragraph role="heading" id="hd_id3147396" xml-lang="en-US" level="2" l10n="U">Example</paragraph>
82*17fc61f3Smseidel<paragraph role="code" id="par_id3144764" xml-lang="en-US" l10n="U">Sub ExampleDoLoop</paragraph>
83*17fc61f3Smseidel<paragraph role="code" id="par_id3154791" xml-lang="en-US" l10n="U">Dim sFile As String</paragraph>
84*17fc61f3Smseidel<paragraph role="code" id="par_id3149401" xml-lang="en-US" l10n="U">Dim sPath As String</paragraph>
85*17fc61f3Smseidel<paragraph role="code" id="par_id3155600" xml-lang="en-US" l10n="U">sPath = "c:\"</paragraph>
86*17fc61f3Smseidel<paragraph role="code" id="par_id3150717" xml-lang="en-US" l10n="U">sFile = Dir$( sPath ,22)</paragraph>
87*17fc61f3Smseidel<paragraph role="code" id="par_id3146898" xml-lang="en-US" l10n="U">If sFile &lt;&gt; "" Then</paragraph>
88*17fc61f3Smseidel<paragraph role="code" id="par_id3156333" xml-lang="en-US" l10n="U">Do</paragraph>
89*17fc61f3Smseidel<paragraph role="code" id="par_id3153947" xml-lang="en-US" l10n="U">MsgBox sFile</paragraph>
90*17fc61f3Smseidel<paragraph role="code" id="par_id3150327" xml-lang="en-US" l10n="U">sFile = Dir$</paragraph>
91*17fc61f3Smseidel<paragraph role="code" id="par_id3150749" xml-lang="en-US" l10n="U">Loop Until sFile = ""</paragraph>
92*17fc61f3Smseidel<paragraph role="code" id="par_id3153765" xml-lang="en-US" l10n="U">End If</paragraph>
93*17fc61f3Smseidel<paragraph role="code" id="par_id3148914" xml-lang="en-US" l10n="U">End Sub</paragraph>
94cdf0e10cSrcweir</body>
95cdf0e10cSrcweir</helpdocument>
96