using Acacia.Features.DebugSupport; /// Copyright 2016 Kopano b.v. /// /// This program is free software: you can redistribute it and/or modify /// it under the terms of the GNU Affero General Public License, version 3, /// as published by the Free Software Foundation. /// /// This program 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 Affero General Public License for more details. /// /// You should have received a copy of the GNU Affero General Public License /// along with this program.If not, see. /// /// Consult LICENSE file for details using System; using System.Collections.Concurrent; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading; using System.Threading.Tasks; namespace Acacia.Utils { public class TasksBackground : TaskExecutor { private readonly BlockingCollection _tasks = new BlockingCollection(); public TasksBackground() { Thread t = new Thread(Worker); t.SetApartmentState(ApartmentState.STA); t.Start(); } private void Worker() { try { while (!_tasks.IsCompleted) { Logger.Instance.Trace(this, "Take task 1"); AcaciaTask task = _tasks.Take(); Logger.Instance.Trace(this, "Take task 2: {0}", task); PerformTask(task); Logger.Instance.Trace(this, "Take task 3: {0}", task); } Logger.Instance.Debug(this, "Worker completed"); } catch(Exception e) { Logger.Instance.Warning(this, "Worker failure: {0}", e); } } protected override void EnqueueTask(AcaciaTask task) { Logger.Instance.Trace(this, "EnqueueTask 1: {0}", task); _tasks.Add(task); Logger.Instance.Trace(this, "EnqueueTask 2: {0}", task); } override public string Name { get { return "Background"; } } } }