Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(730)

Unified Diff: third_party/logilab/logilab/common/tasksqueue.py

Issue 1920403002: [content/test/gpu] Run pylint check of gpu tests in unittest instead of PRESUBMIT (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Update path to LICENSE.txt of logilab/README.chromium Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « third_party/logilab/logilab/common/table.py ('k') | third_party/logilab/logilab/common/testlib.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: third_party/logilab/logilab/common/tasksqueue.py
diff --git a/third_party/logilab/logilab/common/tasksqueue.py b/third_party/logilab/logilab/common/tasksqueue.py
new file mode 100644
index 0000000000000000000000000000000000000000..ed74cf5ab5de78b550437eb206e091198c37d1c6
--- /dev/null
+++ b/third_party/logilab/logilab/common/tasksqueue.py
@@ -0,0 +1,101 @@
+# copyright 2003-2011 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
+# contact http://www.logilab.fr/ -- mailto:contact@logilab.fr
+#
+# This file is part of logilab-common.
+#
+# logilab-common is free software: you can redistribute it and/or modify it under
+# the terms of the GNU Lesser General Public License as published by the Free
+# Software Foundation, either version 2.1 of the License, or (at your option) any
+# later version.
+#
+# logilab-common 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 Lesser General Public License for more
+# details.
+#
+# You should have received a copy of the GNU Lesser General Public License along
+# with logilab-common. If not, see <http://www.gnu.org/licenses/>.
+"""Prioritized tasks queue"""
+
+__docformat__ = "restructuredtext en"
+
+from bisect import insort_left
+
+from six.moves import queue
+
+LOW = 0
+MEDIUM = 10
+HIGH = 100
+
+PRIORITY = {
+ 'LOW': LOW,
+ 'MEDIUM': MEDIUM,
+ 'HIGH': HIGH,
+ }
+REVERSE_PRIORITY = dict((values, key) for key, values in PRIORITY.items())
+
+
+
+class PrioritizedTasksQueue(queue.Queue):
+
+ def _init(self, maxsize):
+ """Initialize the queue representation"""
+ self.maxsize = maxsize
+ # ordered list of task, from the lowest to the highest priority
+ self.queue = []
+
+ def _put(self, item):
+ """Put a new item in the queue"""
+ for i, task in enumerate(self.queue):
+ # equivalent task
+ if task == item:
+ # if new task has a higher priority, remove the one already
+ # queued so the new priority will be considered
+ if task < item:
+ item.merge(task)
+ del self.queue[i]
+ break
+ # else keep it so current order is kept
+ task.merge(item)
+ return
+ insort_left(self.queue, item)
+
+ def _get(self):
+ """Get an item from the queue"""
+ return self.queue.pop()
+
+ def __iter__(self):
+ return iter(self.queue)
+
+ def remove(self, tid):
+ """remove a specific task from the queue"""
+ # XXX acquire lock
+ for i, task in enumerate(self):
+ if task.id == tid:
+ self.queue.pop(i)
+ return
+ raise ValueError('not task of id %s in queue' % tid)
+
+class Task(object):
+ def __init__(self, tid, priority=LOW):
+ # task id
+ self.id = tid
+ # task priority
+ self.priority = priority
+
+ def __repr__(self):
+ return '<Task %s @%#x>' % (self.id, id(self))
+
+ def __cmp__(self, other):
+ return cmp(self.priority, other.priority)
+
+ def __lt__(self, other):
+ return self.priority < other.priority
+
+ def __eq__(self, other):
+ return self.id == other.id
+
+ __hash__ = object.__hash__
+
+ def merge(self, other):
+ pass
« no previous file with comments | « third_party/logilab/logilab/common/table.py ('k') | third_party/logilab/logilab/common/testlib.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698