summaryrefslogtreecommitdiffstats
path: root/telephony/java
diff options
context:
space:
mode:
authorHung-ying Tyan <tyanh@google.com>2010-10-19 18:35:32 +0800
committerHung-ying Tyan <tyanh@google.com>2010-10-21 02:38:04 +0800
commit88e3f0ad28c40eb1c76fa996277e64996acd9b03 (patch)
tree28ff25c11f6ccbe904b0c311a7f50c679528d5fc /telephony/java
parent1180f2a099a134c40f923c7e4162a5e7d7ca0184 (diff)
downloadframeworks_base-88e3f0ad28c40eb1c76fa996277e64996acd9b03.zip
frameworks_base-88e3f0ad28c40eb1c76fa996277e64996acd9b03.tar.gz
frameworks_base-88e3f0ad28c40eb1c76fa996277e64996acd9b03.tar.bz2
Silently reject a ringing call when another call is dialing/ringing.
http://b/issue?id=3109483 http://b/issue?id=3103072 Change-Id: I34f13225319c7f2a41e1ea9e25811866432ab809
Diffstat (limited to 'telephony/java')
-rw-r--r--telephony/java/com/android/internal/telephony/CallManager.java22
1 files changed, 20 insertions, 2 deletions
diff --git a/telephony/java/com/android/internal/telephony/CallManager.java b/telephony/java/com/android/internal/telephony/CallManager.java
index 3f0ec0a..ab7b601 100644
--- a/telephony/java/com/android/internal/telephony/CallManager.java
+++ b/telephony/java/com/android/internal/telephony/CallManager.java
@@ -1626,7 +1626,15 @@ public final class CallManager {
}
-
+ private boolean hasMoreThanOneRingingCall() {
+ int count = 0;
+ for (Call call : mRingingCalls) {
+ if (call.getState().isRinging()) {
+ if (++count > 1) return true;
+ }
+ }
+ return false;
+ }
private Handler mHandler = new Handler() {
@@ -1644,7 +1652,17 @@ public final class CallManager {
break;
case EVENT_NEW_RINGING_CONNECTION:
if (VDBG) Log.d(LOG_TAG, " handleMessage (EVENT_NEW_RINGING_CONNECTION)");
- mNewRingingConnectionRegistrants.notifyRegistrants((AsyncResult) msg.obj);
+ if (getActiveFgCallState().isDialing() || hasMoreThanOneRingingCall()) {
+ Connection c = (Connection) ((AsyncResult) msg.obj).result;
+ try {
+ Log.d(LOG_TAG, "silently drop incoming call: " + c.getCall());
+ c.getCall().hangup();
+ } catch (CallStateException e) {
+ Log.w(LOG_TAG, "new ringing connection", e);
+ }
+ } else {
+ mNewRingingConnectionRegistrants.notifyRegistrants((AsyncResult) msg.obj);
+ }
break;
case EVENT_UNKNOWN_CONNECTION:
if (VDBG) Log.d(LOG_TAG, " handleMessage (EVENT_UNKNOWN_CONNECTION)");