diff options
author | Wink Saville <wink@google.com> | 2013-03-14 13:23:19 -0700 |
---|---|---|
committer | Wink Saville <wink@google.com> | 2013-03-14 13:23:19 -0700 |
commit | 8b0db520405c88414bcf8fdcb96293fb7075e524 (patch) | |
tree | dcc98f3b45228d7d3f9f12f3c30697e32c9e5c19 | |
parent | 24943bf19d3d000f9f5840513526b48523b62c71 (diff) | |
download | frameworks_base-8b0db520405c88414bcf8fdcb96293fb7075e524.zip frameworks_base-8b0db520405c88414bcf8fdcb96293fb7075e524.tar.gz frameworks_base-8b0db520405c88414bcf8fdcb96293fb7075e524.tar.bz2 |
Add all variations message parameters for send/obtain.
Change-Id: Ib8f3b66650d2ae2a8af7a537871361613e65b48e
-rw-r--r-- | core/java/com/android/internal/util/StateMachine.java | 103 |
1 files changed, 101 insertions, 2 deletions
diff --git a/core/java/com/android/internal/util/StateMachine.java b/core/java/com/android/internal/util/StateMachine.java index e547f23..2cdd579 100644 --- a/core/java/com/android/internal/util/StateMachine.java +++ b/core/java/com/android/internal/util/StateMachine.java @@ -1549,6 +1549,24 @@ public class StateMachine { * * @param what is assigned to Message.what * @param arg1 is assigned to Message.arg1 + * @return A Message object from the global pool + */ + public final Message obtainMessage(int what, int arg1) { + // use this obtain so we don't match the obtain(h, what, Object) method + return Message.obtain(mSmHandler, what, arg1, 0); + } + + /** + * Get a message and set Message.target state machine handler, + * what, arg1 and arg2 + * + * Note: The handler can be null if the state machine has quit, + * which means target will be null and may cause a AndroidRuntimeException + * in MessageQueue#enqueMessage if sent directly or if sent using + * StateMachine#sendMessage the message will just be ignored. + * + * @param what is assigned to Message.what + * @param arg1 is assigned to Message.arg1 * @param arg2 is assigned to Message.arg2 * @return A Message object from the global pool */ @@ -1606,6 +1624,32 @@ public class StateMachine { * * Message is ignored if state machine has quit. */ + public final void sendMessage(int what, int arg1) { + // mSmHandler can be null if the state machine has quit. + SmHandler smh = mSmHandler; + if (smh == null) return; + + smh.sendMessage(obtainMessage(what, arg1)); + } + + /** + * Enqueue a message to this state machine. + * + * Message is ignored if state machine has quit. + */ + public final void sendMessage(int what, int arg1, int arg2) { + // mSmHandler can be null if the state machine has quit. + SmHandler smh = mSmHandler; + if (smh == null) return; + + smh.sendMessage(obtainMessage(what, arg1, arg2)); + } + + /** + * Enqueue a message to this state machine. + * + * Message is ignored if state machine has quit. + */ public final void sendMessage(int what, int arg1, int arg2, Object obj) { // mSmHandler can be null if the state machine has quit. SmHandler smh = mSmHandler; @@ -1658,6 +1702,32 @@ public class StateMachine { * * Message is ignored if state machine has quit. */ + public final void sendMessageDelayed(int what, int arg1, long delayMillis) { + // mSmHandler can be null if the state machine has quit. + SmHandler smh = mSmHandler; + if (smh == null) return; + + smh.sendMessageDelayed(obtainMessage(what, arg1), delayMillis); + } + + /** + * Enqueue a message to this state machine after a delay. + * + * Message is ignored if state machine has quit. + */ + public final void sendMessageDelayed(int what, int arg1, int arg2, long delayMillis) { + // mSmHandler can be null if the state machine has quit. + SmHandler smh = mSmHandler; + if (smh == null) return; + + smh.sendMessageDelayed(obtainMessage(what, arg1, arg2), delayMillis); + } + + /** + * Enqueue a message to this state machine after a delay. + * + * Message is ignored if state machine has quit. + */ public final void sendMessageDelayed(int what, int arg1, int arg2, Object obj, long delayMillis) { // mSmHandler can be null if the state machine has quit. @@ -1686,6 +1756,20 @@ public class StateMachine { * * Message is ignored if state machine has quit. */ + protected final void sendMessageAtFrontOfQueue(int what) { + // mSmHandler can be null if the state machine has quit. + SmHandler smh = mSmHandler; + if (smh == null) return; + + smh.sendMessageAtFrontOfQueue(obtainMessage(what)); + } + + /** + * Enqueue a message to the front of the queue for this state machine. + * Protected, may only be called by instances of StateMachine. + * + * Message is ignored if state machine has quit. + */ protected final void sendMessageAtFrontOfQueue(int what, Object obj) { // mSmHandler can be null if the state machine has quit. SmHandler smh = mSmHandler; @@ -1700,12 +1784,27 @@ public class StateMachine { * * Message is ignored if state machine has quit. */ - protected final void sendMessageAtFrontOfQueue(int what) { + protected final void sendMessageAtFrontOfQueue(int what, int arg1) { // mSmHandler can be null if the state machine has quit. SmHandler smh = mSmHandler; if (smh == null) return; - smh.sendMessageAtFrontOfQueue(obtainMessage(what)); + smh.sendMessageAtFrontOfQueue(obtainMessage(what, arg1)); + } + + + /** + * Enqueue a message to the front of the queue for this state machine. + * Protected, may only be called by instances of StateMachine. + * + * Message is ignored if state machine has quit. + */ + protected final void sendMessageAtFrontOfQueue(int what, int arg1, int arg2) { + // mSmHandler can be null if the state machine has quit. + SmHandler smh = mSmHandler; + if (smh == null) return; + + smh.sendMessageAtFrontOfQueue(obtainMessage(what, arg1, arg2)); } /** |