mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge.git
synced 2025-01-10 09:01:55 +01:00
Huawei: Parallelize init requests
This commit is contained in:
parent
42def1cefb
commit
fcf8becb23
@ -39,6 +39,7 @@ import java.util.ArrayList;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
|
||||||
import de.greenrobot.dao.query.QueryBuilder;
|
import de.greenrobot.dao.query.QueryBuilder;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
||||||
@ -178,7 +179,7 @@ import nodomain.freeyourgadget.gadgetbridge.util.StringUtils;
|
|||||||
public class HuaweiSupportProvider {
|
public class HuaweiSupportProvider {
|
||||||
private static final Logger LOG = LoggerFactory.getLogger(HuaweiSupportProvider.class);
|
private static final Logger LOG = LoggerFactory.getLogger(HuaweiSupportProvider.class);
|
||||||
|
|
||||||
private final int initTimeout = 1000;
|
private final int initTimeout = 2500;
|
||||||
|
|
||||||
private HuaweiBRSupport brSupport;
|
private HuaweiBRSupport brSupport;
|
||||||
private HuaweiLESupport leSupport;
|
private HuaweiLESupport leSupport;
|
||||||
@ -584,16 +585,17 @@ public class HuaweiSupportProvider {
|
|||||||
initRequestQueue.add(new SetTimeRequest(this, true));
|
initRequestQueue.add(new SetTimeRequest(this, true));
|
||||||
initRequestQueue.add(batteryLevelReq);
|
initRequestQueue.add(batteryLevelReq);
|
||||||
initRequestQueue.add(new SendFitnessUserInfoRequest(this));
|
initRequestQueue.add(new SendFitnessUserInfoRequest(this));
|
||||||
initRequestQueue.add(new GetSupportedServicesRequest(this)); // MUST BE LAST - it indirectly kicks off initializeDynamicServices
|
|
||||||
|
|
||||||
// Queue all the requests
|
// Queue all the requests
|
||||||
for (int i = 1; i < initRequestQueue.size(); i++) {
|
parallelize(initRequestQueue, initRequestQueue.size(), () -> {
|
||||||
initRequestQueue.get(i - 1).setupTimeoutUntilNext(initTimeout);
|
try {
|
||||||
initRequestQueue.get(i - 1).nextRequest(initRequestQueue.get(i));
|
// MUST BE LAST - it indirectly kicks off initializeDynamicServices
|
||||||
}
|
new GetSupportedServicesRequest(this).doPerform();
|
||||||
initRequestQueue.get(initRequestQueue.size() - 1).setupTimeoutUntilNext(initTimeout);
|
} catch (final IOException e) {
|
||||||
|
// Should we disconnect?
|
||||||
initRequestQueue.get(0).doPerform();
|
LOG.error("Failed to get supported services", e);
|
||||||
|
}
|
||||||
|
});
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
// TODO: Use translatable string
|
// TODO: Use translatable string
|
||||||
GB.toast(context, "Final initialization of Huawei device failed", Toast.LENGTH_SHORT, GB.ERROR, e);
|
GB.toast(context, "Final initialization of Huawei device failed", Toast.LENGTH_SHORT, GB.ERROR, e);
|
||||||
@ -747,21 +749,10 @@ public class HuaweiSupportProvider {
|
|||||||
initializeAlarms();
|
initializeAlarms();
|
||||||
|
|
||||||
// Queue all the requests
|
// Queue all the requests
|
||||||
for (int i = 1; i < initRequestQueue.size(); i++) {
|
parallelize(initRequestQueue, 5, () -> {
|
||||||
initRequestQueue.get(i - 1).setupTimeoutUntilNext(initTimeout);
|
gbDevice.setState(GBDevice.State.INITIALIZED);
|
||||||
initRequestQueue.get(i - 1).nextRequest(initRequestQueue.get(i));
|
gbDevice.sendDeviceUpdateIntent(getContext(), GBDevice.DeviceUpdateSubject.DEVICE_STATE);
|
||||||
}
|
|
||||||
|
|
||||||
initRequestQueue.get(initRequestQueue.size() - 1).setupTimeoutUntilNext(initTimeout);
|
|
||||||
initRequestQueue.get(initRequestQueue.size() - 1).setFinalizeReq(new RequestCallback() {
|
|
||||||
@Override
|
|
||||||
public void call() {
|
|
||||||
gbDevice.setState(GBDevice.State.INITIALIZED);
|
|
||||||
gbDevice.sendDeviceUpdateIntent(getContext(), GBDevice.DeviceUpdateSubject.DEVICE_STATE);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
initRequestQueue.get(0).doPerform();
|
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
// TODO: Translatable string
|
// TODO: Translatable string
|
||||||
GB.toast("Initialize dynamic services of Huawei device failed", Toast.LENGTH_SHORT, GB.ERROR, e);
|
GB.toast("Initialize dynamic services of Huawei device failed", Toast.LENGTH_SHORT, GB.ERROR, e);
|
||||||
@ -769,6 +760,45 @@ public class HuaweiSupportProvider {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Takes a list of requests and parallelizes multiple chains. Executes a runnable at the end,
|
||||||
|
* once all chains finish.
|
||||||
|
* @param requests the list of requests to parallelize
|
||||||
|
* @param parallelChains the maximum number of chains that can run in parallel
|
||||||
|
* @param callback the callback to execute when all chains finish
|
||||||
|
* @throws IOException if any of the first requests in each chain fails
|
||||||
|
*/
|
||||||
|
private void parallelize(final List<Request> requests,
|
||||||
|
final int parallelChains,
|
||||||
|
final Runnable callback) throws IOException {
|
||||||
|
final AtomicInteger missingChains = new AtomicInteger(0);
|
||||||
|
final int partitionSize = Math.round(requests.size() / (float) parallelChains);
|
||||||
|
for (int i = 0; i < requests.size(); i += partitionSize) {
|
||||||
|
final List<Request> chain = requests.subList(i, Math.min(i + partitionSize, requests.size() - 1));
|
||||||
|
|
||||||
|
for (int j = 1; j < chain.size(); j++) {
|
||||||
|
chain.get(i - 1).setupTimeoutUntilNext(initTimeout);
|
||||||
|
chain.get(i - 1).nextRequest(chain.get(i));
|
||||||
|
}
|
||||||
|
|
||||||
|
chain.get(chain.size() - 1).setupTimeoutUntilNext(initTimeout);
|
||||||
|
chain.get(chain.size() - 1).setFinalizeReq(new RequestCallback() {
|
||||||
|
@Override
|
||||||
|
public void call() {
|
||||||
|
if (missingChains.decrementAndGet() == 0) {
|
||||||
|
callback.run();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
missingChains.incrementAndGet();
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < requests.size(); i += partitionSize) {
|
||||||
|
requests.get(0).doPerform();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void setProtocolVersion(byte protocolVersion) {
|
public void setProtocolVersion(byte protocolVersion) {
|
||||||
this.protocolVersion = protocolVersion;
|
this.protocolVersion = protocolVersion;
|
||||||
}
|
}
|
||||||
@ -1980,7 +2010,7 @@ public class HuaweiSupportProvider {
|
|||||||
huaweiWatchfaceManager.requestWatchfaceList();
|
huaweiWatchfaceManager.requestWatchfaceList();
|
||||||
huaweiAppManager.requestAppList();
|
huaweiAppManager.requestAppList();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onAppStart(final UUID uuid, boolean start) {
|
public void onAppStart(final UUID uuid, boolean start) {
|
||||||
if (start) {
|
if (start) {
|
||||||
//NOTE: to prevent exception in watchfaces code
|
//NOTE: to prevent exception in watchfaces code
|
||||||
|
Loading…
Reference in New Issue
Block a user