source: trunk/autoquest-core-events/src/main/java/de/ugoe/cs/autoquest/eventcore/guimodel/IGUIElement.java @ 927

Last change on this file since 927 was 927, checked in by sherbold, 12 years ago
  • added copyright under the Apache License, Version 2.0
  • Property svn:executable set to *
File size: 2.3 KB
Line 
1//   Copyright 2012 Georg-August-Universität Göttingen, Germany
2//
3//   Licensed under the Apache License, Version 2.0 (the "License");
4//   you may not use this file except in compliance with the License.
5//   You may obtain a copy of the License at
6//
7//       http://www.apache.org/licenses/LICENSE-2.0
8//
9//   Unless required by applicable law or agreed to in writing, software
10//   distributed under the License is distributed on an "AS IS" BASIS,
11//   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12//   See the License for the specific language governing permissions and
13//   limitations under the License.
14
15package de.ugoe.cs.autoquest.eventcore.guimodel;
16
17import de.ugoe.cs.autoquest.eventcore.IEventTarget;
18
19/**
20 * <p>
21 * Common interface for all GUI elements.
22 * </p>
23 *
24 * @version 1.0
25 * @author Patrick Harms
26 */
27public interface IGUIElement extends IEventTarget {
28
29    /**
30     * <p>
31     * Returns the specification of the GUI element.
32     * </p>
33     *
34     * @return the specification
35     */
36    public IGUIElementSpec getSpecification();
37
38    /**
39     * <p>
40     * Returns the parent of the GUI element.
41     * </p>
42     *
43     * @return the parent
44     */
45    public IGUIElement getParent();
46
47    /**
48     * <p>
49     * Defines that {@link IGUIElement} implementations have to define equals.
50     * </p>
51     *
52     * @see Object#equals(Object)
53     */
54    @Override
55    public boolean equals(Object other);
56
57    /**
58     * <p>
59     * Defines that {@link IGUIElement} implementations have to define hashCode.
60     * </p>
61     *
62     * @see Object#hashCode()
63     */
64    @Override
65    public int hashCode();
66
67    /**
68     * <p>
69     * Updates the specification of a GUI element with another specification, e.g., to add further
70     * known names of the GUI element.
71     * </p>
72     *
73     * @param furtherSpec
74     *            additional specification
75     */
76    public void updateSpecification(IGUIElementSpec furtherSpec);
77
78    /**
79     * <p>
80     * The {@link IGUIElement} that is passed by this function is equal to the current GUI element
81     * and will hereafter be treated as such.
82     * </p>
83     *
84     * @param guiElement
85     *            GUI element that is equal
86     */
87    public void addEqualGUIElement(IGUIElement equalElement);
88}
Note: See TracBrowser for help on using the repository browser.