Subversion Repository Public Repository

litesoft

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
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
/*
 * Copyright 2008 Google Inc.
 * 
 * Licensed 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
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations under
 * the License.
 */
package com.google.gwt.gen2.event.shared;

/**
 * Root of all gwt events. All gwt events are considered dead and should no
 * longer be accessed once the {@link HandlerManager} which originally fired the
 * event finishes with it.
 *
 * @deprecated use the com.google.gwt.event.shared classes instead
 */
@Deprecated
public abstract class AbstractEvent {
    /**
     * Type class used to register events with the {@link HandlerManager}.
     * <p>
     * Type is parameterized by the event and handler type in order to make the
     * addHandler method type safe and to avoid type-casts when implementing
     * {@link AbstractEvent.Type#fire(EventHandler, AbstractEvent)}.
     * </p>
     *
     * @param <EventType>   event type
     * @param <HandlerType> handler type
     */
    public abstract static class Type<EventType extends AbstractEvent, HandlerType extends EventHandler> {

        private int index;

        /**
         * Constructor.
         */
        public Type() {
            index = HandlerManager.createKeyIndex();
        }

        // We override hash code to make it as efficient as possible.
        @Override
        public final int hashCode() {
            return index;
        }

        /**
         * Fires the given handler on the supplied event.
         *
         * @param handler the handler to fire
         * @param event   the event
         */
        protected abstract void fire( HandlerType handler, EventType event );
    }

    private boolean dead;

    private Object source;

    /**
     * Constructor.
     */
    protected AbstractEvent() {
    }

    /**
     * Returns the source that last fired this event.
     *
     * @return object representing the source of this event
     */
    public Object getSource() {
        assertLive();
        return source;
    }

    /**
     * This is a method used primarily for debugging. It gives a string
     * representation of the event details. This does not override the toString
     * method because the compiler cannot always optimize toString out correctly.
     * Event types should override as desired.
     *
     * @return a string representing the event's specifics.
     */
    public String toDebugString() {
        String name = this.getClass().getName();
        name = name.substring( name.lastIndexOf( "." ) );
        return name + ": source = " + source;
    }

    /**
     * The toString() for abstract event is overridden to avoid accidently
     * including class literals in the the compiled output. Use
     * {@link AbstractEvent} #toDebugString to get more information about the
     * event.
     */
    @Override
    public String toString() {
        return "An event type";
    }

    /**
     * Asserts that the event still should be accessed. All events are considered
     * to be "dead" after their original handler manager finishes firing them. An
     * event can be revived by calling {@link AbstractEvent#revive()}.
     */
    protected void assertLive() {
        assert (!dead) : "This event has already finished being processed by its original handler manager, so you can no longer access it";
    }

    /**
     * Returns the type used to register this event.
     *
     * @return the type
     */
    protected abstract Type getType();

    /**
     * Is the event current live?
     *
     * @return whether the event is live
     */
    protected boolean isLive() {
        return !dead;
    }

    /**
     * Revives the event. Used when recycling event instances.
     */
    protected void revive() {
        dead = false;
    }

    /**
     * Kills the event. Used when recycling event instances.
     */
    final void kill() {
        dead = true;
        source = null;
    }

    /**
     * Set the source that triggered this event.
     *
     * @param source the source of this event, should only be set by a
     *               {@link HandlerManager}
     */
    void setSource( Object source ) {
        this.source = source;
    }
}

Commits for litesoft/trunk/Java/GWT/Client/src/com/google/gwt/gen2/event/shared/AbstractEvent.java

Diff revisions: vs.
Revision Author Commited Message
948 Diff Diff GeorgeS picture GeorgeS Sat 07 Jun, 2014 23:42:39 +0000

Jusefuls Formatter Updated to New Code Format

475 Diff Diff GeorgeS picture GeorgeS Sat 03 Sep, 2011 13:54:51 +0000
282 GeorgeS picture GeorgeS Fri 17 Jun, 2011 13:54:39 +0000