2009-04-30 07:18:06 +02:00
|
|
|
%%% ====================================================================
|
|
|
|
%%% ``The contents of this file are subject to the Erlang Public License,
|
|
|
|
%%% Version 1.1, (the "License"); you may not use this file except in
|
|
|
|
%%% compliance with the License. You should have received a copy of the
|
|
|
|
%%% Erlang Public License along with this software. If not, it can be
|
|
|
|
%%% retrieved via the world wide web at http://www.erlang.org/.
|
|
|
|
%%%
|
|
|
|
%%% Software distributed under the License is distributed on an "AS IS"
|
|
|
|
%%% basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
|
|
|
|
%%% the License for the specific language governing rights and limitations
|
|
|
|
%%% under the License.
|
|
|
|
%%%
|
|
|
|
%%% The Initial Developer of the Original Code is ProcessOne.
|
2011-02-14 13:47:22 +01:00
|
|
|
%%% Portions created by ProcessOne are Copyright 2006-2011, ProcessOne
|
2009-04-30 07:18:06 +02:00
|
|
|
%%% All Rights Reserved.''
|
2011-02-14 13:47:22 +01:00
|
|
|
%%% This software is copyright 2006-2011, ProcessOne.
|
2009-04-30 07:18:06 +02:00
|
|
|
%%%
|
|
|
|
%%%
|
2011-02-14 13:47:22 +01:00
|
|
|
%%% @copyright 2006-2011 ProcessOne
|
2009-04-30 07:18:06 +02:00
|
|
|
%%% @author Christophe Romain <christophe.romain@process-one.net>
|
|
|
|
%%% [http://www.process-one.net/]
|
|
|
|
%%% @version {@vsn}, {@date} {@time}
|
|
|
|
%%% @end
|
|
|
|
%%% ====================================================================
|
|
|
|
|
|
|
|
%% important note:
|
|
|
|
%% new/1 and free/2 MUST be called inside a transaction bloc
|
|
|
|
|
|
|
|
-module(pubsub_index).
|
|
|
|
-author('christophe.romain@process-one.net').
|
|
|
|
|
|
|
|
-include("pubsub.hrl").
|
|
|
|
|
2010-09-29 11:48:19 +02:00
|
|
|
-export([
|
|
|
|
init/3,
|
|
|
|
new/1,
|
|
|
|
free/2
|
|
|
|
]).
|
|
|
|
|
|
|
|
|
|
|
|
-spec(init/3 ::
|
|
|
|
(
|
|
|
|
Host :: string(),
|
|
|
|
ServerHost :: string(),
|
|
|
|
Opts :: [{Key::atom(), Value::term()}])
|
|
|
|
-> 'ok'
|
|
|
|
).
|
2009-04-30 07:18:06 +02:00
|
|
|
|
|
|
|
init(_Host, _ServerHost, _Opts) ->
|
|
|
|
mnesia:create_table(pubsub_index,
|
|
|
|
[{disc_copies, [node()]},
|
|
|
|
{attributes, record_info(fields, pubsub_index)}]).
|
|
|
|
|
2010-09-29 11:48:19 +02:00
|
|
|
|
|
|
|
-spec(new/1 ::
|
|
|
|
(
|
|
|
|
Index::atom())
|
|
|
|
-> Idx::integer()
|
|
|
|
).
|
|
|
|
|
2009-04-30 07:18:06 +02:00
|
|
|
new(Index) ->
|
|
|
|
case mnesia:read({pubsub_index, Index}) of
|
2010-09-29 11:48:19 +02:00
|
|
|
[#pubsub_index{free = [], last = Last} = PubsubIndex] ->
|
|
|
|
Idx = Last + 1,
|
|
|
|
mnesia:write(PubsubIndex#pubsub_index{last = Idx}),
|
|
|
|
Idx;
|
|
|
|
[#pubsub_index{free = [Idx|Free]} = PubsubIndex] ->
|
|
|
|
mnesia:write(PubsubIndex#pubsub_index{free = Free}),
|
|
|
|
Idx;
|
|
|
|
_ ->
|
|
|
|
mnesia:write(#pubsub_index{index = Index, last = 1, free = []}),
|
|
|
|
1
|
2009-04-30 07:18:06 +02:00
|
|
|
end.
|
|
|
|
|
2010-09-29 11:48:19 +02:00
|
|
|
|
|
|
|
-spec(free/2 ::
|
|
|
|
(
|
|
|
|
Index :: atom(),
|
|
|
|
Idx :: integer())
|
|
|
|
-> 'ok'
|
|
|
|
).
|
|
|
|
|
|
|
|
free(Index, Idx) ->
|
2009-04-30 07:18:06 +02:00
|
|
|
case mnesia:read({pubsub_index, Index}) of
|
2010-09-29 11:48:19 +02:00
|
|
|
[#pubsub_index{free = Free} = PubsubIndex] ->
|
|
|
|
mnesia:write(PubsubIndex#pubsub_index{free = [Idx|Free]});
|
|
|
|
_ -> ok
|
2009-04-30 07:18:06 +02:00
|
|
|
end.
|