From 23a9adc062c58198eae18ec14a609cfa0d882250 Mon Sep 17 00:00:00 2001 From: untidylamp <44341286+untidylamp@users.noreply.github.com> Date: Sun, 21 Oct 2018 10:24:52 -0400 Subject: [PATCH] Long sms support fix for bug SMS gets cut up into many messages #15 Thanks to https://github.com/vovs/gtalksms/blob/master/src/com/googlecode/gtalksms/receivers/SmsReceiver.java --- .../droogers/smsmatrix/ReceiverListener.java | 44 ++++++++++++++----- 1 file changed, 32 insertions(+), 12 deletions(-) diff --git a/app/src/main/java/eu/droogers/smsmatrix/ReceiverListener.java b/app/src/main/java/eu/droogers/smsmatrix/ReceiverListener.java index db19e36..cf1e6c0 100644 --- a/app/src/main/java/eu/droogers/smsmatrix/ReceiverListener.java +++ b/app/src/main/java/eu/droogers/smsmatrix/ReceiverListener.java @@ -7,6 +7,8 @@ import android.os.Bundle; import android.telephony.SmsMessage; import android.telephony.TelephonyManager; import android.util.Log; +import java.util.HashMap; +import java.util.Map; /** * Created by gerben on 6-10-17. @@ -25,23 +27,41 @@ public class ReceiverListener extends BroadcastReceiver { } private void handleIncomingSMS(Context context, Intent intent) { - Bundle bundle = intent.getExtras(); + Map msg = null; SmsMessage[] msgs = null; - String msg_from; - if (bundle != null){ - try{ - Object[] pdus = (Object[]) bundle.get("pdus"); - msgs = new SmsMessage[pdus.length]; - for(int i=0; i(nbrOfpdus); + msgs = new SmsMessage[nbrOfpdus]; + + // Send long SMS of same sender in one message + for (int i = 0; i < nbrOfpdus; i++) { msgs[i] = SmsMessage.createFromPdu((byte[])pdus[i]); - msg_from = msgs[i].getOriginatingAddress(); - String msgBody = msgs[i].getMessageBody(); - Utilities.sendMatrix(context, msgBody, msg_from, Matrix.MESSAGE_TYPE_TEXT); + + String originatinAddress = msgs[i].getOriginatingAddress(); + + // Check if index with number exists + if (!msg.containsKey(originatinAddress)) { + // Index with number doesn't exist + msg.put(msgs[i].getOriginatingAddress(), msgs[i].getMessageBody()); + + } else { + // Number is there. + String previousparts = msg.get(originatinAddress); + String msgString = previousparts + msgs[i].getMessageBody(); + msg.put(originatinAddress, msgString); + } } - }catch(Exception e){ - Log.d("Exception caught",e.getMessage()); } } + for (String originatinAddress : msg.keySet()) { + Utilities.sendMatrix(context, msg.get(originatinAddress), originatinAddress, Matrix.MESSAGE_TYPE_TEXT); + } } private void handleIncomingCall(Context context, Intent intent) {