# HG changeset patch # User Da Risk # Date 1669759463 14400 # Node ID 34fe2a0c47c8534580224bc9d4143da4950b55c3 # Parent 45a1084ed99ca1c676b4a5880d3427c4781a3f8a geekdroid: remove deprecated ThreadedJobService diff -r 45a1084ed99c -r 34fe2a0c47c8 geekdroid/src/main/java/com/geekorum/geekdroid/jobs/JobThread.java --- a/geekdroid/src/main/java/com/geekorum/geekdroid/jobs/JobThread.java Tue Nov 29 17:53:25 2022 -0400 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,50 +0,0 @@ -/* - * Geekdroid is a utility library for development on the Android - * Platform. - * - * Copyright (C) 2017-2022 by Frederic-Charles Barthelery. - * - * This file is part of Geekdroid. - * - * Geekdroid is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * Geekdroid is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with Geekdroid. If not, see . - */ -package com.geekorum.geekdroid.jobs; - -import android.app.job.JobParameters; -import android.os.Process; -import com.geekorum.geekdroid.utils.ProcessPriority; - -/** - * A thread that execute a job from a {@link ThreadedJobService} - * @Deprecated Use androidx.work - */ -@Deprecated -public abstract class JobThread extends Thread { - private final ThreadedJobService jobService; - private final JobParameters parameters; - - protected JobThread(ThreadedJobService jobService, JobParameters parameters) { - this.jobService = jobService; - this.parameters = parameters; - } - - protected void setProcessPriority(@ProcessPriority int processPriority) { - Process.setThreadPriority(processPriority); - } - - protected void completeJob(boolean needReschedule) { - jobService.completeJob(parameters, needReschedule); - } - -} diff -r 45a1084ed99c -r 34fe2a0c47c8 geekdroid/src/main/java/com/geekorum/geekdroid/jobs/ThreadedJobService.java --- a/geekdroid/src/main/java/com/geekorum/geekdroid/jobs/ThreadedJobService.java Tue Nov 29 17:53:25 2022 -0400 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,84 +0,0 @@ -/* - * Geekdroid is a utility library for development on the Android - * Platform. - * - * Copyright (C) 2017-2022 by Frederic-Charles Barthelery. - * - * This file is part of Geekdroid. - * - * Geekdroid is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * Geekdroid is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with Geekdroid. If not, see . - */ -package com.geekorum.geekdroid.jobs; - -import android.app.job.JobParameters; -import android.app.job.JobService; - -import java.util.Collections; -import java.util.HashMap; -import java.util.Map; -import java.util.concurrent.ExecutorService; -import java.util.concurrent.Executors; -import java.util.concurrent.Future; - -/** - * Execute each job of the {@link JobService} in a separate thread. - * @Deprecated Use androidx.work - */ -@Deprecated -public abstract class ThreadedJobService extends JobService { - private Map> tasks = Collections.synchronizedMap(new HashMap>()); - private ExecutorService executorService; - - @Override - public void onCreate() { - super.onCreate(); - executorService = Executors.newCachedThreadPool(); - } - - @Override - public void onDestroy() { - super.onDestroy(); - executorService.shutdownNow(); - } - - @Override - public boolean onStartJob(JobParameters params) { - JobThread jobThread = createJobThread(params); - if (jobThread == null) { - return false; - } - Future task = executorService.submit(jobThread); - tasks.put(params, task); - return true; - } - - @Override - public boolean onStopJob(JobParameters params) { - Future task = tasks.remove(params); - if (task != null) { - task.cancel(true); - return true; - } - return false; - } - - void completeJob(JobParameters jobParameters, boolean needReschedule) { - Future task = tasks.remove(jobParameters); - if (task != null) { - jobFinished(jobParameters, needReschedule); - } - } - - protected abstract JobThread createJobThread(JobParameters jobParameters); -}