Mirror for Apache CouchDB

Clone this repo:
  1. 0b1c646 v0.2.1 by Takeru Ohta · 6 years ago main master 0.2.1
  2. b36d339 Support OTP-21 by Takeru Ohta · 6 years ago
  3. 8322642 Update README.md by Takeru Ohta · 7 years ago
  4. 665bb8a Bump version to v0.2.0 by Takeru Ohta · 7 years ago 0.2.0
  5. 96f9a47 Update README.md by Takeru Ohta · 7 years ago

local

hex.pm version Build Status Code Coverage License: MIT

A Local Name Registration Facility.

The library provides the following features:

  • Registration of locally scoped names
    • gen_server (and other OTP behaviours) can use the registration facility through {via, local, local:name()} formatted name
  • Can be embedded in another aplication

Documentation

QuickStart

# clone
$ git clone git://github.com/sile/local.git
$ cd local

# compile
$ make compile

# run tests
$ make eunit

# dialyze
$ make dialyze

# Erlang shell
$ make start
1> local:start(sample_name_server).
ok

Usage Example

%% Starts name server
> ok = local:start_name_server(sample_name_server).
> local:which_name_servers().
[sample_name_server]


%% Registers process name
> self().
<0.42.0>

> local:register_name({sample_name_server, hoge}, self()). % succeeded
yes

> local:register_name({sample_name_server, hoge}, self()). % failed: name collision
no

> local:whereis_name({sample_name_server, hoge}).
<0.42.0>

%% Registered name can be used as gen_server's via name
> gen_server:cast({via, local, {sample_name_server, hoge}}, hello).
ok

> flush().
Shell got {'$gen_cast',hello}
ok


%% Unregisters process name
> local:unregister_name({sample_name_server, hoge}).
ok

> local:whereis_name({sample_name_server, hoge}).
undefined


%% Stops name server
> ok = local:stop_name_server(sample_name_server).
> local:which_name_servers().
[]

Embedded Mode

Local can be embedded in your application.

%% Embedding Example
-module(your_app_sup).

-behaviour(supervisor).

-export([init/1]). % 'supervisor' callback API

init([]) ->
    Child1 = local:name_server_child_spec(your_app_name_server_1),
    Child2 = local:name_server_child_spec(your_app_name_server_2),
    {ok, { {one_for_one, 5, 10}, [Child1, Child2]} }.