OSDN Git Service

Update to 5b5ec56126af820b2d3c86e94ce4c056bf3b9904 about bug fixes.
authors_kawamoto <s_kawamoto@users.sourceforge.jp>
Thu, 13 Oct 2011 07:30:16 +0000 (16:30 +0900)
committers_kawamoto <s_kawamoto@users.sourceforge.jp>
Thu, 13 Oct 2011 07:30:16 +0000 (16:30 +0900)
Add new member names to copyright.
Fix line feed codes (somehow commited automatically by TortoiseGit).

92 files changed:
FFFTP_Eng_Release/FFFTP.exe
Package/installer_config.bat
Package/make_installer_post.bat
Package/make_installer_pre.bat
Package/package_readme.txt
Release/FFFTP.exe
Resource/FFFTP.rc
Resource_eng/FFFTP-eng.rc
contrib/openssl/include/openssl/aes.h
contrib/openssl/include/openssl/applink.c
contrib/openssl/include/openssl/asn1.h
contrib/openssl/include/openssl/asn1_mac.h
contrib/openssl/include/openssl/asn1t.h
contrib/openssl/include/openssl/bio.h
contrib/openssl/include/openssl/blowfish.h
contrib/openssl/include/openssl/bn.h
contrib/openssl/include/openssl/buffer.h
contrib/openssl/include/openssl/camellia.h
contrib/openssl/include/openssl/cast.h
contrib/openssl/include/openssl/cms.h
contrib/openssl/include/openssl/comp.h
contrib/openssl/include/openssl/conf.h
contrib/openssl/include/openssl/conf_api.h
contrib/openssl/include/openssl/crypto.h
contrib/openssl/include/openssl/des.h
contrib/openssl/include/openssl/des_old.h
contrib/openssl/include/openssl/dh.h
contrib/openssl/include/openssl/dsa.h
contrib/openssl/include/openssl/dso.h
contrib/openssl/include/openssl/dtls1.h
contrib/openssl/include/openssl/e_os2.h
contrib/openssl/include/openssl/ebcdic.h
contrib/openssl/include/openssl/ec.h
contrib/openssl/include/openssl/ecdh.h
contrib/openssl/include/openssl/ecdsa.h
contrib/openssl/include/openssl/engine.h
contrib/openssl/include/openssl/err.h
contrib/openssl/include/openssl/evp.h
contrib/openssl/include/openssl/hmac.h
contrib/openssl/include/openssl/idea.h
contrib/openssl/include/openssl/krb5_asn.h
contrib/openssl/include/openssl/kssl.h
contrib/openssl/include/openssl/lhash.h
contrib/openssl/include/openssl/md4.h
contrib/openssl/include/openssl/md5.h
contrib/openssl/include/openssl/mdc2.h
contrib/openssl/include/openssl/modes.h
contrib/openssl/include/openssl/obj_mac.h
contrib/openssl/include/openssl/objects.h
contrib/openssl/include/openssl/ocsp.h
contrib/openssl/include/openssl/opensslconf.h
contrib/openssl/include/openssl/opensslv.h
contrib/openssl/include/openssl/ossl_typ.h
contrib/openssl/include/openssl/pem.h
contrib/openssl/include/openssl/pem2.h
contrib/openssl/include/openssl/pkcs12.h
contrib/openssl/include/openssl/pkcs7.h
contrib/openssl/include/openssl/pqueue.h
contrib/openssl/include/openssl/rand.h
contrib/openssl/include/openssl/rc2.h
contrib/openssl/include/openssl/rc4.h
contrib/openssl/include/openssl/ripemd.h
contrib/openssl/include/openssl/rsa.h
contrib/openssl/include/openssl/safestack.h
contrib/openssl/include/openssl/seed.h
contrib/openssl/include/openssl/sha.h
contrib/openssl/include/openssl/ssl.h
contrib/openssl/include/openssl/ssl2.h
contrib/openssl/include/openssl/ssl23.h
contrib/openssl/include/openssl/ssl3.h
contrib/openssl/include/openssl/stack.h
contrib/openssl/include/openssl/symhacks.h
contrib/openssl/include/openssl/tls1.h
contrib/openssl/include/openssl/ts.h
contrib/openssl/include/openssl/txt_db.h
contrib/openssl/include/openssl/ui.h
contrib/openssl/include/openssl/ui_compat.h
contrib/openssl/include/openssl/whrlpool.h
contrib/openssl/include/openssl/x509.h
contrib/openssl/include/openssl/x509_vfy.h
contrib/openssl/include/openssl/x509v3.h
dist/readme_dist.txt
doc/eng/FFFTP.txt
doc/eng/history.txt
doc/jpn/FFFTP.txt
doc/jpn/history.txt
main.c
mbswrapper.c
mesg-eng.old.h
mesg-jpn.old.h
registory.c
toolmenu.c

index cf0e919..9842d71 100644 (file)
Binary files a/FFFTP_Eng_Release/FFFTP.exe and b/FFFTP_Eng_Release/FFFTP.exe differ
index 050ab33..1a5aa07 100644 (file)
@@ -1,25 +1,25 @@
-REM;
-REM;  This is batch-file to setup variables for some batchs.
-REM; 
-
-
-REM;  Set directory and path information
-set DIR_JPN=zip\jpn\ffftp
-set DIR_ENG=zip\eng\ffftp
-set JPN_ZIP=zip\jpn\ffftp.zip
-set ENG_ZIP=zip\eng\ffftp.zip
-
-set DIR_JPN_INST=EXEpress\jpn\ffftp
-set DIR_ENG_INST=EXEpress\eng\ffftp
-set JPN_INST=EXEpress\jpn\ffftp.exe
-set ENG_INST=EXEpress\eng\ffftp.exe
-
-set HTMLHELP=..\htmlhelp\FFFTP.CHM
-set BIN_JPN=..\Release\FFFTP.exe
-set BIN_ENG=..\FFFTP_Eng_Release\FFFTP.exe
-
-set DIR_JPN_DOC=..\doc\jpn
-set DIR_ENG_DOC=..\doc\eng
-set DIR_DIST=..\dist
-
-set FFFTP_VERSION=1.99
+REM;\r
+REM;  This is batch-file to setup variables for some batchs.\r
+REM; \r
+\r
+\r
+REM;  Set directory and path information\r
+set DIR_JPN=zip\jpn\ffftp\r
+set DIR_ENG=zip\eng\ffftp\r
+set JPN_ZIP=zip\jpn\ffftp.zip\r
+set ENG_ZIP=zip\eng\ffftp.zip\r
+\r
+set DIR_JPN_INST=EXEpress\jpn\ffftp\r
+set DIR_ENG_INST=EXEpress\eng\ffftp\r
+set JPN_INST=EXEpress\jpn\ffftp.exe\r
+set ENG_INST=EXEpress\eng\ffftp.exe\r
+\r
+set HTMLHELP=..\htmlhelp\FFFTP.CHM\r
+set BIN_JPN=..\Release\FFFTP.exe\r
+set BIN_ENG=..\FFFTP_Eng_Release\FFFTP.exe\r
+\r
+set DIR_JPN_DOC=..\doc\jpn\r
+set DIR_ENG_DOC=..\doc\eng\r
+set DIR_DIST=..\dist\r
+\r
+set FFFTP_VERSION=1.99\r
index e19158b..0c936e6 100644 (file)
@@ -1,17 +1,17 @@
-REM;
-REM;  This is batch-file to copy FFFTP installer and archive.
-REM;  Please run in "ffftp\Package" directory.
-REM;  To change settings, please edit "instaler_config.bat".
-REM; 
-
-call installer_config.bat
-
-REM;  copy zip archive
-copy /Y %JPN_ZIP% ffftp-%FFFTP_VERSION%.zip
-copy /Y %ENG_ZIP% ffftp-%FFFTP_VERSION%-eng.zip
-
-REM; copy installer
-copy /Y %JPN_INST% ffftp-%FFFTP_VERSION%.exe
-copy /Y %ENG_INST% ffftp-%FFFTP_VERSION%-eng.exe
-
-pause
+REM;\r
+REM;  This is batch-file to copy FFFTP installer and archive.\r
+REM;  Please run in "ffftp\Package" directory.\r
+REM;  To change settings, please edit "instaler_config.bat".\r
+REM; \r
+\r
+call installer_config.bat\r
+\r
+REM;  copy zip archive\r
+copy /Y %JPN_ZIP% ffftp-%FFFTP_VERSION%.zip\r
+copy /Y %ENG_ZIP% ffftp-%FFFTP_VERSION%-eng.zip\r
+\r
+REM; copy installer\r
+copy /Y %JPN_INST% ffftp-%FFFTP_VERSION%.exe\r
+copy /Y %ENG_INST% ffftp-%FFFTP_VERSION%-eng.exe\r
+\r
+pause\r
index e091911..374aa0c 100644 (file)
@@ -1,28 +1,28 @@
-REM;
-REM;  This is batch-file to prepare for creating FFFTP installer.
-REM;  Please run in "ffftp\Package" directory.
-REM;  To change settings, please edit "instaler_config.bat".
-REM; 
-
-call installer_config.bat
-
-REM;  copy Japanese files
-mkdir %DIR_JPN%
-copy /Y %BIN_JPN% %DIR_JPN%
-copy /Y %HTMLHELP% %DIR_JPN%
-copy /Y %DIR_JPN_DOC%\*.txt %DIR_JPN%
-copy /Y %DIR_DIST%\*.dll %DIR_JPN%
-copy /Y %DIR_DIST%\*.manifest %DIR_JPN%
-
-REM;  copy English files
-mkdir %DIR_ENG%
-copy /Y %BIN_ENG% %DIR_ENG%
-copy /Y %DIR_ENG_DOC%\*.txt %DIR_ENG%
-copy /Y %DIR_DIST%\*.dll %DIR_ENG%
-copy /Y %DIR_DIST%\*.manifest %DIR_ENG%
-
-REM; copy to installer working directory
-copy /Y %DIR_JPN%\*.* %DIR_JPN_INST%
-copy /Y %DIR_ENG%\*.* %DIR_ENG_INST%
-
-pause
+REM;\r
+REM;  This is batch-file to prepare for creating FFFTP installer.\r
+REM;  Please run in "ffftp\Package" directory.\r
+REM;  To change settings, please edit "instaler_config.bat".\r
+REM; \r
+\r
+call installer_config.bat\r
+\r
+REM;  copy Japanese files\r
+mkdir %DIR_JPN%\r
+copy /Y %BIN_JPN% %DIR_JPN%\r
+copy /Y %HTMLHELP% %DIR_JPN%\r
+copy /Y %DIR_JPN_DOC%\*.txt %DIR_JPN%\r
+copy /Y %DIR_DIST%\*.dll %DIR_JPN%\r
+copy /Y %DIR_DIST%\*.manifest %DIR_JPN%\r
+\r
+REM;  copy English files\r
+mkdir %DIR_ENG%\r
+copy /Y %BIN_ENG% %DIR_ENG%\r
+copy /Y %DIR_ENG_DOC%\*.txt %DIR_ENG%\r
+copy /Y %DIR_DIST%\*.dll %DIR_ENG%\r
+copy /Y %DIR_DIST%\*.manifest %DIR_ENG%\r
+\r
+REM; copy to installer working directory\r
+copy /Y %DIR_JPN%\*.* %DIR_JPN_INST%\r
+copy /Y %DIR_ENG%\*.* %DIR_ENG_INST%\r
+\r
+pause\r
index eaaecab..78464fe 100644 (file)
@@ -1,23 +1,23 @@
-開発者向けドキュメント:インストーラの作成方法
-
-インストーラの作成にはEXEpress CX 5を使用します。EXEpress CX 5はフリーソフトウェア向けのものが無償でダウンロードできます。
-
-1. 準備
-  1.1. make_installer_pre.batを実行
-
-2. 日本語版インストーラを作成
-  2.1. EXEpress\jpn\ffftp\内のファイルをCAB形式で圧縮、EXEpress\jpn\ffftp.cabとして保存(Windows標準のiexpressツールが利用できます)
-  2.2. EXEpressを起動し、「設定読み込み」でEXEpress\jpn\ffftp.iniを指定、「作成」をクリックする
-
-3. 英語版インストーラを作成
-  3.1. EXEpress\eng\ffftp\内のファイルをCAB形式で圧縮、EXEpress\eng\ffftp.cabとして保存
-  3.2. EXEpressを起動し、「設定読み込み」でEXEpress\eng\ffftp.iniを指定、「作成」をクリックする
-
-4. 日本語版ZIPファイルを作成
-  4.1. zip\jpn\ffftpフォルダをZIP形式で圧縮(「送る」→「圧縮(ZIP形式)フォルダ」で可能)
-
-5. 英語版ZIPファイルを作成
-  4.1. zip\enf\ffftpフォルダをZIP形式で圧縮(「送る」→「圧縮(ZIP形式)フォルダ」で可能)
-
-6. ファイルを収集
-  6.1. make_installer_post.batを実行
+開発者向けドキュメント:インストーラの作成方法\r
+\r
+インストーラの作成にはEXEpress CX 5を使用します。EXEpress CX 5はフリーソフトウェア向けのものが無償でダウンロードできます。\r
+\r
+1. 準備\r
+  1.1. make_installer_pre.batを実行\r
+\r
+2. 日本語版インストーラを作成\r
+  2.1. EXEpress\jpn\ffftp\内のファイルをCAB形式で圧縮、EXEpress\jpn\ffftp.cabとして保存(Windows標準のiexpressツールが利用できます)\r
+  2.2. EXEpressを起動し、「設定読み込み」でEXEpress\jpn\ffftp.iniを指定、「作成」をクリックする\r
+\r
+3. 英語版インストーラを作成\r
+  3.1. EXEpress\eng\ffftp\内のファイルをCAB形式で圧縮、EXEpress\eng\ffftp.cabとして保存\r
+  3.2. EXEpressを起動し、「設定読み込み」でEXEpress\eng\ffftp.iniを指定、「作成」をクリックする\r
+\r
+4. 日本語版ZIPファイルを作成\r
+  4.1. zip\jpn\ffftpフォルダをZIP形式で圧縮(「送る」→「圧縮(ZIP形式)フォルダ」で可能)\r
+\r
+5. 英語版ZIPファイルを作成\r
+  4.1. zip\enf\ffftpフォルダをZIP形式で圧縮(「送る」→「圧縮(ZIP形式)フォルダ」で可能)\r
+\r
+6. ファイルを収集\r
+  6.1. make_installer_post.batを実行\r
index 269d101..0141b13 100644 (file)
Binary files a/Release/FFFTP.exe and b/Release/FFFTP.exe differ
index 34bbc1d..4daf284 100644 (file)
@@ -228,21 +228,21 @@ END
 // Dialog\r
 //\r
 \r
-about_dlg DIALOGEX 0, 0, 319, 291\r
+about_dlg DIALOGEX 0, 0, 319, 315\r
 STYLE DS_SETFONT | DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU\r
 CAPTION "FFFTP\82É\82Â\82¢\82Ä"\r
 FONT 9, "\82l\82\82o\83S\83V\83b\83N", 0, 0, 0x0\r
 BEGIN\r
-    DEFPUSHBUTTON   "OK",IDOK,133,270,50,14\r
+    DEFPUSHBUTTON   "OK",IDOK,133,294,50,14\r
     ICON            ffftp,-1,7,4,20,20\r
     CTEXT           "FFFTP  Ver 1.99",-1,113,11,90,8\r
-    CTEXT           "FFFTP\82Ífreeware\82Å\82·",-1,7,255,305,8\r
-    CTEXT           "Copyright(C) 1997-2010 Sota & \82²\8b¦\97Í\82¢\82½\82¾\82¢\82½\95û\81X\nCopyright (C) 2011 FFFTP Project (Hiromichi Matsushima, Suguru Kawamoto)",-1,7,25,305,20,SS_NOPREFIX\r
-    CTEXT           "",ABOUT_JRE,7,72,305,8\r
-    EDITTEXT        ABOUT_URL,7,52,305,12,ES_CENTER | ES_AUTOHSCROLL | ES_READONLY | NOT WS_BORDER\r
-    CTEXT           "OLE D&&D\8b@\94\ by \95½\93c\96L\82³\82ñ\81Anakka\82³\82ñ\n\83z\83X\83g\93à\82Å\82Ì\83t\83@\83C\83\8b\88Ú\93®\8b@\94\ by \95½\93c\96L\82³\82ñ\n\82¢\82­\82Â\82©\82Ì\8b@\94\ by miau\82³\82ñ\n\83}\83X\83^\81[\83p\83X\83\8f\81[\83h\8b@\94\ by \82°\82ñ\82°\82ñ\82³\82ñ\nAES\88Ã\8d\86\89» by Moca\82³\82ñ\n\n\91¼\81A\91½\82­\82Ì\95û\82Ì\82²\8b¦\97Í\82ð\82¢\82½\82¾\82«\82Ü\82µ\82½\81B",-1,7,119,305,60\r
-    CTEXT           "AES program code :\nCopyright (c) 1998-2008, Brian Gladman, Worcester, UK.\nAll rights reserved.",-1,7,87,305,27\r
-    CTEXT           "FTP over SSL/TLS\82Ì\8eÀ\91\95\82É\82ÍOpenSSL\82ð\8eg\97p\82µ\82Ä\82¢\82Ü\82·\81B\nCopyright (c) 1998-2011 The OpenSSL Project.  All rights reserved.",-1,7,183,305,60\r
+    CTEXT           "FFFTP\82Ífreeware\82Å\82·",-1,7,279,305,8\r
+    CTEXT           "Copyright(C) 1997-2010 Sota & \82²\8b¦\97Í\82¢\82½\82¾\82¢\82½\95û\81X\nCopyright (C) 2011 FFFTP Project (Hiromichi Matsushima, Suguru Kawamoto, IWAMOTO Kouichi, vitamin0x, \82¤\82È\81[, raido)",-1,7,25,305,44,SS_NOPREFIX\r
+    CTEXT           "",ABOUT_JRE,7,96,305,8\r
+    EDITTEXT        ABOUT_URL,7,76,305,12,ES_CENTER | ES_AUTOHSCROLL | ES_READONLY | NOT WS_BORDER\r
+    CTEXT           "OLE D&&D\8b@\94\ by \95½\93c\96L\82³\82ñ\81Anakka\82³\82ñ\n\83z\83X\83g\93à\82Å\82Ì\83t\83@\83C\83\8b\88Ú\93®\8b@\94\ by \95½\93c\96L\82³\82ñ\n\82¢\82­\82Â\82©\82Ì\8b@\94\ by miau\82³\82ñ\n\83}\83X\83^\81[\83p\83X\83\8f\81[\83h\8b@\94\ by \82°\82ñ\82°\82ñ\82³\82ñ\nAES\88Ã\8d\86\89» by Moca\82³\82ñ\n\n\91¼\81A\91½\82­\82Ì\95û\82Ì\82²\8b¦\97Í\82ð\82¢\82½\82¾\82«\82Ü\82µ\82½\81B",-1,7,143,305,60\r
+    CTEXT           "AES program code :\nCopyright (c) 1998-2008, Brian Gladman, Worcester, UK.\nAll rights reserved.",-1,7,111,305,27\r
+    CTEXT           "FTP over SSL/TLS\82Ì\8eÀ\91\95\82É\82ÍOpenSSL\82ð\8eg\97p\82µ\82Ä\82¢\82Ü\82·\81B\nCopyright (c) 1998-2011 The OpenSSL Project.  All rights reserved.",-1,7,207,305,60\r
 END\r
 \r
 transfer_dlg DIALOG  0, 0, 199, 91\r
@@ -1375,7 +1375,7 @@ BEGIN
         LEFTMARGIN, 7\r
         RIGHTMARGIN, 312\r
         TOPMARGIN, 4\r
-        BOTTOMMARGIN, 284\r
+        BOTTOMMARGIN, 308\r
     END\r
 \r
     transfer_dlg, DIALOG\r
@@ -2033,7 +2033,7 @@ BEGIN
             VALUE "FileDescription", "FFFTP"\r
             VALUE "FileVersion", "1, 99, 0, 0"\r
             VALUE "InternalName", "FFFTP"\r
-            VALUE "LegalCopyright", "Copyright (C) 1997-2010 Sota & \82²\8b¦\97Í\82¢\82½\82¾\82¢\82½\95û\81X\nCopyright (C) 2011 FFFTP Project (Hiromichi Matsushima, Suguru Kawamoto)."\r
+            VALUE "LegalCopyright", "Copyright (C) 1997-2010 Sota & \82²\8b¦\97Í\82¢\82½\82¾\82¢\82½\95û\81X\nCopyright (C) 2011 FFFTP Project (Hiromichi Matsushima, Suguru Kawamoto, IWAMOTO Kouichi, vitamin0x, \82¤\82È\81[, raido)."\r
             VALUE "OriginalFilename", "FFFTP.exe"\r
             VALUE "ProductName", "FFFTP"\r
             VALUE "ProductVersion", "1, 99, 0, 0"\r
index e82bebf..13d2662 100644 (file)
@@ -228,21 +228,21 @@ END
 // Dialog\r
 //\r
 \r
-about_dlg DIALOGEX 0, 0, 315, 293\r
+about_dlg DIALOGEX 0, 0, 315, 317\r
 STYLE DS_SETFONT | DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU\r
 CAPTION "About FFFTP"\r
 FONT 9, "MS Sans Serif", 0, 0, 0x0\r
 BEGIN\r
-    DEFPUSHBUTTON   "OK",IDOK,132,272,50,14\r
+    DEFPUSHBUTTON   "OK",IDOK,132,296,50,14\r
     ICON            ffftp,-1,7,4,20,20\r
     CTEXT           "FFFTP  Ver 1.99",-1,110,11,90,8\r
-    CTEXT           "FFFTP is freeware",-1,7,257,301,8\r
-    CTEXT           "Copyright(C) 1997-2010 Sota && cooperators\nCopyright (C) 2011 FFFTP Project (Hiromichi Matsushima, Suguru Kawamoto)",-1,7,25,301,20\r
-    CTEXT           "",ABOUT_JRE,7,69,301,8\r
-    EDITTEXT        ABOUT_URL,7,52,301,12,ES_CENTER | ES_AUTOHSCROLL | ES_READONLY | NOT WS_BORDER\r
-    CTEXT           "OLE D&&D by Yutaka Hirata-san, nakka-san\nIn site file mover by Hirata-san\nAny issues by miau-san\nMaster Password by Gengen-san\nAES encryption by Moca-san\n\nI had cooperation of many other one.",-1,7,118,301,59\r
-    CTEXT           "AES program code :\nCopyright (c) 1998-2008, Brian Gladman, Worcester, UK.\nAll rights reserved.",-1,7,86,301,27\r
-    CTEXT           "OpenSSL is used for implementation of FTP over SSL/TLS.\nCopyright (c) 1998-2011 The OpenSSL Project.  All rights reserved.",-1,7,185,305,60\r
+    CTEXT           "FFFTP is freeware",-1,7,281,301,8\r
+    CTEXT           "Copyright(C) 1997-2010 Sota && cooperators\nCopyright (C) 2011 FFFTP Project (Hiromichi Matsushima, Suguru Kawamoto, IWAMOTO Kouichi, vitamin0x, unarist, raido)",-1,7,25,301,44\r
+    CTEXT           "",ABOUT_JRE,7,93,301,8\r
+    EDITTEXT        ABOUT_URL,7,76,301,12,ES_CENTER | ES_AUTOHSCROLL | ES_READONLY | NOT WS_BORDER\r
+    CTEXT           "OLE D&&D by Yutaka Hirata-san, nakka-san\nIn site file mover by Hirata-san\nAny issues by miau-san\nMaster Password by Gengen-san\nAES encryption by Moca-san\n\nI had cooperation of many other one.",-1,7,142,301,59\r
+    CTEXT           "AES program code :\nCopyright (c) 1998-2008, Brian Gladman, Worcester, UK.\nAll rights reserved.",-1,7,110,301,27\r
+    CTEXT           "OpenSSL is used for implementation of FTP over SSL/TLS.\nCopyright (c) 1998-2011 The OpenSSL Project.  All rights reserved.",-1,7,209,305,60\r
 END\r
 \r
 transfer_dlg DIALOG  0, 0, 199, 91\r
@@ -1400,7 +1400,7 @@ BEGIN
         LEFTMARGIN, 7\r
         RIGHTMARGIN, 308\r
         TOPMARGIN, 4\r
-        BOTTOMMARGIN, 286\r
+        BOTTOMMARGIN, 310\r
     END\r
 \r
     transfer_dlg, DIALOG\r
@@ -2055,7 +2055,7 @@ BEGIN
             VALUE "FileDescription", "FFFTP"\r
             VALUE "FileVersion", "1, 99, 0, 0"\r
             VALUE "InternalName", "FFFTP"\r
-            VALUE "LegalCopyright", "Copyright (C) 1997-2010 Sota & cooperators\nCopyright (C) 2011 FFFTP Project (Hiromichi Matsushima, Suguru Kawamoto)."\r
+            VALUE "LegalCopyright", "Copyright (C) 1997-2010 Sota & cooperators\nCopyright (C) 2011 FFFTP Project (Hiromichi Matsushima, Suguru Kawamoto, IWAMOTO Kouichi, vitamin0x, unarist, raido)."\r
             VALUE "OriginalFilename", "FFFTP.exe"\r
             VALUE "ProductName", "FFFTP"\r
             VALUE "ProductVersion", "1, 99, 0, 0"\r
index 2c5de24..a0ec30d 100644 (file)
-/* crypto/aes/aes.h -*- mode:C; c-file-style: "eay" -*- */
-/* ====================================================================
- * Copyright (c) 1998-2002 The OpenSSL Project.  All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- *
- * 1. Redistributions of source code must retain the above copyright
- *    notice, this list of conditions and the following disclaimer.
- *
- * 2. Redistributions in binary form must reproduce the above copyright
- *    notice, this list of conditions and the following disclaimer in
- *    the documentation and/or other materials provided with the
- *    distribution.
- *
- * 3. All advertising materials mentioning features or use of this
- *    software must display the following acknowledgment:
- *    "This product includes software developed by the OpenSSL Project
- *    for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
- *
- * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
- *    endorse or promote products derived from this software without
- *    prior written permission. For written permission, please contact
- *    openssl-core@openssl.org.
- *
- * 5. Products derived from this software may not be called "OpenSSL"
- *    nor may "OpenSSL" appear in their names without prior written
- *    permission of the OpenSSL Project.
- *
- * 6. Redistributions of any form whatsoever must retain the following
- *    acknowledgment:
- *    "This product includes software developed by the OpenSSL Project
- *    for use in the OpenSSL Toolkit (http://www.openssl.org/)"
- *
- * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
- * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR
- * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
- * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
- * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
- * OF THE POSSIBILITY OF SUCH DAMAGE.
- * ====================================================================
- *
- */
-
-#ifndef HEADER_AES_H
-#define HEADER_AES_H
-
-#include <openssl/opensslconf.h>
-
-#ifdef OPENSSL_NO_AES
-#error AES is disabled.
-#endif
-
-#include <stddef.h>
-
-#define AES_ENCRYPT    1
-#define AES_DECRYPT    0
-
-/* Because array size can't be a const in C, the following two are macros.
-   Both sizes are in bytes. */
-#define AES_MAXNR 14
-#define AES_BLOCK_SIZE 16
-
-#ifdef  __cplusplus
-extern "C" {
-#endif
-
-/* This should be a hidden type, but EVP requires that the size be known */
-struct aes_key_st {
-#ifdef AES_LONG
-    unsigned long rd_key[4 *(AES_MAXNR + 1)];
-#else
-    unsigned int rd_key[4 *(AES_MAXNR + 1)];
-#endif
-    int rounds;
-};
-typedef struct aes_key_st AES_KEY;
-
-const char *AES_options(void);
-
-int AES_set_encrypt_key(const unsigned char *userKey, const int bits,
-       AES_KEY *key);
-int AES_set_decrypt_key(const unsigned char *userKey, const int bits,
-       AES_KEY *key);
-
-void AES_encrypt(const unsigned char *in, unsigned char *out,
-       const AES_KEY *key);
-void AES_decrypt(const unsigned char *in, unsigned char *out,
-       const AES_KEY *key);
-
-void AES_ecb_encrypt(const unsigned char *in, unsigned char *out,
-       const AES_KEY *key, const int enc);
-void AES_cbc_encrypt(const unsigned char *in, unsigned char *out,
-       size_t length, const AES_KEY *key,
-       unsigned char *ivec, const int enc);
-void AES_cfb128_encrypt(const unsigned char *in, unsigned char *out,
-       size_t length, const AES_KEY *key,
-       unsigned char *ivec, int *num, const int enc);
-void AES_cfb1_encrypt(const unsigned char *in, unsigned char *out,
-       size_t length, const AES_KEY *key,
-       unsigned char *ivec, int *num, const int enc);
-void AES_cfb8_encrypt(const unsigned char *in, unsigned char *out,
-       size_t length, const AES_KEY *key,
-       unsigned char *ivec, int *num, const int enc);
-void AES_ofb128_encrypt(const unsigned char *in, unsigned char *out,
-       size_t length, const AES_KEY *key,
-       unsigned char *ivec, int *num);
-void AES_ctr128_encrypt(const unsigned char *in, unsigned char *out,
-       size_t length, const AES_KEY *key,
-       unsigned char ivec[AES_BLOCK_SIZE],
-       unsigned char ecount_buf[AES_BLOCK_SIZE],
-       unsigned int *num);
-/* NB: the IV is _two_ blocks long */
-void AES_ige_encrypt(const unsigned char *in, unsigned char *out,
-                    size_t length, const AES_KEY *key,
-                    unsigned char *ivec, const int enc);
-/* NB: the IV is _four_ blocks long */
-void AES_bi_ige_encrypt(const unsigned char *in, unsigned char *out,
-                       size_t length, const AES_KEY *key,
-                       const AES_KEY *key2, const unsigned char *ivec,
-                       const int enc);
-
-int AES_wrap_key(AES_KEY *key, const unsigned char *iv,
-               unsigned char *out,
-               const unsigned char *in, unsigned int inlen);
-int AES_unwrap_key(AES_KEY *key, const unsigned char *iv,
-               unsigned char *out,
-               const unsigned char *in, unsigned int inlen);
-
-
-#ifdef  __cplusplus
-}
-#endif
-
-#endif /* !HEADER_AES_H */
+/* crypto/aes/aes.h -*- mode:C; c-file-style: "eay" -*- */\r
+/* ====================================================================\r
+ * Copyright (c) 1998-2002 The OpenSSL Project.  All rights reserved.\r
+ *\r
+ * Redistribution and use in source and binary forms, with or without\r
+ * modification, are permitted provided that the following conditions\r
+ * are met:\r
+ *\r
+ * 1. Redistributions of source code must retain the above copyright\r
+ *    notice, this list of conditions and the following disclaimer.\r
+ *\r
+ * 2. Redistributions in binary form must reproduce the above copyright\r
+ *    notice, this list of conditions and the following disclaimer in\r
+ *    the documentation and/or other materials provided with the\r
+ *    distribution.\r
+ *\r
+ * 3. All advertising materials mentioning features or use of this\r
+ *    software must display the following acknowledgment:\r
+ *    "This product includes software developed by the OpenSSL Project\r
+ *    for use in the OpenSSL Toolkit. (http://www.openssl.org/)"\r
+ *\r
+ * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to\r
+ *    endorse or promote products derived from this software without\r
+ *    prior written permission. For written permission, please contact\r
+ *    openssl-core@openssl.org.\r
+ *\r
+ * 5. Products derived from this software may not be called "OpenSSL"\r
+ *    nor may "OpenSSL" appear in their names without prior written\r
+ *    permission of the OpenSSL Project.\r
+ *\r
+ * 6. Redistributions of any form whatsoever must retain the following\r
+ *    acknowledgment:\r
+ *    "This product includes software developed by the OpenSSL Project\r
+ *    for use in the OpenSSL Toolkit (http://www.openssl.org/)"\r
+ *\r
+ * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY\r
+ * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\r
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR\r
+ * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR\r
+ * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,\r
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT\r
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\r
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\r
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,\r
+ * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\r
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED\r
+ * OF THE POSSIBILITY OF SUCH DAMAGE.\r
+ * ====================================================================\r
+ *\r
+ */\r
+\r
+#ifndef HEADER_AES_H\r
+#define HEADER_AES_H\r
+\r
+#include <openssl/opensslconf.h>\r
+\r
+#ifdef OPENSSL_NO_AES\r
+#error AES is disabled.\r
+#endif\r
+\r
+#include <stddef.h>\r
+\r
+#define AES_ENCRYPT    1\r
+#define AES_DECRYPT    0\r
+\r
+/* Because array size can't be a const in C, the following two are macros.\r
+   Both sizes are in bytes. */\r
+#define AES_MAXNR 14\r
+#define AES_BLOCK_SIZE 16\r
+\r
+#ifdef  __cplusplus\r
+extern "C" {\r
+#endif\r
+\r
+/* This should be a hidden type, but EVP requires that the size be known */\r
+struct aes_key_st {\r
+#ifdef AES_LONG\r
+    unsigned long rd_key[4 *(AES_MAXNR + 1)];\r
+#else\r
+    unsigned int rd_key[4 *(AES_MAXNR + 1)];\r
+#endif\r
+    int rounds;\r
+};\r
+typedef struct aes_key_st AES_KEY;\r
+\r
+const char *AES_options(void);\r
+\r
+int AES_set_encrypt_key(const unsigned char *userKey, const int bits,\r
+       AES_KEY *key);\r
+int AES_set_decrypt_key(const unsigned char *userKey, const int bits,\r
+       AES_KEY *key);\r
+\r
+void AES_encrypt(const unsigned char *in, unsigned char *out,\r
+       const AES_KEY *key);\r
+void AES_decrypt(const unsigned char *in, unsigned char *out,\r
+       const AES_KEY *key);\r
+\r
+void AES_ecb_encrypt(const unsigned char *in, unsigned char *out,\r
+       const AES_KEY *key, const int enc);\r
+void AES_cbc_encrypt(const unsigned char *in, unsigned char *out,\r
+       size_t length, const AES_KEY *key,\r
+       unsigned char *ivec, const int enc);\r
+void AES_cfb128_encrypt(const unsigned char *in, unsigned char *out,\r
+       size_t length, const AES_KEY *key,\r
+       unsigned char *ivec, int *num, const int enc);\r
+void AES_cfb1_encrypt(const unsigned char *in, unsigned char *out,\r
+       size_t length, const AES_KEY *key,\r
+       unsigned char *ivec, int *num, const int enc);\r
+void AES_cfb8_encrypt(const unsigned char *in, unsigned char *out,\r
+       size_t length, const AES_KEY *key,\r
+       unsigned char *ivec, int *num, const int enc);\r
+void AES_ofb128_encrypt(const unsigned char *in, unsigned char *out,\r
+       size_t length, const AES_KEY *key,\r
+       unsigned char *ivec, int *num);\r
+void AES_ctr128_encrypt(const unsigned char *in, unsigned char *out,\r
+       size_t length, const AES_KEY *key,\r
+       unsigned char ivec[AES_BLOCK_SIZE],\r
+       unsigned char ecount_buf[AES_BLOCK_SIZE],\r
+       unsigned int *num);\r
+/* NB: the IV is _two_ blocks long */\r
+void AES_ige_encrypt(const unsigned char *in, unsigned char *out,\r
+                    size_t length, const AES_KEY *key,\r
+                    unsigned char *ivec, const int enc);\r
+/* NB: the IV is _four_ blocks long */\r
+void AES_bi_ige_encrypt(const unsigned char *in, unsigned char *out,\r
+                       size_t length, const AES_KEY *key,\r
+                       const AES_KEY *key2, const unsigned char *ivec,\r
+                       const int enc);\r
+\r
+int AES_wrap_key(AES_KEY *key, const unsigned char *iv,\r
+               unsigned char *out,\r
+               const unsigned char *in, unsigned int inlen);\r
+int AES_unwrap_key(AES_KEY *key, const unsigned char *iv,\r
+               unsigned char *out,\r
+               const unsigned char *in, unsigned int inlen);\r
+\r
+\r
+#ifdef  __cplusplus\r
+}\r
+#endif\r
+\r
+#endif /* !HEADER_AES_H */\r
index 54a0a64..7789bd9 100644 (file)
@@ -1,94 +1,94 @@
-#define APPLINK_STDIN  1
-#define APPLINK_STDOUT 2
-#define APPLINK_STDERR 3
-#define APPLINK_FPRINTF        4
-#define APPLINK_FGETS  5
-#define APPLINK_FREAD  6
-#define APPLINK_FWRITE 7
-#define APPLINK_FSETMOD        8
-#define APPLINK_FEOF   9
-#define APPLINK_FCLOSE         10      /* should not be used */
-
-#define APPLINK_FOPEN  11      /* solely for completeness */
-#define APPLINK_FSEEK  12
-#define APPLINK_FTELL  13
-#define APPLINK_FFLUSH 14
-#define APPLINK_FERROR 15
-#define APPLINK_CLEARERR 16
-#define APPLINK_FILENO 17      /* to be used with below */
-
-#define APPLINK_OPEN   18      /* formally can't be used, as flags can vary */
-#define APPLINK_READ   19
-#define APPLINK_WRITE  20
-#define APPLINK_LSEEK  21
-#define APPLINK_CLOSE  22
-#define APPLINK_MAX    22      /* always same as last macro */
-
-#ifndef APPMACROS_ONLY
-#include <stdio.h>
-#include <io.h>
-#include <fcntl.h>
-
-static void *app_stdin(void)           { return stdin;  }
-static void *app_stdout(void)          { return stdout; }
-static void *app_stderr(void)          { return stderr; }
-static int   app_feof(FILE *fp)                { return feof(fp); }
-static int   app_ferror(FILE *fp)      { return ferror(fp); }
-static void  app_clearerr(FILE *fp)    { clearerr(fp); }
-static int   app_fileno(FILE *fp)      { return _fileno(fp); }
-static int   app_fsetmod(FILE *fp,char mod)
-{ return _setmode (_fileno(fp),mod=='b'?_O_BINARY:_O_TEXT); }
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-__declspec(dllexport)
-void **
-#if defined(__BORLANDC__)
-__stdcall      /* __stdcall appears to be the only way to get the name
-                * decoration right with Borland C. Otherwise it works
-                * purely incidentally, as we pass no parameters. */
-#else
-__cdecl
-#endif
-OPENSSL_Applink(void)
-{ static int once=1;
-  static void *OPENSSL_ApplinkTable[APPLINK_MAX+1]={(void *)APPLINK_MAX};
-
-    if (once)
-    {  OPENSSL_ApplinkTable[APPLINK_STDIN]     = app_stdin;
-       OPENSSL_ApplinkTable[APPLINK_STDOUT]    = app_stdout;
-       OPENSSL_ApplinkTable[APPLINK_STDERR]    = app_stderr;
-       OPENSSL_ApplinkTable[APPLINK_FPRINTF]   = fprintf;
-       OPENSSL_ApplinkTable[APPLINK_FGETS]     = fgets;
-       OPENSSL_ApplinkTable[APPLINK_FREAD]     = fread;
-       OPENSSL_ApplinkTable[APPLINK_FWRITE]    = fwrite;
-       OPENSSL_ApplinkTable[APPLINK_FSETMOD]   = app_fsetmod;
-       OPENSSL_ApplinkTable[APPLINK_FEOF]      = app_feof;
-       OPENSSL_ApplinkTable[APPLINK_FCLOSE]    = fclose;
-
-       OPENSSL_ApplinkTable[APPLINK_FOPEN]     = fopen;
-       OPENSSL_ApplinkTable[APPLINK_FSEEK]     = fseek;
-       OPENSSL_ApplinkTable[APPLINK_FTELL]     = ftell;
-       OPENSSL_ApplinkTable[APPLINK_FFLUSH]    = fflush;
-       OPENSSL_ApplinkTable[APPLINK_FERROR]    = app_ferror;
-       OPENSSL_ApplinkTable[APPLINK_CLEARERR]  = app_clearerr;
-       OPENSSL_ApplinkTable[APPLINK_FILENO]    = app_fileno;
-
-       OPENSSL_ApplinkTable[APPLINK_OPEN]      = _open;
-       OPENSSL_ApplinkTable[APPLINK_READ]      = _read;
-       OPENSSL_ApplinkTable[APPLINK_WRITE]     = _write;
-       OPENSSL_ApplinkTable[APPLINK_LSEEK]     = _lseek;
-       OPENSSL_ApplinkTable[APPLINK_CLOSE]     = _close;
-
-       once = 0;
-    }
-
-  return OPENSSL_ApplinkTable;
-}
-
-#ifdef __cplusplus
-}
-#endif
-#endif
+#define APPLINK_STDIN  1\r
+#define APPLINK_STDOUT 2\r
+#define APPLINK_STDERR 3\r
+#define APPLINK_FPRINTF        4\r
+#define APPLINK_FGETS  5\r
+#define APPLINK_FREAD  6\r
+#define APPLINK_FWRITE 7\r
+#define APPLINK_FSETMOD        8\r
+#define APPLINK_FEOF   9\r
+#define APPLINK_FCLOSE         10      /* should not be used */\r
+\r
+#define APPLINK_FOPEN  11      /* solely for completeness */\r
+#define APPLINK_FSEEK  12\r
+#define APPLINK_FTELL  13\r
+#define APPLINK_FFLUSH 14\r
+#define APPLINK_FERROR 15\r
+#define APPLINK_CLEARERR 16\r
+#define APPLINK_FILENO 17      /* to be used with below */\r
+\r
+#define APPLINK_OPEN   18      /* formally can't be used, as flags can vary */\r
+#define APPLINK_READ   19\r
+#define APPLINK_WRITE  20\r
+#define APPLINK_LSEEK  21\r
+#define APPLINK_CLOSE  22\r
+#define APPLINK_MAX    22      /* always same as last macro */\r
+\r
+#ifndef APPMACROS_ONLY\r
+#include <stdio.h>\r
+#include <io.h>\r
+#include <fcntl.h>\r
+\r
+static void *app_stdin(void)           { return stdin;  }\r
+static void *app_stdout(void)          { return stdout; }\r
+static void *app_stderr(void)          { return stderr; }\r
+static int   app_feof(FILE *fp)                { return feof(fp); }\r
+static int   app_ferror(FILE *fp)      { return ferror(fp); }\r
+static void  app_clearerr(FILE *fp)    { clearerr(fp); }\r
+static int   app_fileno(FILE *fp)      { return _fileno(fp); }\r
+static int   app_fsetmod(FILE *fp,char mod)\r
+{ return _setmode (_fileno(fp),mod=='b'?_O_BINARY:_O_TEXT); }\r
+\r
+#ifdef __cplusplus\r
+extern "C" {\r
+#endif\r
+\r
+__declspec(dllexport)\r
+void **\r
+#if defined(__BORLANDC__)\r
+__stdcall      /* __stdcall appears to be the only way to get the name\r
+                * decoration right with Borland C. Otherwise it works\r
+                * purely incidentally, as we pass no parameters. */\r
+#else\r
+__cdecl\r
+#endif\r
+OPENSSL_Applink(void)\r
+{ static int once=1;\r
+  static void *OPENSSL_ApplinkTable[APPLINK_MAX+1]={(void *)APPLINK_MAX};\r
+\r
+    if (once)\r
+    {  OPENSSL_ApplinkTable[APPLINK_STDIN]     = app_stdin;\r
+       OPENSSL_ApplinkTable[APPLINK_STDOUT]    = app_stdout;\r
+       OPENSSL_ApplinkTable[APPLINK_STDERR]    = app_stderr;\r
+       OPENSSL_ApplinkTable[APPLINK_FPRINTF]   = fprintf;\r
+       OPENSSL_ApplinkTable[APPLINK_FGETS]     = fgets;\r
+       OPENSSL_ApplinkTable[APPLINK_FREAD]     = fread;\r
+       OPENSSL_ApplinkTable[APPLINK_FWRITE]    = fwrite;\r
+       OPENSSL_ApplinkTable[APPLINK_FSETMOD]   = app_fsetmod;\r
+       OPENSSL_ApplinkTable[APPLINK_FEOF]      = app_feof;\r
+       OPENSSL_ApplinkTable[APPLINK_FCLOSE]    = fclose;\r
+\r
+       OPENSSL_ApplinkTable[APPLINK_FOPEN]     = fopen;\r
+       OPENSSL_ApplinkTable[APPLINK_FSEEK]     = fseek;\r
+       OPENSSL_ApplinkTable[APPLINK_FTELL]     = ftell;\r
+       OPENSSL_ApplinkTable[APPLINK_FFLUSH]    = fflush;\r
+       OPENSSL_ApplinkTable[APPLINK_FERROR]    = app_ferror;\r
+       OPENSSL_ApplinkTable[APPLINK_CLEARERR]  = app_clearerr;\r
+       OPENSSL_ApplinkTable[APPLINK_FILENO]    = app_fileno;\r
+\r
+       OPENSSL_ApplinkTable[APPLINK_OPEN]      = _open;\r
+       OPENSSL_ApplinkTable[APPLINK_READ]      = _read;\r
+       OPENSSL_ApplinkTable[APPLINK_WRITE]     = _write;\r
+       OPENSSL_ApplinkTable[APPLINK_LSEEK]     = _lseek;\r
+       OPENSSL_ApplinkTable[APPLINK_CLOSE]     = _close;\r
+\r
+       once = 0;\r
+    }\r
+\r
+  return OPENSSL_ApplinkTable;\r
+}\r
+\r
+#ifdef __cplusplus\r
+}\r
+#endif\r
+#endif\r
index 6ab8373..289f1e6 100644 (file)
-/* crypto/asn1/asn1.h */
-/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
- * All rights reserved.
- *
- * This package is an SSL implementation written
- * by Eric Young (eay@cryptsoft.com).
- * The implementation was written so as to conform with Netscapes SSL.
- *
- * This library is free for commercial and non-commercial use as long as
- * the following conditions are aheared to.  The following conditions
- * apply to all code found in this distribution, be it the RC4, RSA,
- * lhash, DES, etc., code; not just the SSL code.  The SSL documentation
- * included with this distribution is covered by the same copyright terms
- * except that the holder is Tim Hudson (tjh@cryptsoft.com).
- *
- * Copyright remains Eric Young's, and as such any Copyright notices in
- * the code are not to be removed.
- * If this package is used in a product, Eric Young should be given attribution
- * as the author of the parts of the library used.
- * This can be in the form of a textual message at program startup or
- * in documentation (online or textual) provided with the package.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the copyright
- *    notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- *    notice, this list of conditions and the following disclaimer in the
- *    documentation and/or other materials provided with the distribution.
- * 3. All advertising materials mentioning features or use of this software
- *    must display the following acknowledgement:
- *    "This product includes cryptographic software written by
- *     Eric Young (eay@cryptsoft.com)"
- *    The word 'cryptographic' can be left out if the rouines from the library
- *    being used are not cryptographic related :-).
- * 4. If you include any Windows specific code (or a derivative thereof) from
- *    the apps directory (application code) you must include an acknowledgement:
- *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
- *
- * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
- * SUCH DAMAGE.
- *
- * The licence and distribution terms for any publically available version or
- * derivative of this code cannot be changed.  i.e. this code cannot simply be
- * copied and put under another distribution licence
- * [including the GNU Public Licence.]
- */
-
-#ifndef HEADER_ASN1_H
-#define HEADER_ASN1_H
-
-#include <time.h>
-#include <openssl/e_os2.h>
-#ifndef OPENSSL_NO_BIO
-#include <openssl/bio.h>
-#endif
-#include <openssl/stack.h>
-#include <openssl/safestack.h>
-
-#include <openssl/symhacks.h>
-
-#include <openssl/ossl_typ.h>
-#ifndef OPENSSL_NO_DEPRECATED
-#include <openssl/bn.h>
-#endif
-
-#ifdef OPENSSL_BUILD_SHLIBCRYPTO
-# undef OPENSSL_EXTERN
-# define OPENSSL_EXTERN OPENSSL_EXPORT
-#endif
-
-#ifdef  __cplusplus
-extern "C" {
-#endif
-
-#define V_ASN1_UNIVERSAL               0x00
-#define        V_ASN1_APPLICATION              0x40
-#define V_ASN1_CONTEXT_SPECIFIC                0x80
-#define V_ASN1_PRIVATE                 0xc0
-
-#define V_ASN1_CONSTRUCTED             0x20
-#define V_ASN1_PRIMITIVE_TAG           0x1f
-#define V_ASN1_PRIMATIVE_TAG           0x1f
-
-#define V_ASN1_APP_CHOOSE              -2      /* let the recipient choose */
-#define V_ASN1_OTHER                   -3      /* used in ASN1_TYPE */
-#define V_ASN1_ANY                     -4      /* used in ASN1 template code */
-
-#define V_ASN1_NEG                     0x100   /* negative flag */
-
-#define V_ASN1_UNDEF                   -1
-#define V_ASN1_EOC                     0
-#define V_ASN1_BOOLEAN                 1       /**/
-#define V_ASN1_INTEGER                 2
-#define V_ASN1_NEG_INTEGER             (2 | V_ASN1_NEG)
-#define V_ASN1_BIT_STRING              3
-#define V_ASN1_OCTET_STRING            4
-#define V_ASN1_NULL                    5
-#define V_ASN1_OBJECT                  6
-#define V_ASN1_OBJECT_DESCRIPTOR       7
-#define V_ASN1_EXTERNAL                        8
-#define V_ASN1_REAL                    9
-#define V_ASN1_ENUMERATED              10
-#define V_ASN1_NEG_ENUMERATED          (10 | V_ASN1_NEG)
-#define V_ASN1_UTF8STRING              12
-#define V_ASN1_SEQUENCE                        16
-#define V_ASN1_SET                     17
-#define V_ASN1_NUMERICSTRING           18      /**/
-#define V_ASN1_PRINTABLESTRING         19
-#define V_ASN1_T61STRING               20
-#define V_ASN1_TELETEXSTRING           20      /* alias */
-#define V_ASN1_VIDEOTEXSTRING          21      /**/
-#define V_ASN1_IA5STRING               22
-#define V_ASN1_UTCTIME                 23
-#define V_ASN1_GENERALIZEDTIME         24      /**/
-#define V_ASN1_GRAPHICSTRING           25      /**/
-#define V_ASN1_ISO64STRING             26      /**/
-#define V_ASN1_VISIBLESTRING           26      /* alias */
-#define V_ASN1_GENERALSTRING           27      /**/
-#define V_ASN1_UNIVERSALSTRING         28      /**/
-#define V_ASN1_BMPSTRING               30
-
-/* For use with d2i_ASN1_type_bytes() */
-#define B_ASN1_NUMERICSTRING   0x0001
-#define B_ASN1_PRINTABLESTRING 0x0002
-#define B_ASN1_T61STRING       0x0004
-#define B_ASN1_TELETEXSTRING   0x0004
-#define B_ASN1_VIDEOTEXSTRING  0x0008
-#define B_ASN1_IA5STRING       0x0010
-#define B_ASN1_GRAPHICSTRING   0x0020
-#define B_ASN1_ISO64STRING     0x0040
-#define B_ASN1_VISIBLESTRING   0x0040
-#define B_ASN1_GENERALSTRING   0x0080
-#define B_ASN1_UNIVERSALSTRING 0x0100
-#define B_ASN1_OCTET_STRING    0x0200
-#define B_ASN1_BIT_STRING      0x0400
-#define B_ASN1_BMPSTRING       0x0800
-#define B_ASN1_UNKNOWN         0x1000
-#define B_ASN1_UTF8STRING      0x2000
-#define B_ASN1_UTCTIME         0x4000
-#define B_ASN1_GENERALIZEDTIME 0x8000
-#define B_ASN1_SEQUENCE                0x10000
-
-/* For use with ASN1_mbstring_copy() */
-#define MBSTRING_FLAG          0x1000
-#define MBSTRING_UTF8          (MBSTRING_FLAG)
-#define MBSTRING_ASC           (MBSTRING_FLAG|1)
-#define MBSTRING_BMP           (MBSTRING_FLAG|2)
-#define MBSTRING_UNIV          (MBSTRING_FLAG|4)
-
-#define SMIME_OLDMIME          0x400
-#define SMIME_CRLFEOL          0x800
-#define SMIME_STREAM           0x1000
-
-struct X509_algor_st;
-DECLARE_STACK_OF(X509_ALGOR)
-
-#define DECLARE_ASN1_SET_OF(type) /* filled in by mkstack.pl */
-#define IMPLEMENT_ASN1_SET_OF(type) /* nothing, no longer needed */
-
-/* We MUST make sure that, except for constness, asn1_ctx_st and
-   asn1_const_ctx are exactly the same.  Fortunately, as soon as
-   the old ASN1 parsing macros are gone, we can throw this away
-   as well... */
-typedef struct asn1_ctx_st
-       {
-       unsigned char *p;/* work char pointer */
-       int eos;        /* end of sequence read for indefinite encoding */
-       int error;      /* error code to use when returning an error */
-       int inf;        /* constructed if 0x20, indefinite is 0x21 */
-       int tag;        /* tag from last 'get object' */
-       int xclass;     /* class from last 'get object' */
-       long slen;      /* length of last 'get object' */
-       unsigned char *max; /* largest value of p allowed */
-       unsigned char *q;/* temporary variable */
-       unsigned char **pp;/* variable */
-       int line;       /* used in error processing */
-       } ASN1_CTX;
-
-typedef struct asn1_const_ctx_st
-       {
-       const unsigned char *p;/* work char pointer */
-       int eos;        /* end of sequence read for indefinite encoding */
-       int error;      /* error code to use when returning an error */
-       int inf;        /* constructed if 0x20, indefinite is 0x21 */
-       int tag;        /* tag from last 'get object' */
-       int xclass;     /* class from last 'get object' */
-       long slen;      /* length of last 'get object' */
-       const unsigned char *max; /* largest value of p allowed */
-       const unsigned char *q;/* temporary variable */
-       const unsigned char **pp;/* variable */
-       int line;       /* used in error processing */
-       } ASN1_const_CTX;
-
-/* These are used internally in the ASN1_OBJECT to keep track of
- * whether the names and data need to be free()ed */
-#define ASN1_OBJECT_FLAG_DYNAMIC        0x01   /* internal use */
-#define ASN1_OBJECT_FLAG_CRITICAL       0x02   /* critical x509v3 object id */
-#define ASN1_OBJECT_FLAG_DYNAMIC_STRINGS 0x04  /* internal use */
-#define ASN1_OBJECT_FLAG_DYNAMIC_DATA   0x08   /* internal use */
-typedef struct asn1_object_st
-       {
-       const char *sn,*ln;
-       int nid;
-       int length;
-       const unsigned char *data;      /* data remains const after init */
-       int flags;      /* Should we free this one */
-       } ASN1_OBJECT;
-
-#define ASN1_STRING_FLAG_BITS_LEFT 0x08 /* Set if 0x07 has bits left value */
-/* This indicates that the ASN1_STRING is not a real value but just a place
- * holder for the location where indefinite length constructed data should
- * be inserted in the memory buffer
- */
-#define ASN1_STRING_FLAG_NDEF 0x010
-
-/* This flag is used by the CMS code to indicate that a string is not
- * complete and is a place holder for content when it had all been
- * accessed. The flag will be reset when content has been written to it.
- */
-
-#define ASN1_STRING_FLAG_CONT 0x020
-/* This flag is used by ASN1 code to indicate an ASN1_STRING is an MSTRING
- * type.
- */
-#define ASN1_STRING_FLAG_MSTRING 0x040
-/* This is the base type that holds just about everything :-) */
-typedef struct asn1_string_st
-       {
-       int length;
-       int type;
-       unsigned char *data;
-       /* The value of the following field depends on the type being
-        * held.  It is mostly being used for BIT_STRING so if the
-        * input data has a non-zero 'unused bits' value, it will be
-        * handled correctly */
-       long flags;
-       } ASN1_STRING;
-
-/* ASN1_ENCODING structure: this is used to save the received
- * encoding of an ASN1 type. This is useful to get round
- * problems with invalid encodings which can break signatures.
- */
-
-typedef struct ASN1_ENCODING_st
-       {
-       unsigned char *enc;     /* DER encoding */
-       long len;               /* Length of encoding */
-       int modified;            /* set to 1 if 'enc' is invalid */
-       } ASN1_ENCODING;
-
-/* Used with ASN1 LONG type: if a long is set to this it is omitted */
-#define ASN1_LONG_UNDEF        0x7fffffffL
-
-#define STABLE_FLAGS_MALLOC    0x01
-#define STABLE_NO_MASK         0x02
-#define DIRSTRING_TYPE \
- (B_ASN1_PRINTABLESTRING|B_ASN1_T61STRING|B_ASN1_BMPSTRING|B_ASN1_UTF8STRING)
-#define PKCS9STRING_TYPE (DIRSTRING_TYPE|B_ASN1_IA5STRING)
-
-typedef struct asn1_string_table_st {
-       int nid;
-       long minsize;
-       long maxsize;
-       unsigned long mask;
-       unsigned long flags;
-} ASN1_STRING_TABLE;
-
-DECLARE_STACK_OF(ASN1_STRING_TABLE)
-
-/* size limits: this stuff is taken straight from RFC2459 */
-
-#define ub_name                                32768
-#define ub_common_name                 64
-#define ub_locality_name               128
-#define ub_state_name                  128
-#define ub_organization_name           64
-#define ub_organization_unit_name      64
-#define ub_title                       64
-#define ub_email_address               128
-
-/* Declarations for template structures: for full definitions
- * see asn1t.h
- */
-typedef struct ASN1_TEMPLATE_st ASN1_TEMPLATE;
-typedef struct ASN1_ITEM_st ASN1_ITEM;
-typedef struct ASN1_TLC_st ASN1_TLC;
-/* This is just an opaque pointer */
-typedef struct ASN1_VALUE_st ASN1_VALUE;
-
-/* Declare ASN1 functions: the implement macro in in asn1t.h */
-
-#define DECLARE_ASN1_FUNCTIONS(type) DECLARE_ASN1_FUNCTIONS_name(type, type)
-
-#define DECLARE_ASN1_ALLOC_FUNCTIONS(type) \
-       DECLARE_ASN1_ALLOC_FUNCTIONS_name(type, type)
-
-#define DECLARE_ASN1_FUNCTIONS_name(type, name) \
-       DECLARE_ASN1_ALLOC_FUNCTIONS_name(type, name) \
-       DECLARE_ASN1_ENCODE_FUNCTIONS(type, name, name)
-
-#define DECLARE_ASN1_FUNCTIONS_fname(type, itname, name) \
-       DECLARE_ASN1_ALLOC_FUNCTIONS_name(type, name) \
-       DECLARE_ASN1_ENCODE_FUNCTIONS(type, itname, name)
-
-#define        DECLARE_ASN1_ENCODE_FUNCTIONS(type, itname, name) \
-       type *d2i_##name(type **a, const unsigned char **in, long len); \
-       int i2d_##name(type *a, unsigned char **out); \
-       DECLARE_ASN1_ITEM(itname)
-
-#define        DECLARE_ASN1_ENCODE_FUNCTIONS_const(type, name) \
-       type *d2i_##name(type **a, const unsigned char **in, long len); \
-       int i2d_##name(const type *a, unsigned char **out); \
-       DECLARE_ASN1_ITEM(name)
-
-#define        DECLARE_ASN1_NDEF_FUNCTION(name) \
-       int i2d_##name##_NDEF(name *a, unsigned char **out);
-
-#define DECLARE_ASN1_FUNCTIONS_const(name) \
-       DECLARE_ASN1_ALLOC_FUNCTIONS(name) \
-       DECLARE_ASN1_ENCODE_FUNCTIONS_const(name, name)
-
-#define DECLARE_ASN1_ALLOC_FUNCTIONS_name(type, name) \
-       type *name##_new(void); \
-       void name##_free(type *a);
-
-#define DECLARE_ASN1_PRINT_FUNCTION(stname) \
-       DECLARE_ASN1_PRINT_FUNCTION_fname(stname, stname)
-
-#define DECLARE_ASN1_PRINT_FUNCTION_fname(stname, fname) \
-       int fname##_print_ctx(BIO *out, stname *x, int indent, \
-                                        const ASN1_PCTX *pctx);
-
-#define D2I_OF(type) type *(*)(type **,const unsigned char **,long)
-#define I2D_OF(type) int (*)(type *,unsigned char **)
-#define I2D_OF_const(type) int (*)(const type *,unsigned char **)
-
-#define CHECKED_D2I_OF(type, d2i) \
-    ((d2i_of_void*) (1 ? d2i : ((D2I_OF(type))0)))
-#define CHECKED_I2D_OF(type, i2d) \
-    ((i2d_of_void*) (1 ? i2d : ((I2D_OF(type))0)))
-#define CHECKED_NEW_OF(type, xnew) \
-    ((void *(*)(void)) (1 ? xnew : ((type *(*)(void))0)))
-#define CHECKED_PTR_OF(type, p) \
-    ((void*) (1 ? p : (type*)0))
-#define CHECKED_PPTR_OF(type, p) \
-    ((void**) (1 ? p : (type**)0))
-
-#define TYPEDEF_D2I_OF(type) typedef type *d2i_of_##type(type **,const unsigned char **,long)
-#define TYPEDEF_I2D_OF(type) typedef int i2d_of_##type(type *,unsigned char **)
-#define TYPEDEF_D2I2D_OF(type) TYPEDEF_D2I_OF(type); TYPEDEF_I2D_OF(type)
-
-TYPEDEF_D2I2D_OF(void);
-
-/* The following macros and typedefs allow an ASN1_ITEM
- * to be embedded in a structure and referenced. Since
- * the ASN1_ITEM pointers need to be globally accessible
- * (possibly from shared libraries) they may exist in
- * different forms. On platforms that support it the
- * ASN1_ITEM structure itself will be globally exported.
- * Other platforms will export a function that returns
- * an ASN1_ITEM pointer.
- *
- * To handle both cases transparently the macros below
- * should be used instead of hard coding an ASN1_ITEM
- * pointer in a structure.
- *
- * The structure will look like this:
- *
- * typedef struct SOMETHING_st {
- *      ...
- *      ASN1_ITEM_EXP *iptr;
- *      ...
- * } SOMETHING;
- *
- * It would be initialised as e.g.:
- *
- * SOMETHING somevar = {...,ASN1_ITEM_ref(X509),...};
- *
- * and the actual pointer extracted with:
- *
- * const ASN1_ITEM *it = ASN1_ITEM_ptr(somevar.iptr);
- *
- * Finally an ASN1_ITEM pointer can be extracted from an
- * appropriate reference with: ASN1_ITEM_rptr(X509). This
- * would be used when a function takes an ASN1_ITEM * argument.
- *
- */
-
-#ifndef OPENSSL_EXPORT_VAR_AS_FUNCTION
-
-/* ASN1_ITEM pointer exported type */
-typedef const ASN1_ITEM ASN1_ITEM_EXP;
-
-/* Macro to obtain ASN1_ITEM pointer from exported type */
-#define ASN1_ITEM_ptr(iptr) (iptr)
-
-/* Macro to include ASN1_ITEM pointer from base type */
-#define ASN1_ITEM_ref(iptr) (&(iptr##_it))
-
-#define ASN1_ITEM_rptr(ref) (&(ref##_it))
-
-#define DECLARE_ASN1_ITEM(name) \
-       OPENSSL_EXTERN const ASN1_ITEM name##_it;
-
-#else
-
-/* Platforms that can't easily handle shared global variables are declared
- * as functions returning ASN1_ITEM pointers.
- */
-
-/* ASN1_ITEM pointer exported type */
-typedef const ASN1_ITEM * ASN1_ITEM_EXP(void);
-
-/* Macro to obtain ASN1_ITEM pointer from exported type */
-#define ASN1_ITEM_ptr(iptr) (iptr())
-
-/* Macro to include ASN1_ITEM pointer from base type */
-#define ASN1_ITEM_ref(iptr) (iptr##_it)
-
-#define ASN1_ITEM_rptr(ref) (ref##_it())
-
-#define DECLARE_ASN1_ITEM(name) \
-       const ASN1_ITEM * name##_it(void);
-
-#endif
-
-/* Parameters used by ASN1_STRING_print_ex() */
-
-/* These determine which characters to escape:
- * RFC2253 special characters, control characters and
- * MSB set characters
- */
-
-#define ASN1_STRFLGS_ESC_2253          1
-#define ASN1_STRFLGS_ESC_CTRL          2
-#define ASN1_STRFLGS_ESC_MSB           4
-
-
-/* This flag determines how we do escaping: normally
- * RC2253 backslash only, set this to use backslash and
- * quote.
- */
-
-#define ASN1_STRFLGS_ESC_QUOTE         8
-
-
-/* These three flags are internal use only. */
-
-/* Character is a valid PrintableString character */
-#define CHARTYPE_PRINTABLESTRING       0x10
-/* Character needs escaping if it is the first character */
-#define CHARTYPE_FIRST_ESC_2253                0x20
-/* Character needs escaping if it is the last character */
-#define CHARTYPE_LAST_ESC_2253         0x40
-
-/* NB the internal flags are safely reused below by flags
- * handled at the top level.
- */
-
-/* If this is set we convert all character strings
- * to UTF8 first
- */
-
-#define ASN1_STRFLGS_UTF8_CONVERT      0x10
-
-/* If this is set we don't attempt to interpret content:
- * just assume all strings are 1 byte per character. This
- * will produce some pretty odd looking output!
- */
-
-#define ASN1_STRFLGS_IGNORE_TYPE       0x20
-
-/* If this is set we include the string type in the output */
-#define ASN1_STRFLGS_SHOW_TYPE         0x40
-
-/* This determines which strings to display and which to
- * 'dump' (hex dump of content octets or DER encoding). We can
- * only dump non character strings or everything. If we
- * don't dump 'unknown' they are interpreted as character
- * strings with 1 octet per character and are subject to
- * the usual escaping options.
- */
-
-#define ASN1_STRFLGS_DUMP_ALL          0x80
-#define ASN1_STRFLGS_DUMP_UNKNOWN      0x100
-
-/* These determine what 'dumping' does, we can dump the
- * content octets or the DER encoding: both use the
- * RFC2253 #XXXXX notation.
- */
-
-#define ASN1_STRFLGS_DUMP_DER          0x200
-
-/* All the string flags consistent with RFC2253,
- * escaping control characters isn't essential in
- * RFC2253 but it is advisable anyway.
- */
-
-#define ASN1_STRFLGS_RFC2253   (ASN1_STRFLGS_ESC_2253 | \
-                               ASN1_STRFLGS_ESC_CTRL | \
-                               ASN1_STRFLGS_ESC_MSB | \
-                               ASN1_STRFLGS_UTF8_CONVERT | \
-                               ASN1_STRFLGS_DUMP_UNKNOWN | \
-                               ASN1_STRFLGS_DUMP_DER)
-
-DECLARE_STACK_OF(ASN1_INTEGER)
-DECLARE_ASN1_SET_OF(ASN1_INTEGER)
-
-DECLARE_STACK_OF(ASN1_GENERALSTRING)
-
-typedef struct asn1_type_st
-       {
-       int type;
-       union   {
-               char *ptr;
-               ASN1_BOOLEAN            boolean;
-               ASN1_STRING *           asn1_string;
-               ASN1_OBJECT *           object;
-               ASN1_INTEGER *          integer;
-               ASN1_ENUMERATED *       enumerated;
-               ASN1_BIT_STRING *       bit_string;
-               ASN1_OCTET_STRING *     octet_string;
-               ASN1_PRINTABLESTRING *  printablestring;
-               ASN1_T61STRING *        t61string;
-               ASN1_IA5STRING *        ia5string;
-               ASN1_GENERALSTRING *    generalstring;
-               ASN1_BMPSTRING *        bmpstring;
-               ASN1_UNIVERSALSTRING *  universalstring;
-               ASN1_UTCTIME *          utctime;
-               ASN1_GENERALIZEDTIME *  generalizedtime;
-               ASN1_VISIBLESTRING *    visiblestring;
-               ASN1_UTF8STRING *       utf8string;
-               /* set and sequence are left complete and still
-                * contain the set or sequence bytes */
-               ASN1_STRING *           set;
-               ASN1_STRING *           sequence;
-               ASN1_VALUE *            asn1_value;
-               } value;
-       } ASN1_TYPE;
-
-DECLARE_STACK_OF(ASN1_TYPE)
-DECLARE_ASN1_SET_OF(ASN1_TYPE)
-
-typedef STACK_OF(ASN1_TYPE) ASN1_SEQUENCE_ANY;
-
-DECLARE_ASN1_ENCODE_FUNCTIONS_const(ASN1_SEQUENCE_ANY, ASN1_SEQUENCE_ANY)
-DECLARE_ASN1_ENCODE_FUNCTIONS_const(ASN1_SEQUENCE_ANY, ASN1_SET_ANY)
-
-typedef struct NETSCAPE_X509_st
-       {
-       ASN1_OCTET_STRING *header;
-       X509 *cert;
-       } NETSCAPE_X509;
-
-/* This is used to contain a list of bit names */
-typedef struct BIT_STRING_BITNAME_st {
-       int bitnum;
-       const char *lname;
-       const char *sname;
-} BIT_STRING_BITNAME;
-
-
-#define M_ASN1_STRING_length(x)        ((x)->length)
-#define M_ASN1_STRING_length_set(x, n) ((x)->length = (n))
-#define M_ASN1_STRING_type(x)  ((x)->type)
-#define M_ASN1_STRING_data(x)  ((x)->data)
-
-/* Macros for string operations */
-#define M_ASN1_BIT_STRING_new()        (ASN1_BIT_STRING *)\
-               ASN1_STRING_type_new(V_ASN1_BIT_STRING)
-#define M_ASN1_BIT_STRING_free(a)      ASN1_STRING_free((ASN1_STRING *)a)
-#define M_ASN1_BIT_STRING_dup(a) (ASN1_BIT_STRING *)\
-               ASN1_STRING_dup((const ASN1_STRING *)a)
-#define M_ASN1_BIT_STRING_cmp(a,b) ASN1_STRING_cmp(\
-               (const ASN1_STRING *)a,(const ASN1_STRING *)b)
-#define M_ASN1_BIT_STRING_set(a,b,c) ASN1_STRING_set((ASN1_STRING *)a,b,c)
-
-#define M_ASN1_INTEGER_new()   (ASN1_INTEGER *)\
-               ASN1_STRING_type_new(V_ASN1_INTEGER)
-#define M_ASN1_INTEGER_free(a)         ASN1_STRING_free((ASN1_STRING *)a)
-#define M_ASN1_INTEGER_dup(a) (ASN1_INTEGER *)\
-               ASN1_STRING_dup((const ASN1_STRING *)a)
-#define M_ASN1_INTEGER_cmp(a,b)        ASN1_STRING_cmp(\
-               (const ASN1_STRING *)a,(const ASN1_STRING *)b)
-
-#define M_ASN1_ENUMERATED_new()        (ASN1_ENUMERATED *)\
-               ASN1_STRING_type_new(V_ASN1_ENUMERATED)
-#define M_ASN1_ENUMERATED_free(a)      ASN1_STRING_free((ASN1_STRING *)a)
-#define M_ASN1_ENUMERATED_dup(a) (ASN1_ENUMERATED *)\
-               ASN1_STRING_dup((const ASN1_STRING *)a)
-#define M_ASN1_ENUMERATED_cmp(a,b)     ASN1_STRING_cmp(\
-               (const ASN1_STRING *)a,(const ASN1_STRING *)b)
-
-#define M_ASN1_OCTET_STRING_new()      (ASN1_OCTET_STRING *)\
-               ASN1_STRING_type_new(V_ASN1_OCTET_STRING)
-#define M_ASN1_OCTET_STRING_free(a)    ASN1_STRING_free((ASN1_STRING *)a)
-#define M_ASN1_OCTET_STRING_dup(a) (ASN1_OCTET_STRING *)\
-               ASN1_STRING_dup((const ASN1_STRING *)a)
-#define M_ASN1_OCTET_STRING_cmp(a,b) ASN1_STRING_cmp(\
-               (const ASN1_STRING *)a,(const ASN1_STRING *)b)
-#define M_ASN1_OCTET_STRING_set(a,b,c) ASN1_STRING_set((ASN1_STRING *)a,b,c)
-#define M_ASN1_OCTET_STRING_print(a,b) ASN1_STRING_print(a,(ASN1_STRING *)b)
-#define M_i2d_ASN1_OCTET_STRING(a,pp) \
-               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_OCTET_STRING,\
-               V_ASN1_UNIVERSAL)
-
-#define B_ASN1_TIME \
-                       B_ASN1_UTCTIME | \
-                       B_ASN1_GENERALIZEDTIME
-
-#define B_ASN1_PRINTABLE \
-                       B_ASN1_NUMERICSTRING| \
-                       B_ASN1_PRINTABLESTRING| \
-                       B_ASN1_T61STRING| \
-                       B_ASN1_IA5STRING| \
-                       B_ASN1_BIT_STRING| \
-                       B_ASN1_UNIVERSALSTRING|\
-                       B_ASN1_BMPSTRING|\
-                       B_ASN1_UTF8STRING|\
-                       B_ASN1_SEQUENCE|\
-                       B_ASN1_UNKNOWN
-
-#define B_ASN1_DIRECTORYSTRING \
-                       B_ASN1_PRINTABLESTRING| \
-                       B_ASN1_TELETEXSTRING|\
-                       B_ASN1_BMPSTRING|\
-                       B_ASN1_UNIVERSALSTRING|\
-                       B_ASN1_UTF8STRING
-
-#define B_ASN1_DISPLAYTEXT \
-                       B_ASN1_IA5STRING| \
-                       B_ASN1_VISIBLESTRING| \
-                       B_ASN1_BMPSTRING|\
-                       B_ASN1_UTF8STRING
-
-#define M_ASN1_PRINTABLE_new() ASN1_STRING_type_new(V_ASN1_T61STRING)
-#define M_ASN1_PRINTABLE_free(a)       ASN1_STRING_free((ASN1_STRING *)a)
-#define M_i2d_ASN1_PRINTABLE(a,pp) i2d_ASN1_bytes((ASN1_STRING *)a,\
-               pp,a->type,V_ASN1_UNIVERSAL)
-#define M_d2i_ASN1_PRINTABLE(a,pp,l) \
-               d2i_ASN1_type_bytes((ASN1_STRING **)a,pp,l, \
-                       B_ASN1_PRINTABLE)
-
-#define M_DIRECTORYSTRING_new() ASN1_STRING_type_new(V_ASN1_PRINTABLESTRING)
-#define M_DIRECTORYSTRING_free(a)      ASN1_STRING_free((ASN1_STRING *)a)
-#define M_i2d_DIRECTORYSTRING(a,pp) i2d_ASN1_bytes((ASN1_STRING *)a,\
-                                               pp,a->type,V_ASN1_UNIVERSAL)
-#define M_d2i_DIRECTORYSTRING(a,pp,l) \
-               d2i_ASN1_type_bytes((ASN1_STRING **)a,pp,l, \
-                       B_ASN1_DIRECTORYSTRING)
-
-#define M_DISPLAYTEXT_new() ASN1_STRING_type_new(V_ASN1_VISIBLESTRING)
-#define M_DISPLAYTEXT_free(a) ASN1_STRING_free((ASN1_STRING *)a)
-#define M_i2d_DISPLAYTEXT(a,pp) i2d_ASN1_bytes((ASN1_STRING *)a,\
-                                               pp,a->type,V_ASN1_UNIVERSAL)
-#define M_d2i_DISPLAYTEXT(a,pp,l) \
-               d2i_ASN1_type_bytes((ASN1_STRING **)a,pp,l, \
-                       B_ASN1_DISPLAYTEXT)
-
-#define M_ASN1_PRINTABLESTRING_new() (ASN1_PRINTABLESTRING *)\
-               ASN1_STRING_type_new(V_ASN1_PRINTABLESTRING)
-#define M_ASN1_PRINTABLESTRING_free(a) ASN1_STRING_free((ASN1_STRING *)a)
-#define M_i2d_ASN1_PRINTABLESTRING(a,pp) \
-               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_PRINTABLESTRING,\
-               V_ASN1_UNIVERSAL)
-#define M_d2i_ASN1_PRINTABLESTRING(a,pp,l) \
-               (ASN1_PRINTABLESTRING *)d2i_ASN1_type_bytes\
-               ((ASN1_STRING **)a,pp,l,B_ASN1_PRINTABLESTRING)
-
-#define M_ASN1_T61STRING_new() (ASN1_T61STRING *)\
-               ASN1_STRING_type_new(V_ASN1_T61STRING)
-#define M_ASN1_T61STRING_free(a)       ASN1_STRING_free((ASN1_STRING *)a)
-#define M_i2d_ASN1_T61STRING(a,pp) \
-               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_T61STRING,\
-               V_ASN1_UNIVERSAL)
-#define M_d2i_ASN1_T61STRING(a,pp,l) \
-               (ASN1_T61STRING *)d2i_ASN1_type_bytes\
-               ((ASN1_STRING **)a,pp,l,B_ASN1_T61STRING)
-
-#define M_ASN1_IA5STRING_new() (ASN1_IA5STRING *)\
-               ASN1_STRING_type_new(V_ASN1_IA5STRING)
-#define M_ASN1_IA5STRING_free(a)       ASN1_STRING_free((ASN1_STRING *)a)
-#define M_ASN1_IA5STRING_dup(a)        \
-               (ASN1_IA5STRING *)ASN1_STRING_dup((const ASN1_STRING *)a)
-#define M_i2d_ASN1_IA5STRING(a,pp) \
-               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_IA5STRING,\
-                       V_ASN1_UNIVERSAL)
-#define M_d2i_ASN1_IA5STRING(a,pp,l) \
-               (ASN1_IA5STRING *)d2i_ASN1_type_bytes((ASN1_STRING **)a,pp,l,\
-                       B_ASN1_IA5STRING)
-
-#define M_ASN1_UTCTIME_new()   (ASN1_UTCTIME *)\
-               ASN1_STRING_type_new(V_ASN1_UTCTIME)
-#define M_ASN1_UTCTIME_free(a) ASN1_STRING_free((ASN1_STRING *)a)
-#define M_ASN1_UTCTIME_dup(a) (ASN1_UTCTIME *)\
-               ASN1_STRING_dup((const ASN1_STRING *)a)
-
-#define M_ASN1_GENERALIZEDTIME_new()   (ASN1_GENERALIZEDTIME *)\
-               ASN1_STRING_type_new(V_ASN1_GENERALIZEDTIME)
-#define M_ASN1_GENERALIZEDTIME_free(a) ASN1_STRING_free((ASN1_STRING *)a)
-#define M_ASN1_GENERALIZEDTIME_dup(a) (ASN1_GENERALIZEDTIME *)ASN1_STRING_dup(\
-       (const ASN1_STRING *)a)
-
-#define M_ASN1_TIME_new()      (ASN1_TIME *)\
-               ASN1_STRING_type_new(V_ASN1_UTCTIME)
-#define M_ASN1_TIME_free(a)    ASN1_STRING_free((ASN1_STRING *)a)
-#define M_ASN1_TIME_dup(a) (ASN1_TIME *)\
-       ASN1_STRING_dup((const ASN1_STRING *)a)
-
-#define M_ASN1_GENERALSTRING_new()     (ASN1_GENERALSTRING *)\
-               ASN1_STRING_type_new(V_ASN1_GENERALSTRING)
-#define M_ASN1_GENERALSTRING_free(a)   ASN1_STRING_free((ASN1_STRING *)a)
-#define M_i2d_ASN1_GENERALSTRING(a,pp) \
-               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_GENERALSTRING,\
-                       V_ASN1_UNIVERSAL)
-#define M_d2i_ASN1_GENERALSTRING(a,pp,l) \
-               (ASN1_GENERALSTRING *)d2i_ASN1_type_bytes\
-               ((ASN1_STRING **)a,pp,l,B_ASN1_GENERALSTRING)
-
-#define M_ASN1_UNIVERSALSTRING_new()   (ASN1_UNIVERSALSTRING *)\
-               ASN1_STRING_type_new(V_ASN1_UNIVERSALSTRING)
-#define M_ASN1_UNIVERSALSTRING_free(a) ASN1_STRING_free((ASN1_STRING *)a)
-#define M_i2d_ASN1_UNIVERSALSTRING(a,pp) \
-               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_UNIVERSALSTRING,\
-                       V_ASN1_UNIVERSAL)
-#define M_d2i_ASN1_UNIVERSALSTRING(a,pp,l) \
-               (ASN1_UNIVERSALSTRING *)d2i_ASN1_type_bytes\
-               ((ASN1_STRING **)a,pp,l,B_ASN1_UNIVERSALSTRING)
-
-#define M_ASN1_BMPSTRING_new() (ASN1_BMPSTRING *)\
-               ASN1_STRING_type_new(V_ASN1_BMPSTRING)
-#define M_ASN1_BMPSTRING_free(a)       ASN1_STRING_free((ASN1_STRING *)a)
-#define M_i2d_ASN1_BMPSTRING(a,pp) \
-               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_BMPSTRING,\
-                       V_ASN1_UNIVERSAL)
-#define M_d2i_ASN1_BMPSTRING(a,pp,l) \
-               (ASN1_BMPSTRING *)d2i_ASN1_type_bytes\
-               ((ASN1_STRING **)a,pp,l,B_ASN1_BMPSTRING)
-
-#define M_ASN1_VISIBLESTRING_new()     (ASN1_VISIBLESTRING *)\
-               ASN1_STRING_type_new(V_ASN1_VISIBLESTRING)
-#define M_ASN1_VISIBLESTRING_free(a)   ASN1_STRING_free((ASN1_STRING *)a)
-#define M_i2d_ASN1_VISIBLESTRING(a,pp) \
-               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_VISIBLESTRING,\
-                       V_ASN1_UNIVERSAL)
-#define M_d2i_ASN1_VISIBLESTRING(a,pp,l) \
-               (ASN1_VISIBLESTRING *)d2i_ASN1_type_bytes\
-               ((ASN1_STRING **)a,pp,l,B_ASN1_VISIBLESTRING)
-
-#define M_ASN1_UTF8STRING_new()        (ASN1_UTF8STRING *)\
-               ASN1_STRING_type_new(V_ASN1_UTF8STRING)
-#define M_ASN1_UTF8STRING_free(a)      ASN1_STRING_free((ASN1_STRING *)a)
-#define M_i2d_ASN1_UTF8STRING(a,pp) \
-               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_UTF8STRING,\
-                       V_ASN1_UNIVERSAL)
-#define M_d2i_ASN1_UTF8STRING(a,pp,l) \
-               (ASN1_UTF8STRING *)d2i_ASN1_type_bytes\
-               ((ASN1_STRING **)a,pp,l,B_ASN1_UTF8STRING)
-
-  /* for the is_set parameter to i2d_ASN1_SET */
-#define IS_SEQUENCE    0
-#define IS_SET         1
-
-DECLARE_ASN1_FUNCTIONS_fname(ASN1_TYPE, ASN1_ANY, ASN1_TYPE)
-
-int ASN1_TYPE_get(ASN1_TYPE *a);
-void ASN1_TYPE_set(ASN1_TYPE *a, int type, void *value);
-int ASN1_TYPE_set1(ASN1_TYPE *a, int type, const void *value);
-int            ASN1_TYPE_cmp(ASN1_TYPE *a, ASN1_TYPE *b);
-
-ASN1_OBJECT *  ASN1_OBJECT_new(void );
-void           ASN1_OBJECT_free(ASN1_OBJECT *a);
-int            i2d_ASN1_OBJECT(ASN1_OBJECT *a,unsigned char **pp);
-ASN1_OBJECT *  c2i_ASN1_OBJECT(ASN1_OBJECT **a,const unsigned char **pp,
-                       long length);
-ASN1_OBJECT *  d2i_ASN1_OBJECT(ASN1_OBJECT **a,const unsigned char **pp,
-                       long length);
-
-DECLARE_ASN1_ITEM(ASN1_OBJECT)
-
-DECLARE_STACK_OF(ASN1_OBJECT)
-DECLARE_ASN1_SET_OF(ASN1_OBJECT)
-
-ASN1_STRING *  ASN1_STRING_new(void);
-void           ASN1_STRING_free(ASN1_STRING *a);
-int            ASN1_STRING_copy(ASN1_STRING *dst, const ASN1_STRING *str);
-ASN1_STRING *  ASN1_STRING_dup(const ASN1_STRING *a);
-ASN1_STRING *  ASN1_STRING_type_new(int type );
-int            ASN1_STRING_cmp(const ASN1_STRING *a, const ASN1_STRING *b);
-  /* Since this is used to store all sorts of things, via macros, for now, make
-     its data void * */
-int            ASN1_STRING_set(ASN1_STRING *str, const void *data, int len);
-void           ASN1_STRING_set0(ASN1_STRING *str, void *data, int len);
-int ASN1_STRING_length(const ASN1_STRING *x);
-void ASN1_STRING_length_set(ASN1_STRING *x, int n);
-int ASN1_STRING_type(ASN1_STRING *x);
-unsigned char * ASN1_STRING_data(ASN1_STRING *x);
-
-DECLARE_ASN1_FUNCTIONS(ASN1_BIT_STRING)
-int            i2c_ASN1_BIT_STRING(ASN1_BIT_STRING *a,unsigned char **pp);
-ASN1_BIT_STRING *c2i_ASN1_BIT_STRING(ASN1_BIT_STRING **a,const unsigned char **pp,
-                       long length);
-int            ASN1_BIT_STRING_set(ASN1_BIT_STRING *a, unsigned char *d,
-                       int length );
-int            ASN1_BIT_STRING_set_bit(ASN1_BIT_STRING *a, int n, int value);
-int            ASN1_BIT_STRING_get_bit(ASN1_BIT_STRING *a, int n);
-int            ASN1_BIT_STRING_check(ASN1_BIT_STRING *a,
-                                     unsigned char *flags, int flags_len);
-
-#ifndef OPENSSL_NO_BIO
-int ASN1_BIT_STRING_name_print(BIO *out, ASN1_BIT_STRING *bs,
-                               BIT_STRING_BITNAME *tbl, int indent);
-#endif
-int ASN1_BIT_STRING_num_asc(char *name, BIT_STRING_BITNAME *tbl);
-int ASN1_BIT_STRING_set_asc(ASN1_BIT_STRING *bs, char *name, int value,
-                               BIT_STRING_BITNAME *tbl);
-
-int            i2d_ASN1_BOOLEAN(int a,unsigned char **pp);
-int            d2i_ASN1_BOOLEAN(int *a,const unsigned char **pp,long length);
-
-DECLARE_ASN1_FUNCTIONS(ASN1_INTEGER)
-int            i2c_ASN1_INTEGER(ASN1_INTEGER *a,unsigned char **pp);
-ASN1_INTEGER *c2i_ASN1_INTEGER(ASN1_INTEGER **a,const unsigned char **pp,
-                       long length);
-ASN1_INTEGER *d2i_ASN1_UINTEGER(ASN1_INTEGER **a,const unsigned char **pp,
-                       long length);
-ASN1_INTEGER * ASN1_INTEGER_dup(const ASN1_INTEGER *x);
-int ASN1_INTEGER_cmp(const ASN1_INTEGER *x, const ASN1_INTEGER *y);
-
-DECLARE_ASN1_FUNCTIONS(ASN1_ENUMERATED)
-
-int ASN1_UTCTIME_check(ASN1_UTCTIME *a);
-ASN1_UTCTIME *ASN1_UTCTIME_set(ASN1_UTCTIME *s,time_t t);
-ASN1_UTCTIME *ASN1_UTCTIME_adj(ASN1_UTCTIME *s, time_t t,
-                               int offset_day, long offset_sec);
-int ASN1_UTCTIME_set_string(ASN1_UTCTIME *s, const char *str);
-int ASN1_UTCTIME_cmp_time_t(const ASN1_UTCTIME *s, time_t t);
-#if 0
-time_t ASN1_UTCTIME_get(const ASN1_UTCTIME *s);
-#endif
-
-int ASN1_GENERALIZEDTIME_check(ASN1_GENERALIZEDTIME *a);
-ASN1_GENERALIZEDTIME *ASN1_GENERALIZEDTIME_set(ASN1_GENERALIZEDTIME *s,time_t t);
-ASN1_GENERALIZEDTIME *ASN1_GENERALIZEDTIME_adj(ASN1_GENERALIZEDTIME *s,
-            time_t t, int offset_day, long offset_sec);
-int ASN1_GENERALIZEDTIME_set_string(ASN1_GENERALIZEDTIME *s, const char *str);
-
-DECLARE_ASN1_FUNCTIONS(ASN1_OCTET_STRING)
-ASN1_OCTET_STRING *    ASN1_OCTET_STRING_dup(const ASN1_OCTET_STRING *a);
-int    ASN1_OCTET_STRING_cmp(const ASN1_OCTET_STRING *a, const ASN1_OCTET_STRING *b);
-int    ASN1_OCTET_STRING_set(ASN1_OCTET_STRING *str, const unsigned char *data, int len);
-
-DECLARE_ASN1_FUNCTIONS(ASN1_VISIBLESTRING)
-DECLARE_ASN1_FUNCTIONS(ASN1_UNIVERSALSTRING)
-DECLARE_ASN1_FUNCTIONS(ASN1_UTF8STRING)
-DECLARE_ASN1_FUNCTIONS(ASN1_NULL)
-DECLARE_ASN1_FUNCTIONS(ASN1_BMPSTRING)
-
-int UTF8_getc(const unsigned char *str, int len, unsigned long *val);
-int UTF8_putc(unsigned char *str, int len, unsigned long value);
-
-DECLARE_ASN1_FUNCTIONS_name(ASN1_STRING, ASN1_PRINTABLE)
-
-DECLARE_ASN1_FUNCTIONS_name(ASN1_STRING, DIRECTORYSTRING)
-DECLARE_ASN1_FUNCTIONS_name(ASN1_STRING, DISPLAYTEXT)
-DECLARE_ASN1_FUNCTIONS(ASN1_PRINTABLESTRING)
-DECLARE_ASN1_FUNCTIONS(ASN1_T61STRING)
-DECLARE_ASN1_FUNCTIONS(ASN1_IA5STRING)
-DECLARE_ASN1_FUNCTIONS(ASN1_GENERALSTRING)
-DECLARE_ASN1_FUNCTIONS(ASN1_UTCTIME)
-DECLARE_ASN1_FUNCTIONS(ASN1_GENERALIZEDTIME)
-DECLARE_ASN1_FUNCTIONS(ASN1_TIME)
-
-DECLARE_ASN1_ITEM(ASN1_OCTET_STRING_NDEF)
-
-ASN1_TIME *ASN1_TIME_set(ASN1_TIME *s,time_t t);
-ASN1_TIME *ASN1_TIME_adj(ASN1_TIME *s,time_t t,
-                               int offset_day, long offset_sec);
-int ASN1_TIME_check(ASN1_TIME *t);
-ASN1_GENERALIZEDTIME *ASN1_TIME_to_generalizedtime(ASN1_TIME *t, ASN1_GENERALIZEDTIME **out);
-int ASN1_TIME_set_string(ASN1_TIME *s, const char *str);
-
-int i2d_ASN1_SET(STACK_OF(OPENSSL_BLOCK) *a, unsigned char **pp,
-                i2d_of_void *i2d, int ex_tag, int ex_class,
-                int is_set);
-STACK_OF(OPENSSL_BLOCK) *d2i_ASN1_SET(STACK_OF(OPENSSL_BLOCK) **a,
-                             const unsigned char **pp,
-                             long length, d2i_of_void *d2i,
-                             void (*free_func)(OPENSSL_BLOCK), int ex_tag,
-                             int ex_class);
-
-#ifndef OPENSSL_NO_BIO
-int i2a_ASN1_INTEGER(BIO *bp, ASN1_INTEGER *a);
-int a2i_ASN1_INTEGER(BIO *bp,ASN1_INTEGER *bs,char *buf,int size);
-int i2a_ASN1_ENUMERATED(BIO *bp, ASN1_ENUMERATED *a);
-int a2i_ASN1_ENUMERATED(BIO *bp,ASN1_ENUMERATED *bs,char *buf,int size);
-int i2a_ASN1_OBJECT(BIO *bp,ASN1_OBJECT *a);
-int a2i_ASN1_STRING(BIO *bp,ASN1_STRING *bs,char *buf,int size);
-int i2a_ASN1_STRING(BIO *bp, ASN1_STRING *a, int type);
-#endif
-int i2t_ASN1_OBJECT(char *buf,int buf_len,ASN1_OBJECT *a);
-
-int a2d_ASN1_OBJECT(unsigned char *out,int olen, const char *buf, int num);
-ASN1_OBJECT *ASN1_OBJECT_create(int nid, unsigned char *data,int len,
-       const char *sn, const char *ln);
-
-int ASN1_INTEGER_set(ASN1_INTEGER *a, long v);
-long ASN1_INTEGER_get(const ASN1_INTEGER *a);
-ASN1_INTEGER *BN_to_ASN1_INTEGER(const BIGNUM *bn, ASN1_INTEGER *ai);
-BIGNUM *ASN1_INTEGER_to_BN(const ASN1_INTEGER *ai,BIGNUM *bn);
-
-int ASN1_ENUMERATED_set(ASN1_ENUMERATED *a, long v);
-long ASN1_ENUMERATED_get(ASN1_ENUMERATED *a);
-ASN1_ENUMERATED *BN_to_ASN1_ENUMERATED(BIGNUM *bn, ASN1_ENUMERATED *ai);
-BIGNUM *ASN1_ENUMERATED_to_BN(ASN1_ENUMERATED *ai,BIGNUM *bn);
-
-/* General */
-/* given a string, return the correct type, max is the maximum length */
-int ASN1_PRINTABLE_type(const unsigned char *s, int max);
-
-int i2d_ASN1_bytes(ASN1_STRING *a, unsigned char **pp, int tag, int xclass);
-ASN1_STRING *d2i_ASN1_bytes(ASN1_STRING **a, const unsigned char **pp,
-       long length, int Ptag, int Pclass);
-unsigned long ASN1_tag2bit(int tag);
-/* type is one or more of the B_ASN1_ values. */
-ASN1_STRING *d2i_ASN1_type_bytes(ASN1_STRING **a,const unsigned char **pp,
-               long length,int type);
-
-/* PARSING */
-int asn1_Finish(ASN1_CTX *c);
-int asn1_const_Finish(ASN1_const_CTX *c);
-
-/* SPECIALS */
-int ASN1_get_object(const unsigned char **pp, long *plength, int *ptag,
-       int *pclass, long omax);
-int ASN1_check_infinite_end(unsigned char **p,long len);
-int ASN1_const_check_infinite_end(const unsigned char **p,long len);
-void ASN1_put_object(unsigned char **pp, int constructed, int length,
-       int tag, int xclass);
-int ASN1_put_eoc(unsigned char **pp);
-int ASN1_object_size(int constructed, int length, int tag);
-
-/* Used to implement other functions */
-void *ASN1_dup(i2d_of_void *i2d, d2i_of_void *d2i, void *x);
-
-#define ASN1_dup_of(type,i2d,d2i,x) \
-    ((type*)ASN1_dup(CHECKED_I2D_OF(type, i2d), \
-                    CHECKED_D2I_OF(type, d2i), \
-                    CHECKED_PTR_OF(type, x)))
-
-#define ASN1_dup_of_const(type,i2d,d2i,x) \
-    ((type*)ASN1_dup(CHECKED_I2D_OF(const type, i2d), \
-                    CHECKED_D2I_OF(type, d2i), \
-                    CHECKED_PTR_OF(const type, x)))
-
-void *ASN1_item_dup(const ASN1_ITEM *it, void *x);
-
-/* ASN1 alloc/free macros for when a type is only used internally */
-
-#define M_ASN1_new_of(type) (type *)ASN1_item_new(ASN1_ITEM_rptr(type))
-#define M_ASN1_free_of(x, type) \
-               ASN1_item_free(CHECKED_PTR_OF(type, x), ASN1_ITEM_rptr(type))
-
-#ifndef OPENSSL_NO_FP_API
-void *ASN1_d2i_fp(void *(*xnew)(void), d2i_of_void *d2i, FILE *in, void **x);
-
-#define ASN1_d2i_fp_of(type,xnew,d2i,in,x) \
-    ((type*)ASN1_d2i_fp(CHECKED_NEW_OF(type, xnew), \
-                       CHECKED_D2I_OF(type, d2i), \
-                       in, \
-                       CHECKED_PPTR_OF(type, x)))
-
-void *ASN1_item_d2i_fp(const ASN1_ITEM *it, FILE *in, void *x);
-int ASN1_i2d_fp(i2d_of_void *i2d,FILE *out,void *x);
-
-#define ASN1_i2d_fp_of(type,i2d,out,x) \
-    (ASN1_i2d_fp(CHECKED_I2D_OF(type, i2d), \
-                out, \
-                CHECKED_PTR_OF(type, x)))
-
-#define ASN1_i2d_fp_of_const(type,i2d,out,x) \
-    (ASN1_i2d_fp(CHECKED_I2D_OF(const type, i2d), \
-                out, \
-                CHECKED_PTR_OF(const type, x)))
-
-int ASN1_item_i2d_fp(const ASN1_ITEM *it, FILE *out, void *x);
-int ASN1_STRING_print_ex_fp(FILE *fp, ASN1_STRING *str, unsigned long flags);
-#endif
-
-int ASN1_STRING_to_UTF8(unsigned char **out, ASN1_STRING *in);
-
-#ifndef OPENSSL_NO_BIO
-void *ASN1_d2i_bio(void *(*xnew)(void), d2i_of_void *d2i, BIO *in, void **x);
-
-#define ASN1_d2i_bio_of(type,xnew,d2i,in,x) \
-    ((type*)ASN1_d2i_bio( CHECKED_NEW_OF(type, xnew), \
-                         CHECKED_D2I_OF(type, d2i), \
-                         in, \
-                         CHECKED_PPTR_OF(type, x)))
-
-void *ASN1_item_d2i_bio(const ASN1_ITEM *it, BIO *in, void *x);
-int ASN1_i2d_bio(i2d_of_void *i2d,BIO *out, unsigned char *x);
-
-#define ASN1_i2d_bio_of(type,i2d,out,x) \
-    (ASN1_i2d_bio(CHECKED_I2D_OF(type, i2d), \
-                 out, \
-                 CHECKED_PTR_OF(type, x)))
-
-#define ASN1_i2d_bio_of_const(type,i2d,out,x) \
-    (ASN1_i2d_bio(CHECKED_I2D_OF(const type, i2d), \
-                 out, \
-                 CHECKED_PTR_OF(const type, x)))
-
-int ASN1_item_i2d_bio(const ASN1_ITEM *it, BIO *out, void *x);
-int ASN1_UTCTIME_print(BIO *fp, const ASN1_UTCTIME *a);
-int ASN1_GENERALIZEDTIME_print(BIO *fp, const ASN1_GENERALIZEDTIME *a);
-int ASN1_TIME_print(BIO *fp, const ASN1_TIME *a);
-int ASN1_STRING_print(BIO *bp, const ASN1_STRING *v);
-int ASN1_STRING_print_ex(BIO *out, ASN1_STRING *str, unsigned long flags);
-int ASN1_bn_print(BIO *bp, const char *number, const BIGNUM *num,
-                               unsigned char *buf, int off);
-int ASN1_parse(BIO *bp,const unsigned char *pp,long len,int indent);
-int ASN1_parse_dump(BIO *bp,const unsigned char *pp,long len,int indent,int dump);
-#endif
-const char *ASN1_tag2str(int tag);
-
-/* Used to load and write netscape format cert */
-
-DECLARE_ASN1_FUNCTIONS(NETSCAPE_X509)
-
-int ASN1_UNIVERSALSTRING_to_string(ASN1_UNIVERSALSTRING *s);
-
-int ASN1_TYPE_set_octetstring(ASN1_TYPE *a,
-       unsigned char *data, int len);
-int ASN1_TYPE_get_octetstring(ASN1_TYPE *a,
-       unsigned char *data, int max_len);
-int ASN1_TYPE_set_int_octetstring(ASN1_TYPE *a, long num,
-       unsigned char *data, int len);
-int ASN1_TYPE_get_int_octetstring(ASN1_TYPE *a,long *num,
-       unsigned char *data, int max_len);
-
-STACK_OF(OPENSSL_BLOCK) *ASN1_seq_unpack(const unsigned char *buf, int len,
-                                d2i_of_void *d2i, void (*free_func)(OPENSSL_BLOCK));
-unsigned char *ASN1_seq_pack(STACK_OF(OPENSSL_BLOCK) *safes, i2d_of_void *i2d,
-                            unsigned char **buf, int *len );
-void *ASN1_unpack_string(ASN1_STRING *oct, d2i_of_void *d2i);
-void *ASN1_item_unpack(ASN1_STRING *oct, const ASN1_ITEM *it);
-ASN1_STRING *ASN1_pack_string(void *obj, i2d_of_void *i2d,
-                             ASN1_OCTET_STRING **oct);
-
-#define ASN1_pack_string_of(type,obj,i2d,oct) \
-    (ASN1_pack_string(CHECKED_PTR_OF(type, obj), \
-                     CHECKED_I2D_OF(type, i2d), \
-                     oct))
-
-ASN1_STRING *ASN1_item_pack(void *obj, const ASN1_ITEM *it, ASN1_OCTET_STRING **oct);
-
-void ASN1_STRING_set_default_mask(unsigned long mask);
-int ASN1_STRING_set_default_mask_asc(const char *p);
-unsigned long ASN1_STRING_get_default_mask(void);
-int ASN1_mbstring_copy(ASN1_STRING **out, const unsigned char *in, int len,
-                                       int inform, unsigned long mask);
-int ASN1_mbstring_ncopy(ASN1_STRING **out, const unsigned char *in, int len,
-                                       int inform, unsigned long mask,
-                                       long minsize, long maxsize);
-
-ASN1_STRING *ASN1_STRING_set_by_NID(ASN1_STRING **out,
-               const unsigned char *in, int inlen, int inform, int nid);
-ASN1_STRING_TABLE *ASN1_STRING_TABLE_get(int nid);
-int ASN1_STRING_TABLE_add(int, long, long, unsigned long, unsigned long);
-void ASN1_STRING_TABLE_cleanup(void);
-
-/* ASN1 template functions */
-
-/* Old API compatible functions */
-ASN1_VALUE *ASN1_item_new(const ASN1_ITEM *it);
-void ASN1_item_free(ASN1_VALUE *val, const ASN1_ITEM *it);
-ASN1_VALUE * ASN1_item_d2i(ASN1_VALUE **val, const unsigned char **in, long len, const ASN1_ITEM *it);
-int ASN1_item_i2d(ASN1_VALUE *val, unsigned char **out, const ASN1_ITEM *it);
-int ASN1_item_ndef_i2d(ASN1_VALUE *val, unsigned char **out, const ASN1_ITEM *it);
-
-void ASN1_add_oid_module(void);
-
-ASN1_TYPE *ASN1_generate_nconf(char *str, CONF *nconf);
-ASN1_TYPE *ASN1_generate_v3(char *str, X509V3_CTX *cnf);
-
-/* ASN1 Print flags */
-
-/* Indicate missing OPTIONAL fields */
-#define ASN1_PCTX_FLAGS_SHOW_ABSENT            0x001
-/* Mark start and end of SEQUENCE */
-#define ASN1_PCTX_FLAGS_SHOW_SEQUENCE          0x002
-/* Mark start and end of SEQUENCE/SET OF */
-#define ASN1_PCTX_FLAGS_SHOW_SSOF              0x004
-/* Show the ASN1 type of primitives */
-#define ASN1_PCTX_FLAGS_SHOW_TYPE              0x008
-/* Don't show ASN1 type of ANY */
-#define ASN1_PCTX_FLAGS_NO_ANY_TYPE            0x010
-/* Don't show ASN1 type of MSTRINGs */
-#define ASN1_PCTX_FLAGS_NO_MSTRING_TYPE                0x020
-/* Don't show field names in SEQUENCE */
-#define ASN1_PCTX_FLAGS_NO_FIELD_NAME          0x040
-/* Show structure names of each SEQUENCE field */
-#define ASN1_PCTX_FLAGS_SHOW_FIELD_STRUCT_NAME 0x080
-/* Don't show structure name even at top level */
-#define ASN1_PCTX_FLAGS_NO_STRUCT_NAME         0x100
-
-int ASN1_item_print(BIO *out, ASN1_VALUE *ifld, int indent,
-                               const ASN1_ITEM *it, const ASN1_PCTX *pctx);
-ASN1_PCTX *ASN1_PCTX_new(void);
-void ASN1_PCTX_free(ASN1_PCTX *p);
-unsigned long ASN1_PCTX_get_flags(ASN1_PCTX *p);
-void ASN1_PCTX_set_flags(ASN1_PCTX *p, unsigned long flags);
-unsigned long ASN1_PCTX_get_nm_flags(ASN1_PCTX *p);
-void ASN1_PCTX_set_nm_flags(ASN1_PCTX *p, unsigned long flags);
-unsigned long ASN1_PCTX_get_cert_flags(ASN1_PCTX *p);
-void ASN1_PCTX_set_cert_flags(ASN1_PCTX *p, unsigned long flags);
-unsigned long ASN1_PCTX_get_oid_flags(ASN1_PCTX *p);
-void ASN1_PCTX_set_oid_flags(ASN1_PCTX *p, unsigned long flags);
-unsigned long ASN1_PCTX_get_str_flags(ASN1_PCTX *p);
-void ASN1_PCTX_set_str_flags(ASN1_PCTX *p, unsigned long flags);
-
-BIO_METHOD *BIO_f_asn1(void);
-
-BIO *BIO_new_NDEF(BIO *out, ASN1_VALUE *val, const ASN1_ITEM *it);
-
-int i2d_ASN1_bio_stream(BIO *out, ASN1_VALUE *val, BIO *in, int flags,
-                               const ASN1_ITEM *it);
-int PEM_write_bio_ASN1_stream(BIO *out, ASN1_VALUE *val, BIO *in, int flags,
-                               const char *hdr,
-                               const ASN1_ITEM *it);
-int SMIME_write_ASN1(BIO *bio, ASN1_VALUE *val, BIO *data, int flags,
-                               int ctype_nid, int econt_nid,
-                               STACK_OF(X509_ALGOR) *mdalgs,
-                               const ASN1_ITEM *it);
-ASN1_VALUE *SMIME_read_ASN1(BIO *bio, BIO **bcont, const ASN1_ITEM *it);
-int SMIME_crlf_copy(BIO *in, BIO *out, int flags);
-int SMIME_text(BIO *in, BIO *out);
-
-/* BEGIN ERROR CODES */
-/* The following lines are auto generated by the script mkerr.pl. Any changes
- * made after this point may be overwritten when the script is next run.
- */
-void ERR_load_ASN1_strings(void);
-
-/* Error codes for the ASN1 functions. */
-
-/* Function codes. */
-#define ASN1_F_A2D_ASN1_OBJECT                          100
-#define ASN1_F_A2I_ASN1_ENUMERATED                      101
-#define ASN1_F_A2I_ASN1_INTEGER                                 102
-#define ASN1_F_A2I_ASN1_STRING                          103
-#define ASN1_F_APPEND_EXP                               176
-#define ASN1_F_ASN1_BIT_STRING_SET_BIT                  183
-#define ASN1_F_ASN1_CB                                  177
-#define ASN1_F_ASN1_CHECK_TLEN                          104
-#define ASN1_F_ASN1_COLLATE_PRIMITIVE                   105
-#define ASN1_F_ASN1_COLLECT                             106
-#define ASN1_F_ASN1_D2I_EX_PRIMITIVE                    108
-#define ASN1_F_ASN1_D2I_FP                              109
-#define ASN1_F_ASN1_D2I_READ_BIO                        107
-#define ASN1_F_ASN1_DIGEST                              184
-#define ASN1_F_ASN1_DO_ADB                              110
-#define ASN1_F_ASN1_DUP                                         111
-#define ASN1_F_ASN1_ENUMERATED_SET                      112
-#define ASN1_F_ASN1_ENUMERATED_TO_BN                    113
-#define ASN1_F_ASN1_EX_C2I                              204
-#define ASN1_F_ASN1_FIND_END                            190
-#define ASN1_F_ASN1_GENERALIZEDTIME_ADJ                         216
-#define ASN1_F_ASN1_GENERALIZEDTIME_SET                         185
-#define ASN1_F_ASN1_GENERATE_V3                                 178
-#define ASN1_F_ASN1_GET_OBJECT                          114
-#define ASN1_F_ASN1_HEADER_NEW                          115
-#define ASN1_F_ASN1_I2D_BIO                             116
-#define ASN1_F_ASN1_I2D_FP                              117
-#define ASN1_F_ASN1_INTEGER_SET                                 118
-#define ASN1_F_ASN1_INTEGER_TO_BN                       119
-#define ASN1_F_ASN1_ITEM_D2I_FP                                 206
-#define ASN1_F_ASN1_ITEM_DUP                            191
-#define ASN1_F_ASN1_ITEM_EX_COMBINE_NEW                         121
-#define ASN1_F_ASN1_ITEM_EX_D2I                                 120
-#define ASN1_F_ASN1_ITEM_I2D_BIO                        192
-#define ASN1_F_ASN1_ITEM_I2D_FP                                 193
-#define ASN1_F_ASN1_ITEM_PACK                           198
-#define ASN1_F_ASN1_ITEM_SIGN                           195
-#define ASN1_F_ASN1_ITEM_UNPACK                                 199
-#define ASN1_F_ASN1_ITEM_VERIFY                                 197
-#define ASN1_F_ASN1_MBSTRING_NCOPY                      122
-#define ASN1_F_ASN1_OBJECT_NEW                          123
-#define ASN1_F_ASN1_OUTPUT_DATA                                 214
-#define ASN1_F_ASN1_PACK_STRING                                 124
-#define ASN1_F_ASN1_PCTX_NEW                            205
-#define ASN1_F_ASN1_PKCS5_PBE_SET                       125
-#define ASN1_F_ASN1_SEQ_PACK                            126
-#define ASN1_F_ASN1_SEQ_UNPACK                          127
-#define ASN1_F_ASN1_SIGN                                128
-#define ASN1_F_ASN1_STR2TYPE                            179
-#define ASN1_F_ASN1_STRING_SET                          186
-#define ASN1_F_ASN1_STRING_TABLE_ADD                    129
-#define ASN1_F_ASN1_STRING_TYPE_NEW                     130
-#define ASN1_F_ASN1_TEMPLATE_EX_D2I                     132
-#define ASN1_F_ASN1_TEMPLATE_NEW                        133
-#define ASN1_F_ASN1_TEMPLATE_NOEXP_D2I                  131
-#define ASN1_F_ASN1_TIME_ADJ                            217
-#define ASN1_F_ASN1_TIME_SET                            175
-#define ASN1_F_ASN1_TYPE_GET_INT_OCTETSTRING            134
-#define ASN1_F_ASN1_TYPE_GET_OCTETSTRING                135
-#define ASN1_F_ASN1_UNPACK_STRING                       136
-#define ASN1_F_ASN1_UTCTIME_ADJ                                 218
-#define ASN1_F_ASN1_UTCTIME_SET                                 187
-#define ASN1_F_ASN1_VERIFY                              137
-#define ASN1_F_B64_READ_ASN1                            209
-#define ASN1_F_B64_WRITE_ASN1                           210
-#define ASN1_F_BIO_NEW_NDEF                             208
-#define ASN1_F_BITSTR_CB                                180
-#define ASN1_F_BN_TO_ASN1_ENUMERATED                    138
-#define ASN1_F_BN_TO_ASN1_INTEGER                       139
-#define ASN1_F_C2I_ASN1_BIT_STRING                      189
-#define ASN1_F_C2I_ASN1_INTEGER                                 194
-#define ASN1_F_C2I_ASN1_OBJECT                          196
-#define ASN1_F_COLLECT_DATA                             140
-#define ASN1_F_D2I_ASN1_BIT_STRING                      141
-#define ASN1_F_D2I_ASN1_BOOLEAN                                 142
-#define ASN1_F_D2I_ASN1_BYTES                           143
-#define ASN1_F_D2I_ASN1_GENERALIZEDTIME                         144
-#define ASN1_F_D2I_ASN1_HEADER                          145
-#define ASN1_F_D2I_ASN1_INTEGER                                 146
-#define ASN1_F_D2I_ASN1_OBJECT                          147
-#define ASN1_F_D2I_ASN1_SET                             148
-#define ASN1_F_D2I_ASN1_TYPE_BYTES                      149
-#define ASN1_F_D2I_ASN1_UINTEGER                        150
-#define ASN1_F_D2I_ASN1_UTCTIME                                 151
-#define ASN1_F_D2I_AUTOPRIVATEKEY                       207
-#define ASN1_F_D2I_NETSCAPE_RSA                                 152
-#define ASN1_F_D2I_NETSCAPE_RSA_2                       153
-#define ASN1_F_D2I_PRIVATEKEY                           154
-#define ASN1_F_D2I_PUBLICKEY                            155
-#define ASN1_F_D2I_RSA_NET                              200
-#define ASN1_F_D2I_RSA_NET_2                            201
-#define ASN1_F_D2I_X509                                         156
-#define ASN1_F_D2I_X509_CINF                            157
-#define ASN1_F_D2I_X509_PKEY                            159
-#define ASN1_F_I2D_ASN1_BIO_STREAM                      211
-#define ASN1_F_I2D_ASN1_SET                             188
-#define ASN1_F_I2D_ASN1_TIME                            160
-#define ASN1_F_I2D_DSA_PUBKEY                           161
-#define ASN1_F_I2D_EC_PUBKEY                            181
-#define ASN1_F_I2D_PRIVATEKEY                           163
-#define ASN1_F_I2D_PUBLICKEY                            164
-#define ASN1_F_I2D_RSA_NET                              162
-#define ASN1_F_I2D_RSA_PUBKEY                           165
-#define ASN1_F_LONG_C2I                                         166
-#define ASN1_F_OID_MODULE_INIT                          174
-#define ASN1_F_PARSE_TAGGING                            182
-#define ASN1_F_PKCS5_PBE2_SET_IV                        167
-#define ASN1_F_PKCS5_PBE_SET                            202
-#define ASN1_F_PKCS5_PBE_SET0_ALGOR                     215
-#define ASN1_F_SMIME_READ_ASN1                          212
-#define ASN1_F_SMIME_TEXT                               213
-#define ASN1_F_X509_CINF_NEW                            168
-#define ASN1_F_X509_CRL_ADD0_REVOKED                    169
-#define ASN1_F_X509_INFO_NEW                            170
-#define ASN1_F_X509_NAME_ENCODE                                 203
-#define ASN1_F_X509_NAME_EX_D2I                                 158
-#define ASN1_F_X509_NAME_EX_NEW                                 171
-#define ASN1_F_X509_NEW                                         172
-#define ASN1_F_X509_PKEY_NEW                            173
-
-/* Reason codes. */
-#define ASN1_R_ADDING_OBJECT                            171
-#define ASN1_R_ASN1_PARSE_ERROR                                 203
-#define ASN1_R_ASN1_SIG_PARSE_ERROR                     204
-#define ASN1_R_AUX_ERROR                                100
-#define ASN1_R_BAD_CLASS                                101
-#define ASN1_R_BAD_OBJECT_HEADER                        102
-#define ASN1_R_BAD_PASSWORD_READ                        103
-#define ASN1_R_BAD_TAG                                  104
-#define ASN1_R_BMPSTRING_IS_WRONG_LENGTH                214
-#define ASN1_R_BN_LIB                                   105
-#define ASN1_R_BOOLEAN_IS_WRONG_LENGTH                  106
-#define ASN1_R_BUFFER_TOO_SMALL                                 107
-#define ASN1_R_CIPHER_HAS_NO_OBJECT_IDENTIFIER          108
-#define ASN1_R_DATA_IS_WRONG                            109
-#define ASN1_R_DECODE_ERROR                             110
-#define ASN1_R_DECODING_ERROR                           111
-#define ASN1_R_DEPTH_EXCEEDED                           174
-#define ASN1_R_DIGEST_AND_KEY_TYPE_NOT_SUPPORTED        198
-#define ASN1_R_ENCODE_ERROR                             112
-#define ASN1_R_ERROR_GETTING_TIME                       173
-#define ASN1_R_ERROR_LOADING_SECTION                    172
-#define ASN1_R_ERROR_PARSING_SET_ELEMENT                113
-#define ASN1_R_ERROR_SETTING_CIPHER_PARAMS              114
-#define ASN1_R_EXPECTING_AN_INTEGER                     115
-#define ASN1_R_EXPECTING_AN_OBJECT                      116
-#define ASN1_R_EXPECTING_A_BOOLEAN                      117
-#define ASN1_R_EXPECTING_A_TIME                                 118
-#define ASN1_R_EXPLICIT_LENGTH_MISMATCH                         119
-#define ASN1_R_EXPLICIT_TAG_NOT_CONSTRUCTED             120
-#define ASN1_R_FIELD_MISSING                            121
-#define ASN1_R_FIRST_NUM_TOO_LARGE                      122
-#define ASN1_R_HEADER_TOO_LONG                          123
-#define ASN1_R_ILLEGAL_BITSTRING_FORMAT                         175
-#define ASN1_R_ILLEGAL_BOOLEAN                          176
-#define ASN1_R_ILLEGAL_CHARACTERS                       124
-#define ASN1_R_ILLEGAL_FORMAT                           177
-#define ASN1_R_ILLEGAL_HEX                              178
-#define ASN1_R_ILLEGAL_IMPLICIT_TAG                     179
-#define ASN1_R_ILLEGAL_INTEGER                          180
-#define ASN1_R_ILLEGAL_NESTED_TAGGING                   181
-#define ASN1_R_ILLEGAL_NULL                             125
-#define ASN1_R_ILLEGAL_NULL_VALUE                       182
-#define ASN1_R_ILLEGAL_OBJECT                           183
-#define ASN1_R_ILLEGAL_OPTIONAL_ANY                     126
-#define ASN1_R_ILLEGAL_OPTIONS_ON_ITEM_TEMPLATE                 170
-#define ASN1_R_ILLEGAL_TAGGED_ANY                       127
-#define ASN1_R_ILLEGAL_TIME_VALUE                       184
-#define ASN1_R_INTEGER_NOT_ASCII_FORMAT                         185
-#define ASN1_R_INTEGER_TOO_LARGE_FOR_LONG               128
-#define ASN1_R_INVALID_BMPSTRING_LENGTH                         129
-#define ASN1_R_INVALID_DIGIT                            130
-#define ASN1_R_INVALID_MIME_TYPE                        205
-#define ASN1_R_INVALID_MODIFIER                                 186
-#define ASN1_R_INVALID_NUMBER                           187
-#define ASN1_R_INVALID_OBJECT_ENCODING                  216
-#define ASN1_R_INVALID_SEPARATOR                        131
-#define ASN1_R_INVALID_TIME_FORMAT                      132
-#define ASN1_R_INVALID_UNIVERSALSTRING_LENGTH           133
-#define ASN1_R_INVALID_UTF8STRING                       134
-#define ASN1_R_IV_TOO_LARGE                             135
-#define ASN1_R_LENGTH_ERROR                             136
-#define ASN1_R_LIST_ERROR                               188
-#define ASN1_R_MIME_NO_CONTENT_TYPE                     206
-#define ASN1_R_MIME_PARSE_ERROR                                 207
-#define ASN1_R_MIME_SIG_PARSE_ERROR                     208
-#define ASN1_R_MISSING_EOC                              137
-#define ASN1_R_MISSING_SECOND_NUMBER                    138
-#define ASN1_R_MISSING_VALUE                            189
-#define ASN1_R_MSTRING_NOT_UNIVERSAL                    139
-#define ASN1_R_MSTRING_WRONG_TAG                        140
-#define ASN1_R_NESTED_ASN1_STRING                       197
-#define ASN1_R_NON_HEX_CHARACTERS                       141
-#define ASN1_R_NOT_ASCII_FORMAT                                 190
-#define ASN1_R_NOT_ENOUGH_DATA                          142
-#define ASN1_R_NO_CONTENT_TYPE                          209
-#define ASN1_R_NO_DEFAULT_DIGEST                        201
-#define ASN1_R_NO_MATCHING_CHOICE_TYPE                  143
-#define ASN1_R_NO_MULTIPART_BODY_FAILURE                210
-#define ASN1_R_NO_MULTIPART_BOUNDARY                    211
-#define ASN1_R_NO_SIG_CONTENT_TYPE                      212
-#define ASN1_R_NULL_IS_WRONG_LENGTH                     144
-#define ASN1_R_OBJECT_NOT_ASCII_FORMAT                  191
-#define ASN1_R_ODD_NUMBER_OF_CHARS                      145
-#define ASN1_R_PRIVATE_KEY_HEADER_MISSING               146
-#define ASN1_R_SECOND_NUMBER_TOO_LARGE                  147
-#define ASN1_R_SEQUENCE_LENGTH_MISMATCH                         148
-#define ASN1_R_SEQUENCE_NOT_CONSTRUCTED                         149
-#define ASN1_R_SEQUENCE_OR_SET_NEEDS_CONFIG             192
-#define ASN1_R_SHORT_LINE                               150
-#define ASN1_R_SIG_INVALID_MIME_TYPE                    213
-#define ASN1_R_STREAMING_NOT_SUPPORTED                  202
-#define ASN1_R_STRING_TOO_LONG                          151
-#define ASN1_R_STRING_TOO_SHORT                                 152
-#define ASN1_R_TAG_VALUE_TOO_HIGH                       153
-#define ASN1_R_THE_ASN1_OBJECT_IDENTIFIER_IS_NOT_KNOWN_FOR_THIS_MD 154
-#define ASN1_R_TIME_NOT_ASCII_FORMAT                    193
-#define ASN1_R_TOO_LONG                                         155
-#define ASN1_R_TYPE_NOT_CONSTRUCTED                     156
-#define ASN1_R_UNABLE_TO_DECODE_RSA_KEY                         157
-#define ASN1_R_UNABLE_TO_DECODE_RSA_PRIVATE_KEY                 158
-#define ASN1_R_UNEXPECTED_EOC                           159
-#define ASN1_R_UNIVERSALSTRING_IS_WRONG_LENGTH          215
-#define ASN1_R_UNKNOWN_FORMAT                           160
-#define ASN1_R_UNKNOWN_MESSAGE_DIGEST_ALGORITHM                 161
-#define ASN1_R_UNKNOWN_OBJECT_TYPE                      162
-#define ASN1_R_UNKNOWN_PUBLIC_KEY_TYPE                  163
-#define ASN1_R_UNKNOWN_SIGNATURE_ALGORITHM              199
-#define ASN1_R_UNKNOWN_TAG                              194
-#define ASN1_R_UNKOWN_FORMAT                            195
-#define ASN1_R_UNSUPPORTED_ANY_DEFINED_BY_TYPE          164
-#define ASN1_R_UNSUPPORTED_CIPHER                       165
-#define ASN1_R_UNSUPPORTED_ENCRYPTION_ALGORITHM                 166
-#define ASN1_R_UNSUPPORTED_PUBLIC_KEY_TYPE              167
-#define ASN1_R_UNSUPPORTED_TYPE                                 196
-#define ASN1_R_WRONG_PUBLIC_KEY_TYPE                    200
-#define ASN1_R_WRONG_TAG                                168
-#define ASN1_R_WRONG_TYPE                               169
-
-#ifdef  __cplusplus
-}
-#endif
-#endif
+/* crypto/asn1/asn1.h */\r
+/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)\r
+ * All rights reserved.\r
+ *\r
+ * This package is an SSL implementation written\r
+ * by Eric Young (eay@cryptsoft.com).\r
+ * The implementation was written so as to conform with Netscapes SSL.\r
+ *\r
+ * This library is free for commercial and non-commercial use as long as\r
+ * the following conditions are aheared to.  The following conditions\r
+ * apply to all code found in this distribution, be it the RC4, RSA,\r
+ * lhash, DES, etc., code; not just the SSL code.  The SSL documentation\r
+ * included with this distribution is covered by the same copyright terms\r
+ * except that the holder is Tim Hudson (tjh@cryptsoft.com).\r
+ *\r
+ * Copyright remains Eric Young's, and as such any Copyright notices in\r
+ * the code are not to be removed.\r
+ * If this package is used in a product, Eric Young should be given attribution\r
+ * as the author of the parts of the library used.\r
+ * This can be in the form of a textual message at program startup or\r
+ * in documentation (online or textual) provided with the package.\r
+ *\r
+ * Redistribution and use in source and binary forms, with or without\r
+ * modification, are permitted provided that the following conditions\r
+ * are met:\r
+ * 1. Redistributions of source code must retain the copyright\r
+ *    notice, this list of conditions and the following disclaimer.\r
+ * 2. Redistributions in binary form must reproduce the above copyright\r
+ *    notice, this list of conditions and the following disclaimer in the\r
+ *    documentation and/or other materials provided with the distribution.\r
+ * 3. All advertising materials mentioning features or use of this software\r
+ *    must display the following acknowledgement:\r
+ *    "This product includes cryptographic software written by\r
+ *     Eric Young (eay@cryptsoft.com)"\r
+ *    The word 'cryptographic' can be left out if the rouines from the library\r
+ *    being used are not cryptographic related :-).\r
+ * 4. If you include any Windows specific code (or a derivative thereof) from\r
+ *    the apps directory (application code) you must include an acknowledgement:\r
+ *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"\r
+ *\r
+ * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND\r
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\r
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\r
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE\r
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\r
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\r
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\r
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT\r
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY\r
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF\r
+ * SUCH DAMAGE.\r
+ *\r
+ * The licence and distribution terms for any publically available version or\r
+ * derivative of this code cannot be changed.  i.e. this code cannot simply be\r
+ * copied and put under another distribution licence\r
+ * [including the GNU Public Licence.]\r
+ */\r
+\r
+#ifndef HEADER_ASN1_H\r
+#define HEADER_ASN1_H\r
+\r
+#include <time.h>\r
+#include <openssl/e_os2.h>\r
+#ifndef OPENSSL_NO_BIO\r
+#include <openssl/bio.h>\r
+#endif\r
+#include <openssl/stack.h>\r
+#include <openssl/safestack.h>\r
+\r
+#include <openssl/symhacks.h>\r
+\r
+#include <openssl/ossl_typ.h>\r
+#ifndef OPENSSL_NO_DEPRECATED\r
+#include <openssl/bn.h>\r
+#endif\r
+\r
+#ifdef OPENSSL_BUILD_SHLIBCRYPTO\r
+# undef OPENSSL_EXTERN\r
+# define OPENSSL_EXTERN OPENSSL_EXPORT\r
+#endif\r
+\r
+#ifdef  __cplusplus\r
+extern "C" {\r
+#endif\r
+\r
+#define V_ASN1_UNIVERSAL               0x00\r
+#define        V_ASN1_APPLICATION              0x40\r
+#define V_ASN1_CONTEXT_SPECIFIC                0x80\r
+#define V_ASN1_PRIVATE                 0xc0\r
+\r
+#define V_ASN1_CONSTRUCTED             0x20\r
+#define V_ASN1_PRIMITIVE_TAG           0x1f\r
+#define V_ASN1_PRIMATIVE_TAG           0x1f\r
+\r
+#define V_ASN1_APP_CHOOSE              -2      /* let the recipient choose */\r
+#define V_ASN1_OTHER                   -3      /* used in ASN1_TYPE */\r
+#define V_ASN1_ANY                     -4      /* used in ASN1 template code */\r
+\r
+#define V_ASN1_NEG                     0x100   /* negative flag */\r
+\r
+#define V_ASN1_UNDEF                   -1\r
+#define V_ASN1_EOC                     0\r
+#define V_ASN1_BOOLEAN                 1       /**/\r
+#define V_ASN1_INTEGER                 2\r
+#define V_ASN1_NEG_INTEGER             (2 | V_ASN1_NEG)\r
+#define V_ASN1_BIT_STRING              3\r
+#define V_ASN1_OCTET_STRING            4\r
+#define V_ASN1_NULL                    5\r
+#define V_ASN1_OBJECT                  6\r
+#define V_ASN1_OBJECT_DESCRIPTOR       7\r
+#define V_ASN1_EXTERNAL                        8\r
+#define V_ASN1_REAL                    9\r
+#define V_ASN1_ENUMERATED              10\r
+#define V_ASN1_NEG_ENUMERATED          (10 | V_ASN1_NEG)\r
+#define V_ASN1_UTF8STRING              12\r
+#define V_ASN1_SEQUENCE                        16\r
+#define V_ASN1_SET                     17\r
+#define V_ASN1_NUMERICSTRING           18      /**/\r
+#define V_ASN1_PRINTABLESTRING         19\r
+#define V_ASN1_T61STRING               20\r
+#define V_ASN1_TELETEXSTRING           20      /* alias */\r
+#define V_ASN1_VIDEOTEXSTRING          21      /**/\r
+#define V_ASN1_IA5STRING               22\r
+#define V_ASN1_UTCTIME                 23\r
+#define V_ASN1_GENERALIZEDTIME         24      /**/\r
+#define V_ASN1_GRAPHICSTRING           25      /**/\r
+#define V_ASN1_ISO64STRING             26      /**/\r
+#define V_ASN1_VISIBLESTRING           26      /* alias */\r
+#define V_ASN1_GENERALSTRING           27      /**/\r
+#define V_ASN1_UNIVERSALSTRING         28      /**/\r
+#define V_ASN1_BMPSTRING               30\r
+\r
+/* For use with d2i_ASN1_type_bytes() */\r
+#define B_ASN1_NUMERICSTRING   0x0001\r
+#define B_ASN1_PRINTABLESTRING 0x0002\r
+#define B_ASN1_T61STRING       0x0004\r
+#define B_ASN1_TELETEXSTRING   0x0004\r
+#define B_ASN1_VIDEOTEXSTRING  0x0008\r
+#define B_ASN1_IA5STRING       0x0010\r
+#define B_ASN1_GRAPHICSTRING   0x0020\r
+#define B_ASN1_ISO64STRING     0x0040\r
+#define B_ASN1_VISIBLESTRING   0x0040\r
+#define B_ASN1_GENERALSTRING   0x0080\r
+#define B_ASN1_UNIVERSALSTRING 0x0100\r
+#define B_ASN1_OCTET_STRING    0x0200\r
+#define B_ASN1_BIT_STRING      0x0400\r
+#define B_ASN1_BMPSTRING       0x0800\r
+#define B_ASN1_UNKNOWN         0x1000\r
+#define B_ASN1_UTF8STRING      0x2000\r
+#define B_ASN1_UTCTIME         0x4000\r
+#define B_ASN1_GENERALIZEDTIME 0x8000\r
+#define B_ASN1_SEQUENCE                0x10000\r
+\r
+/* For use with ASN1_mbstring_copy() */\r
+#define MBSTRING_FLAG          0x1000\r
+#define MBSTRING_UTF8          (MBSTRING_FLAG)\r
+#define MBSTRING_ASC           (MBSTRING_FLAG|1)\r
+#define MBSTRING_BMP           (MBSTRING_FLAG|2)\r
+#define MBSTRING_UNIV          (MBSTRING_FLAG|4)\r
+\r
+#define SMIME_OLDMIME          0x400\r
+#define SMIME_CRLFEOL          0x800\r
+#define SMIME_STREAM           0x1000\r
+\r
+struct X509_algor_st;\r
+DECLARE_STACK_OF(X509_ALGOR)\r
+\r
+#define DECLARE_ASN1_SET_OF(type) /* filled in by mkstack.pl */\r
+#define IMPLEMENT_ASN1_SET_OF(type) /* nothing, no longer needed */\r
+\r
+/* We MUST make sure that, except for constness, asn1_ctx_st and\r
+   asn1_const_ctx are exactly the same.  Fortunately, as soon as\r
+   the old ASN1 parsing macros are gone, we can throw this away\r
+   as well... */\r
+typedef struct asn1_ctx_st\r
+       {\r
+       unsigned char *p;/* work char pointer */\r
+       int eos;        /* end of sequence read for indefinite encoding */\r
+       int error;      /* error code to use when returning an error */\r
+       int inf;        /* constructed if 0x20, indefinite is 0x21 */\r
+       int tag;        /* tag from last 'get object' */\r
+       int xclass;     /* class from last 'get object' */\r
+       long slen;      /* length of last 'get object' */\r
+       unsigned char *max; /* largest value of p allowed */\r
+       unsigned char *q;/* temporary variable */\r
+       unsigned char **pp;/* variable */\r
+       int line;       /* used in error processing */\r
+       } ASN1_CTX;\r
+\r
+typedef struct asn1_const_ctx_st\r
+       {\r
+       const unsigned char *p;/* work char pointer */\r
+       int eos;        /* end of sequence read for indefinite encoding */\r
+       int error;      /* error code to use when returning an error */\r
+       int inf;        /* constructed if 0x20, indefinite is 0x21 */\r
+       int tag;        /* tag from last 'get object' */\r
+       int xclass;     /* class from last 'get object' */\r
+       long slen;      /* length of last 'get object' */\r
+       const unsigned char *max; /* largest value of p allowed */\r
+       const unsigned char *q;/* temporary variable */\r
+       const unsigned char **pp;/* variable */\r
+       int line;       /* used in error processing */\r
+       } ASN1_const_CTX;\r
+\r
+/* These are used internally in the ASN1_OBJECT to keep track of\r
+ * whether the names and data need to be free()ed */\r
+#define ASN1_OBJECT_FLAG_DYNAMIC        0x01   /* internal use */\r
+#define ASN1_OBJECT_FLAG_CRITICAL       0x02   /* critical x509v3 object id */\r
+#define ASN1_OBJECT_FLAG_DYNAMIC_STRINGS 0x04  /* internal use */\r
+#define ASN1_OBJECT_FLAG_DYNAMIC_DATA   0x08   /* internal use */\r
+typedef struct asn1_object_st\r
+       {\r
+       const char *sn,*ln;\r
+       int nid;\r
+       int length;\r
+       const unsigned char *data;      /* data remains const after init */\r
+       int flags;      /* Should we free this one */\r
+       } ASN1_OBJECT;\r
+\r
+#define ASN1_STRING_FLAG_BITS_LEFT 0x08 /* Set if 0x07 has bits left value */\r
+/* This indicates that the ASN1_STRING is not a real value but just a place\r
+ * holder for the location where indefinite length constructed data should\r
+ * be inserted in the memory buffer\r
+ */\r
+#define ASN1_STRING_FLAG_NDEF 0x010\r
+\r
+/* This flag is used by the CMS code to indicate that a string is not\r
+ * complete and is a place holder for content when it had all been\r
+ * accessed. The flag will be reset when content has been written to it.\r
+ */\r
+\r
+#define ASN1_STRING_FLAG_CONT 0x020\r
+/* This flag is used by ASN1 code to indicate an ASN1_STRING is an MSTRING\r
+ * type.\r
+ */\r
+#define ASN1_STRING_FLAG_MSTRING 0x040\r
+/* This is the base type that holds just about everything :-) */\r
+typedef struct asn1_string_st\r
+       {\r
+       int length;\r
+       int type;\r
+       unsigned char *data;\r
+       /* The value of the following field depends on the type being\r
+        * held.  It is mostly being used for BIT_STRING so if the\r
+        * input data has a non-zero 'unused bits' value, it will be\r
+        * handled correctly */\r
+       long flags;\r
+       } ASN1_STRING;\r
+\r
+/* ASN1_ENCODING structure: this is used to save the received\r
+ * encoding of an ASN1 type. This is useful to get round\r
+ * problems with invalid encodings which can break signatures.\r
+ */\r
+\r
+typedef struct ASN1_ENCODING_st\r
+       {\r
+       unsigned char *enc;     /* DER encoding */\r
+       long len;               /* Length of encoding */\r
+       int modified;            /* set to 1 if 'enc' is invalid */\r
+       } ASN1_ENCODING;\r
+\r
+/* Used with ASN1 LONG type: if a long is set to this it is omitted */\r
+#define ASN1_LONG_UNDEF        0x7fffffffL\r
+\r
+#define STABLE_FLAGS_MALLOC    0x01\r
+#define STABLE_NO_MASK         0x02\r
+#define DIRSTRING_TYPE \\r
+ (B_ASN1_PRINTABLESTRING|B_ASN1_T61STRING|B_ASN1_BMPSTRING|B_ASN1_UTF8STRING)\r
+#define PKCS9STRING_TYPE (DIRSTRING_TYPE|B_ASN1_IA5STRING)\r
+\r
+typedef struct asn1_string_table_st {\r
+       int nid;\r
+       long minsize;\r
+       long maxsize;\r
+       unsigned long mask;\r
+       unsigned long flags;\r
+} ASN1_STRING_TABLE;\r
+\r
+DECLARE_STACK_OF(ASN1_STRING_TABLE)\r
+\r
+/* size limits: this stuff is taken straight from RFC2459 */\r
+\r
+#define ub_name                                32768\r
+#define ub_common_name                 64\r
+#define ub_locality_name               128\r
+#define ub_state_name                  128\r
+#define ub_organization_name           64\r
+#define ub_organization_unit_name      64\r
+#define ub_title                       64\r
+#define ub_email_address               128\r
+\r
+/* Declarations for template structures: for full definitions\r
+ * see asn1t.h\r
+ */\r
+typedef struct ASN1_TEMPLATE_st ASN1_TEMPLATE;\r
+typedef struct ASN1_ITEM_st ASN1_ITEM;\r
+typedef struct ASN1_TLC_st ASN1_TLC;\r
+/* This is just an opaque pointer */\r
+typedef struct ASN1_VALUE_st ASN1_VALUE;\r
+\r
+/* Declare ASN1 functions: the implement macro in in asn1t.h */\r
+\r
+#define DECLARE_ASN1_FUNCTIONS(type) DECLARE_ASN1_FUNCTIONS_name(type, type)\r
+\r
+#define DECLARE_ASN1_ALLOC_FUNCTIONS(type) \\r
+       DECLARE_ASN1_ALLOC_FUNCTIONS_name(type, type)\r
+\r
+#define DECLARE_ASN1_FUNCTIONS_name(type, name) \\r
+       DECLARE_ASN1_ALLOC_FUNCTIONS_name(type, name) \\r
+       DECLARE_ASN1_ENCODE_FUNCTIONS(type, name, name)\r
+\r
+#define DECLARE_ASN1_FUNCTIONS_fname(type, itname, name) \\r
+       DECLARE_ASN1_ALLOC_FUNCTIONS_name(type, name) \\r
+       DECLARE_ASN1_ENCODE_FUNCTIONS(type, itname, name)\r
+\r
+#define        DECLARE_ASN1_ENCODE_FUNCTIONS(type, itname, name) \\r
+       type *d2i_##name(type **a, const unsigned char **in, long len); \\r
+       int i2d_##name(type *a, unsigned char **out); \\r
+       DECLARE_ASN1_ITEM(itname)\r
+\r
+#define        DECLARE_ASN1_ENCODE_FUNCTIONS_const(type, name) \\r
+       type *d2i_##name(type **a, const unsigned char **in, long len); \\r
+       int i2d_##name(const type *a, unsigned char **out); \\r
+       DECLARE_ASN1_ITEM(name)\r
+\r
+#define        DECLARE_ASN1_NDEF_FUNCTION(name) \\r
+       int i2d_##name##_NDEF(name *a, unsigned char **out);\r
+\r
+#define DECLARE_ASN1_FUNCTIONS_const(name) \\r
+       DECLARE_ASN1_ALLOC_FUNCTIONS(name) \\r
+       DECLARE_ASN1_ENCODE_FUNCTIONS_const(name, name)\r
+\r
+#define DECLARE_ASN1_ALLOC_FUNCTIONS_name(type, name) \\r
+       type *name##_new(void); \\r
+       void name##_free(type *a);\r
+\r
+#define DECLARE_ASN1_PRINT_FUNCTION(stname) \\r
+       DECLARE_ASN1_PRINT_FUNCTION_fname(stname, stname)\r
+\r
+#define DECLARE_ASN1_PRINT_FUNCTION_fname(stname, fname) \\r
+       int fname##_print_ctx(BIO *out, stname *x, int indent, \\r
+                                        const ASN1_PCTX *pctx);\r
+\r
+#define D2I_OF(type) type *(*)(type **,const unsigned char **,long)\r
+#define I2D_OF(type) int (*)(type *,unsigned char **)\r
+#define I2D_OF_const(type) int (*)(const type *,unsigned char **)\r
+\r
+#define CHECKED_D2I_OF(type, d2i) \\r
+    ((d2i_of_void*) (1 ? d2i : ((D2I_OF(type))0)))\r
+#define CHECKED_I2D_OF(type, i2d) \\r
+    ((i2d_of_void*) (1 ? i2d : ((I2D_OF(type))0)))\r
+#define CHECKED_NEW_OF(type, xnew) \\r
+    ((void *(*)(void)) (1 ? xnew : ((type *(*)(void))0)))\r
+#define CHECKED_PTR_OF(type, p) \\r
+    ((void*) (1 ? p : (type*)0))\r
+#define CHECKED_PPTR_OF(type, p) \\r
+    ((void**) (1 ? p : (type**)0))\r
+\r
+#define TYPEDEF_D2I_OF(type) typedef type *d2i_of_##type(type **,const unsigned char **,long)\r
+#define TYPEDEF_I2D_OF(type) typedef int i2d_of_##type(type *,unsigned char **)\r
+#define TYPEDEF_D2I2D_OF(type) TYPEDEF_D2I_OF(type); TYPEDEF_I2D_OF(type)\r
+\r
+TYPEDEF_D2I2D_OF(void);\r
+\r
+/* The following macros and typedefs allow an ASN1_ITEM\r
+ * to be embedded in a structure and referenced. Since\r
+ * the ASN1_ITEM pointers need to be globally accessible\r
+ * (possibly from shared libraries) they may exist in\r
+ * different forms. On platforms that support it the\r
+ * ASN1_ITEM structure itself will be globally exported.\r
+ * Other platforms will export a function that returns\r
+ * an ASN1_ITEM pointer.\r
+ *\r
+ * To handle both cases transparently the macros below\r
+ * should be used instead of hard coding an ASN1_ITEM\r
+ * pointer in a structure.\r
+ *\r
+ * The structure will look like this:\r
+ *\r
+ * typedef struct SOMETHING_st {\r
+ *      ...\r
+ *      ASN1_ITEM_EXP *iptr;\r
+ *      ...\r
+ * } SOMETHING;\r
+ *\r
+ * It would be initialised as e.g.:\r
+ *\r
+ * SOMETHING somevar = {...,ASN1_ITEM_ref(X509),...};\r
+ *\r
+ * and the actual pointer extracted with:\r
+ *\r
+ * const ASN1_ITEM *it = ASN1_ITEM_ptr(somevar.iptr);\r
+ *\r
+ * Finally an ASN1_ITEM pointer can be extracted from an\r
+ * appropriate reference with: ASN1_ITEM_rptr(X509). This\r
+ * would be used when a function takes an ASN1_ITEM * argument.\r
+ *\r
+ */\r
+\r
+#ifndef OPENSSL_EXPORT_VAR_AS_FUNCTION\r
+\r
+/* ASN1_ITEM pointer exported type */\r
+typedef const ASN1_ITEM ASN1_ITEM_EXP;\r
+\r
+/* Macro to obtain ASN1_ITEM pointer from exported type */\r
+#define ASN1_ITEM_ptr(iptr) (iptr)\r
+\r
+/* Macro to include ASN1_ITEM pointer from base type */\r
+#define ASN1_ITEM_ref(iptr) (&(iptr##_it))\r
+\r
+#define ASN1_ITEM_rptr(ref) (&(ref##_it))\r
+\r
+#define DECLARE_ASN1_ITEM(name) \\r
+       OPENSSL_EXTERN const ASN1_ITEM name##_it;\r
+\r
+#else\r
+\r
+/* Platforms that can't easily handle shared global variables are declared\r
+ * as functions returning ASN1_ITEM pointers.\r
+ */\r
+\r
+/* ASN1_ITEM pointer exported type */\r
+typedef const ASN1_ITEM * ASN1_ITEM_EXP(void);\r
+\r
+/* Macro to obtain ASN1_ITEM pointer from exported type */\r
+#define ASN1_ITEM_ptr(iptr) (iptr())\r
+\r
+/* Macro to include ASN1_ITEM pointer from base type */\r
+#define ASN1_ITEM_ref(iptr) (iptr##_it)\r
+\r
+#define ASN1_ITEM_rptr(ref) (ref##_it())\r
+\r
+#define DECLARE_ASN1_ITEM(name) \\r
+       const ASN1_ITEM * name##_it(void);\r
+\r
+#endif\r
+\r
+/* Parameters used by ASN1_STRING_print_ex() */\r
+\r
+/* These determine which characters to escape:\r
+ * RFC2253 special characters, control characters and\r
+ * MSB set characters\r
+ */\r
+\r
+#define ASN1_STRFLGS_ESC_2253          1\r
+#define ASN1_STRFLGS_ESC_CTRL          2\r
+#define ASN1_STRFLGS_ESC_MSB           4\r
+\r
+\r
+/* This flag determines how we do escaping: normally\r
+ * RC2253 backslash only, set this to use backslash and\r
+ * quote.\r
+ */\r
+\r
+#define ASN1_STRFLGS_ESC_QUOTE         8\r
+\r
+\r
+/* These three flags are internal use only. */\r
+\r
+/* Character is a valid PrintableString character */\r
+#define CHARTYPE_PRINTABLESTRING       0x10\r
+/* Character needs escaping if it is the first character */\r
+#define CHARTYPE_FIRST_ESC_2253                0x20\r
+/* Character needs escaping if it is the last character */\r
+#define CHARTYPE_LAST_ESC_2253         0x40\r
+\r
+/* NB the internal flags are safely reused below by flags\r
+ * handled at the top level.\r
+ */\r
+\r
+/* If this is set we convert all character strings\r
+ * to UTF8 first\r
+ */\r
+\r
+#define ASN1_STRFLGS_UTF8_CONVERT      0x10\r
+\r
+/* If this is set we don't attempt to interpret content:\r
+ * just assume all strings are 1 byte per character. This\r
+ * will produce some pretty odd looking output!\r
+ */\r
+\r
+#define ASN1_STRFLGS_IGNORE_TYPE       0x20\r
+\r
+/* If this is set we include the string type in the output */\r
+#define ASN1_STRFLGS_SHOW_TYPE         0x40\r
+\r
+/* This determines which strings to display and which to\r
+ * 'dump' (hex dump of content octets or DER encoding). We can\r
+ * only dump non character strings or everything. If we\r
+ * don't dump 'unknown' they are interpreted as character\r
+ * strings with 1 octet per character and are subject to\r
+ * the usual escaping options.\r
+ */\r
+\r
+#define ASN1_STRFLGS_DUMP_ALL          0x80\r
+#define ASN1_STRFLGS_DUMP_UNKNOWN      0x100\r
+\r
+/* These determine what 'dumping' does, we can dump the\r
+ * content octets or the DER encoding: both use the\r
+ * RFC2253 #XXXXX notation.\r
+ */\r
+\r
+#define ASN1_STRFLGS_DUMP_DER          0x200\r
+\r
+/* All the string flags consistent with RFC2253,\r
+ * escaping control characters isn't essential in\r
+ * RFC2253 but it is advisable anyway.\r
+ */\r
+\r
+#define ASN1_STRFLGS_RFC2253   (ASN1_STRFLGS_ESC_2253 | \\r
+                               ASN1_STRFLGS_ESC_CTRL | \\r
+                               ASN1_STRFLGS_ESC_MSB | \\r
+                               ASN1_STRFLGS_UTF8_CONVERT | \\r
+                               ASN1_STRFLGS_DUMP_UNKNOWN | \\r
+                               ASN1_STRFLGS_DUMP_DER)\r
+\r
+DECLARE_STACK_OF(ASN1_INTEGER)\r
+DECLARE_ASN1_SET_OF(ASN1_INTEGER)\r
+\r
+DECLARE_STACK_OF(ASN1_GENERALSTRING)\r
+\r
+typedef struct asn1_type_st\r
+       {\r
+       int type;\r
+       union   {\r
+               char *ptr;\r
+               ASN1_BOOLEAN            boolean;\r
+               ASN1_STRING *           asn1_string;\r
+               ASN1_OBJECT *           object;\r
+               ASN1_INTEGER *          integer;\r
+               ASN1_ENUMERATED *       enumerated;\r
+               ASN1_BIT_STRING *       bit_string;\r
+               ASN1_OCTET_STRING *     octet_string;\r
+               ASN1_PRINTABLESTRING *  printablestring;\r
+               ASN1_T61STRING *        t61string;\r
+               ASN1_IA5STRING *        ia5string;\r
+               ASN1_GENERALSTRING *    generalstring;\r
+               ASN1_BMPSTRING *        bmpstring;\r
+               ASN1_UNIVERSALSTRING *  universalstring;\r
+               ASN1_UTCTIME *          utctime;\r
+               ASN1_GENERALIZEDTIME *  generalizedtime;\r
+               ASN1_VISIBLESTRING *    visiblestring;\r
+               ASN1_UTF8STRING *       utf8string;\r
+               /* set and sequence are left complete and still\r
+                * contain the set or sequence bytes */\r
+               ASN1_STRING *           set;\r
+               ASN1_STRING *           sequence;\r
+               ASN1_VALUE *            asn1_value;\r
+               } value;\r
+       } ASN1_TYPE;\r
+\r
+DECLARE_STACK_OF(ASN1_TYPE)\r
+DECLARE_ASN1_SET_OF(ASN1_TYPE)\r
+\r
+typedef STACK_OF(ASN1_TYPE) ASN1_SEQUENCE_ANY;\r
+\r
+DECLARE_ASN1_ENCODE_FUNCTIONS_const(ASN1_SEQUENCE_ANY, ASN1_SEQUENCE_ANY)\r
+DECLARE_ASN1_ENCODE_FUNCTIONS_const(ASN1_SEQUENCE_ANY, ASN1_SET_ANY)\r
+\r
+typedef struct NETSCAPE_X509_st\r
+       {\r
+       ASN1_OCTET_STRING *header;\r
+       X509 *cert;\r
+       } NETSCAPE_X509;\r
+\r
+/* This is used to contain a list of bit names */\r
+typedef struct BIT_STRING_BITNAME_st {\r
+       int bitnum;\r
+       const char *lname;\r
+       const char *sname;\r
+} BIT_STRING_BITNAME;\r
+\r
+\r
+#define M_ASN1_STRING_length(x)        ((x)->length)\r
+#define M_ASN1_STRING_length_set(x, n) ((x)->length = (n))\r
+#define M_ASN1_STRING_type(x)  ((x)->type)\r
+#define M_ASN1_STRING_data(x)  ((x)->data)\r
+\r
+/* Macros for string operations */\r
+#define M_ASN1_BIT_STRING_new()        (ASN1_BIT_STRING *)\\r
+               ASN1_STRING_type_new(V_ASN1_BIT_STRING)\r
+#define M_ASN1_BIT_STRING_free(a)      ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_ASN1_BIT_STRING_dup(a) (ASN1_BIT_STRING *)\\r
+               ASN1_STRING_dup((const ASN1_STRING *)a)\r
+#define M_ASN1_BIT_STRING_cmp(a,b) ASN1_STRING_cmp(\\r
+               (const ASN1_STRING *)a,(const ASN1_STRING *)b)\r
+#define M_ASN1_BIT_STRING_set(a,b,c) ASN1_STRING_set((ASN1_STRING *)a,b,c)\r
+\r
+#define M_ASN1_INTEGER_new()   (ASN1_INTEGER *)\\r
+               ASN1_STRING_type_new(V_ASN1_INTEGER)\r
+#define M_ASN1_INTEGER_free(a)         ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_ASN1_INTEGER_dup(a) (ASN1_INTEGER *)\\r
+               ASN1_STRING_dup((const ASN1_STRING *)a)\r
+#define M_ASN1_INTEGER_cmp(a,b)        ASN1_STRING_cmp(\\r
+               (const ASN1_STRING *)a,(const ASN1_STRING *)b)\r
+\r
+#define M_ASN1_ENUMERATED_new()        (ASN1_ENUMERATED *)\\r
+               ASN1_STRING_type_new(V_ASN1_ENUMERATED)\r
+#define M_ASN1_ENUMERATED_free(a)      ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_ASN1_ENUMERATED_dup(a) (ASN1_ENUMERATED *)\\r
+               ASN1_STRING_dup((const ASN1_STRING *)a)\r
+#define M_ASN1_ENUMERATED_cmp(a,b)     ASN1_STRING_cmp(\\r
+               (const ASN1_STRING *)a,(const ASN1_STRING *)b)\r
+\r
+#define M_ASN1_OCTET_STRING_new()      (ASN1_OCTET_STRING *)\\r
+               ASN1_STRING_type_new(V_ASN1_OCTET_STRING)\r
+#define M_ASN1_OCTET_STRING_free(a)    ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_ASN1_OCTET_STRING_dup(a) (ASN1_OCTET_STRING *)\\r
+               ASN1_STRING_dup((const ASN1_STRING *)a)\r
+#define M_ASN1_OCTET_STRING_cmp(a,b) ASN1_STRING_cmp(\\r
+               (const ASN1_STRING *)a,(const ASN1_STRING *)b)\r
+#define M_ASN1_OCTET_STRING_set(a,b,c) ASN1_STRING_set((ASN1_STRING *)a,b,c)\r
+#define M_ASN1_OCTET_STRING_print(a,b) ASN1_STRING_print(a,(ASN1_STRING *)b)\r
+#define M_i2d_ASN1_OCTET_STRING(a,pp) \\r
+               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_OCTET_STRING,\\r
+               V_ASN1_UNIVERSAL)\r
+\r
+#define B_ASN1_TIME \\r
+                       B_ASN1_UTCTIME | \\r
+                       B_ASN1_GENERALIZEDTIME\r
+\r
+#define B_ASN1_PRINTABLE \\r
+                       B_ASN1_NUMERICSTRING| \\r
+                       B_ASN1_PRINTABLESTRING| \\r
+                       B_ASN1_T61STRING| \\r
+                       B_ASN1_IA5STRING| \\r
+                       B_ASN1_BIT_STRING| \\r
+                       B_ASN1_UNIVERSALSTRING|\\r
+                       B_ASN1_BMPSTRING|\\r
+                       B_ASN1_UTF8STRING|\\r
+                       B_ASN1_SEQUENCE|\\r
+                       B_ASN1_UNKNOWN\r
+\r
+#define B_ASN1_DIRECTORYSTRING \\r
+                       B_ASN1_PRINTABLESTRING| \\r
+                       B_ASN1_TELETEXSTRING|\\r
+                       B_ASN1_BMPSTRING|\\r
+                       B_ASN1_UNIVERSALSTRING|\\r
+                       B_ASN1_UTF8STRING\r
+\r
+#define B_ASN1_DISPLAYTEXT \\r
+                       B_ASN1_IA5STRING| \\r
+                       B_ASN1_VISIBLESTRING| \\r
+                       B_ASN1_BMPSTRING|\\r
+                       B_ASN1_UTF8STRING\r
+\r
+#define M_ASN1_PRINTABLE_new() ASN1_STRING_type_new(V_ASN1_T61STRING)\r
+#define M_ASN1_PRINTABLE_free(a)       ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_i2d_ASN1_PRINTABLE(a,pp) i2d_ASN1_bytes((ASN1_STRING *)a,\\r
+               pp,a->type,V_ASN1_UNIVERSAL)\r
+#define M_d2i_ASN1_PRINTABLE(a,pp,l) \\r
+               d2i_ASN1_type_bytes((ASN1_STRING **)a,pp,l, \\r
+                       B_ASN1_PRINTABLE)\r
+\r
+#define M_DIRECTORYSTRING_new() ASN1_STRING_type_new(V_ASN1_PRINTABLESTRING)\r
+#define M_DIRECTORYSTRING_free(a)      ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_i2d_DIRECTORYSTRING(a,pp) i2d_ASN1_bytes((ASN1_STRING *)a,\\r
+                                               pp,a->type,V_ASN1_UNIVERSAL)\r
+#define M_d2i_DIRECTORYSTRING(a,pp,l) \\r
+               d2i_ASN1_type_bytes((ASN1_STRING **)a,pp,l, \\r
+                       B_ASN1_DIRECTORYSTRING)\r
+\r
+#define M_DISPLAYTEXT_new() ASN1_STRING_type_new(V_ASN1_VISIBLESTRING)\r
+#define M_DISPLAYTEXT_free(a) ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_i2d_DISPLAYTEXT(a,pp) i2d_ASN1_bytes((ASN1_STRING *)a,\\r
+                                               pp,a->type,V_ASN1_UNIVERSAL)\r
+#define M_d2i_DISPLAYTEXT(a,pp,l) \\r
+               d2i_ASN1_type_bytes((ASN1_STRING **)a,pp,l, \\r
+                       B_ASN1_DISPLAYTEXT)\r
+\r
+#define M_ASN1_PRINTABLESTRING_new() (ASN1_PRINTABLESTRING *)\\r
+               ASN1_STRING_type_new(V_ASN1_PRINTABLESTRING)\r
+#define M_ASN1_PRINTABLESTRING_free(a) ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_i2d_ASN1_PRINTABLESTRING(a,pp) \\r
+               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_PRINTABLESTRING,\\r
+               V_ASN1_UNIVERSAL)\r
+#define M_d2i_ASN1_PRINTABLESTRING(a,pp,l) \\r
+               (ASN1_PRINTABLESTRING *)d2i_ASN1_type_bytes\\r
+               ((ASN1_STRING **)a,pp,l,B_ASN1_PRINTABLESTRING)\r
+\r
+#define M_ASN1_T61STRING_new() (ASN1_T61STRING *)\\r
+               ASN1_STRING_type_new(V_ASN1_T61STRING)\r
+#define M_ASN1_T61STRING_free(a)       ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_i2d_ASN1_T61STRING(a,pp) \\r
+               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_T61STRING,\\r
+               V_ASN1_UNIVERSAL)\r
+#define M_d2i_ASN1_T61STRING(a,pp,l) \\r
+               (ASN1_T61STRING *)d2i_ASN1_type_bytes\\r
+               ((ASN1_STRING **)a,pp,l,B_ASN1_T61STRING)\r
+\r
+#define M_ASN1_IA5STRING_new() (ASN1_IA5STRING *)\\r
+               ASN1_STRING_type_new(V_ASN1_IA5STRING)\r
+#define M_ASN1_IA5STRING_free(a)       ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_ASN1_IA5STRING_dup(a)        \\r
+               (ASN1_IA5STRING *)ASN1_STRING_dup((const ASN1_STRING *)a)\r
+#define M_i2d_ASN1_IA5STRING(a,pp) \\r
+               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_IA5STRING,\\r
+                       V_ASN1_UNIVERSAL)\r
+#define M_d2i_ASN1_IA5STRING(a,pp,l) \\r
+               (ASN1_IA5STRING *)d2i_ASN1_type_bytes((ASN1_STRING **)a,pp,l,\\r
+                       B_ASN1_IA5STRING)\r
+\r
+#define M_ASN1_UTCTIME_new()   (ASN1_UTCTIME *)\\r
+               ASN1_STRING_type_new(V_ASN1_UTCTIME)\r
+#define M_ASN1_UTCTIME_free(a) ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_ASN1_UTCTIME_dup(a) (ASN1_UTCTIME *)\\r
+               ASN1_STRING_dup((const ASN1_STRING *)a)\r
+\r
+#define M_ASN1_GENERALIZEDTIME_new()   (ASN1_GENERALIZEDTIME *)\\r
+               ASN1_STRING_type_new(V_ASN1_GENERALIZEDTIME)\r
+#define M_ASN1_GENERALIZEDTIME_free(a) ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_ASN1_GENERALIZEDTIME_dup(a) (ASN1_GENERALIZEDTIME *)ASN1_STRING_dup(\\r
+       (const ASN1_STRING *)a)\r
+\r
+#define M_ASN1_TIME_new()      (ASN1_TIME *)\\r
+               ASN1_STRING_type_new(V_ASN1_UTCTIME)\r
+#define M_ASN1_TIME_free(a)    ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_ASN1_TIME_dup(a) (ASN1_TIME *)\\r
+       ASN1_STRING_dup((const ASN1_STRING *)a)\r
+\r
+#define M_ASN1_GENERALSTRING_new()     (ASN1_GENERALSTRING *)\\r
+               ASN1_STRING_type_new(V_ASN1_GENERALSTRING)\r
+#define M_ASN1_GENERALSTRING_free(a)   ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_i2d_ASN1_GENERALSTRING(a,pp) \\r
+               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_GENERALSTRING,\\r
+                       V_ASN1_UNIVERSAL)\r
+#define M_d2i_ASN1_GENERALSTRING(a,pp,l) \\r
+               (ASN1_GENERALSTRING *)d2i_ASN1_type_bytes\\r
+               ((ASN1_STRING **)a,pp,l,B_ASN1_GENERALSTRING)\r
+\r
+#define M_ASN1_UNIVERSALSTRING_new()   (ASN1_UNIVERSALSTRING *)\\r
+               ASN1_STRING_type_new(V_ASN1_UNIVERSALSTRING)\r
+#define M_ASN1_UNIVERSALSTRING_free(a) ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_i2d_ASN1_UNIVERSALSTRING(a,pp) \\r
+               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_UNIVERSALSTRING,\\r
+                       V_ASN1_UNIVERSAL)\r
+#define M_d2i_ASN1_UNIVERSALSTRING(a,pp,l) \\r
+               (ASN1_UNIVERSALSTRING *)d2i_ASN1_type_bytes\\r
+               ((ASN1_STRING **)a,pp,l,B_ASN1_UNIVERSALSTRING)\r
+\r
+#define M_ASN1_BMPSTRING_new() (ASN1_BMPSTRING *)\\r
+               ASN1_STRING_type_new(V_ASN1_BMPSTRING)\r
+#define M_ASN1_BMPSTRING_free(a)       ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_i2d_ASN1_BMPSTRING(a,pp) \\r
+               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_BMPSTRING,\\r
+                       V_ASN1_UNIVERSAL)\r
+#define M_d2i_ASN1_BMPSTRING(a,pp,l) \\r
+               (ASN1_BMPSTRING *)d2i_ASN1_type_bytes\\r
+               ((ASN1_STRING **)a,pp,l,B_ASN1_BMPSTRING)\r
+\r
+#define M_ASN1_VISIBLESTRING_new()     (ASN1_VISIBLESTRING *)\\r
+               ASN1_STRING_type_new(V_ASN1_VISIBLESTRING)\r
+#define M_ASN1_VISIBLESTRING_free(a)   ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_i2d_ASN1_VISIBLESTRING(a,pp) \\r
+               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_VISIBLESTRING,\\r
+                       V_ASN1_UNIVERSAL)\r
+#define M_d2i_ASN1_VISIBLESTRING(a,pp,l) \\r
+               (ASN1_VISIBLESTRING *)d2i_ASN1_type_bytes\\r
+               ((ASN1_STRING **)a,pp,l,B_ASN1_VISIBLESTRING)\r
+\r
+#define M_ASN1_UTF8STRING_new()        (ASN1_UTF8STRING *)\\r
+               ASN1_STRING_type_new(V_ASN1_UTF8STRING)\r
+#define M_ASN1_UTF8STRING_free(a)      ASN1_STRING_free((ASN1_STRING *)a)\r
+#define M_i2d_ASN1_UTF8STRING(a,pp) \\r
+               i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_UTF8STRING,\\r
+                       V_ASN1_UNIVERSAL)\r
+#define M_d2i_ASN1_UTF8STRING(a,pp,l) \\r
+               (ASN1_UTF8STRING *)d2i_ASN1_type_bytes\\r
+               ((ASN1_STRING **)a,pp,l,B_ASN1_UTF8STRING)\r
+\r
+  /* for the is_set parameter to i2d_ASN1_SET */\r
+#define IS_SEQUENCE    0\r
+#define IS_SET         1\r
+\r
+DECLARE_ASN1_FUNCTIONS_fname(ASN1_TYPE, ASN1_ANY, ASN1_TYPE)\r
+\r
+int ASN1_TYPE_get(ASN1_TYPE *a);\r
+void ASN1_TYPE_set(ASN1_TYPE *a, int type, void *value);\r
+int ASN1_TYPE_set1(ASN1_TYPE *a, int type, const void *value);\r
+int            ASN1_TYPE_cmp(ASN1_TYPE *a, ASN1_TYPE *b);\r
+\r
+ASN1_OBJECT *  ASN1_OBJECT_new(void );\r
+void           ASN1_OBJECT_free(ASN1_OBJECT *a);\r
+int            i2d_ASN1_OBJECT(ASN1_OBJECT *a,unsigned char **pp);\r
+ASN1_OBJECT *  c2i_ASN1_OBJECT(ASN1_OBJECT **a,const unsigned char **pp,\r
+                       long length);\r
+ASN1_OBJECT *  d2i_ASN1_OBJECT(ASN1_OBJECT **a,const unsigned char **pp,\r
+                       long length);\r
+\r
+DECLARE_ASN1_ITEM(ASN1_OBJECT)\r
+\r
+DECLARE_STACK_OF(ASN1_OBJECT)\r
+DECLARE_ASN1_SET_OF(ASN1_OBJECT)\r
+\r
+ASN1_STRING *  ASN1_STRING_new(void);\r
+void           ASN1_STRING_free(ASN1_STRING *a);\r
+int            ASN1_STRING_copy(ASN1_STRING *dst, const ASN1_STRING *str);\r
+ASN1_STRING *  ASN1_STRING_dup(const ASN1_STRING *a);\r
+ASN1_STRING *  ASN1_STRING_type_new(int type );\r
+int            ASN1_STRING_cmp(const ASN1_STRING *a, const ASN1_STRING *b);\r
+  /* Since this is used to store all sorts of things, via macros, for now, make\r
+     its data void * */\r
+int            ASN1_STRING_set(ASN1_STRING *str, const void *data, int len);\r
+void           ASN1_STRING_set0(ASN1_STRING *str, void *data, int len);\r
+int ASN1_STRING_length(const ASN1_STRING *x);\r
+void ASN1_STRING_length_set(ASN1_STRING *x, int n);\r
+int ASN1_STRING_type(ASN1_STRING *x);\r
+unsigned char * ASN1_STRING_data(ASN1_STRING *x);\r
+\r
+DECLARE_ASN1_FUNCTIONS(ASN1_BIT_STRING)\r
+int            i2c_ASN1_BIT_STRING(ASN1_BIT_STRING *a,unsigned char **pp);\r
+ASN1_BIT_STRING *c2i_ASN1_BIT_STRING(ASN1_BIT_STRING **a,const unsigned char **pp,\r
+                       long length);\r
+int            ASN1_BIT_STRING_set(ASN1_BIT_STRING *a, unsigned char *d,\r
+                       int length );\r
+int            ASN1_BIT_STRING_set_bit(ASN1_BIT_STRING *a, int n, int value);\r
+int            ASN1_BIT_STRING_get_bit(ASN1_BIT_STRING *a, int n);\r
+int            ASN1_BIT_STRING_check(ASN1_BIT_STRING *a,\r
+                                     unsigned char *flags, int flags_len);\r
+\r
+#ifndef OPENSSL_NO_BIO\r
+int ASN1_BIT_STRING_name_print(BIO *out, ASN1_BIT_STRING *bs,\r
+                               BIT_STRING_BITNAME *tbl, int indent);\r
+#endif\r
+int ASN1_BIT_STRING_num_asc(char *name, BIT_STRING_BITNAME *tbl);\r
+int ASN1_BIT_STRING_set_asc(ASN1_BIT_STRING *bs, char *name, int value,\r
+                               BIT_STRING_BITNAME *tbl);\r
+\r
+int            i2d_ASN1_BOOLEAN(int a,unsigned char **pp);\r
+int            d2i_ASN1_BOOLEAN(int *a,const unsigned char **pp,long length);\r
+\r
+DECLARE_ASN1_FUNCTIONS(ASN1_INTEGER)\r
+int            i2c_ASN1_INTEGER(ASN1_INTEGER *a,unsigned char **pp);\r
+ASN1_INTEGER *c2i_ASN1_INTEGER(ASN1_INTEGER **a,const unsigned char **pp,\r
+                       long length);\r
+ASN1_INTEGER *d2i_ASN1_UINTEGER(ASN1_INTEGER **a,const unsigned char **pp,\r
+                       long length);\r
+ASN1_INTEGER * ASN1_INTEGER_dup(const ASN1_INTEGER *x);\r
+int ASN1_INTEGER_cmp(const ASN1_INTEGER *x, const ASN1_INTEGER *y);\r
+\r
+DECLARE_ASN1_FUNCTIONS(ASN1_ENUMERATED)\r
+\r
+int ASN1_UTCTIME_check(ASN1_UTCTIME *a);\r
+ASN1_UTCTIME *ASN1_UTCTIME_set(ASN1_UTCTIME *s,time_t t);\r
+ASN1_UTCTIME *ASN1_UTCTIME_adj(ASN1_UTCTIME *s, time_t t,\r
+                               int offset_day, long offset_sec);\r
+int ASN1_UTCTIME_set_string(ASN1_UTCTIME *s, const char *str);\r
+int ASN1_UTCTIME_cmp_time_t(const ASN1_UTCTIME *s, time_t t);\r
+#if 0\r
+time_t ASN1_UTCTIME_get(const ASN1_UTCTIME *s);\r
+#endif\r
+\r
+int ASN1_GENERALIZEDTIME_check(ASN1_GENERALIZEDTIME *a);\r
+ASN1_GENERALIZEDTIME *ASN1_GENERALIZEDTIME_set(ASN1_GENERALIZEDTIME *s,time_t t);\r
+ASN1_GENERALIZEDTIME *ASN1_GENERALIZEDTIME_adj(ASN1_GENERALIZEDTIME *s,\r
+            time_t t, int offset_day, long offset_sec);\r
+int ASN1_GENERALIZEDTIME_set_string(ASN1_GENERALIZEDTIME *s, const char *str);\r
+\r
+DECLARE_ASN1_FUNCTIONS(ASN1_OCTET_STRING)\r
+ASN1_OCTET_STRING *    ASN1_OCTET_STRING_dup(const ASN1_OCTET_STRING *a);\r
+int    ASN1_OCTET_STRING_cmp(const ASN1_OCTET_STRING *a, const ASN1_OCTET_STRING *b);\r
+int    ASN1_OCTET_STRING_set(ASN1_OCTET_STRING *str, const unsigned char *data, int len);\r
+\r
+DECLARE_ASN1_FUNCTIONS(ASN1_VISIBLESTRING)\r
+DECLARE_ASN1_FUNCTIONS(ASN1_UNIVERSALSTRING)\r
+DECLARE_ASN1_FUNCTIONS(ASN1_UTF8STRING)\r
+DECLARE_ASN1_FUNCTIONS(ASN1_NULL)\r
+DECLARE_ASN1_FUNCTIONS(ASN1_BMPSTRING)\r
+\r
+int UTF8_getc(const unsigned char *str, int len, unsigned long *val);\r
+int UTF8_putc(unsigned char *str, int len, unsigned long value);\r
+\r
+DECLARE_ASN1_FUNCTIONS_name(ASN1_STRING, ASN1_PRINTABLE)\r
+\r
+DECLARE_ASN1_FUNCTIONS_name(ASN1_STRING, DIRECTORYSTRING)\r
+DECLARE_ASN1_FUNCTIONS_name(ASN1_STRING, DISPLAYTEXT)\r
+DECLARE_ASN1_FUNCTIONS(ASN1_PRINTABLESTRING)\r
+DECLARE_ASN1_FUNCTIONS(ASN1_T61STRING)\r
+DECLARE_ASN1_FUNCTIONS(ASN1_IA5STRING)\r
+DECLARE_ASN1_FUNCTIONS(ASN1_GENERALSTRING)\r
+DECLARE_ASN1_FUNCTIONS(ASN1_UTCTIME)\r
+DECLARE_ASN1_FUNCTIONS(ASN1_GENERALIZEDTIME)\r
+DECLARE_ASN1_FUNCTIONS(ASN1_TIME)\r
+\r
+DECLARE_ASN1_ITEM(ASN1_OCTET_STRING_NDEF)\r
+\r
+ASN1_TIME *ASN1_TIME_set(ASN1_TIME *s,time_t t);\r
+ASN1_TIME *ASN1_TIME_adj(ASN1_TIME *s,time_t t,\r
+                               int offset_day, long offset_sec);\r
+int ASN1_TIME_check(ASN1_TIME *t);\r
+ASN1_GENERALIZEDTIME *ASN1_TIME_to_generalizedtime(ASN1_TIME *t, ASN1_GENERALIZEDTIME **out);\r
+int ASN1_TIME_set_string(ASN1_TIME *s, const char *str);\r
+\r
+int i2d_ASN1_SET(STACK_OF(OPENSSL_BLOCK) *a, unsigned char **pp,\r
+                i2d_of_void *i2d, int ex_tag, int ex_class,\r
+                int is_set);\r
+STACK_OF(OPENSSL_BLOCK) *d2i_ASN1_SET(STACK_OF(OPENSSL_BLOCK) **a,\r
+                             const unsigned char **pp,\r
+                             long length, d2i_of_void *d2i,\r
+                             void (*free_func)(OPENSSL_BLOCK), int ex_tag,\r
+                             int ex_class);\r
+\r
+#ifndef OPENSSL_NO_BIO\r
+int i2a_ASN1_INTEGER(BIO *bp, ASN1_INTEGER *a);\r
+int a2i_ASN1_INTEGER(BIO *bp,ASN1_INTEGER *bs,char *buf,int size);\r
+int i2a_ASN1_ENUMERATED(BIO *bp, ASN1_ENUMERATED *a);\r
+int a2i_ASN1_ENUMERATED(BIO *bp,ASN1_ENUMERATED *bs,char *buf,int size);\r
+int i2a_ASN1_OBJECT(BIO *bp,ASN1_OBJECT *a);\r
+int a2i_ASN1_STRING(BIO *bp,ASN1_STRING *bs,char *buf,int size);\r
+int i2a_ASN1_STRING(BIO *bp, ASN1_STRING *a, int type);\r
+#endif\r
+int i2t_ASN1_OBJECT(char *buf,int buf_len,ASN1_OBJECT *a);\r
+\r
+int a2d_ASN1_OBJECT(unsigned char *out,int olen, const char *buf, int num);\r
+ASN1_OBJECT *ASN1_OBJECT_create(int nid, unsigned char *data,int len,\r
+       const char *sn, const char *ln);\r
+\r
+int ASN1_INTEGER_set(ASN1_INTEGER *a, long v);\r
+long ASN1_INTEGER_get(const ASN1_INTEGER *a);\r
+ASN1_INTEGER *BN_to_ASN1_INTEGER(const BIGNUM *bn, ASN1_INTEGER *ai);\r
+BIGNUM *ASN1_INTEGER_to_BN(const ASN1_INTEGER *ai,BIGNUM *bn);\r
+\r
+int ASN1_ENUMERATED_set(ASN1_ENUMERATED *a, long v);\r
+long ASN1_ENUMERATED_get(ASN1_ENUMERATED *a);\r
+ASN1_ENUMERATED *BN_to_ASN1_ENUMERATED(BIGNUM *bn, ASN1_ENUMERATED *ai);\r
+BIGNUM *ASN1_ENUMERATED_to_BN(ASN1_ENUMERATED *ai,BIGNUM *bn);\r
+\r
+/* General */\r
+/* given a string, return the correct type, max is the maximum length */\r
+int ASN1_PRINTABLE_type(const unsigned char *s, int max);\r
+\r
+int i2d_ASN1_bytes(ASN1_STRING *a, unsigned char **pp, int tag, int xclass);\r
+ASN1_STRING *d2i_ASN1_bytes(ASN1_STRING **a, const unsigned char **pp,\r
+       long length, int Ptag, int Pclass);\r
+unsigned long ASN1_tag2bit(int tag);\r
+/* type is one or more of the B_ASN1_ values. */\r
+ASN1_STRING *d2i_ASN1_type_bytes(ASN1_STRING **a,const unsigned char **pp,\r
+               long length,int type);\r
+\r
+/* PARSING */\r
+int asn1_Finish(ASN1_CTX *c);\r
+int asn1_const_Finish(ASN1_const_CTX *c);\r
+\r
+/* SPECIALS */\r
+int ASN1_get_object(const unsigned char **pp, long *plength, int *ptag,\r
+       int *pclass, long omax);\r
+int ASN1_check_infinite_end(unsigned char **p,long len);\r
+int ASN1_const_check_infinite_end(const unsigned char **p,long len);\r
+void ASN1_put_object(unsigned char **pp, int constructed, int length,\r
+       int tag, int xclass);\r
+int ASN1_put_eoc(unsigned char **pp);\r
+int ASN1_object_size(int constructed, int length, int tag);\r
+\r
+/* Used to implement other functions */\r
+void *ASN1_dup(i2d_of_void *i2d, d2i_of_void *d2i, void *x);\r
+\r
+#define ASN1_dup_of(type,i2d,d2i,x) \\r
+    ((type*)ASN1_dup(CHECKED_I2D_OF(type, i2d), \\r
+                    CHECKED_D2I_OF(type, d2i), \\r
+                    CHECKED_PTR_OF(type, x)))\r
+\r
+#define ASN1_dup_of_const(type,i2d,d2i,x) \\r
+    ((type*)ASN1_dup(CHECKED_I2D_OF(const type, i2d), \\r
+                    CHECKED_D2I_OF(type, d2i), \\r
+                    CHECKED_PTR_OF(const type, x)))\r
+\r
+void *ASN1_item_dup(const ASN1_ITEM *it, void *x);\r
+\r
+/* ASN1 alloc/free macros for when a type is only used internally */\r
+\r
+#define M_ASN1_new_of(type) (type *)ASN1_item_new(ASN1_ITEM_rptr(type))\r
+#define M_ASN1_free_of(x, type) \\r
+               ASN1_item_free(CHECKED_PTR_OF(type, x), ASN1_ITEM_rptr(type))\r
+\r
+#ifndef OPENSSL_NO_FP_API\r
+void *ASN1_d2i_fp(void *(*xnew)(void), d2i_of_void *d2i, FILE *in, void **x);\r
+\r
+#define ASN1_d2i_fp_of(type,xnew,d2i,in,x) \\r
+    ((type*)ASN1_d2i_fp(CHECKED_NEW_OF(type, xnew), \\r
+                       CHECKED_D2I_OF(type, d2i), \\r
+                       in, \\r
+                       CHECKED_PPTR_OF(type, x)))\r
+\r
+void *ASN1_item_d2i_fp(const ASN1_ITEM *it, FILE *in, void *x);\r
+int ASN1_i2d_fp(i2d_of_void *i2d,FILE *out,void *x);\r
+\r
+#define ASN1_i2d_fp_of(type,i2d,out,x) \\r
+    (ASN1_i2d_fp(CHECKED_I2D_OF(type, i2d), \\r
+                out, \\r
+                CHECKED_PTR_OF(type, x)))\r
+\r
+#define ASN1_i2d_fp_of_const(type,i2d,out,x) \\r
+    (ASN1_i2d_fp(CHECKED_I2D_OF(const type, i2d), \\r
+                out, \\r
+                CHECKED_PTR_OF(const type, x)))\r
+\r
+int ASN1_item_i2d_fp(const ASN1_ITEM *it, FILE *out, void *x);\r
+int ASN1_STRING_print_ex_fp(FILE *fp, ASN1_STRING *str, unsigned long flags);\r
+#endif\r
+\r
+int ASN1_STRING_to_UTF8(unsigned char **out, ASN1_STRING *in);\r
+\r
+#ifndef OPENSSL_NO_BIO\r
+void *ASN1_d2i_bio(void *(*xnew)(void), d2i_of_void *d2i, BIO *in, void **x);\r
+\r
+#define ASN1_d2i_bio_of(type,xnew,d2i,in,x) \\r
+    ((type*)ASN1_d2i_bio( CHECKED_NEW_OF(type, xnew), \\r
+                         CHECKED_D2I_OF(type, d2i), \\r
+                         in, \\r
+                         CHECKED_PPTR_OF(type, x)))\r
+\r
+void *ASN1_item_d2i_bio(const ASN1_ITEM *it, BIO *in, void *x);\r
+int ASN1_i2d_bio(i2d_of_void *i2d,BIO *out, unsigned char *x);\r
+\r
+#define ASN1_i2d_bio_of(type,i2d,out,x) \\r
+    (ASN1_i2d_bio(CHECKED_I2D_OF(type, i2d), \\r
+                 out, \\r
+                 CHECKED_PTR_OF(type, x)))\r
+\r
+#define ASN1_i2d_bio_of_const(type,i2d,out,x) \\r
+    (ASN1_i2d_bio(CHECKED_I2D_OF(const type, i2d), \\r
+                 out, \\r
+                 CHECKED_PTR_OF(const type, x)))\r
+\r
+int ASN1_item_i2d_bio(const ASN1_ITEM *it, BIO *out, void *x);\r
+int ASN1_UTCTIME_print(BIO *fp, const ASN1_UTCTIME *a);\r
+int ASN1_GENERALIZEDTIME_print(BIO *fp, const ASN1_GENERALIZEDTIME *a);\r
+int ASN1_TIME_print(BIO *fp, const ASN1_TIME *a);\r
+int ASN1_STRING_print(BIO *bp, const ASN1_STRING *v);\r
+int ASN1_STRING_print_ex(BIO *out, ASN1_STRING *str, unsigned long flags);\r
+int ASN1_bn_print(BIO *bp, const char *number, const BIGNUM *num,\r
+                               unsigned char *buf, int off);\r
+int ASN1_parse(BIO *bp,const unsigned char *pp,long len,int indent);\r
+int ASN1_parse_dump(BIO *bp,const unsigned char *pp,long len,int indent,int dump);\r
+#endif\r
+const char *ASN1_tag2str(int tag);\r
+\r
+/* Used to load and write netscape format cert */\r
+\r
+DECLARE_ASN1_FUNCTIONS(NETSCAPE_X509)\r
+\r
+int ASN1_UNIVERSALSTRING_to_string(ASN1_UNIVERSALSTRING *s);\r
+\r
+int ASN1_TYPE_set_octetstring(ASN1_TYPE *a,\r
+       unsigned char *data, int len);\r
+int ASN1_TYPE_get_octetstring(ASN1_TYPE *a,\r
+       unsigned char *data, int max_len);\r
+int ASN1_TYPE_set_int_octetstring(ASN1_TYPE *a, long num,\r
+       unsigned char *data, int len);\r
+int ASN1_TYPE_get_int_octetstring(ASN1_TYPE *a,long *num,\r
+       unsigned char *data, int max_len);\r
+\r
+STACK_OF(OPENSSL_BLOCK) *ASN1_seq_unpack(const unsigned char *buf, int len,\r
+                                d2i_of_void *d2i, void (*free_func)(OPENSSL_BLOCK));\r
+unsigned char *ASN1_seq_pack(STACK_OF(OPENSSL_BLOCK) *safes, i2d_of_void *i2d,\r
+                            unsigned char **buf, int *len );\r
+void *ASN1_unpack_string(ASN1_STRING *oct, d2i_of_void *d2i);\r
+void *ASN1_item_unpack(ASN1_STRING *oct, const ASN1_ITEM *it);\r
+ASN1_STRING *ASN1_pack_string(void *obj, i2d_of_void *i2d,\r
+                             ASN1_OCTET_STRING **oct);\r
+\r
+#define ASN1_pack_string_of(type,obj,i2d,oct) \\r
+    (ASN1_pack_string(CHECKED_PTR_OF(type, obj), \\r
+                     CHECKED_I2D_OF(type, i2d), \\r
+                     oct))\r
+\r
+ASN1_STRING *ASN1_item_pack(void *obj, const ASN1_ITEM *it, ASN1_OCTET_STRING **oct);\r
+\r
+void ASN1_STRING_set_default_mask(unsigned long mask);\r
+int ASN1_STRING_set_default_mask_asc(const char *p);\r
+unsigned long ASN1_STRING_get_default_mask(void);\r
+int ASN1_mbstring_copy(ASN1_STRING **out, const unsigned char *in, int len,\r
+                                       int inform, unsigned long mask);\r
+int ASN1_mbstring_ncopy(ASN1_STRING **out, const unsigned char *in, int len,\r
+                                       int inform, unsigned long mask,\r
+                                       long minsize, long maxsize);\r
+\r
+ASN1_STRING *ASN1_STRING_set_by_NID(ASN1_STRING **out,\r
+               const unsigned char *in, int inlen, int inform, int nid);\r
+ASN1_STRING_TABLE *ASN1_STRING_TABLE_get(int nid);\r
+int ASN1_STRING_TABLE_add(int, long, long, unsigned long, unsigned long);\r
+void ASN1_STRING_TABLE_cleanup(void);\r
+\r
+/* ASN1 template functions */\r
+\r
+/* Old API compatible functions */\r
+ASN1_VALUE *ASN1_item_new(const ASN1_ITEM *it);\r
+void ASN1_item_free(ASN1_VALUE *val, const ASN1_ITEM *it);\r
+ASN1_VALUE * ASN1_item_d2i(ASN1_VALUE **val, const unsigned char **in, long len, const ASN1_ITEM *it);\r
+int ASN1_item_i2d(ASN1_VALUE *val, unsigned char **out, const ASN1_ITEM *it);\r
+int ASN1_item_ndef_i2d(ASN1_VALUE *val, unsigned char **out, const ASN1_ITEM *it);\r
+\r
+void ASN1_add_oid_module(void);\r
+\r
+ASN1_TYPE *ASN1_generate_nconf(char *str, CONF *nconf);\r
+ASN1_TYPE *ASN1_generate_v3(char *str, X509V3_CTX *cnf);\r
+\r
+/* ASN1 Print flags */\r
+\r
+/* Indicate missing OPTIONAL fields */\r
+#define ASN1_PCTX_FLAGS_SHOW_ABSENT            0x001\r
+/* Mark start and end of SEQUENCE */\r
+#define ASN1_PCTX_FLAGS_SHOW_SEQUENCE          0x002\r
+/* Mark start and end of SEQUENCE/SET OF */\r
+#define ASN1_PCTX_FLAGS_SHOW_SSOF              0x004\r
+/* Show the ASN1 type of primitives */\r
+#define ASN1_PCTX_FLAGS_SHOW_TYPE              0x008\r
+/* Don't show ASN1 type of ANY */\r
+#define ASN1_PCTX_FLAGS_NO_ANY_TYPE            0x010\r
+/* Don't show ASN1 type of MSTRINGs */\r
+#define ASN1_PCTX_FLAGS_NO_MSTRING_TYPE                0x020\r
+/* Don't show field names in SEQUENCE */\r
+#define ASN1_PCTX_FLAGS_NO_FIELD_NAME          0x040\r
+/* Show structure names of each SEQUENCE field */\r
+#define ASN1_PCTX_FLAGS_SHOW_FIELD_STRUCT_NAME 0x080\r
+/* Don't show structure name even at top level */\r
+#define ASN1_PCTX_FLAGS_NO_STRUCT_NAME         0x100\r
+\r
+int ASN1_item_print(BIO *out, ASN1_VALUE *ifld, int indent,\r
+                               const ASN1_ITEM *it, const ASN1_PCTX *pctx);\r
+ASN1_PCTX *ASN1_PCTX_new(void);\r
+void ASN1_PCTX_free(ASN1_PCTX *p);\r
+unsigned long ASN1_PCTX_get_flags(ASN1_PCTX *p);\r
+void ASN1_PCTX_set_flags(ASN1_PCTX *p, unsigned long flags);\r
+unsigned long ASN1_PCTX_get_nm_flags(ASN1_PCTX *p);\r
+void ASN1_PCTX_set_nm_flags(ASN1_PCTX *p, unsigned long flags);\r
+unsigned long ASN1_PCTX_get_cert_flags(ASN1_PCTX *p);\r
+void ASN1_PCTX_set_cert_flags(ASN1_PCTX *p, unsigned long flags);\r
+unsigned long ASN1_PCTX_get_oid_flags(ASN1_PCTX *p);\r
+void ASN1_PCTX_set_oid_flags(ASN1_PCTX *p, unsigned long flags);\r
+unsigned long ASN1_PCTX_get_str_flags(ASN1_PCTX *p);\r
+void ASN1_PCTX_set_str_flags(ASN1_PCTX *p, unsigned long flags);\r
+\r
+BIO_METHOD *BIO_f_asn1(void);\r
+\r
+BIO *BIO_new_NDEF(BIO *out, ASN1_VALUE *val, const ASN1_ITEM *it);\r
+\r
+int i2d_ASN1_bio_stream(BIO *out, ASN1_VALUE *val, BIO *in, int flags,\r
+                               const ASN1_ITEM *it);\r
+int PEM_write_bio_ASN1_stream(BIO *out, ASN1_VALUE *val, BIO *in, int flags,\r
+                               const char *hdr,\r
+                               const ASN1_ITEM *it);\r
+int SMIME_write_ASN1(BIO *bio, ASN1_VALUE *val, BIO *data, int flags,\r
+                               int ctype_nid, int econt_nid,\r
+                               STACK_OF(X509_ALGOR) *mdalgs,\r
+                               const ASN1_ITEM *it);\r
+ASN1_VALUE *SMIME_read_ASN1(BIO *bio, BIO **bcont, const ASN1_ITEM *it);\r
+int SMIME_crlf_copy(BIO *in, BIO *out, int flags);\r
+int SMIME_text(BIO *in, BIO *out);\r
+\r
+/* BEGIN ERROR CODES */\r
+/* The following lines are auto generated by the script mkerr.pl. Any changes\r
+ * made after this point may be overwritten when the script is next run.\r
+ */\r
+void ERR_load_ASN1_strings(void);\r
+\r
+/* Error codes for the ASN1 functions. */\r
+\r
+/* Function codes. */\r
+#define ASN1_F_A2D_ASN1_OBJECT                          100\r
+#define ASN1_F_A2I_ASN1_ENUMERATED                      101\r
+#define ASN1_F_A2I_ASN1_INTEGER                                 102\r
+#define ASN1_F_A2I_ASN1_STRING                          103\r
+#define ASN1_F_APPEND_EXP                               176\r
+#define ASN1_F_ASN1_BIT_STRING_SET_BIT                  183\r
+#define ASN1_F_ASN1_CB                                  177\r
+#define ASN1_F_ASN1_CHECK_TLEN                          104\r
+#define ASN1_F_ASN1_COLLATE_PRIMITIVE                   105\r
+#define ASN1_F_ASN1_COLLECT                             106\r
+#define ASN1_F_ASN1_D2I_EX_PRIMITIVE                    108\r
+#define ASN1_F_ASN1_D2I_FP                              109\r
+#define ASN1_F_ASN1_D2I_READ_BIO                        107\r
+#define ASN1_F_ASN1_DIGEST                              184\r
+#define ASN1_F_ASN1_DO_ADB                              110\r
+#define ASN1_F_ASN1_DUP                                         111\r
+#define ASN1_F_ASN1_ENUMERATED_SET                      112\r
+#define ASN1_F_ASN1_ENUMERATED_TO_BN                    113\r
+#define ASN1_F_ASN1_EX_C2I                              204\r
+#define ASN1_F_ASN1_FIND_END                            190\r
+#define ASN1_F_ASN1_GENERALIZEDTIME_ADJ                         216\r
+#define ASN1_F_ASN1_GENERALIZEDTIME_SET                         185\r
+#define ASN1_F_ASN1_GENERATE_V3                                 178\r
+#define ASN1_F_ASN1_GET_OBJECT                          114\r
+#define ASN1_F_ASN1_HEADER_NEW                          115\r
+#define ASN1_F_ASN1_I2D_BIO                             116\r
+#define ASN1_F_ASN1_I2D_FP                              117\r
+#define ASN1_F_ASN1_INTEGER_SET                                 118\r
+#define ASN1_F_ASN1_INTEGER_TO_BN                       119\r
+#define ASN1_F_ASN1_ITEM_D2I_FP                                 206\r
+#define ASN1_F_ASN1_ITEM_DUP                            191\r
+#define ASN1_F_ASN1_ITEM_EX_COMBINE_NEW                         121\r
+#define ASN1_F_ASN1_ITEM_EX_D2I                                 120\r
+#define ASN1_F_ASN1_ITEM_I2D_BIO                        192\r
+#define ASN1_F_ASN1_ITEM_I2D_FP                                 193\r
+#define ASN1_F_ASN1_ITEM_PACK                           198\r
+#define ASN1_F_ASN1_ITEM_SIGN                           195\r
+#define ASN1_F_ASN1_ITEM_UNPACK                                 199\r
+#define ASN1_F_ASN1_ITEM_VERIFY                                 197\r
+#define ASN1_F_ASN1_MBSTRING_NCOPY                      122\r
+#define ASN1_F_ASN1_OBJECT_NEW                          123\r
+#define ASN1_F_ASN1_OUTPUT_DATA                                 214\r
+#define ASN1_F_ASN1_PACK_STRING                                 124\r
+#define ASN1_F_ASN1_PCTX_NEW                            205\r
+#define ASN1_F_ASN1_PKCS5_PBE_SET                       125\r
+#define ASN1_F_ASN1_SEQ_PACK                            126\r
+#define ASN1_F_ASN1_SEQ_UNPACK                          127\r
+#define ASN1_F_ASN1_SIGN                                128\r
+#define ASN1_F_ASN1_STR2TYPE                            179\r
+#define ASN1_F_ASN1_STRING_SET                          186\r
+#define ASN1_F_ASN1_STRING_TABLE_ADD                    129\r
+#define ASN1_F_ASN1_STRING_TYPE_NEW                     130\r
+#define ASN1_F_ASN1_TEMPLATE_EX_D2I                     132\r
+#define ASN1_F_ASN1_TEMPLATE_NEW                        133\r
+#define ASN1_F_ASN1_TEMPLATE_NOEXP_D2I                  131\r
+#define ASN1_F_ASN1_TIME_ADJ                            217\r
+#define ASN1_F_ASN1_TIME_SET                            175\r
+#define ASN1_F_ASN1_TYPE_GET_INT_OCTETSTRING            134\r
+#define ASN1_F_ASN1_TYPE_GET_OCTETSTRING                135\r
+#define ASN1_F_ASN1_UNPACK_STRING                       136\r
+#define ASN1_F_ASN1_UTCTIME_ADJ                                 218\r
+#define ASN1_F_ASN1_UTCTIME_SET                                 187\r
+#define ASN1_F_ASN1_VERIFY                              137\r
+#define ASN1_F_B64_READ_ASN1                            209\r
+#define ASN1_F_B64_WRITE_ASN1                           210\r
+#define ASN1_F_BIO_NEW_NDEF                             208\r
+#define ASN1_F_BITSTR_CB                                180\r
+#define ASN1_F_BN_TO_ASN1_ENUMERATED                    138\r
+#define ASN1_F_BN_TO_ASN1_INTEGER                       139\r
+#define ASN1_F_C2I_ASN1_BIT_STRING                      189\r
+#define ASN1_F_C2I_ASN1_INTEGER                                 194\r
+#define ASN1_F_C2I_ASN1_OBJECT                          196\r
+#define ASN1_F_COLLECT_DATA                             140\r
+#define ASN1_F_D2I_ASN1_BIT_STRING                      141\r
+#define ASN1_F_D2I_ASN1_BOOLEAN                                 142\r
+#define ASN1_F_D2I_ASN1_BYTES                           143\r
+#define ASN1_F_D2I_ASN1_GENERALIZEDTIME                         144\r
+#define ASN1_F_D2I_ASN1_HEADER                          145\r
+#define ASN1_F_D2I_ASN1_INTEGER                                 146\r
+#define ASN1_F_D2I_ASN1_OBJECT                          147\r
+#define ASN1_F_D2I_ASN1_SET                             148\r
+#define ASN1_F_D2I_ASN1_TYPE_BYTES                      149\r
+#define ASN1_F_D2I_ASN1_UINTEGER                        150\r
+#define ASN1_F_D2I_ASN1_UTCTIME                                 151\r
+#define ASN1_F_D2I_AUTOPRIVATEKEY                       207\r
+#define ASN1_F_D2I_NETSCAPE_RSA                                 152\r
+#define ASN1_F_D2I_NETSCAPE_RSA_2                       153\r
+#define ASN1_F_D2I_PRIVATEKEY                           154\r
+#define ASN1_F_D2I_PUBLICKEY                            155\r
+#define ASN1_F_D2I_RSA_NET                              200\r
+#define ASN1_F_D2I_RSA_NET_2                            201\r
+#define ASN1_F_D2I_X509                                         156\r
+#define ASN1_F_D2I_X509_CINF                            157\r
+#define ASN1_F_D2I_X509_PKEY                            159\r
+#define ASN1_F_I2D_ASN1_BIO_STREAM                      211\r
+#define ASN1_F_I2D_ASN1_SET                             188\r
+#define ASN1_F_I2D_ASN1_TIME                            160\r
+#define ASN1_F_I2D_DSA_PUBKEY                           161\r
+#define ASN1_F_I2D_EC_PUBKEY                            181\r
+#define ASN1_F_I2D_PRIVATEKEY                           163\r
+#define ASN1_F_I2D_PUBLICKEY                            164\r
+#define ASN1_F_I2D_RSA_NET                              162\r
+#define ASN1_F_I2D_RSA_PUBKEY                           165\r
+#define ASN1_F_LONG_C2I                                         166\r
+#define ASN1_F_OID_MODULE_INIT                          174\r
+#define ASN1_F_PARSE_TAGGING                            182\r
+#define ASN1_F_PKCS5_PBE2_SET_IV                        167\r
+#define ASN1_F_PKCS5_PBE_SET                            202\r
+#define ASN1_F_PKCS5_PBE_SET0_ALGOR                     215\r
+#define ASN1_F_SMIME_READ_ASN1                          212\r
+#define ASN1_F_SMIME_TEXT                               213\r
+#define ASN1_F_X509_CINF_NEW                            168\r
+#define ASN1_F_X509_CRL_ADD0_REVOKED                    169\r
+#define ASN1_F_X509_INFO_NEW                            170\r
+#define ASN1_F_X509_NAME_ENCODE                                 203\r
+#define ASN1_F_X509_NAME_EX_D2I                                 158\r
+#define ASN1_F_X509_NAME_EX_NEW                                 171\r
+#define ASN1_F_X509_NEW                                         172\r
+#define ASN1_F_X509_PKEY_NEW                            173\r
+\r
+/* Reason codes. */\r
+#define ASN1_R_ADDING_OBJECT                            171\r
+#define ASN1_R_ASN1_PARSE_ERROR                                 203\r
+#define ASN1_R_ASN1_SIG_PARSE_ERROR                     204\r
+#define ASN1_R_AUX_ERROR                                100\r
+#define ASN1_R_BAD_CLASS                                101\r
+#define ASN1_R_BAD_OBJECT_HEADER                        102\r
+#define ASN1_R_BAD_PASSWORD_READ                        103\r
+#define ASN1_R_BAD_TAG                                  104\r
+#define ASN1_R_BMPSTRING_IS_WRONG_LENGTH                214\r
+#define ASN1_R_BN_LIB                                   105\r
+#define ASN1_R_BOOLEAN_IS_WRONG_LENGTH                  106\r
+#define ASN1_R_BUFFER_TOO_SMALL                                 107\r
+#define ASN1_R_CIPHER_HAS_NO_OBJECT_IDENTIFIER          108\r
+#define ASN1_R_DATA_IS_WRONG                            109\r
+#define ASN1_R_DECODE_ERROR                             110\r
+#define ASN1_R_DECODING_ERROR                           111\r
+#define ASN1_R_DEPTH_EXCEEDED                           174\r
+#define ASN1_R_DIGEST_AND_KEY_TYPE_NOT_SUPPORTED        198\r
+#define ASN1_R_ENCODE_ERROR                             112\r
+#define ASN1_R_ERROR_GETTING_TIME                       173\r
+#define ASN1_R_ERROR_LOADING_SECTION                    172\r
+#define ASN1_R_ERROR_PARSING_SET_ELEMENT                113\r
+#define ASN1_R_ERROR_SETTING_CIPHER_PARAMS              114\r
+#define ASN1_R_EXPECTING_AN_INTEGER                     115\r
+#define ASN1_R_EXPECTING_AN_OBJECT                      116\r
+#define ASN1_R_EXPECTING_A_BOOLEAN                      117\r
+#define ASN1_R_EXPECTING_A_TIME                                 118\r
+#define ASN1_R_EXPLICIT_LENGTH_MISMATCH                         119\r
+#define ASN1_R_EXPLICIT_TAG_NOT_CONSTRUCTED             120\r
+#define ASN1_R_FIELD_MISSING                            121\r
+#define ASN1_R_FIRST_NUM_TOO_LARGE                      122\r
+#define ASN1_R_HEADER_TOO_LONG                          123\r
+#define ASN1_R_ILLEGAL_BITSTRING_FORMAT                         175\r
+#define ASN1_R_ILLEGAL_BOOLEAN                          176\r
+#define ASN1_R_ILLEGAL_CHARACTERS                       124\r
+#define ASN1_R_ILLEGAL_FORMAT                           177\r
+#define ASN1_R_ILLEGAL_HEX                              178\r
+#define ASN1_R_ILLEGAL_IMPLICIT_TAG                     179\r
+#define ASN1_R_ILLEGAL_INTEGER                          180\r
+#define ASN1_R_ILLEGAL_NESTED_TAGGING                   181\r
+#define ASN1_R_ILLEGAL_NULL                             125\r
+#define ASN1_R_ILLEGAL_NULL_VALUE                       182\r
+#define ASN1_R_ILLEGAL_OBJECT                           183\r
+#define ASN1_R_ILLEGAL_OPTIONAL_ANY                     126\r
+#define ASN1_R_ILLEGAL_OPTIONS_ON_ITEM_TEMPLATE                 170\r
+#define ASN1_R_ILLEGAL_TAGGED_ANY                       127\r
+#define ASN1_R_ILLEGAL_TIME_VALUE                       184\r
+#define ASN1_R_INTEGER_NOT_ASCII_FORMAT                         185\r
+#define ASN1_R_INTEGER_TOO_LARGE_FOR_LONG               128\r
+#define ASN1_R_INVALID_BMPSTRING_LENGTH                         129\r
+#define ASN1_R_INVALID_DIGIT                            130\r
+#define ASN1_R_INVALID_MIME_TYPE                        205\r
+#define ASN1_R_INVALID_MODIFIER                                 186\r
+#define ASN1_R_INVALID_NUMBER                           187\r
+#define ASN1_R_INVALID_OBJECT_ENCODING                  216\r
+#define ASN1_R_INVALID_SEPARATOR                        131\r
+#define ASN1_R_INVALID_TIME_FORMAT                      132\r
+#define ASN1_R_INVALID_UNIVERSALSTRING_LENGTH           133\r
+#define ASN1_R_INVALID_UTF8STRING                       134\r
+#define ASN1_R_IV_TOO_LARGE                             135\r
+#define ASN1_R_LENGTH_ERROR                             136\r
+#define ASN1_R_LIST_ERROR                               188\r
+#define ASN1_R_MIME_NO_CONTENT_TYPE                     206\r
+#define ASN1_R_MIME_PARSE_ERROR                                 207\r
+#define ASN1_R_MIME_SIG_PARSE_ERROR                     208\r
+#define ASN1_R_MISSING_EOC                              137\r
+#define ASN1_R_MISSING_SECOND_NUMBER                    138\r
+#define ASN1_R_MISSING_VALUE                            189\r
+#define ASN1_R_MSTRING_NOT_UNIVERSAL                    139\r
+#define ASN1_R_MSTRING_WRONG_TAG                        140\r
+#define ASN1_R_NESTED_ASN1_STRING                       197\r
+#define ASN1_R_NON_HEX_CHARACTERS                       141\r
+#define ASN1_R_NOT_ASCII_FORMAT                                 190\r
+#define ASN1_R_NOT_ENOUGH_DATA                          142\r
+#define ASN1_R_NO_CONTENT_TYPE                          209\r
+#define ASN1_R_NO_DEFAULT_DIGEST                        201\r
+#define ASN1_R_NO_MATCHING_CHOICE_TYPE                  143\r
+#define ASN1_R_NO_MULTIPART_BODY_FAILURE                210\r
+#define ASN1_R_NO_MULTIPART_BOUNDARY                    211\r
+#define ASN1_R_NO_SIG_CONTENT_TYPE                      212\r
+#define ASN1_R_NULL_IS_WRONG_LENGTH                     144\r
+#define ASN1_R_OBJECT_NOT_ASCII_FORMAT                  191\r
+#define ASN1_R_ODD_NUMBER_OF_CHARS                      145\r
+#define ASN1_R_PRIVATE_KEY_HEADER_MISSING               146\r
+#define ASN1_R_SECOND_NUMBER_TOO_LARGE                  147\r
+#define ASN1_R_SEQUENCE_LENGTH_MISMATCH                         148\r
+#define ASN1_R_SEQUENCE_NOT_CONSTRUCTED                         149\r
+#define ASN1_R_SEQUENCE_OR_SET_NEEDS_CONFIG             192\r
+#define ASN1_R_SHORT_LINE                               150\r
+#define ASN1_R_SIG_INVALID_MIME_TYPE                    213\r
+#define ASN1_R_STREAMING_NOT_SUPPORTED                  202\r
+#define ASN1_R_STRING_TOO_LONG                          151\r
+#define ASN1_R_STRING_TOO_SHORT                                 152\r
+#define ASN1_R_TAG_VALUE_TOO_HIGH                       153\r
+#define ASN1_R_THE_ASN1_OBJECT_IDENTIFIER_IS_NOT_KNOWN_FOR_THIS_MD 154\r
+#define ASN1_R_TIME_NOT_ASCII_FORMAT                    193\r
+#define ASN1_R_TOO_LONG                                         155\r
+#define ASN1_R_TYPE_NOT_CONSTRUCTED                     156\r
+#define ASN1_R_UNABLE_TO_DECODE_RSA_KEY                         157\r
+#define ASN1_R_UNABLE_TO_DECODE_RSA_PRIVATE_KEY                 158\r
+#define ASN1_R_UNEXPECTED_EOC                           159\r
+#define ASN1_R_UNIVERSALSTRING_IS_WRONG_LENGTH          215\r
+#define ASN1_R_UNKNOWN_FORMAT                           160\r
+#define ASN1_R_UNKNOWN_MESSAGE_DIGEST_ALGORITHM                 161\r
+#define ASN1_R_UNKNOWN_OBJECT_TYPE                      162\r
+#define ASN1_R_UNKNOWN_PUBLIC_KEY_TYPE                  163\r
+#define ASN1_R_UNKNOWN_SIGNATURE_ALGORITHM              199\r
+#define ASN1_R_UNKNOWN_TAG                              194\r
+#define ASN1_R_UNKOWN_FORMAT                            195\r
+#define ASN1_R_UNSUPPORTED_ANY_DEFINED_BY_TYPE          164\r
+#define ASN1_R_UNSUPPORTED_CIPHER                       165\r
+#define ASN1_R_UNSUPPORTED_ENCRYPTION_ALGORITHM                 166\r
+#define ASN1_R_UNSUPPORTED_PUBLIC_KEY_TYPE              167\r
+#define ASN1_R_UNSUPPORTED_TYPE                                 196\r
+#define ASN1_R_WRONG_PUBLIC_KEY_TYPE                    200\r
+#define ASN1_R_WRONG_TAG                                168\r
+#define ASN1_R_WRONG_TYPE                               169\r
+\r
+#ifdef  __cplusplus\r
+}\r
+#endif\r
+#endif\r
index 9bf1199..a5677f8 100644 (file)
-/* crypto/asn1/asn1_mac.h */
-/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
- * All rights reserved.
- *
- * This package is an SSL implementation written
- * by Eric Young (eay@cryptsoft.com).
- * The implementation was written so as to conform with Netscapes SSL.
- *
- * This library is free for commercial and non-commercial use as long as
- * the following conditions are aheared to.  The following conditions
- * apply to all code found in this distribution, be it the RC4, RSA,
- * lhash, DES, etc., code; not just the SSL code.  The SSL documentation
- * included with this distribution is covered by the same copyright terms
- * except that the holder is Tim Hudson (tjh@cryptsoft.com).
- *
- * Copyright remains Eric Young's, and as such any Copyright notices in
- * the code are not to be removed.
- * If this package is used in a product, Eric Young should be given attribution
- * as the author of the parts of the library used.
- * This can be in the form of a textual message at program startup or
- * in documentation (online or textual) provided with the package.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the copyright
- *    notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- *    notice, this list of conditions and the following disclaimer in the
- *    documentation and/or other materials provided with the distribution.
- * 3. All advertising materials mentioning features or use of this software
- *    must display the following acknowledgement:
- *    "This product includes cryptographic software written by
- *     Eric Young (eay@cryptsoft.com)"
- *    The word 'cryptographic' can be left out if the rouines from the library
- *    being used are not cryptographic related :-).
- * 4. If you include any Windows specific code (or a derivative thereof) from
- *    the apps directory (application code) you must include an acknowledgement:
- *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
- *
- * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
- * SUCH DAMAGE.
- *
- * The licence and distribution terms for any publically available version or
- * derivative of this code cannot be changed.  i.e. this code cannot simply be
- * copied and put under another distribution licence
- * [including the GNU Public Licence.]
- */
-
-#ifndef HEADER_ASN1_MAC_H
-#define HEADER_ASN1_MAC_H
-
-#include <openssl/asn1.h>
-
-#ifdef  __cplusplus
-extern "C" {
-#endif
-
-#ifndef ASN1_MAC_ERR_LIB
-#define ASN1_MAC_ERR_LIB       ERR_LIB_ASN1
-#endif
-
-#define ASN1_MAC_H_err(f,r,line) \
-       ERR_PUT_error(ASN1_MAC_ERR_LIB,(f),(r),__FILE__,(line))
-
-#define M_ASN1_D2I_vars(a,type,func) \
-       ASN1_const_CTX c; \
-       type ret=NULL; \
-       \
-       c.pp=(const unsigned char **)pp; \
-       c.q= *(const unsigned char **)pp; \
-       c.error=ERR_R_NESTED_ASN1_ERROR; \
-       if ((a == NULL) || ((*a) == NULL)) \
-               { if ((ret=(type)func()) == NULL) \
-                       { c.line=__LINE__; goto err; } } \
-       else    ret=(*a);
-
-#define M_ASN1_D2I_Init() \
-       c.p= *(const unsigned char **)pp; \
-       c.max=(length == 0)?0:(c.p+length);
-
-#define M_ASN1_D2I_Finish_2(a) \
-       if (!asn1_const_Finish(&c)) \
-               { c.line=__LINE__; goto err; } \
-       *(const unsigned char **)pp=c.p; \
-       if (a != NULL) (*a)=ret; \
-       return(ret);
-
-#define M_ASN1_D2I_Finish(a,func,e) \
-       M_ASN1_D2I_Finish_2(a); \
-err:\
-       ASN1_MAC_H_err((e),c.error,c.line); \
-       asn1_add_error(*(const unsigned char **)pp,(int)(c.q- *pp)); \
-       if ((ret != NULL) && ((a == NULL) || (*a != ret))) func(ret); \
-       return(NULL)
-
-#define M_ASN1_D2I_start_sequence() \
-       if (!asn1_GetSequence(&c,&length)) \
-               { c.line=__LINE__; goto err; }
-/* Begin reading ASN1 without a surrounding sequence */
-#define M_ASN1_D2I_begin() \
-       c.slen = length;
-
-/* End reading ASN1 with no check on length */
-#define M_ASN1_D2I_Finish_nolen(a, func, e) \
-       *pp=c.p; \
-       if (a != NULL) (*a)=ret; \
-       return(ret); \
-err:\
-       ASN1_MAC_H_err((e),c.error,c.line); \
-       asn1_add_error(*pp,(int)(c.q- *pp)); \
-       if ((ret != NULL) && ((a == NULL) || (*a != ret))) func(ret); \
-       return(NULL)
-
-#define M_ASN1_D2I_end_sequence() \
-       (((c.inf&1) == 0)?(c.slen <= 0): \
-               (c.eos=ASN1_const_check_infinite_end(&c.p,c.slen)))
-
-/* Don't use this with d2i_ASN1_BOOLEAN() */
-#define M_ASN1_D2I_get(b, func) \
-       c.q=c.p; \
-       if (func(&(b),&c.p,c.slen) == NULL) \
-               {c.line=__LINE__; goto err; } \
-       c.slen-=(c.p-c.q);
-
-/* Don't use this with d2i_ASN1_BOOLEAN() */
-#define M_ASN1_D2I_get_x(type,b,func) \
-       c.q=c.p; \
-       if (((D2I_OF(type))func)(&(b),&c.p,c.slen) == NULL) \
-               {c.line=__LINE__; goto err; } \
-       c.slen-=(c.p-c.q);
-
-/* use this instead () */
-#define M_ASN1_D2I_get_int(b,func) \
-       c.q=c.p; \
-       if (func(&(b),&c.p,c.slen) < 0) \
-               {c.line=__LINE__; goto err; } \
-       c.slen-=(c.p-c.q);
-
-#define M_ASN1_D2I_get_opt(b,func,type) \
-       if ((c.slen != 0) && ((M_ASN1_next & (~V_ASN1_CONSTRUCTED)) \
-               == (V_ASN1_UNIVERSAL|(type)))) \
-               { \
-               M_ASN1_D2I_get(b,func); \
-               }
-
-#define M_ASN1_D2I_get_int_opt(b,func,type) \
-       if ((c.slen != 0) && ((M_ASN1_next & (~V_ASN1_CONSTRUCTED)) \
-               == (V_ASN1_UNIVERSAL|(type)))) \
-               { \
-               M_ASN1_D2I_get_int(b,func); \
-               }
-
-#define M_ASN1_D2I_get_imp(b,func, type) \
-       M_ASN1_next=(_tmp& V_ASN1_CONSTRUCTED)|type; \
-       c.q=c.p; \
-       if (func(&(b),&c.p,c.slen) == NULL) \
-               {c.line=__LINE__; M_ASN1_next_prev = _tmp; goto err; } \
-       c.slen-=(c.p-c.q);\
-       M_ASN1_next_prev=_tmp;
-
-#define M_ASN1_D2I_get_IMP_opt(b,func,tag,type) \
-       if ((c.slen != 0) && ((M_ASN1_next & (~V_ASN1_CONSTRUCTED)) == \
-               (V_ASN1_CONTEXT_SPECIFIC|(tag)))) \
-               { \
-               unsigned char _tmp = M_ASN1_next; \
-               M_ASN1_D2I_get_imp(b,func, type);\
-               }
-
-#define M_ASN1_D2I_get_set(r,func,free_func) \
-               M_ASN1_D2I_get_imp_set(r,func,free_func, \
-                       V_ASN1_SET,V_ASN1_UNIVERSAL);
-
-#define M_ASN1_D2I_get_set_type(type,r,func,free_func) \
-               M_ASN1_D2I_get_imp_set_type(type,r,func,free_func, \
-                       V_ASN1_SET,V_ASN1_UNIVERSAL);
-
-#define M_ASN1_D2I_get_set_opt(r,func,free_func) \
-       if ((c.slen != 0) && (M_ASN1_next == (V_ASN1_UNIVERSAL| \
-               V_ASN1_CONSTRUCTED|V_ASN1_SET)))\
-               { M_ASN1_D2I_get_set(r,func,free_func); }
-
-#define M_ASN1_D2I_get_set_opt_type(type,r,func,free_func) \
-       if ((c.slen != 0) && (M_ASN1_next == (V_ASN1_UNIVERSAL| \
-               V_ASN1_CONSTRUCTED|V_ASN1_SET)))\
-               { M_ASN1_D2I_get_set_type(type,r,func,free_func); }
-
-#define M_ASN1_I2D_len_SET_opt(a,f) \
-       if ((a != NULL) && (sk_num(a) != 0)) \
-               M_ASN1_I2D_len_SET(a,f);
-
-#define M_ASN1_I2D_put_SET_opt(a,f) \
-       if ((a != NULL) && (sk_num(a) != 0)) \
-               M_ASN1_I2D_put_SET(a,f);
-
-#define M_ASN1_I2D_put_SEQUENCE_opt(a,f) \
-       if ((a != NULL) && (sk_num(a) != 0)) \
-               M_ASN1_I2D_put_SEQUENCE(a,f);
-
-#define M_ASN1_I2D_put_SEQUENCE_opt_type(type,a,f) \
-       if ((a != NULL) && (sk_##type##_num(a) != 0)) \
-               M_ASN1_I2D_put_SEQUENCE_type(type,a,f);
-
-#define M_ASN1_D2I_get_IMP_set_opt(b,func,free_func,tag) \
-       if ((c.slen != 0) && \
-               (M_ASN1_next == \
-               (V_ASN1_CONTEXT_SPECIFIC|V_ASN1_CONSTRUCTED|(tag))))\
-               { \
-               M_ASN1_D2I_get_imp_set(b,func,free_func,\
-                       tag,V_ASN1_CONTEXT_SPECIFIC); \
-               }
-
-#define M_ASN1_D2I_get_IMP_set_opt_type(type,b,func,free_func,tag) \
-       if ((c.slen != 0) && \
-               (M_ASN1_next == \
-               (V_ASN1_CONTEXT_SPECIFIC|V_ASN1_CONSTRUCTED|(tag))))\
-               { \
-               M_ASN1_D2I_get_imp_set_type(type,b,func,free_func,\
-                       tag,V_ASN1_CONTEXT_SPECIFIC); \
-               }
-
-#define M_ASN1_D2I_get_seq(r,func,free_func) \
-               M_ASN1_D2I_get_imp_set(r,func,free_func,\
-                       V_ASN1_SEQUENCE,V_ASN1_UNIVERSAL);
-
-#define M_ASN1_D2I_get_seq_type(type,r,func,free_func) \
-               M_ASN1_D2I_get_imp_set_type(type,r,func,free_func,\
-                                           V_ASN1_SEQUENCE,V_ASN1_UNIVERSAL)
-
-#define M_ASN1_D2I_get_seq_opt(r,func,free_func) \
-       if ((c.slen != 0) && (M_ASN1_next == (V_ASN1_UNIVERSAL| \
-               V_ASN1_CONSTRUCTED|V_ASN1_SEQUENCE)))\
-               { M_ASN1_D2I_get_seq(r,func,free_func); }
-
-#define M_ASN1_D2I_get_seq_opt_type(type,r,func,free_func) \
-       if ((c.slen != 0) && (M_ASN1_next == (V_ASN1_UNIVERSAL| \
-               V_ASN1_CONSTRUCTED|V_ASN1_SEQUENCE)))\
-               { M_ASN1_D2I_get_seq_type(type,r,func,free_func); }
-
-#define M_ASN1_D2I_get_IMP_set(r,func,free_func,x) \
-               M_ASN1_D2I_get_imp_set(r,func,free_func,\
-                       x,V_ASN1_CONTEXT_SPECIFIC);
-
-#define M_ASN1_D2I_get_IMP_set_type(type,r,func,free_func,x) \
-               M_ASN1_D2I_get_imp_set_type(type,r,func,free_func,\
-                       x,V_ASN1_CONTEXT_SPECIFIC);
-
-#define M_ASN1_D2I_get_imp_set(r,func,free_func,a,b) \
-       c.q=c.p; \
-       if (d2i_ASN1_SET(&(r),&c.p,c.slen,(char *(*)())func,\
-               (void (*)())free_func,a,b) == NULL) \
-               { c.line=__LINE__; goto err; } \
-       c.slen-=(c.p-c.q);
-
-#define M_ASN1_D2I_get_imp_set_type(type,r,func,free_func,a,b) \
-       c.q=c.p; \
-       if (d2i_ASN1_SET_OF_##type(&(r),&c.p,c.slen,func,\
-                                  free_func,a,b) == NULL) \
-               { c.line=__LINE__; goto err; } \
-       c.slen-=(c.p-c.q);
-
-#define M_ASN1_D2I_get_set_strings(r,func,a,b) \
-       c.q=c.p; \
-       if (d2i_ASN1_STRING_SET(&(r),&c.p,c.slen,a,b) == NULL) \
-               { c.line=__LINE__; goto err; } \
-       c.slen-=(c.p-c.q);
-
-#define M_ASN1_D2I_get_EXP_opt(r,func,tag) \
-       if ((c.slen != 0L) && (M_ASN1_next == \
-               (V_ASN1_CONSTRUCTED|V_ASN1_CONTEXT_SPECIFIC|tag))) \
-               { \
-               int Tinf,Ttag,Tclass; \
-               long Tlen; \
-               \
-               c.q=c.p; \
-               Tinf=ASN1_get_object(&c.p,&Tlen,&Ttag,&Tclass,c.slen); \
-               if (Tinf & 0x80) \
-                       { c.error=ERR_R_BAD_ASN1_OBJECT_HEADER; \
-                       c.line=__LINE__; goto err; } \
-               if (Tinf == (V_ASN1_CONSTRUCTED+1)) \
-                                       Tlen = c.slen - (c.p - c.q) - 2; \
-               if (func(&(r),&c.p,Tlen) == NULL) \
-                       { c.line=__LINE__; goto err; } \
-               if (Tinf == (V_ASN1_CONSTRUCTED+1)) { \
-                       Tlen = c.slen - (c.p - c.q); \
-                       if(!ASN1_const_check_infinite_end(&c.p, Tlen)) \
-                               { c.error=ERR_R_MISSING_ASN1_EOS; \
-                               c.line=__LINE__; goto err; } \
-               }\
-               c.slen-=(c.p-c.q); \
-               }
-
-#define M_ASN1_D2I_get_EXP_set_opt(r,func,free_func,tag,b) \
-       if ((c.slen != 0) && (M_ASN1_next == \
-               (V_ASN1_CONSTRUCTED|V_ASN1_CONTEXT_SPECIFIC|tag))) \
-               { \
-               int Tinf,Ttag,Tclass; \
-               long Tlen; \
-               \
-               c.q=c.p; \
-               Tinf=ASN1_get_object(&c.p,&Tlen,&Ttag,&Tclass,c.slen); \
-               if (Tinf & 0x80) \
-                       { c.error=ERR_R_BAD_ASN1_OBJECT_HEADER; \
-                       c.line=__LINE__; goto err; } \
-               if (Tinf == (V_ASN1_CONSTRUCTED+1)) \
-                                       Tlen = c.slen - (c.p - c.q) - 2; \
-               if (d2i_ASN1_SET(&(r),&c.p,Tlen,(char *(*)())func, \
-                       (void (*)())free_func, \
-                       b,V_ASN1_UNIVERSAL) == NULL) \
-                       { c.line=__LINE__; goto err; } \
-               if (Tinf == (V_ASN1_CONSTRUCTED+1)) { \
-                       Tlen = c.slen - (c.p - c.q); \
-                       if(!ASN1_check_infinite_end(&c.p, Tlen)) \
-                               { c.error=ERR_R_MISSING_ASN1_EOS; \
-                               c.line=__LINE__; goto err; } \
-               }\
-               c.slen-=(c.p-c.q); \
-               }
-
-#define M_ASN1_D2I_get_EXP_set_opt_type(type,r,func,free_func,tag,b) \
-       if ((c.slen != 0) && (M_ASN1_next == \
-               (V_ASN1_CONSTRUCTED|V_ASN1_CONTEXT_SPECIFIC|tag))) \
-               { \
-               int Tinf,Ttag,Tclass; \
-               long Tlen; \
-               \
-               c.q=c.p; \
-               Tinf=ASN1_get_object(&c.p,&Tlen,&Ttag,&Tclass,c.slen); \
-               if (Tinf & 0x80) \
-                       { c.error=ERR_R_BAD_ASN1_OBJECT_HEADER; \
-                       c.line=__LINE__; goto err; } \
-               if (Tinf == (V_ASN1_CONSTRUCTED+1)) \
-                                       Tlen = c.slen - (c.p - c.q) - 2; \
-               if (d2i_ASN1_SET_OF_##type(&(r),&c.p,Tlen,func, \
-                       free_func,b,V_ASN1_UNIVERSAL) == NULL) \
-                       { c.line=__LINE__; goto err; } \
-               if (Tinf == (V_ASN1_CONSTRUCTED+1)) { \
-                       Tlen = c.slen - (c.p - c.q); \
-                       if(!ASN1_check_infinite_end(&c.p, Tlen)) \
-                               { c.error=ERR_R_MISSING_ASN1_EOS; \
-                               c.line=__LINE__; goto err; } \
-               }\
-               c.slen-=(c.p-c.q); \
-               }
-
-/* New macros */
-#define M_ASN1_New_Malloc(ret,type) \
-       if ((ret=(type *)OPENSSL_malloc(sizeof(type))) == NULL) \
-               { c.line=__LINE__; goto err2; }
-
-#define M_ASN1_New(arg,func) \
-       if (((arg)=func()) == NULL) return(NULL)
-
-#define M_ASN1_New_Error(a) \
-/*     err:    ASN1_MAC_H_err((a),ERR_R_NESTED_ASN1_ERROR,c.line); \
-               return(NULL);*/ \
-       err2:   ASN1_MAC_H_err((a),ERR_R_MALLOC_FAILURE,c.line); \
-               return(NULL)
-
-
-/* BIG UGLY WARNING!  This is so damn ugly I wanna puke.  Unfortunately,
-   some macros that use ASN1_const_CTX still insist on writing in the input
-   stream.  ARGH!  ARGH!  ARGH!  Let's get rid of this macro package.
-   Please?                                             -- Richard Levitte */
-#define M_ASN1_next            (*((unsigned char *)(c.p)))
-#define M_ASN1_next_prev       (*((unsigned char *)(c.q)))
-
-/*************************************************/
-
-#define M_ASN1_I2D_vars(a)     int r=0,ret=0; \
-                               unsigned char *p; \
-                               if (a == NULL) return(0)
-
-/* Length Macros */
-#define M_ASN1_I2D_len(a,f)    ret+=f(a,NULL)
-#define M_ASN1_I2D_len_IMP_opt(a,f)    if (a != NULL) M_ASN1_I2D_len(a,f)
-
-#define M_ASN1_I2D_len_SET(a,f) \
-               ret+=i2d_ASN1_SET(a,NULL,f,V_ASN1_SET,V_ASN1_UNIVERSAL,IS_SET);
-
-#define M_ASN1_I2D_len_SET_type(type,a,f) \
-               ret+=i2d_ASN1_SET_OF_##type(a,NULL,f,V_ASN1_SET, \
-                                           V_ASN1_UNIVERSAL,IS_SET);
-
-#define M_ASN1_I2D_len_SEQUENCE(a,f) \
-               ret+=i2d_ASN1_SET(a,NULL,f,V_ASN1_SEQUENCE,V_ASN1_UNIVERSAL, \
-                                 IS_SEQUENCE);
-
-#define M_ASN1_I2D_len_SEQUENCE_type(type,a,f) \
-               ret+=i2d_ASN1_SET_OF_##type(a,NULL,f,V_ASN1_SEQUENCE, \
-                                           V_ASN1_UNIVERSAL,IS_SEQUENCE)
-
-#define M_ASN1_I2D_len_SEQUENCE_opt(a,f) \
-               if ((a != NULL) && (sk_num(a) != 0)) \
-                       M_ASN1_I2D_len_SEQUENCE(a,f);
-
-#define M_ASN1_I2D_len_SEQUENCE_opt_type(type,a,f) \
-               if ((a != NULL) && (sk_##type##_num(a) != 0)) \
-                       M_ASN1_I2D_len_SEQUENCE_type(type,a,f);
-
-#define M_ASN1_I2D_len_IMP_SET(a,f,x) \
-               ret+=i2d_ASN1_SET(a,NULL,f,x,V_ASN1_CONTEXT_SPECIFIC,IS_SET);
-
-#define M_ASN1_I2D_len_IMP_SET_type(type,a,f,x) \
-               ret+=i2d_ASN1_SET_OF_##type(a,NULL,f,x, \
-                                           V_ASN1_CONTEXT_SPECIFIC,IS_SET);
-
-#define M_ASN1_I2D_len_IMP_SET_opt(a,f,x) \
-               if ((a != NULL) && (sk_num(a) != 0)) \
-                       ret+=i2d_ASN1_SET(a,NULL,f,x,V_ASN1_CONTEXT_SPECIFIC, \
-                                         IS_SET);
-
-#define M_ASN1_I2D_len_IMP_SET_opt_type(type,a,f,x) \
-               if ((a != NULL) && (sk_##type##_num(a) != 0)) \
-                       ret+=i2d_ASN1_SET_OF_##type(a,NULL,f,x, \
-                                              V_ASN1_CONTEXT_SPECIFIC,IS_SET);
-
-#define M_ASN1_I2D_len_IMP_SEQUENCE(a,f,x) \
-               ret+=i2d_ASN1_SET(a,NULL,f,x,V_ASN1_CONTEXT_SPECIFIC, \
-                                 IS_SEQUENCE);
-
-#define M_ASN1_I2D_len_IMP_SEQUENCE_opt(a,f,x) \
-               if ((a != NULL) && (sk_num(a) != 0)) \
-                       ret+=i2d_ASN1_SET(a,NULL,f,x,V_ASN1_CONTEXT_SPECIFIC, \
-                                         IS_SEQUENCE);
-
-#define M_ASN1_I2D_len_IMP_SEQUENCE_opt_type(type,a,f,x) \
-               if ((a != NULL) && (sk_##type##_num(a) != 0)) \
-                       ret+=i2d_ASN1_SET_OF_##type(a,NULL,f,x, \
-                                                   V_ASN1_CONTEXT_SPECIFIC, \
-                                                   IS_SEQUENCE);
-
-#define M_ASN1_I2D_len_EXP_opt(a,f,mtag,v) \
-               if (a != NULL)\
-                       { \
-                       v=f(a,NULL); \
-                       ret+=ASN1_object_size(1,v,mtag); \
-                       }
-
-#define M_ASN1_I2D_len_EXP_SET_opt(a,f,mtag,tag,v) \
-               if ((a != NULL) && (sk_num(a) != 0))\
-                       { \
-                       v=i2d_ASN1_SET(a,NULL,f,tag,V_ASN1_UNIVERSAL,IS_SET); \
-                       ret+=ASN1_object_size(1,v,mtag); \
-                       }
-
-#define M_ASN1_I2D_len_EXP_SEQUENCE_opt(a,f,mtag,tag,v) \
-               if ((a != NULL) && (sk_num(a) != 0))\
-                       { \
-                       v=i2d_ASN1_SET(a,NULL,f,tag,V_ASN1_UNIVERSAL, \
-                                      IS_SEQUENCE); \
-                       ret+=ASN1_object_size(1,v,mtag); \
-                       }
-
-#define M_ASN1_I2D_len_EXP_SEQUENCE_opt_type(type,a,f,mtag,tag,v) \
-               if ((a != NULL) && (sk_##type##_num(a) != 0))\
-                       { \
-                       v=i2d_ASN1_SET_OF_##type(a,NULL,f,tag, \
-                                                V_ASN1_UNIVERSAL, \
-                                                IS_SEQUENCE); \
-                       ret+=ASN1_object_size(1,v,mtag); \
-                       }
-
-/* Put Macros */
-#define M_ASN1_I2D_put(a,f)    f(a,&p)
-
-#define M_ASN1_I2D_put_IMP_opt(a,f,t)  \
-               if (a != NULL) \
-                       { \
-                       unsigned char *q=p; \
-                       f(a,&p); \
-                       *q=(V_ASN1_CONTEXT_SPECIFIC|t|(*q&V_ASN1_CONSTRUCTED));\
-                       }
-
-#define M_ASN1_I2D_put_SET(a,f) i2d_ASN1_SET(a,&p,f,V_ASN1_SET,\
-                       V_ASN1_UNIVERSAL,IS_SET)
-#define M_ASN1_I2D_put_SET_type(type,a,f) \
-     i2d_ASN1_SET_OF_##type(a,&p,f,V_ASN1_SET,V_ASN1_UNIVERSAL,IS_SET)
-#define M_ASN1_I2D_put_IMP_SET(a,f,x) i2d_ASN1_SET(a,&p,f,x,\
-                       V_ASN1_CONTEXT_SPECIFIC,IS_SET)
-#define M_ASN1_I2D_put_IMP_SET_type(type,a,f,x) \
-     i2d_ASN1_SET_OF_##type(a,&p,f,x,V_ASN1_CONTEXT_SPECIFIC,IS_SET)
-#define M_ASN1_I2D_put_IMP_SEQUENCE(a,f,x) i2d_ASN1_SET(a,&p,f,x,\
-                       V_ASN1_CONTEXT_SPECIFIC,IS_SEQUENCE)
-
-#define M_ASN1_I2D_put_SEQUENCE(a,f) i2d_ASN1_SET(a,&p,f,V_ASN1_SEQUENCE,\
-                                            V_ASN1_UNIVERSAL,IS_SEQUENCE)
-
-#define M_ASN1_I2D_put_SEQUENCE_type(type,a,f) \
-     i2d_ASN1_SET_OF_##type(a,&p,f,V_ASN1_SEQUENCE,V_ASN1_UNIVERSAL, \
-                           IS_SEQUENCE)
-
-#define M_ASN1_I2D_put_SEQUENCE_opt(a,f) \
-               if ((a != NULL) && (sk_num(a) != 0)) \
-                       M_ASN1_I2D_put_SEQUENCE(a,f);
-
-#define M_ASN1_I2D_put_IMP_SET_opt(a,f,x) \
-               if ((a != NULL) && (sk_num(a) != 0)) \
-                       { i2d_ASN1_SET(a,&p,f,x,V_ASN1_CONTEXT_SPECIFIC, \
-                                      IS_SET); }
-
-#define M_ASN1_I2D_put_IMP_SET_opt_type(type,a,f,x) \
-               if ((a != NULL) && (sk_##type##_num(a) != 0)) \
-                       { i2d_ASN1_SET_OF_##type(a,&p,f,x, \
-                                                V_ASN1_CONTEXT_SPECIFIC, \
-                                                IS_SET); }
-
-#define M_ASN1_I2D_put_IMP_SEQUENCE_opt(a,f,x) \
-               if ((a != NULL) && (sk_num(a) != 0)) \
-                       { i2d_ASN1_SET(a,&p,f,x,V_ASN1_CONTEXT_SPECIFIC, \
-                                      IS_SEQUENCE); }
-
-#define M_ASN1_I2D_put_IMP_SEQUENCE_opt_type(type,a,f,x) \
-               if ((a != NULL) && (sk_##type##_num(a) != 0)) \
-                       { i2d_ASN1_SET_OF_##type(a,&p,f,x, \
-                                                V_ASN1_CONTEXT_SPECIFIC, \
-                                                IS_SEQUENCE); }
-
-#define M_ASN1_I2D_put_EXP_opt(a,f,tag,v) \
-               if (a != NULL) \
-                       { \
-                       ASN1_put_object(&p,1,v,tag,V_ASN1_CONTEXT_SPECIFIC); \
-                       f(a,&p); \
-                       }
-
-#define M_ASN1_I2D_put_EXP_SET_opt(a,f,mtag,tag,v) \
-               if ((a != NULL) && (sk_num(a) != 0)) \
-                       { \
-                       ASN1_put_object(&p,1,v,mtag,V_ASN1_CONTEXT_SPECIFIC); \
-                       i2d_ASN1_SET(a,&p,f,tag,V_ASN1_UNIVERSAL,IS_SET); \
-                       }
-
-#define M_ASN1_I2D_put_EXP_SEQUENCE_opt(a,f,mtag,tag,v) \
-               if ((a != NULL) && (sk_num(a) != 0)) \
-                       { \
-                       ASN1_put_object(&p,1,v,mtag,V_ASN1_CONTEXT_SPECIFIC); \
-                       i2d_ASN1_SET(a,&p,f,tag,V_ASN1_UNIVERSAL,IS_SEQUENCE); \
-                       }
-
-#define M_ASN1_I2D_put_EXP_SEQUENCE_opt_type(type,a,f,mtag,tag,v) \
-               if ((a != NULL) && (sk_##type##_num(a) != 0)) \
-                       { \
-                       ASN1_put_object(&p,1,v,mtag,V_ASN1_CONTEXT_SPECIFIC); \
-                       i2d_ASN1_SET_OF_##type(a,&p,f,tag,V_ASN1_UNIVERSAL, \
-                                              IS_SEQUENCE); \
-                       }
-
-#define M_ASN1_I2D_seq_total() \
-               r=ASN1_object_size(1,ret,V_ASN1_SEQUENCE); \
-               if (pp == NULL) return(r); \
-               p= *pp; \
-               ASN1_put_object(&p,1,ret,V_ASN1_SEQUENCE,V_ASN1_UNIVERSAL)
-
-#define M_ASN1_I2D_INF_seq_start(tag,ctx) \
-               *(p++)=(V_ASN1_CONSTRUCTED|(tag)|(ctx)); \
-               *(p++)=0x80
-
-#define M_ASN1_I2D_INF_seq_end() *(p++)=0x00; *(p++)=0x00
-
-#define M_ASN1_I2D_finish()    *pp=p; \
-                               return(r);
-
-int asn1_GetSequence(ASN1_const_CTX *c, long *length);
-void asn1_add_error(const unsigned char *address,int offset);
-#ifdef  __cplusplus
-}
-#endif
-
-#endif
+/* crypto/asn1/asn1_mac.h */\r
+/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)\r
+ * All rights reserved.\r
+ *\r
+ * This package is an SSL implementation written\r
+ * by Eric Young (eay@cryptsoft.com).\r
+ * The implementation was written so as to conform with Netscapes SSL.\r
+ *\r
+ * This library is free for commercial and non-commercial use as long as\r
+ * the following conditions are aheared to.  The following conditions\r
+ * apply to all code found in this distribution, be it the RC4, RSA,\r
+ * lhash, DES, etc., code; not just the SSL code.  The SSL documentation\r
+ * included with this distribution is covered by the same copyright terms\r
+ * except that the holder is Tim Hudson (tjh@cryptsoft.com).\r
+ *\r
+ * Copyright remains Eric Young's, and as such any Copyright notices in\r
+ * the code are not to be removed.\r
+ * If this package is used in a product, Eric Young should be given attribution\r
+ * as the author of the parts of the library used.\r
+ * This can be in the form of a textual message at program startup or\r
+ * in documentation (online or textual) provided with the package.\r
+ *\r
+ * Redistribution and use in source and binary forms, with or without\r
+ * modification, are permitted provided that the following conditions\r
+ * are met:\r
+ * 1. Redistributions of source code must retain the copyright\r
+ *    notice, this list of conditions and the following disclaimer.\r
+ * 2. Redistributions in binary form must reproduce the above copyright\r
+ *    notice, this list of conditions and the following disclaimer in the\r
+ *    documentation and/or other materials provided with the distribution.\r
+ * 3. All advertising materials mentioning features or use of this software\r
+ *    must display the following acknowledgement:\r
+ *    "This product includes cryptographic software written by\r
+ *     Eric Young (eay@cryptsoft.com)"\r
+ *    The word 'cryptographic' can be left out if the rouines from the library\r
+ *    being used are not cryptographic related :-).\r
+ * 4. If you include any Windows specific code (or a derivative thereof) from\r
+ *    the apps directory (application code) you must include an acknowledgement:\r
+ *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"\r
+ *\r
+ * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND\r
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\r
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\r
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE\r
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\r
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\r
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\r
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT\r
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY\r
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF\r
+ * SUCH DAMAGE.\r
+ *\r
+ * The licence and distribution terms for any publically available version or\r
+ * derivative of this code cannot be changed.  i.e. this code cannot simply be\r
+ * copied and put under another distribution licence\r
+ * [including the GNU Public Licence.]\r
+ */\r
+\r
+#ifndef HEADER_ASN1_MAC_H\r
+#define HEADER_ASN1_MAC_H\r
+\r
+#include <openssl/asn1.h>\r
+\r
+#ifdef  __cplusplus\r
+extern "C" {\r
+#endif\r
+\r
+#ifndef ASN1_MAC_ERR_LIB\r
+#define ASN1_MAC_ERR_LIB       ERR_LIB_ASN1\r
+#endif\r
+\r
+#define ASN1_MAC_H_err(f,r,line) \\r
+       ERR_PUT_error(ASN1_MAC_ERR_LIB,(f),(r),__FILE__,(line))\r
+\r
+#define M_ASN1_D2I_vars(a,type,func) \\r
+       ASN1_const_CTX c; \\r
+       type ret=NULL; \\r
+       \\r
+       c.pp=(const unsigned char **)pp; \\r
+       c.q= *(const unsigned char **)pp; \\r
+       c.error=ERR_R_NESTED_ASN1_ERROR; \\r
+       if ((a == NULL) || ((*a) == NULL)) \\r
+               { if ((ret=(type)func()) == NULL) \\r
+                       { c.line=__LINE__; goto err; } } \\r
+       else    ret=(*a);\r
+\r
+#define M_ASN1_D2I_Init() \\r
+       c.p= *(const unsigned char **)pp; \\r
+       c.max=(length == 0)?0:(c.p+length);\r
+\r
+#define M_ASN1_D2I_Finish_2(a) \\r
+       if (!asn1_const_Finish(&c)) \\r
+               { c.line=__LINE__; goto err; } \\r
+       *(const unsigned char **)pp=c.p; \\r
+       if (a != NULL) (*a)=ret; \\r
+       return(ret);\r
+\r
+#define M_ASN1_D2I_Finish(a,func,e) \\r
+       M_ASN1_D2I_Finish_2(a); \\r
+err:\\r
+       ASN1_MAC_H_err((e),c.error,c.line); \\r
+       asn1_add_error(*(const unsigned char **)pp,(int)(c.q- *pp)); \\r
+       if ((ret != NULL) && ((a == NULL) || (*a != ret))) func(ret); \\r
+       return(NULL)\r
+\r
+#define M_ASN1_D2I_start_sequence() \\r
+       if (!asn1_GetSequence(&c,&length)) \\r
+               { c.line=__LINE__; goto err; }\r
+/* Begin reading ASN1 without a surrounding sequence */\r
+#define M_ASN1_D2I_begin() \\r
+       c.slen = length;\r
+\r
+/* End reading ASN1 with no check on length */\r
+#define M_ASN1_D2I_Finish_nolen(a, func, e) \\r
+       *pp=c.p; \\r
+       if (a != NULL) (*a)=ret; \\r
+       return(ret); \\r
+err:\\r
+       ASN1_MAC_H_err((e),c.error,c.line); \\r
+       asn1_add_error(*pp,(int)(c.q- *pp)); \\r
+       if ((ret != NULL) && ((a == NULL) || (*a != ret))) func(ret); \\r
+       return(NULL)\r
+\r
+#define M_ASN1_D2I_end_sequence() \\r
+       (((c.inf&1) == 0)?(c.slen <= 0): \\r
+               (c.eos=ASN1_const_check_infinite_end(&c.p,c.slen)))\r
+\r
+/* Don't use this with d2i_ASN1_BOOLEAN() */\r
+#define M_ASN1_D2I_get(b, func) \\r
+       c.q=c.p; \\r
+       if (func(&(b),&c.p,c.slen) == NULL) \\r
+               {c.line=__LINE__; goto err; } \\r
+       c.slen-=(c.p-c.q);\r
+\r
+/* Don't use this with d2i_ASN1_BOOLEAN() */\r
+#define M_ASN1_D2I_get_x(type,b,func) \\r
+       c.q=c.p; \\r
+       if (((D2I_OF(type))func)(&(b),&c.p,c.slen) == NULL) \\r
+               {c.line=__LINE__; goto err; } \\r
+       c.slen-=(c.p-c.q);\r
+\r
+/* use this instead () */\r
+#define M_ASN1_D2I_get_int(b,func) \\r
+       c.q=c.p; \\r
+       if (func(&(b),&c.p,c.slen) < 0) \\r
+               {c.line=__LINE__; goto err; } \\r
+       c.slen-=(c.p-c.q);\r
+\r
+#define M_ASN1_D2I_get_opt(b,func,type) \\r
+       if ((c.slen != 0) && ((M_ASN1_next & (~V_ASN1_CONSTRUCTED)) \\r
+               == (V_ASN1_UNIVERSAL|(type)))) \\r
+               { \\r
+               M_ASN1_D2I_get(b,func); \\r
+               }\r
+\r
+#define M_ASN1_D2I_get_int_opt(b,func,type) \\r
+       if ((c.slen != 0) && ((M_ASN1_next & (~V_ASN1_CONSTRUCTED)) \\r
+               == (V_ASN1_UNIVERSAL|(type)))) \\r
+               { \\r
+               M_ASN1_D2I_get_int(b,func); \\r
+               }\r
+\r
+#define M_ASN1_D2I_get_imp(b,func, type) \\r
+       M_ASN1_next=(_tmp& V_ASN1_CONSTRUCTED)|type; \\r
+       c.q=c.p; \\r
+       if (func(&(b),&c.p,c.slen) == NULL) \\r
+               {c.line=__LINE__; M_ASN1_next_prev = _tmp; goto err; } \\r
+       c.slen-=(c.p-c.q);\\r
+       M_ASN1_next_prev=_tmp;\r
+\r
+#define M_ASN1_D2I_get_IMP_opt(b,func,tag,type) \\r
+       if ((c.slen != 0) && ((M_ASN1_next & (~V_ASN1_CONSTRUCTED)) == \\r
+               (V_ASN1_CONTEXT_SPECIFIC|(tag)))) \\r
+               { \\r
+               unsigned char _tmp = M_ASN1_next; \\r
+               M_ASN1_D2I_get_imp(b,func, type);\\r
+               }\r
+\r
+#define M_ASN1_D2I_get_set(r,func,free_func) \\r
+               M_ASN1_D2I_get_imp_set(r,func,free_func, \\r
+                       V_ASN1_SET,V_ASN1_UNIVERSAL);\r
+\r
+#define M_ASN1_D2I_get_set_type(type,r,func,free_func) \\r
+               M_ASN1_D2I_get_imp_set_type(type,r,func,free_func, \\r
+                       V_ASN1_SET,V_ASN1_UNIVERSAL);\r
+\r
+#define M_ASN1_D2I_get_set_opt(r,func,free_func) \\r
+       if ((c.slen != 0) && (M_ASN1_next == (V_ASN1_UNIVERSAL| \\r
+               V_ASN1_CONSTRUCTED|V_ASN1_SET)))\\r
+               { M_ASN1_D2I_get_set(r,func,free_func); }\r
+\r
+#define M_ASN1_D2I_get_set_opt_type(type,r,func,free_func) \\r
+       if ((c.slen != 0) && (M_ASN1_next == (V_ASN1_UNIVERSAL| \\r
+               V_ASN1_CONSTRUCTED|V_ASN1_SET)))\\r
+               { M_ASN1_D2I_get_set_type(type,r,func,free_func); }\r
+\r
+#define M_ASN1_I2D_len_SET_opt(a,f) \\r
+       if ((a != NULL) && (sk_num(a) != 0)) \\r
+               M_ASN1_I2D_len_SET(a,f);\r
+\r
+#define M_ASN1_I2D_put_SET_opt(a,f) \\r
+       if ((a != NULL) && (sk_num(a) != 0)) \\r
+               M_ASN1_I2D_put_SET(a,f);\r
+\r
+#define M_ASN1_I2D_put_SEQUENCE_opt(a,f) \\r
+       if ((a != NULL) && (sk_num(a) != 0)) \\r
+               M_ASN1_I2D_put_SEQUENCE(a,f);\r
+\r
+#define M_ASN1_I2D_put_SEQUENCE_opt_type(type,a,f) \\r
+       if ((a != NULL) && (sk_##type##_num(a) != 0)) \\r
+               M_ASN1_I2D_put_SEQUENCE_type(type,a,f);\r
+\r
+#define M_ASN1_D2I_get_IMP_set_opt(b,func,free_func,tag) \\r
+       if ((c.slen != 0) && \\r
+               (M_ASN1_next == \\r
+               (V_ASN1_CONTEXT_SPECIFIC|V_ASN1_CONSTRUCTED|(tag))))\\r
+               { \\r
+               M_ASN1_D2I_get_imp_set(b,func,free_func,\\r
+                       tag,V_ASN1_CONTEXT_SPECIFIC); \\r
+               }\r
+\r
+#define M_ASN1_D2I_get_IMP_set_opt_type(type,b,func,free_func,tag) \\r
+       if ((c.slen != 0) && \\r
+               (M_ASN1_next == \\r
+               (V_ASN1_CONTEXT_SPECIFIC|V_ASN1_CONSTRUCTED|(tag))))\\r
+               { \\r
+               M_ASN1_D2I_get_imp_set_type(type,b,func,free_func,\\r
+                       tag,V_ASN1_CONTEXT_SPECIFIC); \\r
+               }\r
+\r
+#define M_ASN1_D2I_get_seq(r,func,free_func) \\r
+               M_ASN1_D2I_get_imp_set(r,func,free_func,\\r
+                       V_ASN1_SEQUENCE,V_ASN1_UNIVERSAL);\r
+\r
+#define M_ASN1_D2I_get_seq_type(type,r,func,free_func) \\r
+               M_ASN1_D2I_get_imp_set_type(type,r,func,free_func,\\r
+                                           V_ASN1_SEQUENCE,V_ASN1_UNIVERSAL)\r
+\r
+#define M_ASN1_D2I_get_seq_opt(r,func,free_func) \\r
+       if ((c.slen != 0) && (M_ASN1_next == (V_ASN1_UNIVERSAL| \\r
+               V_ASN1_CONSTRUCTED|V_ASN1_SEQUENCE)))\\r
+               { M_ASN1_D2I_get_seq(r,func,free_func); }\r
+\r
+#define M_ASN1_D2I_get_seq_opt_type(type,r,func,free_func) \\r
+       if ((c.slen != 0) && (M_ASN1_next == (V_ASN1_UNIVERSAL| \\r
+               V_ASN1_CONSTRUCTED|V_ASN1_SEQUENCE)))\\r
+               { M_ASN1_D2I_get_seq_type(type,r,func,free_func); }\r
+\r
+#define M_ASN1_D2I_get_IMP_set(r,func,free_func,x) \\r
+               M_ASN1_D2I_get_imp_set(r,func,free_func,\\r
+                       x,V_ASN1_CONTEXT_SPECIFIC);\r
+\r
+#define M_ASN1_D2I_get_IMP_set_type(type,r,func,free_func,x) \\r
+               M_ASN1_D2I_get_imp_set_type(type,r,func,free_func,\\r
+                       x,V_ASN1_CONTEXT_SPECIFIC);\r
+\r
+#define M_ASN1_D2I_get_imp_set(r,func,free_func,a,b) \\r
+       c.q=c.p; \\r
+       if (d2i_ASN1_SET(&(r),&c.p,c.slen,(char *(*)())func,\\r
+               (void (*)())free_func,a,b) == NULL) \\r
+               { c.line=__LINE__; goto err; } \\r
+       c.slen-=(c.p-c.q);\r
+\r
+#define M_ASN1_D2I_get_imp_set_type(type,r,func,free_func,a,b) \\r
+       c.q=c.p; \\r
+       if (d2i_ASN1_SET_OF_##type(&(r),&c.p,c.slen,func,\\r
+                                  free_func,a,b) == NULL) \\r
+               { c.line=__LINE__; goto err; } \\r
+       c.slen-=(c.p-c.q);\r
+\r
+#define M_ASN1_D2I_get_set_strings(r,func,a,b) \\r
+       c.q=c.p; \\r
+       if (d2i_ASN1_STRING_SET(&(r),&c.p,c.slen,a,b) == NULL) \\r
+               { c.line=__LINE__; goto err; } \\r
+       c.slen-=(c.p-c.q);\r
+\r
+#define M_ASN1_D2I_get_EXP_opt(r,func,tag) \\r
+       if ((c.slen != 0L) && (M_ASN1_next == \\r
+               (V_ASN1_CONSTRUCTED|V_ASN1_CONTEXT_SPECIFIC|tag))) \\r
+               { \\r
+               int Tinf,Ttag,Tclass; \\r
+               long Tlen; \\r
+               \\r
+               c.q=c.p; \\r
+               Tinf=ASN1_get_object(&c.p,&Tlen,&Ttag,&Tclass,c.slen); \\r
+               if (Tinf & 0x80) \\r
+                       { c.error=ERR_R_BAD_ASN1_OBJECT_HEADER; \\r
+                       c.line=__LINE__; goto err; } \\r
+               if (Tinf == (V_ASN1_CONSTRUCTED+1)) \\r
+                                       Tlen = c.slen - (c.p - c.q) - 2; \\r
+               if (func(&(r),&c.p,Tlen) == NULL) \\r
+                       { c.line=__LINE__; goto err; } \\r
+               if (Tinf == (V_ASN1_CONSTRUCTED+1)) { \\r
+                       Tlen = c.slen - (c.p - c.q); \\r
+                       if(!ASN1_const_check_infinite_end(&c.p, Tlen)) \\r
+                               { c.error=ERR_R_MISSING_ASN1_EOS; \\r
+                               c.line=__LINE__; goto err; } \\r
+               }\\r
+               c.slen-=(c.p-c.q); \\r
+               }\r
+\r
+#define M_ASN1_D2I_get_EXP_set_opt(r,func,free_func,tag,b) \\r
+       if ((c.slen != 0) && (M_ASN1_next == \\r
+               (V_ASN1_CONSTRUCTED|V_ASN1_CONTEXT_SPECIFIC|tag))) \\r
+               { \\r
+               int Tinf,Ttag,Tclass; \\r
+               long Tlen; \\r
+               \\r
+               c.q=c.p; \\r
+               Tinf=ASN1_get_object(&c.p,&Tlen,&Ttag,&Tclass,c.slen); \\r
+               if (Tinf & 0x80) \\r
+                       { c.error=ERR_R_BAD_ASN1_OBJECT_HEADER; \\r
+                       c.line=__LINE__; goto err; } \\r
+               if (Tinf == (V_ASN1_CONSTRUCTED+1)) \\r
+                                       Tlen = c.slen - (c.p - c.q) - 2; \\r
+               if (d2i_ASN1_SET(&(r),&c.p,Tlen,(char *(*)())func, \\r
+                       (void (*)())free_func, \\r
+                       b,V_ASN1_UNIVERSAL) == NULL) \\r
+                       { c.line=__LINE__; goto err; } \\r
+               if (Tinf == (V_ASN1_CONSTRUCTED+1)) { \\r
+                       Tlen = c.slen - (c.p - c.q); \\r
+                       if(!ASN1_check_infinite_end(&c.p, Tlen)) \\r
+                               { c.error=ERR_R_MISSING_ASN1_EOS; \\r
+                               c.line=__LINE__; goto err; } \\r
+               }\\r
+               c.slen-=(c.p-c.q); \\r
+               }\r
+\r
+#define M_ASN1_D2I_get_EXP_set_opt_type(type,r,func,free_func,tag,b) \\r
+       if ((c.slen != 0) && (M_ASN1_next == \\r
+               (V_ASN1_CONSTRUCTED|V_ASN1_CONTEXT_SPECIFIC|tag))) \\r
+               { \\r
+               int Tinf,Ttag,Tclass; \\r
+               long Tlen; \\r
+               \\r
+               c.q=c.p; \\r
+               Tinf=ASN1_get_object(&c.p,&Tlen,&Ttag,&Tclass,c.slen); \\r
+               if (Tinf & 0x80) \\r
+                       { c.error=ERR_R_BAD_ASN1_OBJECT_HEADER; \\r
+                       c.line=__LINE__; goto err; } \\r
+               if (Tinf == (V_ASN1_CONSTRUCTED+1)) \\r
+                                       Tlen = c.slen - (c.p - c.q) - 2; \\r
+               if (d2i_ASN1_SET_OF_##type(&(r),&c.p,Tlen,func, \\r
+                       free_func,b,V_ASN1_UNIVERSAL) == NULL) \\r
+                       { c.line=__LINE__; goto err; } \\r
+               if (Tinf == (V_ASN1_CONSTRUCTED+1)) { \\r
+                       Tlen = c.slen - (c.p - c.q); \\r
+                       if(!ASN1_check_infinite_end(&c.p, Tlen)) \\r
+                               { c.error=ERR_R_MISSING_ASN1_EOS; \\r
+                               c.line=__LINE__; goto err; } \\r
+               }\\r
+               c.slen-=(c.p-c.q); \\r
+               }\r
+\r
+/* New macros */\r
+#define M_ASN1_New_Malloc(ret,type) \\r
+       if ((ret=(type *)OPENSSL_malloc(sizeof(type))) == NULL) \\r
+               { c.line=__LINE__; goto err2; }\r
+\r
+#define M_ASN1_New(arg,func) \\r
+       if (((arg)=func()) == NULL) return(NULL)\r
+\r
+#define M_ASN1_New_Error(a) \\r
+/*     err:    ASN1_MAC_H_err((a),ERR_R_NESTED_ASN1_ERROR,c.line); \\r
+               return(NULL);*/ \\r
+       err2:   ASN1_MAC_H_err((a),ERR_R_MALLOC_FAILURE,c.line); \\r
+               return(NULL)\r
+\r
+\r
+/* BIG UGLY WARNING!  This is so damn ugly I wanna puke.  Unfortunately,\r
+   some macros that use ASN1_const_CTX still insist on writing in the input\r
+   stream.  ARGH!  ARGH!  ARGH!  Let's get rid of this macro package.\r
+   Please?                                             -- Richard Levitte */\r
+#define M_ASN1_next            (*((unsigned char *)(c.p)))\r
+#define M_ASN1_next_prev       (*((unsigned char *)(c.q)))\r
+\r
+/*************************************************/\r
+\r
+#define M_ASN1_I2D_vars(a)     int r=0,ret=0; \\r
+                               unsigned char *p; \\r
+                               if (a == NULL) return(0)\r
+\r
+/* Length Macros */\r
+#define M_ASN1_I2D_len(a,f)    ret+=f(a,NULL)\r
+#define M_ASN1_I2D_len_IMP_opt(a,f)    if (a != NULL) M_ASN1_I2D_len(a,f)\r
+\r
+#define M_ASN1_I2D_len_SET(a,f) \\r
+               ret+=i2d_ASN1_SET(a,NULL,f,V_ASN1_SET,V_ASN1_UNIVERSAL,IS_SET);\r
+\r
+#define M_ASN1_I2D_len_SET_type(type,a,f) \\r
+               ret+=i2d_ASN1_SET_OF_##type(a,NULL,f,V_ASN1_SET, \\r
+                                           V_ASN1_UNIVERSAL,IS_SET);\r
+\r
+#define M_ASN1_I2D_len_SEQUENCE(a,f) \\r
+               ret+=i2d_ASN1_SET(a,NULL,f,V_ASN1_SEQUENCE,V_ASN1_UNIVERSAL, \\r
+                                 IS_SEQUENCE);\r
+\r
+#define M_ASN1_I2D_len_SEQUENCE_type(type,a,f) \\r
+               ret+=i2d_ASN1_SET_OF_##type(a,NULL,f,V_ASN1_SEQUENCE, \\r
+                                           V_ASN1_UNIVERSAL,IS_SEQUENCE)\r
+\r
+#define M_ASN1_I2D_len_SEQUENCE_opt(a,f) \\r
+               if ((a != NULL) && (sk_num(a) != 0)) \\r
+                       M_ASN1_I2D_len_SEQUENCE(a,f);\r
+\r
+#define M_ASN1_I2D_len_SEQUENCE_opt_type(type,a,f) \\r
+               if ((a != NULL) && (sk_##type##_num(a) != 0)) \\r
+                       M_ASN1_I2D_len_SEQUENCE_type(type,a,f);\r
+\r
+#define M_ASN1_I2D_len_IMP_SET(a,f,x) \\r
+               ret+=i2d_ASN1_SET(a,NULL,f,x,V_ASN1_CONTEXT_SPECIFIC,IS_SET);\r
+\r
+#define M_ASN1_I2D_len_IMP_SET_type(type,a,f,x) \\r
+               ret+=i2d_ASN1_SET_OF_##type(a,NULL,f,x, \\r
+                                           V_ASN1_CONTEXT_SPECIFIC,IS_SET);\r
+\r
+#define M_ASN1_I2D_len_IMP_SET_opt(a,f,x) \\r
+               if ((a != NULL) && (sk_num(a) != 0)) \\r
+                       ret+=i2d_ASN1_SET(a,NULL,f,x,V_ASN1_CONTEXT_SPECIFIC, \\r
+                                         IS_SET);\r
+\r
+#define M_ASN1_I2D_len_IMP_SET_opt_type(type,a,f,x) \\r
+               if ((a != NULL) && (sk_##type##_num(a) != 0)) \\r
+                       ret+=i2d_ASN1_SET_OF_##type(a,NULL,f,x, \\r
+                                              V_ASN1_CONTEXT_SPECIFIC,IS_SET);\r
+\r
+#define M_ASN1_I2D_len_IMP_SEQUENCE(a,f,x) \\r
+               ret+=i2d_ASN1_SET(a,NULL,f,x,V_ASN1_CONTEXT_SPECIFIC, \\r
+                                 IS_SEQUENCE);\r
+\r
+#define M_ASN1_I2D_len_IMP_SEQUENCE_opt(a,f,x) \\r
+               if ((a != NULL) && (sk_num(a) != 0)) \\r
+                       ret+=i2d_ASN1_SET(a,NULL,f,x,V_ASN1_CONTEXT_SPECIFIC, \\r
+                                         IS_SEQUENCE);\r
+\r
+#define M_ASN1_I2D_len_IMP_SEQUENCE_opt_type(type,a,f,x) \\r
+               if ((a != NULL) && (sk_##type##_num(a) != 0)) \\r
+                       ret+=i2d_ASN1_SET_OF_##type(a,NULL,f,x, \\r
+                                                   V_ASN1_CONTEXT_SPECIFIC, \\r
+                                                   IS_SEQUENCE);\r
+\r
+#define M_ASN1_I2D_len_EXP_opt(a,f,mtag,v) \\r
+               if (a != NULL)\\r
+                       { \\r
+                       v=f(a,NULL); \\r
+                       ret+=ASN1_object_size(1,v,mtag); \\r
+                       }\r
+\r
+#define M_ASN1_I2D_len_EXP_SET_opt(a,f,mtag,tag,v) \\r
+               if ((a != NULL) && (sk_num(a) != 0))\\r
+                       { \\r
+                       v=i2d_ASN1_SET(a,NULL,f,tag,V_ASN1_UNIVERSAL,IS_SET); \\r
+                       ret+=ASN1_object_size(1,v,mtag); \\r
+                       }\r
+\r
+#define M_ASN1_I2D_len_EXP_SEQUENCE_opt(a,f,mtag,tag,v) \\r
+               if ((a != NULL) && (sk_num(a) != 0))\\r
+                       { \\r
+                       v=i2d_ASN1_SET(a,NULL,f,tag,V_ASN1_UNIVERSAL, \\r
+                                      IS_SEQUENCE); \\r
+                       ret+=ASN1_object_size(1,v,mtag); \\r
+                       }\r
+\r
+#define M_ASN1_I2D_len_EXP_SEQUENCE_opt_type(type,a,f,mtag,tag,v) \\r
+               if ((a != NULL) && (sk_##type##_num(a) != 0))\\r
+                       { \\r
+                       v=i2d_ASN1_SET_OF_##type(a,NULL,f,tag, \\r
+                                                V_ASN1_UNIVERSAL, \\r
+                                                IS_SEQUENCE); \\r
+                       ret+=ASN1_object_size(1,v,mtag); \\r
+                       }\r
+\r
+/* Put Macros */\r
+#define M_ASN1_I2D_put(a,f)    f(a,&p)\r
+\r
+#define M_ASN1_I2D_put_IMP_opt(a,f,t)  \\r
+               if (a != NULL) \\r
+                       { \\r
+                       unsigned char *q=p; \\r
+                       f(a,&p); \\r
+                       *q=(V_ASN1_CONTEXT_SPECIFIC|t|(*q&V_ASN1_CONSTRUCTED));\\r
+                       }\r
+\r
+#define M_ASN1_I2D_put_SET(a,f) i2d_ASN1_SET(a,&p,f,V_ASN1_SET,\\r
+                       V_ASN1_UNIVERSAL,IS_SET)\r
+#define M_ASN1_I2D_put_SET_type(type,a,f) \\r
+     i2d_ASN1_SET_OF_##type(a,&p,f,V_ASN1_SET,V_ASN1_UNIVERSAL,IS_SET)\r
+#define M_ASN1_I2D_put_IMP_SET(a,f,x) i2d_ASN1_SET(a,&p,f,x,\\r
+                       V_ASN1_CONTEXT_SPECIFIC,IS_SET)\r
+#define M_ASN1_I2D_put_IMP_SET_type(type,a,f,x) \\r
+     i2d_ASN1_SET_OF_##type(a,&p,f,x,V_ASN1_CONTEXT_SPECIFIC,IS_SET)\r
+#define M_ASN1_I2D_put_IMP_SEQUENCE(a,f,x) i2d_ASN1_SET(a,&p,f,x,\\r
+                       V_ASN1_CONTEXT_SPECIFIC,IS_SEQUENCE)\r
+\r
+#define M_ASN1_I2D_put_SEQUENCE(a,f) i2d_ASN1_SET(a,&p,f,V_ASN1_SEQUENCE,\\r
+                                            V_ASN1_UNIVERSAL,IS_SEQUENCE)\r
+\r
+#define M_ASN1_I2D_put_SEQUENCE_type(type,a,f) \\r
+     i2d_ASN1_SET_OF_##type(a,&p,f,V_ASN1_SEQUENCE,V_ASN1_UNIVERSAL, \\r
+                           IS_SEQUENCE)\r
+\r
+#define M_ASN1_I2D_put_SEQUENCE_opt(a,f) \\r
+               if ((a != NULL) && (sk_num(a) != 0)) \\r
+                       M_ASN1_I2D_put_SEQUENCE(a,f);\r
+\r
+#define M_ASN1_I2D_put_IMP_SET_opt(a,f,x) \\r
+               if ((a != NULL) && (sk_num(a) != 0)) \\r
+                       { i2d_ASN1_SET(a,&p,f,x,V_ASN1_CONTEXT_SPECIFIC, \\r
+                                      IS_SET); }\r
+\r
+#define M_ASN1_I2D_put_IMP_SET_opt_type(type,a,f,x) \\r
+               if ((a != NULL) && (sk_##type##_num(a) != 0)) \\r
+                       { i2d_ASN1_SET_OF_##type(a,&p,f,x, \\r
+                                                V_ASN1_CONTEXT_SPECIFIC, \\r
+                                                IS_SET); }\r
+\r
+#define M_ASN1_I2D_put_IMP_SEQUENCE_opt(a,f,x) \\r
+               if ((a != NULL) && (sk_num(a) != 0)) \\r
+                       { i2d_ASN1_SET(a,&p,f,x,V_ASN1_CONTEXT_SPECIFIC, \\r
+                                      IS_SEQUENCE); }\r
+\r
+#define M_ASN1_I2D_put_IMP_SEQUENCE_opt_type(type,a,f,x) \\r
+               if ((a != NULL) && (sk_##type##_num(a) != 0)) \\r
+                       { i2d_ASN1_SET_OF_##type(a,&p,f,x, \\r
+                                                V_ASN1_CONTEXT_SPECIFIC, \\r
+                                                IS_SEQUENCE); }\r
+\r
+#define M_ASN1_I2D_put_EXP_opt(a,f,tag,v) \\r
+               if (a != NULL) \\r
+                       { \\r
+                       ASN1_put_object(&p,1,v,tag,V_ASN1_CONTEXT_SPECIFIC); \\r
+                       f(a,&p); \\r
+                       }\r
+\r
+#define M_ASN1_I2D_put_EXP_SET_opt(a,f,mtag,tag,v) \\r
+               if ((a != NULL) && (sk_num(a) != 0)) \\r
+                       { \\r
+                       ASN1_put_object(&p,1,v,mtag,V_ASN1_CONTEXT_SPECIFIC); \\r
+                       i2d_ASN1_SET(a,&p,f,tag,V_ASN1_UNIVERSAL,IS_SET); \\r
+                       }\r
+\r
+#define M_ASN1_I2D_put_EXP_SEQUENCE_opt(a,f,mtag,tag,v) \\r
+               if ((a != NULL) && (sk_num(a) != 0)) \\r
+                       { \\r
+                       ASN1_put_object(&p,1,v,mtag,V_ASN1_CONTEXT_SPECIFIC); \\r
+                       i2d_ASN1_SET(a,&p,f,tag,V_ASN1_UNIVERSAL,IS_SEQUENCE); \\r
+                       }\r
+\r
+#define M_ASN1_I2D_put_EXP_SEQUENCE_opt_type(type,a,f,mtag,tag,v) \\r
+               if ((a != NULL) && (sk_##type##_num(a) != 0)) \\r
+                       { \\r
+                       ASN1_put_object(&p,1,v,mtag,V_ASN1_CONTEXT_SPECIFIC); \\r
+                       i2d_ASN1_SET_OF_##type(a,&p,f,tag,V_ASN1_UNIVERSAL, \\r
+                                              IS_SEQUENCE); \\r
+                       }\r
+\r
+#define M_ASN1_I2D_seq_total() \\r
+               r=ASN1_object_size(1,ret,V_ASN1_SEQUENCE); \\r
+               if (pp == NULL) return(r); \\r
+               p= *pp; \\r
+               ASN1_put_object(&p,1,ret,V_ASN1_SEQUENCE,V_ASN1_UNIVERSAL)\r
+\r
+#define M_ASN1_I2D_INF_seq_start(tag,ctx) \\r
+               *(p++)=(V_ASN1_CONSTRUCTED|(tag)|(ctx)); \\r
+               *(p++)=0x80\r
+\r
+#define M_ASN1_I2D_INF_seq_end() *(p++)=0x00; *(p++)=0x00\r
+\r
+#define M_ASN1_I2D_finish()    *pp=p; \\r
+                               return(r);\r
+\r
+int asn1_GetSequence(ASN1_const_CTX *c, long *length);\r
+void asn1_add_error(const unsigned char *address,int offset);\r
+#ifdef  __cplusplus\r
+}\r
+#endif\r
+\r
+#endif\r
index 3e94730..8b04e1e 100644 (file)
-/* asn1t.h */
-/* Written by Dr Stephen N Henson (steve@openssl.org) for the OpenSSL
- * project 2000.
- */
-/* ====================================================================
- * Copyright (c) 2000-2005 The OpenSSL Project.  All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- *
- * 1. Redistributions of source code must retain the above copyright
- *    notice, this list of conditions and the following disclaimer.
- *
- * 2. Redistributions in binary form must reproduce the above copyright
- *    notice, this list of conditions and the following disclaimer in
- *    the documentation and/or other materials provided with the
- *    distribution.
- *
- * 3. All advertising materials mentioning features or use of this
- *    software must display the following acknowledgment:
- *    "This product includes software developed by the OpenSSL Project
- *    for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)"
- *
- * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
- *    endorse or promote products derived from this software without
- *    prior written permission. For written permission, please contact
- *    licensing@OpenSSL.org.
- *
- * 5. Products derived from this software may not be called "OpenSSL"
- *    nor may "OpenSSL" appear in their names without prior written
- *    permission of the OpenSSL Project.
- *
- * 6. Redistributions of any form whatsoever must retain the following
- *    acknowledgment:
- *    "This product includes software developed by the OpenSSL Project
- *    for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"
- *
- * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
- * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR
- * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
- * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
- * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
- * OF THE POSSIBILITY OF SUCH DAMAGE.
- * ====================================================================
- *
- * This product includes cryptographic software written by Eric Young
- * (eay@cryptsoft.com).  This product includes software written by Tim
- * Hudson (tjh@cryptsoft.com).
- *
- */
-#ifndef HEADER_ASN1T_H
-#define HEADER_ASN1T_H
-
-#include <stddef.h>
-#include <openssl/e_os2.h>
-#include <openssl/asn1.h>
-
-#ifdef OPENSSL_BUILD_SHLIBCRYPTO
-# undef OPENSSL_EXTERN
-# define OPENSSL_EXTERN OPENSSL_EXPORT
-#endif
-
-/* ASN1 template defines, structures and functions */
-
-#ifdef  __cplusplus
-extern "C" {
-#endif
-
-
-#ifndef OPENSSL_EXPORT_VAR_AS_FUNCTION
-
-/* Macro to obtain ASN1_ADB pointer from a type (only used internally) */
-#define ASN1_ADB_ptr(iptr) ((const ASN1_ADB *)(iptr))
-
-
-/* Macros for start and end of ASN1_ITEM definition */
-
-#define ASN1_ITEM_start(itname) \
-       OPENSSL_GLOBAL const ASN1_ITEM itname##_it = {
-
-#define ASN1_ITEM_end(itname) \
-               };
-
-#else
-
-/* Macro to obtain ASN1_ADB pointer from a type (only used internally) */
-#define ASN1_ADB_ptr(iptr) ((const ASN1_ADB *)(iptr()))
-
-
-/* Macros for start and end of ASN1_ITEM definition */
-
-#define ASN1_ITEM_start(itname) \
-       const ASN1_ITEM * itname##_it(void) \
-       { \
-               static const ASN1_ITEM local_it = {
-
-#define ASN1_ITEM_end(itname) \
-               }; \
-       return &local_it; \
-       }
-
-#endif
-
-
-/* Macros to aid ASN1 template writing */
-
-#define ASN1_ITEM_TEMPLATE(tname) \
-       static const ASN1_TEMPLATE tname##_item_tt
-
-#define ASN1_ITEM_TEMPLATE_END(tname) \
-       ;\
-       ASN1_ITEM_start(tname) \
-               ASN1_ITYPE_PRIMITIVE,\
-               -1,\
-               &tname##_item_tt,\
-               0,\
-               NULL,\
-               0,\
-               #tname \
-       ASN1_ITEM_end(tname)
-
-
-/* This is a ASN1 type which just embeds a template */
-
-/* This pair helps declare a SEQUENCE. We can do:
- *
- *     ASN1_SEQUENCE(stname) = {
- *             ... SEQUENCE components ...
- *     } ASN1_SEQUENCE_END(stname)
- *
- *     This will produce an ASN1_ITEM called stname_it
- *     for a structure called stname.
- *
- *     If you want the same structure but a different
- *     name then use:
- *
- *     ASN1_SEQUENCE(itname) = {
- *             ... SEQUENCE components ...
- *     } ASN1_SEQUENCE_END_name(stname, itname)
- *
- *     This will create an item called itname_it using
- *     a structure called stname.
- */
-
-#define ASN1_SEQUENCE(tname) \
-       static const ASN1_TEMPLATE tname##_seq_tt[]
-
-#define ASN1_SEQUENCE_END(stname) ASN1_SEQUENCE_END_name(stname, stname)
-
-#define ASN1_SEQUENCE_END_name(stname, tname) \
-       ;\
-       ASN1_ITEM_start(tname) \
-               ASN1_ITYPE_SEQUENCE,\
-               V_ASN1_SEQUENCE,\
-               tname##_seq_tt,\
-               sizeof(tname##_seq_tt) / sizeof(ASN1_TEMPLATE),\
-               NULL,\
-               sizeof(stname),\
-               #stname \
-       ASN1_ITEM_end(tname)
-
-#define ASN1_NDEF_SEQUENCE(tname) \
-       ASN1_SEQUENCE(tname)
-
-#define ASN1_NDEF_SEQUENCE_cb(tname, cb) \
-       ASN1_SEQUENCE_cb(tname, cb)
-
-#define ASN1_SEQUENCE_cb(tname, cb) \
-       static const ASN1_AUX tname##_aux = {NULL, 0, 0, 0, cb, 0}; \
-       ASN1_SEQUENCE(tname)
-
-#define ASN1_BROKEN_SEQUENCE(tname) \
-       static const ASN1_AUX tname##_aux = {NULL, ASN1_AFLG_BROKEN, 0, 0, 0, 0}; \
-       ASN1_SEQUENCE(tname)
-
-#define ASN1_SEQUENCE_ref(tname, cb, lck) \
-       static const ASN1_AUX tname##_aux = {NULL, ASN1_AFLG_REFCOUNT, offsetof(tname, references), lck, cb, 0}; \
-       ASN1_SEQUENCE(tname)
-
-#define ASN1_SEQUENCE_enc(tname, enc, cb) \
-       static const ASN1_AUX tname##_aux = {NULL, ASN1_AFLG_ENCODING, 0, 0, cb, offsetof(tname, enc)}; \
-       ASN1_SEQUENCE(tname)
-
-#define ASN1_NDEF_SEQUENCE_END(tname) \
-       ;\
-       ASN1_ITEM_start(tname) \
-               ASN1_ITYPE_NDEF_SEQUENCE,\
-               V_ASN1_SEQUENCE,\
-               tname##_seq_tt,\
-               sizeof(tname##_seq_tt) / sizeof(ASN1_TEMPLATE),\
-               NULL,\
-               sizeof(tname),\
-               #tname \
-       ASN1_ITEM_end(tname)
-
-#define ASN1_BROKEN_SEQUENCE_END(stname) ASN1_SEQUENCE_END_ref(stname, stname)
-
-#define ASN1_SEQUENCE_END_enc(stname, tname) ASN1_SEQUENCE_END_ref(stname, tname)
-
-#define ASN1_SEQUENCE_END_cb(stname, tname) ASN1_SEQUENCE_END_ref(stname, tname)
-
-#define ASN1_SEQUENCE_END_ref(stname, tname) \
-       ;\
-       ASN1_ITEM_start(tname) \
-               ASN1_ITYPE_SEQUENCE,\
-               V_ASN1_SEQUENCE,\
-               tname##_seq_tt,\
-               sizeof(tname##_seq_tt) / sizeof(ASN1_TEMPLATE),\
-               &tname##_aux,\
-               sizeof(stname),\
-               #stname \
-       ASN1_ITEM_end(tname)
-
-#define ASN1_NDEF_SEQUENCE_END_cb(stname, tname) \
-       ;\
-       ASN1_ITEM_start(tname) \
-               ASN1_ITYPE_NDEF_SEQUENCE,\
-               V_ASN1_SEQUENCE,\
-               tname##_seq_tt,\
-               sizeof(tname##_seq_tt) / sizeof(ASN1_TEMPLATE),\
-               &tname##_aux,\
-               sizeof(stname),\
-               #stname \
-       ASN1_ITEM_end(tname)
-
-
-/* This pair helps declare a CHOICE type. We can do:
- *
- *     ASN1_CHOICE(chname) = {
- *             ... CHOICE options ...
- *     ASN1_CHOICE_END(chname)
- *
- *     This will produce an ASN1_ITEM called chname_it
- *     for a structure called chname. The structure
- *     definition must look like this:
- *     typedef struct {
- *             int type;
- *             union {
- *                     ASN1_SOMETHING *opt1;
- *                     ASN1_SOMEOTHER *opt2;
- *             } value;
- *     } chname;
- *
- *     the name of the selector must be 'type'.
- *     to use an alternative selector name use the
- *      ASN1_CHOICE_END_selector() version.
- */
-
-#define ASN1_CHOICE(tname) \
-       static const ASN1_TEMPLATE tname##_ch_tt[]
-
-#define ASN1_CHOICE_cb(tname, cb) \
-       static const ASN1_AUX tname##_aux = {NULL, 0, 0, 0, cb, 0}; \
-       ASN1_CHOICE(tname)
-
-#define ASN1_CHOICE_END(stname) ASN1_CHOICE_END_name(stname, stname)
-
-#define ASN1_CHOICE_END_name(stname, tname) ASN1_CHOICE_END_selector(stname, tname, type)
-
-#define ASN1_CHOICE_END_selector(stname, tname, selname) \
-       ;\
-       ASN1_ITEM_start(tname) \
-               ASN1_ITYPE_CHOICE,\
-               offsetof(stname,selname) ,\
-               tname##_ch_tt,\
-               sizeof(tname##_ch_tt) / sizeof(ASN1_TEMPLATE),\
-               NULL,\
-               sizeof(stname),\
-               #stname \
-       ASN1_ITEM_end(tname)
-
-#define ASN1_CHOICE_END_cb(stname, tname, selname) \
-       ;\
-       ASN1_ITEM_start(tname) \
-               ASN1_ITYPE_CHOICE,\
-               offsetof(stname,selname) ,\
-               tname##_ch_tt,\
-               sizeof(tname##_ch_tt) / sizeof(ASN1_TEMPLATE),\
-               &tname##_aux,\
-               sizeof(stname),\
-               #stname \
-       ASN1_ITEM_end(tname)
-
-/* This helps with the template wrapper form of ASN1_ITEM */
-
-#define ASN1_EX_TEMPLATE_TYPE(flags, tag, name, type) { \
-       (flags), (tag), 0,\
-       #name, ASN1_ITEM_ref(type) }
-
-/* These help with SEQUENCE or CHOICE components */
-
-/* used to declare other types */
-
-#define ASN1_EX_TYPE(flags, tag, stname, field, type) { \
-       (flags), (tag), offsetof(stname, field),\
-       #field, ASN1_ITEM_ref(type) }
-
-/* used when the structure is combined with the parent */
-
-#define ASN1_EX_COMBINE(flags, tag, type) { \
-       (flags)|ASN1_TFLG_COMBINE, (tag), 0, NULL, ASN1_ITEM_ref(type) }
-
-/* implicit and explicit helper macros */
-
-#define ASN1_IMP_EX(stname, field, type, tag, ex) \
-               ASN1_EX_TYPE(ASN1_TFLG_IMPLICIT | ex, tag, stname, field, type)
-
-#define ASN1_EXP_EX(stname, field, type, tag, ex) \
-               ASN1_EX_TYPE(ASN1_TFLG_EXPLICIT | ex, tag, stname, field, type)
-
-/* Any defined by macros: the field used is in the table itself */
-
-#ifndef OPENSSL_EXPORT_VAR_AS_FUNCTION
-#define ASN1_ADB_OBJECT(tblname) { ASN1_TFLG_ADB_OID, -1, 0, #tblname, (const ASN1_ITEM *)&(tblname##_adb) }
-#define ASN1_ADB_INTEGER(tblname) { ASN1_TFLG_ADB_INT, -1, 0, #tblname, (const ASN1_ITEM *)&(tblname##_adb) }
-#else
-#define ASN1_ADB_OBJECT(tblname) { ASN1_TFLG_ADB_OID, -1, 0, #tblname, tblname##_adb }
-#define ASN1_ADB_INTEGER(tblname) { ASN1_TFLG_ADB_INT, -1, 0, #tblname, tblname##_adb }
-#endif
-/* Plain simple type */
-#define ASN1_SIMPLE(stname, field, type) ASN1_EX_TYPE(0,0, stname, field, type)
-
-/* OPTIONAL simple type */
-#define ASN1_OPT(stname, field, type) ASN1_EX_TYPE(ASN1_TFLG_OPTIONAL, 0, stname, field, type)
-
-/* IMPLICIT tagged simple type */
-#define ASN1_IMP(stname, field, type, tag) ASN1_IMP_EX(stname, field, type, tag, 0)
-
-/* IMPLICIT tagged OPTIONAL simple type */
-#define ASN1_IMP_OPT(stname, field, type, tag) ASN1_IMP_EX(stname, field, type, tag, ASN1_TFLG_OPTIONAL)
-
-/* Same as above but EXPLICIT */
-
-#define ASN1_EXP(stname, field, type, tag) ASN1_EXP_EX(stname, field, type, tag, 0)
-#define ASN1_EXP_OPT(stname, field, type, tag) ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_OPTIONAL)
-
-/* SEQUENCE OF type */
-#define ASN1_SEQUENCE_OF(stname, field, type) \
-               ASN1_EX_TYPE(ASN1_TFLG_SEQUENCE_OF, 0, stname, field, type)
-
-/* OPTIONAL SEQUENCE OF */
-#define ASN1_SEQUENCE_OF_OPT(stname, field, type) \
-               ASN1_EX_TYPE(ASN1_TFLG_SEQUENCE_OF|ASN1_TFLG_OPTIONAL, 0, stname, field, type)
-
-/* Same as above but for SET OF */
-
-#define ASN1_SET_OF(stname, field, type) \
-               ASN1_EX_TYPE(ASN1_TFLG_SET_OF, 0, stname, field, type)
-
-#define ASN1_SET_OF_OPT(stname, field, type) \
-               ASN1_EX_TYPE(ASN1_TFLG_SET_OF|ASN1_TFLG_OPTIONAL, 0, stname, field, type)
-
-/* Finally compound types of SEQUENCE, SET, IMPLICIT, EXPLICIT and OPTIONAL */
-
-#define ASN1_IMP_SET_OF(stname, field, type, tag) \
-                       ASN1_IMP_EX(stname, field, type, tag, ASN1_TFLG_SET_OF)
-
-#define ASN1_EXP_SET_OF(stname, field, type, tag) \
-                       ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_SET_OF)
-
-#define ASN1_IMP_SET_OF_OPT(stname, field, type, tag) \
-                       ASN1_IMP_EX(stname, field, type, tag, ASN1_TFLG_SET_OF|ASN1_TFLG_OPTIONAL)
-
-#define ASN1_EXP_SET_OF_OPT(stname, field, type, tag) \
-                       ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_SET_OF|ASN1_TFLG_OPTIONAL)
-
-#define ASN1_IMP_SEQUENCE_OF(stname, field, type, tag) \
-                       ASN1_IMP_EX(stname, field, type, tag, ASN1_TFLG_SEQUENCE_OF)
-
-#define ASN1_IMP_SEQUENCE_OF_OPT(stname, field, type, tag) \
-                       ASN1_IMP_EX(stname, field, type, tag, ASN1_TFLG_SEQUENCE_OF|ASN1_TFLG_OPTIONAL)
-
-#define ASN1_EXP_SEQUENCE_OF(stname, field, type, tag) \
-                       ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_SEQUENCE_OF)
-
-#define ASN1_EXP_SEQUENCE_OF_OPT(stname, field, type, tag) \
-                       ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_SEQUENCE_OF|ASN1_TFLG_OPTIONAL)
-
-/* EXPLICIT using indefinite length constructed form */
-#define ASN1_NDEF_EXP(stname, field, type, tag) \
-                       ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_NDEF)
-
-/* EXPLICIT OPTIONAL using indefinite length constructed form */
-#define ASN1_NDEF_EXP_OPT(stname, field, type, tag) \
-                       ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_OPTIONAL|ASN1_TFLG_NDEF)
-
-/* Macros for the ASN1_ADB structure */
-
-#define ASN1_ADB(name) \
-       static const ASN1_ADB_TABLE name##_adbtbl[]
-
-#ifndef OPENSSL_EXPORT_VAR_AS_FUNCTION
-
-#define ASN1_ADB_END(name, flags, field, app_table, def, none) \
-       ;\
-       static const ASN1_ADB name##_adb = {\
-               flags,\
-               offsetof(name, field),\
-               app_table,\
-               name##_adbtbl,\
-               sizeof(name##_adbtbl) / sizeof(ASN1_ADB_TABLE),\
-               def,\
-               none\
-       }
-
-#else
-
-#define ASN1_ADB_END(name, flags, field, app_table, def, none) \
-       ;\
-       static const ASN1_ITEM *name##_adb(void) \
-       { \
-       static const ASN1_ADB internal_adb = \
-               {\
-               flags,\
-               offsetof(name, field),\
-               app_table,\
-               name##_adbtbl,\
-               sizeof(name##_adbtbl) / sizeof(ASN1_ADB_TABLE),\
-               def,\
-               none\
-               }; \
-               return (const ASN1_ITEM *) &internal_adb; \
-       } \
-       void dummy_function(void)
-
-#endif
-
-#define ADB_ENTRY(val, template) {val, template}
-
-#define ASN1_ADB_TEMPLATE(name) \
-       static const ASN1_TEMPLATE name##_tt
-
-/* This is the ASN1 template structure that defines
- * a wrapper round the actual type. It determines the
- * actual position of the field in the value structure,
- * various flags such as OPTIONAL and the field name.
- */
-
-struct ASN1_TEMPLATE_st {
-unsigned long flags;           /* Various flags */
-long tag;                      /* tag, not used if no tagging */
-unsigned long offset;          /* Offset of this field in structure */
-#ifndef NO_ASN1_FIELD_NAMES
-const char *field_name;                /* Field name */
-#endif
-ASN1_ITEM_EXP *item;           /* Relevant ASN1_ITEM or ASN1_ADB */
-};
-
-/* Macro to extract ASN1_ITEM and ASN1_ADB pointer from ASN1_TEMPLATE */
-
-#define ASN1_TEMPLATE_item(t) (t->item_ptr)
-#define ASN1_TEMPLATE_adb(t) (t->item_ptr)
-
-typedef struct ASN1_ADB_TABLE_st ASN1_ADB_TABLE;
-typedef struct ASN1_ADB_st ASN1_ADB;
-
-struct ASN1_ADB_st {
-       unsigned long flags;    /* Various flags */
-       unsigned long offset;   /* Offset of selector field */
-       STACK_OF(ASN1_ADB_TABLE) **app_items; /* Application defined items */
-       const ASN1_ADB_TABLE *tbl;      /* Table of possible types */
-       long tblcount;          /* Number of entries in tbl */
-       const ASN1_TEMPLATE *default_tt;  /* Type to use if no match */
-       const ASN1_TEMPLATE *null_tt;  /* Type to use if selector is NULL */
-};
-
-struct ASN1_ADB_TABLE_st {
-       long value;             /* NID for an object or value for an int */
-       const ASN1_TEMPLATE tt;         /* item for this value */
-};
-
-/* template flags */
-
-/* Field is optional */
-#define ASN1_TFLG_OPTIONAL     (0x1)
-
-/* Field is a SET OF */
-#define ASN1_TFLG_SET_OF       (0x1 << 1)
-
-/* Field is a SEQUENCE OF */
-#define ASN1_TFLG_SEQUENCE_OF  (0x2 << 1)
-
-/* Special case: this refers to a SET OF that
- * will be sorted into DER order when encoded *and*
- * the corresponding STACK will be modified to match
- * the new order.
- */
-#define ASN1_TFLG_SET_ORDER    (0x3 << 1)
-
-/* Mask for SET OF or SEQUENCE OF */
-#define ASN1_TFLG_SK_MASK      (0x3 << 1)
-
-/* These flags mean the tag should be taken from the
- * tag field. If EXPLICIT then the underlying type
- * is used for the inner tag.
- */
-
-/* IMPLICIT tagging */
-#define ASN1_TFLG_IMPTAG       (0x1 << 3)
-
-
-/* EXPLICIT tagging, inner tag from underlying type */
-#define ASN1_TFLG_EXPTAG       (0x2 << 3)
-
-#define ASN1_TFLG_TAG_MASK     (0x3 << 3)
-
-/* context specific IMPLICIT */
-#define ASN1_TFLG_IMPLICIT     ASN1_TFLG_IMPTAG|ASN1_TFLG_CONTEXT
-
-/* context specific EXPLICIT */
-#define ASN1_TFLG_EXPLICIT     ASN1_TFLG_EXPTAG|ASN1_TFLG_CONTEXT
-
-/* If tagging is in force these determine the
- * type of tag to use. Otherwise the tag is
- * determined by the underlying type. These
- * values reflect the actual octet format.
- */
-
-/* Universal tag */
-#define ASN1_TFLG_UNIVERSAL    (0x0<<6)
-/* Application tag */
-#define ASN1_TFLG_APPLICATION  (0x1<<6)
-/* Context specific tag */
-#define ASN1_TFLG_CONTEXT      (0x2<<6)
-/* Private tag */
-#define ASN1_TFLG_PRIVATE      (0x3<<6)
-
-#define ASN1_TFLG_TAG_CLASS    (0x3<<6)
-
-/* These are for ANY DEFINED BY type. In this case
- * the 'item' field points to an ASN1_ADB structure
- * which contains a table of values to decode the
- * relevant type
- */
-
-#define ASN1_TFLG_ADB_MASK     (0x3<<8)
-
-#define ASN1_TFLG_ADB_OID      (0x1<<8)
-
-#define ASN1_TFLG_ADB_INT      (0x1<<9)
-
-/* This flag means a parent structure is passed
- * instead of the field: this is useful is a
- * SEQUENCE is being combined with a CHOICE for
- * example. Since this means the structure and
- * item name will differ we need to use the
- * ASN1_CHOICE_END_name() macro for example.
- */
-
-#define ASN1_TFLG_COMBINE      (0x1<<10)
-
-/* This flag when present in a SEQUENCE OF, SET OF
- * or EXPLICIT causes indefinite length constructed
- * encoding to be used if required.
- */
-
-#define ASN1_TFLG_NDEF         (0x1<<11)
-
-/* This is the actual ASN1 item itself */
-
-struct ASN1_ITEM_st {
-char itype;                    /* The item type, primitive, SEQUENCE, CHOICE or extern */
-long utype;                    /* underlying type */
-const ASN1_TEMPLATE *templates;        /* If SEQUENCE or CHOICE this contains the contents */
-long tcount;                   /* Number of templates if SEQUENCE or CHOICE */
-const void *funcs;             /* functions that handle this type */
-long size;                     /* Structure size (usually)*/
-#ifndef NO_ASN1_FIELD_NAMES
-const char *sname;             /* Structure name */
-#endif
-};
-
-/* These are values for the itype field and
- * determine how the type is interpreted.
- *
- * For PRIMITIVE types the underlying type
- * determines the behaviour if items is NULL.
- *
- * Otherwise templates must contain a single
- * template and the type is treated in the
- * same way as the type specified in the template.
- *
- * For SEQUENCE types the templates field points
- * to the members, the size field is the
- * structure size.
- *
- * For CHOICE types the templates field points
- * to each possible member (typically a union)
- * and the 'size' field is the offset of the
- * selector.
- *
- * The 'funcs' field is used for application
- * specific functions.
- *
- * For COMPAT types the funcs field gives a
- * set of functions that handle this type, this
- * supports the old d2i, i2d convention.
- *
- * The EXTERN type uses a new style d2i/i2d.
- * The new style should be used where possible
- * because it avoids things like the d2i IMPLICIT
- * hack.
- *
- * MSTRING is a multiple string type, it is used
- * for a CHOICE of character strings where the
- * actual strings all occupy an ASN1_STRING
- * structure. In this case the 'utype' field
- * has a special meaning, it is used as a mask
- * of acceptable types using the B_ASN1 constants.
- *
- * NDEF_SEQUENCE is the same as SEQUENCE except
- * that it will use indefinite length constructed
- * encoding if requested.
- *
- */
-
-#define ASN1_ITYPE_PRIMITIVE           0x0
-
-#define ASN1_ITYPE_SEQUENCE            0x1
-
-#define ASN1_ITYPE_CHOICE              0x2
-
-#define ASN1_ITYPE_COMPAT              0x3
-
-#define ASN1_ITYPE_EXTERN              0x4
-
-#define ASN1_ITYPE_MSTRING             0x5
-
-#define ASN1_ITYPE_NDEF_SEQUENCE       0x6
-
-/* Cache for ASN1 tag and length, so we
- * don't keep re-reading it for things
- * like CHOICE
- */
-
-struct ASN1_TLC_st{
-       char valid;     /* Values below are valid */
-       int ret;        /* return value */
-       long plen;      /* length */
-       int ptag;       /* class value */
-       int pclass;     /* class value */
-       int hdrlen;     /* header length */
-};
-
-/* Typedefs for ASN1 function pointers */
-
-typedef ASN1_VALUE * ASN1_new_func(void);
-typedef void ASN1_free_func(ASN1_VALUE *a);
-typedef ASN1_VALUE * ASN1_d2i_func(ASN1_VALUE **a, const unsigned char ** in, long length);
-typedef int ASN1_i2d_func(ASN1_VALUE * a, unsigned char **in);
-
-typedef int ASN1_ex_d2i(ASN1_VALUE **pval, const unsigned char **in, long len, const ASN1_ITEM *it,
-                                       int tag, int aclass, char opt, ASN1_TLC *ctx);
-
-typedef int ASN1_ex_i2d(ASN1_VALUE **pval, unsigned char **out, const ASN1_ITEM *it, int tag, int aclass);
-typedef int ASN1_ex_new_func(ASN1_VALUE **pval, const ASN1_ITEM *it);
-typedef void ASN1_ex_free_func(ASN1_VALUE **pval, const ASN1_ITEM *it);
-
-typedef int ASN1_ex_print_func(BIO *out, ASN1_VALUE **pval,
-                                               int indent, const char *fname,
-                                               const ASN1_PCTX *pctx);
-
-typedef int ASN1_primitive_i2c(ASN1_VALUE **pval, unsigned char *cont, int *putype, const ASN1_ITEM *it);
-typedef int ASN1_primitive_c2i(ASN1_VALUE **pval, const unsigned char *cont, int len, int utype, char *free_cont, const ASN1_ITEM *it);
-typedef int ASN1_primitive_print(BIO *out, ASN1_VALUE **pval, const ASN1_ITEM *it, int indent, const ASN1_PCTX *pctx);
-
-typedef struct ASN1_COMPAT_FUNCS_st {
-       ASN1_new_func *asn1_new;
-       ASN1_free_func *asn1_free;
-       ASN1_d2i_func *asn1_d2i;
-       ASN1_i2d_func *asn1_i2d;
-} ASN1_COMPAT_FUNCS;
-
-typedef struct ASN1_EXTERN_FUNCS_st {
-       void *app_data;
-       ASN1_ex_new_func *asn1_ex_new;
-       ASN1_ex_free_func *asn1_ex_free;
-       ASN1_ex_free_func *asn1_ex_clear;
-       ASN1_ex_d2i *asn1_ex_d2i;
-       ASN1_ex_i2d *asn1_ex_i2d;
-       ASN1_ex_print_func *asn1_ex_print;
-} ASN1_EXTERN_FUNCS;
-
-typedef struct ASN1_PRIMITIVE_FUNCS_st {
-       void *app_data;
-       unsigned long flags;
-       ASN1_ex_new_func *prim_new;
-       ASN1_ex_free_func *prim_free;
-       ASN1_ex_free_func *prim_clear;
-       ASN1_primitive_c2i *prim_c2i;
-       ASN1_primitive_i2c *prim_i2c;
-       ASN1_primitive_print *prim_print;
-} ASN1_PRIMITIVE_FUNCS;
-
-/* This is the ASN1_AUX structure: it handles various
- * miscellaneous requirements. For example the use of
- * reference counts and an informational callback.
- *
- * The "informational callback" is called at various
- * points during the ASN1 encoding and decoding. It can
- * be used to provide minor customisation of the structures
- * used. This is most useful where the supplied routines
- * *almost* do the right thing but need some extra help
- * at a few points. If the callback returns zero then
- * it is assumed a fatal error has occurred and the
- * main operation should be abandoned.
- *
- * If major changes in the default behaviour are required
- * then an external type is more appropriate.
- */
-
-typedef int ASN1_aux_cb(int operation, ASN1_VALUE **in, const ASN1_ITEM *it,
-                               void *exarg);
-
-typedef struct ASN1_AUX_st {
-       void *app_data;
-       int flags;
-       int ref_offset;         /* Offset of reference value */
-       int ref_lock;           /* Lock type to use */
-       ASN1_aux_cb *asn1_cb;
-       int enc_offset;         /* Offset of ASN1_ENCODING structure */
-} ASN1_AUX;
-
-/* For print related callbacks exarg points to this structure */
-typedef struct ASN1_PRINT_ARG_st {
-       BIO *out;
-       int indent;
-       const ASN1_PCTX *pctx;
-} ASN1_PRINT_ARG;
-
-/* For streaming related callbacks exarg points to this structure */
-typedef struct ASN1_STREAM_ARG_st {
-       /* BIO to stream through */
-       BIO *out;
-       /* BIO with filters appended */
-       BIO *ndef_bio;
-       /* Streaming I/O boundary */
-       unsigned char **boundary;
-} ASN1_STREAM_ARG;
-
-/* Flags in ASN1_AUX */
-
-/* Use a reference count */
-#define ASN1_AFLG_REFCOUNT     1
-/* Save the encoding of structure (useful for signatures) */
-#define ASN1_AFLG_ENCODING     2
-/* The Sequence length is invalid */
-#define ASN1_AFLG_BROKEN       4
-
-/* operation values for asn1_cb */
-
-#define ASN1_OP_NEW_PRE                0
-#define ASN1_OP_NEW_POST       1
-#define ASN1_OP_FREE_PRE       2
-#define ASN1_OP_FREE_POST      3
-#define ASN1_OP_D2I_PRE                4
-#define ASN1_OP_D2I_POST       5
-#define ASN1_OP_I2D_PRE                6
-#define ASN1_OP_I2D_POST       7
-#define ASN1_OP_PRINT_PRE      8
-#define ASN1_OP_PRINT_POST     9
-#define ASN1_OP_STREAM_PRE     10
-#define ASN1_OP_STREAM_POST    11
-#define ASN1_OP_DETACHED_PRE   12
-#define ASN1_OP_DETACHED_POST  13
-
-/* Macro to implement a primitive type */
-#define IMPLEMENT_ASN1_TYPE(stname) IMPLEMENT_ASN1_TYPE_ex(stname, stname, 0)
-#define IMPLEMENT_ASN1_TYPE_ex(itname, vname, ex) \
-                               ASN1_ITEM_start(itname) \
-                                       ASN1_ITYPE_PRIMITIVE, V_##vname, NULL, 0, NULL, ex, #itname \
-                               ASN1_ITEM_end(itname)
-
-/* Macro to implement a multi string type */
-#define IMPLEMENT_ASN1_MSTRING(itname, mask) \
-                               ASN1_ITEM_start(itname) \
-                                       ASN1_ITYPE_MSTRING, mask, NULL, 0, NULL, sizeof(ASN1_STRING), #itname \
-                               ASN1_ITEM_end(itname)
-
-/* Macro to implement an ASN1_ITEM in terms of old style funcs */
-
-#define IMPLEMENT_COMPAT_ASN1(sname) IMPLEMENT_COMPAT_ASN1_type(sname, V_ASN1_SEQUENCE)
-
-#define IMPLEMENT_COMPAT_ASN1_type(sname, tag) \
-       static const ASN1_COMPAT_FUNCS sname##_ff = { \
-               (ASN1_new_func *)sname##_new, \
-               (ASN1_free_func *)sname##_free, \
-               (ASN1_d2i_func *)d2i_##sname, \
-               (ASN1_i2d_func *)i2d_##sname, \
-       }; \
-       ASN1_ITEM_start(sname) \
-               ASN1_ITYPE_COMPAT, \
-               tag, \
-               NULL, \
-               0, \
-               &sname##_ff, \
-               0, \
-               #sname \
-       ASN1_ITEM_end(sname)
-
-#define IMPLEMENT_EXTERN_ASN1(sname, tag, fptrs) \
-       ASN1_ITEM_start(sname) \
-               ASN1_ITYPE_EXTERN, \
-               tag, \
-               NULL, \
-               0, \
-               &fptrs, \
-               0, \
-               #sname \
-       ASN1_ITEM_end(sname)
-
-/* Macro to implement standard functions in terms of ASN1_ITEM structures */
-
-#define IMPLEMENT_ASN1_FUNCTIONS(stname) IMPLEMENT_ASN1_FUNCTIONS_fname(stname, stname, stname)
-
-#define IMPLEMENT_ASN1_FUNCTIONS_name(stname, itname) IMPLEMENT_ASN1_FUNCTIONS_fname(stname, itname, itname)
-
-#define IMPLEMENT_ASN1_FUNCTIONS_ENCODE_name(stname, itname) \
-                       IMPLEMENT_ASN1_FUNCTIONS_ENCODE_fname(stname, itname, itname)
-
-#define IMPLEMENT_STATIC_ASN1_ALLOC_FUNCTIONS(stname) \
-               IMPLEMENT_ASN1_ALLOC_FUNCTIONS_pfname(static, stname, stname, stname)
-
-#define IMPLEMENT_ASN1_ALLOC_FUNCTIONS(stname) \
-               IMPLEMENT_ASN1_ALLOC_FUNCTIONS_fname(stname, stname, stname)
-
-#define IMPLEMENT_ASN1_ALLOC_FUNCTIONS_pfname(pre, stname, itname, fname) \
-       pre stname *fname##_new(void) \
-       { \
-               return (stname *)ASN1_item_new(ASN1_ITEM_rptr(itname)); \
-       } \
-       pre void fname##_free(stname *a) \
-       { \
-               ASN1_item_free((ASN1_VALUE *)a, ASN1_ITEM_rptr(itname)); \
-       }
-
-#define IMPLEMENT_ASN1_ALLOC_FUNCTIONS_fname(stname, itname, fname) \
-       stname *fname##_new(void) \
-       { \
-               return (stname *)ASN1_item_new(ASN1_ITEM_rptr(itname)); \
-       } \
-       void fname##_free(stname *a) \
-       { \
-               ASN1_item_free((ASN1_VALUE *)a, ASN1_ITEM_rptr(itname)); \
-       }
-
-#define IMPLEMENT_ASN1_FUNCTIONS_fname(stname, itname, fname) \
-       IMPLEMENT_ASN1_ENCODE_FUNCTIONS_fname(stname, itname, fname) \
-       IMPLEMENT_ASN1_ALLOC_FUNCTIONS_fname(stname, itname, fname)
-
-#define IMPLEMENT_ASN1_ENCODE_FUNCTIONS_fname(stname, itname, fname) \
-       stname *d2i_##fname(stname **a, const unsigned char **in, long len) \
-       { \
-               return (stname *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, ASN1_ITEM_rptr(itname));\
-       } \
-       int i2d_##fname(stname *a, unsigned char **out) \
-       { \
-               return ASN1_item_i2d((ASN1_VALUE *)a, out, ASN1_ITEM_rptr(itname));\
-       }
-
-#define IMPLEMENT_ASN1_NDEF_FUNCTION(stname) \
-       int i2d_##stname##_NDEF(stname *a, unsigned char **out) \
-       { \
-               return ASN1_item_ndef_i2d((ASN1_VALUE *)a, out, ASN1_ITEM_rptr(stname));\
-       }
-
-/* This includes evil casts to remove const: they will go away when full
- * ASN1 constification is done.
- */
-#define IMPLEMENT_ASN1_ENCODE_FUNCTIONS_const_fname(stname, itname, fname) \
-       stname *d2i_##fname(stname **a, const unsigned char **in, long len) \
-       { \
-               return (stname *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, ASN1_ITEM_rptr(itname));\
-       } \
-       int i2d_##fname(const stname *a, unsigned char **out) \
-       { \
-               return ASN1_item_i2d((ASN1_VALUE *)a, out, ASN1_ITEM_rptr(itname));\
-       }
-
-#define IMPLEMENT_ASN1_DUP_FUNCTION(stname) \
-       stname * stname##_dup(stname *x) \
-        { \
-        return ASN1_item_dup(ASN1_ITEM_rptr(stname), x); \
-        }
-
-#define IMPLEMENT_ASN1_PRINT_FUNCTION(stname) \
-       IMPLEMENT_ASN1_PRINT_FUNCTION_fname(stname, stname, stname)
-
-#define IMPLEMENT_ASN1_PRINT_FUNCTION_fname(stname, itname, fname) \
-       int fname##_print_ctx(BIO *out, stname *x, int indent, \
-                                               const ASN1_PCTX *pctx) \
-       { \
-               return ASN1_item_print(out, (ASN1_VALUE *)x, indent, \
-                       ASN1_ITEM_rptr(itname), pctx); \
-       }
-
-#define IMPLEMENT_ASN1_FUNCTIONS_const(name) \
-               IMPLEMENT_ASN1_FUNCTIONS_const_fname(name, name, name)
-
-#define IMPLEMENT_ASN1_FUNCTIONS_const_fname(stname, itname, fname) \
-       IMPLEMENT_ASN1_ENCODE_FUNCTIONS_const_fname(stname, itname, fname) \
-       IMPLEMENT_ASN1_ALLOC_FUNCTIONS_fname(stname, itname, fname)
-
-/* external definitions for primitive types */
-
-DECLARE_ASN1_ITEM(ASN1_BOOLEAN)
-DECLARE_ASN1_ITEM(ASN1_TBOOLEAN)
-DECLARE_ASN1_ITEM(ASN1_FBOOLEAN)
-DECLARE_ASN1_ITEM(ASN1_SEQUENCE)
-DECLARE_ASN1_ITEM(CBIGNUM)
-DECLARE_ASN1_ITEM(BIGNUM)
-DECLARE_ASN1_ITEM(LONG)
-DECLARE_ASN1_ITEM(ZLONG)
-
-DECLARE_STACK_OF(ASN1_VALUE)
-
-/* Functions used internally by the ASN1 code */
-
-int ASN1_item_ex_new(ASN1_VALUE **pval, const ASN1_ITEM *it);
-void ASN1_item_ex_free(ASN1_VALUE **pval, const ASN1_ITEM *it);
-int ASN1_template_new(ASN1_VALUE **pval, const ASN1_TEMPLATE *tt);
-int ASN1_primitive_new(ASN1_VALUE **pval, const ASN1_ITEM *it);
-
-void ASN1_template_free(ASN1_VALUE **pval, const ASN1_TEMPLATE *tt);
-int ASN1_template_d2i(ASN1_VALUE **pval, const unsigned char **in, long len, const ASN1_TEMPLATE *tt);
-int ASN1_item_ex_d2i(ASN1_VALUE **pval, const unsigned char **in, long len, const ASN1_ITEM *it,
-                               int tag, int aclass, char opt, ASN1_TLC *ctx);
-
-int ASN1_item_ex_i2d(ASN1_VALUE **pval, unsigned char **out, const ASN1_ITEM *it, int tag, int aclass);
-int ASN1_template_i2d(ASN1_VALUE **pval, unsigned char **out, const ASN1_TEMPLATE *tt);
-void ASN1_primitive_free(ASN1_VALUE **pval, const ASN1_ITEM *it);
-
-int asn1_ex_i2c(ASN1_VALUE **pval, unsigned char *cont, int *putype, const ASN1_ITEM *it);
-int asn1_ex_c2i(ASN1_VALUE **pval, const unsigned char *cont, int len, int utype, char *free_cont, const ASN1_ITEM *it);
-
-int asn1_get_choice_selector(ASN1_VALUE **pval, const ASN1_ITEM *it);
-int asn1_set_choice_selector(ASN1_VALUE **pval, int value, const ASN1_ITEM *it);
-
-ASN1_VALUE ** asn1_get_field_ptr(ASN1_VALUE **pval, const ASN1_TEMPLATE *tt);
-
-const ASN1_TEMPLATE *asn1_do_adb(ASN1_VALUE **pval, const ASN1_TEMPLATE *tt, int nullerr);
-
-int asn1_do_lock(ASN1_VALUE **pval, int op, const ASN1_ITEM *it);
-
-void asn1_enc_init(ASN1_VALUE **pval, const ASN1_ITEM *it);
-void asn1_enc_free(ASN1_VALUE **pval, const ASN1_ITEM *it);
-int asn1_enc_restore(int *len, unsigned char **out, ASN1_VALUE **pval, const ASN1_ITEM *it);
-int asn1_enc_save(ASN1_VALUE **pval, const unsigned char *in, int inlen, const ASN1_ITEM *it);
-
-#ifdef  __cplusplus
-}
-#endif
-#endif
+/* asn1t.h */\r
+/* Written by Dr Stephen N Henson (steve@openssl.org) for the OpenSSL\r
+ * project 2000.\r
+ */\r
+/* ====================================================================\r
+ * Copyright (c) 2000-2005 The OpenSSL Project.  All rights reserved.\r
+ *\r
+ * Redistribution and use in source and binary forms, with or without\r
+ * modification, are permitted provided that the following conditions\r
+ * are met:\r
+ *\r
+ * 1. Redistributions of source code must retain the above copyright\r
+ *    notice, this list of conditions and the following disclaimer.\r
+ *\r
+ * 2. Redistributions in binary form must reproduce the above copyright\r
+ *    notice, this list of conditions and the following disclaimer in\r
+ *    the documentation and/or other materials provided with the\r
+ *    distribution.\r
+ *\r
+ * 3. All advertising materials mentioning features or use of this\r
+ *    software must display the following acknowledgment:\r
+ *    "This product includes software developed by the OpenSSL Project\r
+ *    for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)"\r
+ *\r
+ * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to\r
+ *    endorse or promote products derived from this software without\r
+ *    prior written permission. For written permission, please contact\r
+ *    licensing@OpenSSL.org.\r
+ *\r
+ * 5. Products derived from this software may not be called "OpenSSL"\r
+ *    nor may "OpenSSL" appear in their names without prior written\r
+ *    permission of the OpenSSL Project.\r
+ *\r
+ * 6. Redistributions of any form whatsoever must retain the following\r
+ *    acknowledgment:\r
+ *    "This product includes software developed by the OpenSSL Project\r
+ *    for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"\r
+ *\r
+ * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY\r
+ * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\r
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR\r
+ * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR\r
+ * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,\r
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT\r
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\r
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\r
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,\r
+ * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\r
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED\r
+ * OF THE POSSIBILITY OF SUCH DAMAGE.\r
+ * ====================================================================\r
+ *\r
+ * This product includes cryptographic software written by Eric Young\r
+ * (eay@cryptsoft.com).  This product includes software written by Tim\r
+ * Hudson (tjh@cryptsoft.com).\r
+ *\r
+ */\r
+#ifndef HEADER_ASN1T_H\r
+#define HEADER_ASN1T_H\r
+\r
+#include <stddef.h>\r
+#include <openssl/e_os2.h>\r
+#include <openssl/asn1.h>\r
+\r
+#ifdef OPENSSL_BUILD_SHLIBCRYPTO\r
+# undef OPENSSL_EXTERN\r
+# define OPENSSL_EXTERN OPENSSL_EXPORT\r
+#endif\r
+\r
+/* ASN1 template defines, structures and functions */\r
+\r
+#ifdef  __cplusplus\r
+extern "C" {\r
+#endif\r
+\r
+\r
+#ifndef OPENSSL_EXPORT_VAR_AS_FUNCTION\r
+\r
+/* Macro to obtain ASN1_ADB pointer from a type (only used internally) */\r
+#define ASN1_ADB_ptr(iptr) ((const ASN1_ADB *)(iptr))\r
+\r
+\r
+/* Macros for start and end of ASN1_ITEM definition */\r
+\r
+#define ASN1_ITEM_start(itname) \\r
+       OPENSSL_GLOBAL const ASN1_ITEM itname##_it = {\r
+\r
+#define ASN1_ITEM_end(itname) \\r
+               };\r
+\r
+#else\r
+\r
+/* Macro to obtain ASN1_ADB pointer from a type (only used internally) */\r
+#define ASN1_ADB_ptr(iptr) ((const ASN1_ADB *)(iptr()))\r
+\r
+\r
+/* Macros for start and end of ASN1_ITEM definition */\r
+\r
+#define ASN1_ITEM_start(itname) \\r
+       const ASN1_ITEM * itname##_it(void) \\r
+       { \\r
+               static const ASN1_ITEM local_it = {\r
+\r
+#define ASN1_ITEM_end(itname) \\r
+               }; \\r
+       return &local_it; \\r
+       }\r
+\r
+#endif\r
+\r
+\r
+/* Macros to aid ASN1 template writing */\r
+\r
+#define ASN1_ITEM_TEMPLATE(tname) \\r
+       static const ASN1_TEMPLATE tname##_item_tt\r
+\r
+#define ASN1_ITEM_TEMPLATE_END(tname) \\r
+       ;\\r
+       ASN1_ITEM_start(tname) \\r
+               ASN1_ITYPE_PRIMITIVE,\\r
+               -1,\\r
+               &tname##_item_tt,\\r
+               0,\\r
+               NULL,\\r
+               0,\\r
+               #tname \\r
+       ASN1_ITEM_end(tname)\r
+\r
+\r
+/* This is a ASN1 type which just embeds a template */\r
+\r
+/* This pair helps declare a SEQUENCE. We can do:\r
+ *\r
+ *     ASN1_SEQUENCE(stname) = {\r
+ *             ... SEQUENCE components ...\r
+ *     } ASN1_SEQUENCE_END(stname)\r
+ *\r
+ *     This will produce an ASN1_ITEM called stname_it\r
+ *     for a structure called stname.\r
+ *\r
+ *     If you want the same structure but a different\r
+ *     name then use:\r
+ *\r
+ *     ASN1_SEQUENCE(itname) = {\r
+ *             ... SEQUENCE components ...\r
+ *     } ASN1_SEQUENCE_END_name(stname, itname)\r
+ *\r
+ *     This will create an item called itname_it using\r
+ *     a structure called stname.\r
+ */\r
+\r
+#define ASN1_SEQUENCE(tname) \\r
+       static const ASN1_TEMPLATE tname##_seq_tt[]\r
+\r
+#define ASN1_SEQUENCE_END(stname) ASN1_SEQUENCE_END_name(stname, stname)\r
+\r
+#define ASN1_SEQUENCE_END_name(stname, tname) \\r
+       ;\\r
+       ASN1_ITEM_start(tname) \\r
+               ASN1_ITYPE_SEQUENCE,\\r
+               V_ASN1_SEQUENCE,\\r
+               tname##_seq_tt,\\r
+               sizeof(tname##_seq_tt) / sizeof(ASN1_TEMPLATE),\\r
+               NULL,\\r
+               sizeof(stname),\\r
+               #stname \\r
+       ASN1_ITEM_end(tname)\r
+\r
+#define ASN1_NDEF_SEQUENCE(tname) \\r
+       ASN1_SEQUENCE(tname)\r
+\r
+#define ASN1_NDEF_SEQUENCE_cb(tname, cb) \\r
+       ASN1_SEQUENCE_cb(tname, cb)\r
+\r
+#define ASN1_SEQUENCE_cb(tname, cb) \\r
+       static const ASN1_AUX tname##_aux = {NULL, 0, 0, 0, cb, 0}; \\r
+       ASN1_SEQUENCE(tname)\r
+\r
+#define ASN1_BROKEN_SEQUENCE(tname) \\r
+       static const ASN1_AUX tname##_aux = {NULL, ASN1_AFLG_BROKEN, 0, 0, 0, 0}; \\r
+       ASN1_SEQUENCE(tname)\r
+\r
+#define ASN1_SEQUENCE_ref(tname, cb, lck) \\r
+       static const ASN1_AUX tname##_aux = {NULL, ASN1_AFLG_REFCOUNT, offsetof(tname, references), lck, cb, 0}; \\r
+       ASN1_SEQUENCE(tname)\r
+\r
+#define ASN1_SEQUENCE_enc(tname, enc, cb) \\r
+       static const ASN1_AUX tname##_aux = {NULL, ASN1_AFLG_ENCODING, 0, 0, cb, offsetof(tname, enc)}; \\r
+       ASN1_SEQUENCE(tname)\r
+\r
+#define ASN1_NDEF_SEQUENCE_END(tname) \\r
+       ;\\r
+       ASN1_ITEM_start(tname) \\r
+               ASN1_ITYPE_NDEF_SEQUENCE,\\r
+               V_ASN1_SEQUENCE,\\r
+               tname##_seq_tt,\\r
+               sizeof(tname##_seq_tt) / sizeof(ASN1_TEMPLATE),\\r
+               NULL,\\r
+               sizeof(tname),\\r
+               #tname \\r
+       ASN1_ITEM_end(tname)\r
+\r
+#define ASN1_BROKEN_SEQUENCE_END(stname) ASN1_SEQUENCE_END_ref(stname, stname)\r
+\r
+#define ASN1_SEQUENCE_END_enc(stname, tname) ASN1_SEQUENCE_END_ref(stname, tname)\r
+\r
+#define ASN1_SEQUENCE_END_cb(stname, tname) ASN1_SEQUENCE_END_ref(stname, tname)\r
+\r
+#define ASN1_SEQUENCE_END_ref(stname, tname) \\r
+       ;\\r
+       ASN1_ITEM_start(tname) \\r
+               ASN1_ITYPE_SEQUENCE,\\r
+               V_ASN1_SEQUENCE,\\r
+               tname##_seq_tt,\\r
+               sizeof(tname##_seq_tt) / sizeof(ASN1_TEMPLATE),\\r
+               &tname##_aux,\\r
+               sizeof(stname),\\r
+               #stname \\r
+       ASN1_ITEM_end(tname)\r
+\r
+#define ASN1_NDEF_SEQUENCE_END_cb(stname, tname) \\r
+       ;\\r
+       ASN1_ITEM_start(tname) \\r
+               ASN1_ITYPE_NDEF_SEQUENCE,\\r
+               V_ASN1_SEQUENCE,\\r
+               tname##_seq_tt,\\r
+               sizeof(tname##_seq_tt) / sizeof(ASN1_TEMPLATE),\\r
+               &tname##_aux,\\r
+               sizeof(stname),\\r
+               #stname \\r
+       ASN1_ITEM_end(tname)\r
+\r
+\r
+/* This pair helps declare a CHOICE type. We can do:\r
+ *\r
+ *     ASN1_CHOICE(chname) = {\r
+ *             ... CHOICE options ...\r
+ *     ASN1_CHOICE_END(chname)\r
+ *\r
+ *     This will produce an ASN1_ITEM called chname_it\r
+ *     for a structure called chname. The structure\r
+ *     definition must look like this:\r
+ *     typedef struct {\r
+ *             int type;\r
+ *             union {\r
+ *                     ASN1_SOMETHING *opt1;\r
+ *                     ASN1_SOMEOTHER *opt2;\r
+ *             } value;\r
+ *     } chname;\r
+ *\r
+ *     the name of the selector must be 'type'.\r
+ *     to use an alternative selector name use the\r
+ *      ASN1_CHOICE_END_selector() version.\r
+ */\r
+\r
+#define ASN1_CHOICE(tname) \\r
+       static const ASN1_TEMPLATE tname##_ch_tt[]\r
+\r
+#define ASN1_CHOICE_cb(tname, cb) \\r
+       static const ASN1_AUX tname##_aux = {NULL, 0, 0, 0, cb, 0}; \\r
+       ASN1_CHOICE(tname)\r
+\r
+#define ASN1_CHOICE_END(stname) ASN1_CHOICE_END_name(stname, stname)\r
+\r
+#define ASN1_CHOICE_END_name(stname, tname) ASN1_CHOICE_END_selector(stname, tname, type)\r
+\r
+#define ASN1_CHOICE_END_selector(stname, tname, selname) \\r
+       ;\\r
+       ASN1_ITEM_start(tname) \\r
+               ASN1_ITYPE_CHOICE,\\r
+               offsetof(stname,selname) ,\\r
+               tname##_ch_tt,\\r
+               sizeof(tname##_ch_tt) / sizeof(ASN1_TEMPLATE),\\r
+               NULL,\\r
+               sizeof(stname),\\r
+               #stname \\r
+       ASN1_ITEM_end(tname)\r
+\r
+#define ASN1_CHOICE_END_cb(stname, tname, selname) \\r
+       ;\\r
+       ASN1_ITEM_start(tname) \\r
+               ASN1_ITYPE_CHOICE,\\r
+               offsetof(stname,selname) ,\\r
+               tname##_ch_tt,\\r
+               sizeof(tname##_ch_tt) / sizeof(ASN1_TEMPLATE),\\r
+               &tname##_aux,\\r
+               sizeof(stname),\\r
+               #stname \\r
+       ASN1_ITEM_end(tname)\r
+\r
+/* This helps with the template wrapper form of ASN1_ITEM */\r
+\r
+#define ASN1_EX_TEMPLATE_TYPE(flags, tag, name, type) { \\r
+       (flags), (tag), 0,\\r
+       #name, ASN1_ITEM_ref(type) }\r
+\r
+/* These help with SEQUENCE or CHOICE components */\r
+\r
+/* used to declare other types */\r
+\r
+#define ASN1_EX_TYPE(flags, tag, stname, field, type) { \\r
+       (flags), (tag), offsetof(stname, field),\\r
+       #field, ASN1_ITEM_ref(type) }\r
+\r
+/* used when the structure is combined with the parent */\r
+\r
+#define ASN1_EX_COMBINE(flags, tag, type) { \\r
+       (flags)|ASN1_TFLG_COMBINE, (tag), 0, NULL, ASN1_ITEM_ref(type) }\r
+\r
+/* implicit and explicit helper macros */\r
+\r
+#define ASN1_IMP_EX(stname, field, type, tag, ex) \\r
+               ASN1_EX_TYPE(ASN1_TFLG_IMPLICIT | ex, tag, stname, field, type)\r
+\r
+#define ASN1_EXP_EX(stname, field, type, tag, ex) \\r
+               ASN1_EX_TYPE(ASN1_TFLG_EXPLICIT | ex, tag, stname, field, type)\r
+\r
+/* Any defined by macros: the field used is in the table itself */\r
+\r
+#ifndef OPENSSL_EXPORT_VAR_AS_FUNCTION\r
+#define ASN1_ADB_OBJECT(tblname) { ASN1_TFLG_ADB_OID, -1, 0, #tblname, (const ASN1_ITEM *)&(tblname##_adb) }\r
+#define ASN1_ADB_INTEGER(tblname) { ASN1_TFLG_ADB_INT, -1, 0, #tblname, (const ASN1_ITEM *)&(tblname##_adb) }\r
+#else\r
+#define ASN1_ADB_OBJECT(tblname) { ASN1_TFLG_ADB_OID, -1, 0, #tblname, tblname##_adb }\r
+#define ASN1_ADB_INTEGER(tblname) { ASN1_TFLG_ADB_INT, -1, 0, #tblname, tblname##_adb }\r
+#endif\r
+/* Plain simple type */\r
+#define ASN1_SIMPLE(stname, field, type) ASN1_EX_TYPE(0,0, stname, field, type)\r
+\r
+/* OPTIONAL simple type */\r
+#define ASN1_OPT(stname, field, type) ASN1_EX_TYPE(ASN1_TFLG_OPTIONAL, 0, stname, field, type)\r
+\r
+/* IMPLICIT tagged simple type */\r
+#define ASN1_IMP(stname, field, type, tag) ASN1_IMP_EX(stname, field, type, tag, 0)\r
+\r
+/* IMPLICIT tagged OPTIONAL simple type */\r
+#define ASN1_IMP_OPT(stname, field, type, tag) ASN1_IMP_EX(stname, field, type, tag, ASN1_TFLG_OPTIONAL)\r
+\r
+/* Same as above but EXPLICIT */\r
+\r
+#define ASN1_EXP(stname, field, type, tag) ASN1_EXP_EX(stname, field, type, tag, 0)\r
+#define ASN1_EXP_OPT(stname, field, type, tag) ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_OPTIONAL)\r
+\r
+/* SEQUENCE OF type */\r
+#define ASN1_SEQUENCE_OF(stname, field, type) \\r
+               ASN1_EX_TYPE(ASN1_TFLG_SEQUENCE_OF, 0, stname, field, type)\r
+\r
+/* OPTIONAL SEQUENCE OF */\r
+#define ASN1_SEQUENCE_OF_OPT(stname, field, type) \\r
+               ASN1_EX_TYPE(ASN1_TFLG_SEQUENCE_OF|ASN1_TFLG_OPTIONAL, 0, stname, field, type)\r
+\r
+/* Same as above but for SET OF */\r
+\r
+#define ASN1_SET_OF(stname, field, type) \\r
+               ASN1_EX_TYPE(ASN1_TFLG_SET_OF, 0, stname, field, type)\r
+\r
+#define ASN1_SET_OF_OPT(stname, field, type) \\r
+               ASN1_EX_TYPE(ASN1_TFLG_SET_OF|ASN1_TFLG_OPTIONAL, 0, stname, field, type)\r
+\r
+/* Finally compound types of SEQUENCE, SET, IMPLICIT, EXPLICIT and OPTIONAL */\r
+\r
+#define ASN1_IMP_SET_OF(stname, field, type, tag) \\r
+                       ASN1_IMP_EX(stname, field, type, tag, ASN1_TFLG_SET_OF)\r
+\r
+#define ASN1_EXP_SET_OF(stname, field, type, tag) \\r
+                       ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_SET_OF)\r
+\r
+#define ASN1_IMP_SET_OF_OPT(stname, field, type, tag) \\r
+                       ASN1_IMP_EX(stname, field, type, tag, ASN1_TFLG_SET_OF|ASN1_TFLG_OPTIONAL)\r
+\r
+#define ASN1_EXP_SET_OF_OPT(stname, field, type, tag) \\r
+                       ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_SET_OF|ASN1_TFLG_OPTIONAL)\r
+\r
+#define ASN1_IMP_SEQUENCE_OF(stname, field, type, tag) \\r
+                       ASN1_IMP_EX(stname, field, type, tag, ASN1_TFLG_SEQUENCE_OF)\r
+\r
+#define ASN1_IMP_SEQUENCE_OF_OPT(stname, field, type, tag) \\r
+                       ASN1_IMP_EX(stname, field, type, tag, ASN1_TFLG_SEQUENCE_OF|ASN1_TFLG_OPTIONAL)\r
+\r
+#define ASN1_EXP_SEQUENCE_OF(stname, field, type, tag) \\r
+                       ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_SEQUENCE_OF)\r
+\r
+#define ASN1_EXP_SEQUENCE_OF_OPT(stname, field, type, tag) \\r
+                       ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_SEQUENCE_OF|ASN1_TFLG_OPTIONAL)\r
+\r
+/* EXPLICIT using indefinite length constructed form */\r
+#define ASN1_NDEF_EXP(stname, field, type, tag) \\r
+                       ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_NDEF)\r
+\r
+/* EXPLICIT OPTIONAL using indefinite length constructed form */\r
+#define ASN1_NDEF_EXP_OPT(stname, field, type, tag) \\r
+                       ASN1_EXP_EX(stname, field, type, tag, ASN1_TFLG_OPTIONAL|ASN1_TFLG_NDEF)\r
+\r
+/* Macros for the ASN1_ADB structure */\r
+\r
+#define ASN1_ADB(name) \\r
+       static const ASN1_ADB_TABLE name##_adbtbl[]\r
+\r
+#ifndef OPENSSL_EXPORT_VAR_AS_FUNCTION\r
+\r
+#define ASN1_ADB_END(name, flags, field, app_table, def, none) \\r
+       ;\\r
+       static const ASN1_ADB name##_adb = {\\r
+               flags,\\r
+               offsetof(name, field),\\r
+               app_table,\\r
+               name##_adbtbl,\\r
+               sizeof(name##_adbtbl) / sizeof(ASN1_ADB_TABLE),\\r
+               def,\\r
+               none\\r
+       }\r
+\r
+#else\r
+\r
+#define ASN1_ADB_END(name, flags, field, app_table, def, none) \\r
+       ;\\r
+       static const ASN1_ITEM *name##_adb(void) \\r
+       { \\r
+       static const ASN1_ADB internal_adb = \\r
+               {\\r
+               flags,\\r
+               offsetof(name, field),\\r
+               app_table,\\r
+               name##_adbtbl,\\r
+               sizeof(name##_adbtbl) / sizeof(ASN1_ADB_TABLE),\\r
+               def,\\r
+               none\\r
+               }; \\r
+               return (const ASN1_ITEM *) &internal_adb; \\r
+       } \\r
+       void dummy_function(void)\r
+\r
+#endif\r
+\r
+#define ADB_ENTRY(val, template) {val, template}\r
+\r
+#define ASN1_ADB_TEMPLATE(name) \\r
+       static const ASN1_TEMPLATE name##_tt\r
+\r
+/* This is the ASN1 template structure that defines\r
+ * a wrapper round the actual type. It determines the\r
+ * actual position of the field in the value structure,\r
+ * various flags such as OPTIONAL and the field name.\r
+ */\r
+\r
+struct ASN1_TEMPLATE_st {\r
+unsigned long flags;           /* Various flags */\r
+long tag;                      /* tag, not used if no tagging */\r
+unsigned long offset;          /* Offset of this field in structure */\r
+#ifndef NO_ASN1_FIELD_NAMES\r
+const char *field_name;                /* Field name */\r
+#endif\r
+ASN1_ITEM_EXP *item;           /* Relevant ASN1_ITEM or ASN1_ADB */\r
+};\r
+\r
+/* Macro to extract ASN1_ITEM and ASN1_ADB pointer from ASN1_TEMPLATE */\r
+\r
+#define ASN1_TEMPLATE_item(t) (t->item_ptr)\r
+#define ASN1_TEMPLATE_adb(t) (t->item_ptr)\r
+\r
+typedef struct ASN1_ADB_TABLE_st ASN1_ADB_TABLE;\r
+typedef struct ASN1_ADB_st ASN1_ADB;\r
+\r
+struct ASN1_ADB_st {\r
+       unsigned long flags;    /* Various flags */\r
+       unsigned long offset;   /* Offset of selector field */\r
+       STACK_OF(ASN1_ADB_TABLE) **app_items; /* Application defined items */\r
+       const ASN1_ADB_TABLE *tbl;      /* Table of possible types */\r
+       long tblcount;          /* Number of entries in tbl */\r
+       const ASN1_TEMPLATE *default_tt;  /* Type to use if no match */\r
+       const ASN1_TEMPLATE *null_tt;  /* Type to use if selector is NULL */\r
+};\r
+\r
+struct ASN1_ADB_TABLE_st {\r
+       long value;             /* NID for an object or value for an int */\r
+       const ASN1_TEMPLATE tt;         /* item for this value */\r
+};\r
+\r
+/* template flags */\r
+\r
+/* Field is optional */\r
+#define ASN1_TFLG_OPTIONAL     (0x1)\r
+\r
+/* Field is a SET OF */\r
+#define ASN1_TFLG_SET_OF       (0x1 << 1)\r
+\r
+/* Field is a SEQUENCE OF */\r
+#define ASN1_TFLG_SEQUENCE_OF  (0x2 << 1)\r
+\r
+/* Special case: this refers to a SET OF that\r
+ * will be sorted into DER order when encoded *and*\r
+ * the corresponding STACK will be modified to match\r
+ * the new order.\r
+ */\r
+#define ASN1_TFLG_SET_ORDER    (0x3 << 1)\r
+\r
+/* Mask for SET OF or SEQUENCE OF */\r
+#define ASN1_TFLG_SK_MASK      (0x3 << 1)\r
+\r
+/* These flags mean the tag should be taken from the\r
+ * tag field. If EXPLICIT then the underlying type\r
+ * is used for the inner tag.\r
+ */\r
+\r
+/* IMPLICIT tagging */\r
+#define ASN1_TFLG_IMPTAG       (0x1 << 3)\r
+\r
+\r
+/* EXPLICIT tagging, inner tag from underlying type */\r
+#define ASN1_TFLG_EXPTAG       (0x2 << 3)\r
+\r
+#define ASN1_TFLG_TAG_MASK     (0x3 << 3)\r
+\r
+/* context specific IMPLICIT */\r
+#define ASN1_TFLG_IMPLICIT     ASN1_TFLG_IMPTAG|ASN1_TFLG_CONTEXT\r
+\r
+/* context specific EXPLICIT */\r
+#define ASN1_TFLG_EXPLICIT     ASN1_TFLG_EXPTAG|ASN1_TFLG_CONTEXT\r
+\r
+/* If tagging is in force these determine the\r
+ * type of tag to use. Otherwise the tag is\r
+ * determined by the underlying type. These\r
+ * values reflect the actual octet format.\r
+ */\r
+\r
+/* Universal tag */\r
+#define ASN1_TFLG_UNIVERSAL    (0x0<<6)\r
+/* Application tag */\r
+#define ASN1_TFLG_APPLICATION  (0x1<<6)\r
+/* Context specific tag */\r
+#define ASN1_TFLG_CONTEXT      (0x2<<6)\r
+/* Private tag */\r
+#define ASN1_TFLG_PRIVATE      (0x3<<6)\r
+\r
+#define ASN1_TFLG_TAG_CLASS    (0x3<<6)\r
+\r
+/* These are for ANY DEFINED BY type. In this case\r
+ * the 'item' field points to an ASN1_ADB structure\r
+ * which contains a table of values to decode the\r
+ * relevant type\r
+ */\r
+\r
+#define ASN1_TFLG_ADB_MASK     (0x3<<8)\r
+\r
+#define ASN1_TFLG_ADB_OID      (0x1<<8)\r
+\r
+#define ASN1_TFLG_ADB_INT      (0x1<<9)\r
+\r
+/* This flag means a parent structure is passed\r
+ * instead of the field: this is useful is a\r
+ * SEQUENCE is being combined with a CHOICE for\r
+ * example. Since this means the structure and\r
+ * item name will differ we need to use the\r
+ * ASN1_CHOICE_END_name() macro for example.\r
+ */\r
+\r
+#define ASN1_TFLG_COMBINE      (0x1<<10)\r
+\r
+/* This flag when present in a SEQUENCE OF, SET OF\r
+ * or EXPLICIT causes indefinite length constructed\r
+ * encoding to be used if required.\r
+ */\r
+\r
+#define ASN1_TFLG_NDEF         (0x1<<11)\r
+\r
+/* This is the actual ASN1 item itself */\r
+\r
+struct ASN1_ITEM_st {\r
+char itype;                    /* The item type, primitive, SEQUENCE, CHOICE or extern */\r
+long utype;                    /* underlying type */\r
+const ASN1_TEMPLATE *templates;        /* If SEQUENCE or CHOICE this contains the contents */\r
+long tcount;                   /* Number of templates if SEQUENCE or CHOICE */\r
+const void *funcs;             /* functions that handle this type */\r
+long size;                     /* Structure size (usually)*/\r
+#ifndef NO_ASN1_FIELD_NAMES\r
+const char *sname;             /* Structure name */\r
+#endif\r
+};\r
+\r
+/* These are values for the itype field and\r
+ * determine how the type is interpreted.\r
+ *\r
+ * For PRIMITIVE types the underlying type\r
+ * determines the behaviour if items is NULL.\r
+ *\r
+ * Otherwise templates must contain a single\r
+ * template and the type is treated in the\r
+ * same way as the type specified in the template.\r
+ *\r
+ * For SEQUENCE types the templates field points\r
+ * to the members, the size field is the\r
+ * structure size.\r
+ *\r
+ * For CHOICE types the templates field points\r
+ * to each possible member (typically a union)\r
+ * and the 'size' field is the offset of the\r
+ * selector.\r
+ *\r
+ * The 'funcs' field is used for application\r
+ * specific functions.\r
+ *\r
+ * For COMPAT types the funcs field gives a\r
+ * set of functions that handle this type, this\r
+ * supports the old d2i, i2d convention.\r
+ *\r
+ * The EXTERN type uses a new style d2i/i2d.\r
+ * The new style should be used where possible\r
+ * because it avoids things like the d2i IMPLICIT\r
+ * hack.\r
+ *\r
+ * MSTRING is a multiple string type, it is used\r
+ * for a CHOICE of character strings where the\r
+ * actual strings all occupy an ASN1_STRING\r
+ * structure. In this case the 'utype' field\r
+ * has a special meaning, it is used as a mask\r
+ * of acceptable types using the B_ASN1 constants.\r
+ *\r
+ * NDEF_SEQUENCE is the same as SEQUENCE except\r
+ * that it will use indefinite length constructed\r
+ * encoding if requested.\r
+ *\r
+ */\r
+\r
+#define ASN1_ITYPE_PRIMITIVE           0x0\r
+\r
+#define ASN1_ITYPE_SEQUENCE            0x1\r
+\r
+#define ASN1_ITYPE_CHOICE              0x2\r
+\r
+#define ASN1_ITYPE_COMPAT              0x3\r
+\r
+#define ASN1_ITYPE_EXTERN              0x4\r
+\r
+#define ASN1_ITYPE_MSTRING             0x5\r
+\r
+#define ASN1_ITYPE_NDEF_SEQUENCE       0x6\r
+\r
+/* Cache for ASN1 tag and length, so we\r
+ * don't keep re-reading it for things\r
+ * like CHOICE\r
+ */\r
+\r
+struct ASN1_TLC_st{\r
+       char valid;     /* Values below are valid */\r
+       int ret;        /* return value */\r
+       long plen;      /* length */\r
+       int ptag;       /* class value */\r
+       int pclass;     /* class value */\r
+       int hdrlen;     /* header length */\r
+};\r
+\r
+/* Typedefs for ASN1 function pointers */\r
+\r
+typedef ASN1_VALUE * ASN1_new_func(void);\r
+typedef void ASN1_free_func(ASN1_VALUE *a);\r
+typedef ASN1_VALUE * ASN1_d2i_func(ASN1_VALUE **a, const unsigned char ** in, long length);\r
+typedef int ASN1_i2d_func(ASN1_VALUE * a, unsigned char **in);\r
+\r
+typedef int ASN1_ex_d2i(ASN1_VALUE **pval, const unsigned char **in, long len, const ASN1_ITEM *it,\r
+                                       int tag, int aclass, char opt, ASN1_TLC *ctx);\r
+\r
+typedef int ASN1_ex_i2d(ASN1_VALUE **pval, unsigned char **out, const ASN1_ITEM *it, int tag, int aclass);\r
+typedef int ASN1_ex_new_func(ASN1_VALUE **pval, const ASN1_ITEM *it);\r
+typedef void ASN1_ex_free_func(ASN1_VALUE **pval, const ASN1_ITEM *it);\r
+\r
+typedef int ASN1_ex_print_func(BIO *out, ASN1_VALUE **pval,\r
+                                               int indent, const char *fname,\r
+                                               const ASN1_PCTX *pctx);\r
+\r
+typedef int ASN1_primitive_i2c(ASN1_VALUE **pval, unsigned char *cont, int *putype, const ASN1_ITEM *it);\r
+typedef int ASN1_primitive_c2i(ASN1_VALUE **pval, const unsigned char *cont, int len, int utype, char *free_cont, const ASN1_ITEM *it);\r
+typedef int ASN1_primitive_print(BIO *out, ASN1_VALUE **pval, const ASN1_ITEM *it, int indent, const ASN1_PCTX *pctx);\r
+\r
+typedef struct ASN1_COMPAT_FUNCS_st {\r
+       ASN1_new_func *asn1_new;\r
+       ASN1_free_func *asn1_free;\r
+       ASN1_d2i_func *asn1_d2i;\r
+       ASN1_i2d_func *asn1_i2d;\r
+} ASN1_COMPAT_FUNCS;\r
+\r
+typedef struct ASN1_EXTERN_FUNCS_st {\r
+       void *app_data;\r
+       ASN1_ex_new_func *asn1_ex_new;\r
+       ASN1_ex_free_func *asn1_ex_free;\r
+       ASN1_ex_free_func *asn1_ex_clear;\r
+       ASN1_ex_d2i *asn1_ex_d2i;\r
+       ASN1_ex_i2d *asn1_ex_i2d;\r
+       ASN1_ex_print_func *asn1_ex_print;\r
+} ASN1_EXTERN_FUNCS;\r
+\r
+typedef struct ASN1_PRIMITIVE_FUNCS_st {\r
+       void *app_data;\r
+       unsigned long flags;\r
+       ASN1_ex_new_func *prim_new;\r
+       ASN1_ex_free_func *prim_free;\r
+       ASN1_ex_free_func *prim_clear;\r
+       ASN1_primitive_c2i *prim_c2i;\r
+       ASN1_primitive_i2c *prim_i2c;\r
+       ASN1_primitive_print *prim_print;\r
+} ASN1_PRIMITIVE_FUNCS;\r
+\r
+/* This is the ASN1_AUX structure: it handles various\r
+ * miscellaneous requirements. For example the use of\r
+ * reference counts and an informational callback.\r
+ *\r
+ * The "informational callback" is called at various\r
+ * points during the ASN1 encoding and decoding. It can\r
+ * be used to provide minor customisation of the structures\r
+ * used. This is most useful where the supplied routines\r
+ * *almost* do the right thing but need some extra help\r
+ * at a few points. If the callback returns zero then\r
+ * it is assumed a fatal error has occurred and the\r
+ * main operation should be abandoned.\r
+ *\r
+ * If major changes in the default behaviour are required\r
+ * then an external type is more appropriate.\r
+ */\r
+\r
+typedef int ASN1_aux_cb(int operation, ASN1_VALUE **in, const ASN1_ITEM *it,\r
+                               void *exarg);\r
+\r
+typedef struct ASN1_AUX_st {\r
+       void *app_data;\r
+       int flags;\r
+       int ref_offset;         /* Offset of reference value */\r
+       int ref_lock;           /* Lock type to use */\r
+       ASN1_aux_cb *asn1_cb;\r
+       int enc_offset;         /* Offset of ASN1_ENCODING structure */\r
+} ASN1_AUX;\r
+\r
+/* For print related callbacks exarg points to this structure */\r
+typedef struct ASN1_PRINT_ARG_st {\r
+       BIO *out;\r
+       int indent;\r
+       const ASN1_PCTX *pctx;\r
+} ASN1_PRINT_ARG;\r
+\r
+/* For streaming related callbacks exarg points to this structure */\r
+typedef struct ASN1_STREAM_ARG_st {\r
+       /* BIO to stream through */\r
+       BIO *out;\r
+       /* BIO with filters appended */\r
+       BIO *ndef_bio;\r
+       /* Streaming I/O boundary */\r
+       unsigned char **boundary;\r
+} ASN1_STREAM_ARG;\r
+\r
+/* Flags in ASN1_AUX */\r
+\r
+/* Use a reference count */\r
+#define ASN1_AFLG_REFCOUNT     1\r
+/* Save the encoding of structure (useful for signatures) */\r
+#define ASN1_AFLG_ENCODING     2\r
+/* The Sequence length is invalid */\r
+#define ASN1_AFLG_BROKEN       4\r
+\r
+/* operation values for asn1_cb */\r
+\r
+#define ASN1_OP_NEW_PRE                0\r
+#define ASN1_OP_NEW_POST       1\r
+#define ASN1_OP_FREE_PRE       2\r
+#define ASN1_OP_FREE_POST      3\r
+#define ASN1_OP_D2I_PRE                4\r
+#define ASN1_OP_D2I_POST       5\r
+#define ASN1_OP_I2D_PRE                6\r
+#define ASN1_OP_I2D_POST       7\r
+#define ASN1_OP_PRINT_PRE      8\r
+#define ASN1_OP_PRINT_POST     9\r
+#define ASN1_OP_STREAM_PRE     10\r
+#define ASN1_OP_STREAM_POST    11\r
+#define ASN1_OP_DETACHED_PRE   12\r
+#define ASN1_OP_DETACHED_POST  13\r
+\r
+/* Macro to implement a primitive type */\r
+#define IMPLEMENT_ASN1_TYPE(stname) IMPLEMENT_ASN1_TYPE_ex(stname, stname, 0)\r
+#define IMPLEMENT_ASN1_TYPE_ex(itname, vname, ex) \\r
+                               ASN1_ITEM_start(itname) \\r
+                                       ASN1_ITYPE_PRIMITIVE, V_##vname, NULL, 0, NULL, ex, #itname \\r
+                               ASN1_ITEM_end(itname)\r
+\r
+/* Macro to implement a multi string type */\r
+#define IMPLEMENT_ASN1_MSTRING(itname, mask) \\r
+                               ASN1_ITEM_start(itname) \\r
+                                       ASN1_ITYPE_MSTRING, mask, NULL, 0, NULL, sizeof(ASN1_STRING), #itname \\r
+                               ASN1_ITEM_end(itname)\r
+\r
+/* Macro to implement an ASN1_ITEM in terms of old style funcs */\r
+\r
+#define IMPLEMENT_COMPAT_ASN1(sname) IMPLEMENT_COMPAT_ASN1_type(sname, V_ASN1_SEQUENCE)\r
+\r
+#define IMPLEMENT_COMPAT_ASN1_type(sname, tag) \\r
+       static const ASN1_COMPAT_FUNCS sname##_ff = { \\r
+               (ASN1_new_func *)sname##_new, \\r
+               (ASN1_free_func *)sname##_free, \