Iterate.java revision 18
2ronwalf// The MIT License
2ronwalf//
2ronwalf// Copyright (c) 2004 Evren Sirin
2ronwalf//
2ronwalf// Permission is hereby granted, free of charge, to any person obtaining a copy
2ronwalf// of this software and associated documentation files (the "Software"), to
2ronwalf// deal in the Software without restriction, including without limitation the
2ronwalf// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
2ronwalf// sell copies of the Software, and to permit persons to whom the Software is
2ronwalf// furnished to do so, subject to the following conditions:
2ronwalf//
2ronwalf// The above copyright notice and this permission notice shall be included in
2ronwalf// all copies or substantial portions of the Software.
2ronwalf//
2ronwalf// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
2ronwalf// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
2ronwalf// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
2ronwalf// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
2ronwalf// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
2ronwalf// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
2ronwalf// IN THE SOFTWARE.
2ronwalf
2ronwalf/*
2ronwalf * Created on Dec 28, 2003
2ronwalf *
2ronwalf */
2ronwalfpackage org.mindswap.owls.process;
2ronwalf
2ronwalf/**
18daenzerorama * This is super interface for loop based control constructs such as
18daenzerorama * {@link RepeatUntil}, {@link RepeatWhile} amd the non OWL-S standard
18daenzerorama * {@link ForEach}.
18daenzerorama *
2ronwalf * @author Evren Sirin
18daenzerorama * @author Michael D�nzer, University of Zurich
2ronwalf */
2ronwalfpublic interface Iterate extends ControlConstruct {
18daenzerorama /**
18daenzerorama * Returns the control construct within the loop
18daenzerorama * @return the control construct within the loop
18daenzerorama */
2ronwalf public ControlConstruct getComponent();
2ronwalf
18daenzerorama /**
18daenzerorama * Sets the control construct within the loop
18daenzerorama * @param component the control construct within the loop
18daenzerorama */
2ronwalf public void setComponent(ControlConstruct component);
18daenzerorama
18daenzerorama /**
18daenzerorama * Removes the control construct within the loop. The construct itslef remains
18daenzerorama * untouched. Use {@link #deleteComponent() instead.
18daenzerorama */
18daenzerorama public void removeComponent();
18daenzerorama /**
18daenzerorama * Deletes the control construct within the loop and removes it from the ontology (if possible)
18daenzerorama */
18daenzerorama public void deleteComponent();
2ronwalf}