GoSub...Return-instructie

Roept een subroutine aan die met een label uit een subroutine of een functie wordt aangegeven. De instructies na de label worden uitgevoerd tot de volgende Return-instructie. Daarna gaat het programma verder met de instructie die op de GoSub-instructie volgt.

Syntaxis:


zie 'Parameters'

Parameters:

Sub/Function

instructieblok

Label

instructieblok

GoSub Label

Exit Sub/Function

Label:

instructieblok

Return

End Sub/Function

De instructie GoSub roept een lokale subroutine op die wordt aangegeven met een label, vanuit een subroutine of functie. De naam van de label moet met een dubbele punt (:) eindigen.

Waarschuwingspictogram

Als het programma een Return-instructie tegenkomt die niet door GoSub voorafgegaan wordt, geeft LibreOffice Basic een foutmelding. Gebruik Exit Sub of Exit Function om ervoor te zorgen dat het programma een 'Sub' of 'Function' verlaat voordat de volgende Return-instructie bereikt wordt.


In het volgende voorbeeld wordt het gebruik van GoSub en Return uitgelegd. Het programma kan de vierkantswortel berekenen van twee getallen die door de gebruiker worden ingevoerd, door een programmasectie tweemaal uit te voeren.

Voorbeeld:


Sub ExampleGoSub
Dim iInputa As Single
Dim iInputb As Single
Dim iInputc As Single
    iInvoera = Int(InputBox$ ("Voer het eerste getal in: ","Getalinvoer"))
    iInvoerb = Int(InputBox$ ("Voer het tweede getal in: ","Getalinvoer"))
    iInputc=iInputa
    GoSub SquareRoot
    Print "De vierkantswortel van ";iInvoera;" is";iInvoerc
    iInputc=iInputb
    GoSub SquareRoot
    Print "De vierkantswortel van";iInvoerb;" is";iInvoerc
    Exit Sub
SquareRoot:
    iInputc=sqr(iInputc)
    Return
End Sub