From 93f0641c2122d6c23e2ac5f18579ef879599fc16 Mon Sep 17 00:00:00 2001 From: Adam Lindberg Date: Thu, 5 Jan 2012 17:03:12 +0100 Subject: [asn1] Abstract out table access to new module All table access is now performed in a separate module. This will allow changes to how ETS is handled by changing only this module. Note that the module exports a very ETS-like interface for now which would have to be maintained even if the data format would change (to a hash map for example). --- lib/asn1/src/asn1ct_table.erl | 64 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 64 insertions(+) create mode 100644 lib/asn1/src/asn1ct_table.erl (limited to 'lib/asn1/src/asn1ct_table.erl') diff --git a/lib/asn1/src/asn1ct_table.erl b/lib/asn1/src/asn1ct_table.erl new file mode 100644 index 0000000000..b7ae1d7105 --- /dev/null +++ b/lib/asn1/src/asn1ct_table.erl @@ -0,0 +1,64 @@ +%% +%% %CopyrightBegin% +%% +%% Copyright Ericsson AB 2012. All Rights Reserved. +%% +%% 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 online 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. +%% +%% %CopyrightEnd% +%% +%% +-module(asn1ct_table). + +%% Table abstraction module for ASN.1 compiler + +-export([new/2]). +-export([new_reuse/2]). +-export([exists/1]). +-export([size/1]). +-export([insert/2]). +-export([lookup/2]). +-export([match/2]). +-export([to_list/1]). +-export([delete/1]). % TODO: Remove (since we run in a separate process) + + +%% Always creates a new table +new(Table, Options) -> + case ets:info(Table) of + undefined -> + ets:new(Table, Options); + _ -> + delete(Table), + ets:new(Table, Options) + end. + +new_reuse(Table, Options) -> + not exists(Table) andalso new(Table, Options). + +exists(Table) -> ets:info(Table) =/= undefined. + +size(Table) -> ets:info(Table, size). + +insert(Table, Tuple) -> ets:insert(Table, Tuple). + +lookup(Table, Key) -> ets:lookup(Table, Key). + +match(Table, MatchSpec) -> ets:match(Table, MatchSpec). + +to_list(Table) -> ets:tab2list(Table). + +delete(Tables) when is_list(Tables) -> + [delete(T) || T <- Tables], + true; +delete(Table) when is_atom(Table) -> + exists(Table) andalso ets:delete(Table). -- cgit v1.2.3