diff options
author | Kenneth Lundin <[email protected]> | 2010-02-19 14:01:57 +0000 |
---|---|---|
committer | Erlang/OTP <[email protected]> | 2010-02-19 14:01:57 +0000 |
commit | 18bd1239bee04427340a44f57f993ea92c264e41 (patch) | |
tree | dbb3031dcd2e446eb457ff7ac5229949517d7557 /lib/asn1/test/asn1_wrapper.erl | |
parent | 729565dc3f8bcf8829508136498aef6a542840f4 (diff) | |
download | otp-18bd1239bee04427340a44f57f993ea92c264e41.tar.gz otp-18bd1239bee04427340a44f57f993ea92c264e41.tar.bz2 otp-18bd1239bee04427340a44f57f993ea92c264e41.zip |
OTP-8463 Support for EXTENSIBILITY IMPLIED and SET/SEQ OF NamedType is
added.
Diffstat (limited to 'lib/asn1/test/asn1_wrapper.erl')
-rw-r--r-- | lib/asn1/test/asn1_wrapper.erl | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/lib/asn1/test/asn1_wrapper.erl b/lib/asn1/test/asn1_wrapper.erl new file mode 100644 index 0000000000..553f0b062c --- /dev/null +++ b/lib/asn1/test/asn1_wrapper.erl @@ -0,0 +1,74 @@ +%% +%% %CopyrightBegin% +%% +%% Copyright Ericsson AB 2001-2009. 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(asn1_wrapper). +-author('kenneth@bilbo'). + +-compile(export_all). +%%-export([Function/Arity, ...]). + + +encode(Module,Type,Value) -> + case asn1rt:encode(Module,Type,Value) of + {ok,X} when binary(X) -> + {ok, binary_to_list(X)}; + {ok,X} -> + {ok, binary_to_list(list_to_binary(X))}; + Error -> + Error + end. + +decode(Module,Type,Bytes) -> + case Module:encoding_rule() of + ber -> + asn1rt:decode(Module,Type,Bytes); + ber_bin when binary(Bytes) -> + asn1rt:decode(Module,Type,Bytes); + ber_bin -> + asn1rt:decode(Module,Type,list_to_binary(Bytes)); + ber_bin_v2 when binary(Bytes) -> + asn1rt:decode(Module,Type,Bytes); + ber_bin_v2 -> + asn1rt:decode(Module,Type,list_to_binary(Bytes)); + per -> + asn1rt:decode(Module,Type,Bytes); + per_bin when binary(Bytes) -> + asn1rt:decode(Module,Type,Bytes); + per_bin -> + asn1rt:decode(Module,Type,list_to_binary(Bytes)); + uper_bin when binary(Bytes) -> + asn1rt:decode(Module,Type,Bytes); + uper_bin -> + asn1rt:decode(Module,Type,list_to_binary(Bytes)) + end. + +erule(ber) -> + ber; +erule(ber_bin) -> + ber; +erule(ber_bin_v2) -> + ber; +erule(per) -> + per; +erule(per_bin) -> + per; +erule(uper_bin) -> + per. + + |