use volatile for thread object in XmppConnection

This commit is contained in:
Christian Schneppe 2018-08-30 20:54:41 +02:00
parent 8b4e383d0f
commit 266329ddc4

View file

@ -183,13 +183,12 @@ public class XmppConnection implements Runnable {
private SaslMechanism saslMechanism;
private URL redirectionUrl = null;
private String verifiedHostname = null;
private Thread mThread;
private volatile Thread mThread;
private CountDownLatch mStreamCountDownLatch;
public XmppConnection(final Account account, final XmppConnectionService service) {
this.account = account;
final String tag = account.getJid().asBareJid().toString();
mXmppConnectionService = service;
this.mXmppConnectionService = service;
}
private static void fixResource(Context context, Account account) {
@ -467,7 +466,7 @@ public class XmppConnection implements Runnable {
*
* @return true if server returns with valid xmpp, false otherwise
*/
private boolean startXmpp(Socket socket) throws Exception {
private synchronized boolean startXmpp(Socket socket) throws Exception {
if (Thread.currentThread().isInterrupted()) {
throw new InterruptedException();
}
@ -514,7 +513,7 @@ public class XmppConnection implements Runnable {
connect();
}
private void processStream() throws XmlPullParserException, IOException, NoSuchAlgorithmException {
private void processStream() throws XmlPullParserException, IOException {
final CountDownLatch streamCountDownLatch = new CountDownLatch(1);
this.mStreamCountDownLatch = streamCountDownLatch;
Tag nextTag = tagReader.readTag();