Thread.hx 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. /*
  2. * Copyright (C)2005-2019 Haxe Foundation
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a
  5. * copy of this software and associated documentation files (the "Software"),
  6. * to deal in the Software without restriction, including without limitation
  7. * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  8. * and/or sell copies of the Software, and to permit persons to whom the
  9. * Software is furnished to do so, subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice shall be included in
  12. * all copies or substantial portions of the Software.
  13. *
  14. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  19. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  20. * DEALINGS IN THE SOFTWARE.
  21. */
  22. package sys.thread;
  23. typedef ThreadHandle = hl.Abstract<"hl_thread">;
  24. abstract Thread(ThreadHandle) {
  25. public function sendMessage(msg:Dynamic) {
  26. getQueue(this).add(msg);
  27. }
  28. public static function readMessage(block = true):Dynamic {
  29. return getQueue(cast current()).pop(block);
  30. }
  31. static var queue_mutex:Mutex = null;
  32. static var threads_queues:Array<{t:ThreadHandle, q:Deque<Dynamic>}> = null;
  33. static function getQueue(t:ThreadHandle) {
  34. if (queue_mutex == null) {
  35. queue_mutex = new Mutex();
  36. threads_queues = [];
  37. }
  38. queue_mutex.acquire();
  39. var q = null;
  40. for (tq in threads_queues)
  41. if (tq.t == t) {
  42. q = tq.q;
  43. break;
  44. }
  45. if (q == null) {
  46. q = new Deque<Dynamic>();
  47. threads_queues.push({t: t, q: q});
  48. }
  49. queue_mutex.release();
  50. return q;
  51. }
  52. @:hlNative("std", "thread_create")
  53. public static function create(callb:Void->Void):Thread {
  54. return null;
  55. }
  56. @:hlNative("std", "thread_current")
  57. public static function current():Thread {
  58. return null;
  59. }
  60. }