mirror of
https://github.com/vanitasvitae/Smack.git
synced 2024-12-22 10:37:59 +01:00
Merge pull request #529 from Flowdalic/fix-sd-memleak
[disco] Fix memory leak in ServiceDiscoveryManager
This commit is contained in:
commit
c9af6576c0
1 changed files with 10 additions and 3 deletions
|
@ -1,6 +1,6 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2003-2007 Jive Software, 2018-2020 Florian Schmaus.
|
||||
* Copyright 2003-2007 Jive Software, 2018-2022 Florian Schmaus.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
|
@ -933,6 +933,10 @@ public final class ServiceDiscoveryManager extends Manager {
|
|||
* Notify the {@link EntityCapabilitiesChangedListener} about changed capabilities.
|
||||
*/
|
||||
private synchronized void renewEntityCapsVersion() {
|
||||
if (entityCapabilitiesChangedListeners.isEmpty()) {
|
||||
return;
|
||||
}
|
||||
|
||||
renewEntityCapsRequested++;
|
||||
if (renewEntityCapsScheduledAction != null) {
|
||||
boolean canceled = renewEntityCapsScheduledAction.cancel();
|
||||
|
@ -941,9 +945,12 @@ public final class ServiceDiscoveryManager extends Manager {
|
|||
}
|
||||
}
|
||||
|
||||
final XMPPConnection connection = connection();
|
||||
|
||||
renewEntityCapsScheduledAction = scheduleBlocking(() -> {
|
||||
final XMPPConnection connection = connection();
|
||||
if (connection == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
renewEntityCapsPerformed.incrementAndGet();
|
||||
|
||||
DiscoverInfoBuilder discoverInfoBuilder = DiscoverInfo.builder("synthetized-disco-info-response")
|
||||
|
|
Loading…
Reference in a new issue