syn.hrl 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. %% ==========================================================================================================
  2. %% Syn - A global Process Registry and Process Group manager.
  3. %%
  4. %% The MIT License (MIT)
  5. %%
  6. %% Copyright (c) 2015-2021 Roberto Ostinelli <roberto@ostinelli.net> and Neato Robotics, Inc.
  7. %%
  8. %% Permission is hereby granted, free of charge, to any person obtaining a copy
  9. %% of this software and associated documentation files (the "Software"), to deal
  10. %% in the Software without restriction, including without limitation the rights
  11. %% to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  12. %% copies of the Software, and to permit persons to whom the Software is
  13. %% furnished to do so, subject to the following conditions:
  14. %%
  15. %% The above copyright notice and this permission notice shall be included in
  16. %% all copies or substantial portions of the Software.
  17. %%
  18. %% THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  19. %% IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  20. %% FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  21. %% AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  22. %% LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  23. %% OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  24. %% THE SOFTWARE.
  25. %% ==========================================================================================================
  26. %% types
  27. -type syn_cluster_api_version() :: {
  28. ApiCall :: atom(),
  29. Version :: atom()
  30. }.
  31. -type syn_registry_entry() :: {
  32. Name :: any(),
  33. Pid :: pid(),
  34. Meta :: any(),
  35. Time :: integer(),
  36. MRef :: undefined | reference(),
  37. Node :: node()
  38. }.
  39. -type syn_registry_entry_by_pid() :: {
  40. Pid :: pid(),
  41. Name :: any(),
  42. Meta :: any(),
  43. Time :: integer(),
  44. MRef :: undefined | reference(),
  45. Node :: node()
  46. }.
  47. -type syn_registry_tuple() :: {
  48. Name :: any(),
  49. Pid :: pid(),
  50. Meta :: any(),
  51. Time :: integer()
  52. }.
  53. -type syn_groups_entry() :: {
  54. {
  55. GroupName :: any(),
  56. Pid :: pid()
  57. },
  58. Meta :: any(),
  59. Time :: integer(),
  60. MRef :: undefined | reference(),
  61. Node :: node()
  62. }.
  63. -type syn_groups_tuple() :: {
  64. GroupName :: any(),
  65. Pid :: pid(),
  66. Meta :: any(),
  67. Time :: non_neg_integer()
  68. }.
  69. %% records
  70. -record(state, {
  71. handler = undefined :: undefined | module(),
  72. handler_state = undefined :: any(),
  73. scope = undefined :: atom(),
  74. process_name :: atom(),
  75. nodes_map = #{} :: #{node() => pid()},
  76. multicast_pid :: pid(),
  77. table_by_name :: atom(),
  78. table_by_pid :: atom()
  79. }).
  80. %% macros
  81. -define(DEFAULT_SCOPE, default).