See ChangeLog.
authorTimo Schulz <twoaday@freakmail.de>
Tue, 9 Aug 2005 10:38:12 +0000 (10:38 +0000)
committerTimo Schulz <twoaday@freakmail.de>
Tue, 9 Aug 2005 10:38:12 +0000 (10:38 +0000)
src/ChangeLog
src/MapiGPGME.cpp
src/MapiGPGME.h
src/libgpgmedlgs.def [new file with mode: 0644]
src/libgpgmedlgs/libgpgmedlgs.dsp [new file with mode: 0644]
src/missing/stpcpy.c [new file with mode: 0644]
src/missing/vasprintf.c [new file with mode: 0644]

index 842d8df..57901e1 100644 (file)
@@ -1,3 +1,10 @@
+2005-08-09  Timo Schulz  <ts@g10code.com>
+
+       * missing/stpcpy.c: New.
+       * missing/vasprintf.c: New.
+       * libgpgmedlgs/libgpgmedlgs.{dsw, dsp}: Updated.
+       * MapiGPGME.cpp (_WIN32): Changed sequence of include files.
+
 2005-08-09  Werner Koch  <wk@g10code.com>
 
        * MapiGPGME.cpp (userid_from_key, keyid_from_key): New. Changed
index 316225c..656b815 100644 (file)
 
 #include <windows.h>
 #include <time.h>
-#include <initguid.h>
 
 #ifdef __MINGW32__
 # include "mymapi.h"
 # include "mymapitags.h"
 #else /* !__MINGW32__ */
-# include <mapidefs.h>
-# include <mapiutil.h>
-# include <mapiguid.h>
-# include <atlbase.h>
+#include <atlbase.h>
+#include <mapidefs.h>
+#include <mapiutil.h>
+#include <initguid.h>
+#include <mapiguid.h>
 #endif /* !__MINGW32__ */
 
 #include "gpgme.h"
@@ -43,7 +43,7 @@
 #include "MapiGPGME.h"
 #include "engine.h"
 
-
+#ifdef __MINGW32__
 #define  FreeProws(a)               do { ; } while(0)
 #define  HrGetOneProp(a,b,c)        0
 #define  HrSetOneProp(a,b)          0
@@ -52,7 +52,7 @@
 #define  HrQueryAllRows(a,b,c,d,e,f)  0
 #define  PpropFindProp(a,b,c)       0
 #define  RTFSync(a,b,c)             0
-
+#endif
 
 /* These were omitted from the standard headers */
 #ifndef PR_BODY_HTML
@@ -142,18 +142,18 @@ public:
 
   
 public:
-  int encrypt (void);
-  int decrypt (void);
-  int sign (void);
-  int verify (void);
-  int signEncrypt (void);
-
-  int doCmd(int doEncrypt, int doSign);
-  int doCmdAttach(int action);
-  int doCmdFile(int action, const char *in, const char *out);
-
-  const char* getLogFile (void) { return logfile; }
-  void setLogFile (const char *logfile)
+  int __stdcall encrypt (void);
+  int __stdcall decrypt (void);
+  int __stdcall sign (void);
+  int __stdcall verify (void);
+  int __stdcall signEncrypt (void);
+
+  int __stdcall doCmd(int doEncrypt, int doSign);
+  int __stdcall doCmdAttach(int action);
+  int __stdcall doCmdFile(int action, const char *in, const char *out);
+
+  const char* __stdcall getLogFile (void) { return logfile; }
+  void __stdcall setLogFile (const char *logfile)
   { 
     if (this->logfile) 
       {
@@ -165,101 +165,101 @@ public:
       strcpy (this->logfile, logfile);
   }
 
-  int getStorePasswdTime (void)
+  int __stdcall getStorePasswdTime (void)
   {
     return nstorePasswd;
   }
 
-  void setStorePasswdTime (int nCacheTime)
+  void __stdcall setStorePasswdTime (int nCacheTime)
   {
     this->nstorePasswd = nCacheTime; 
   }
 
-  bool getEncryptDefault (void)
+  bool __stdcall getEncryptDefault (void)
   {
     return doEncrypt;
   }
 
-  void setEncryptDefault (bool doEncrypt)
+  void __stdcall setEncryptDefault (bool doEncrypt)
   {
     this->doEncrypt = doEncrypt; 
   }
 
-  bool getSignDefault (void)
+  bool __stdcall getSignDefault (void)
   { 
     return doSign; 
   }
 
-  void setSignDefault (bool doSign)
+  void __stdcall setSignDefault (bool doSign)
   {
     this->doSign = doSign;
   }
 
-  bool getEncryptWithDefaultKey (void)
+  bool __stdcall getEncryptWithDefaultKey (void)
   {
     return encryptDefault;
   }
   
-  void setEncryptWithDefaultKey (bool encryptDefault)
+  void __stdcall setEncryptWithDefaultKey (bool encryptDefault)
   {
     this->encryptDefault = encryptDefault;
   }
 
-  bool getSaveDecryptedAttachments (void) 
+  bool __stdcall getSaveDecryptedAttachments (void) 
   { 
     return saveDecryptedAtt;
   }
 
-  void setSaveDecryptedAttachments (bool saveDecrAtt)
+  void __stdcall setSaveDecryptedAttachments (bool saveDecrAtt)
   {
     this->saveDecryptedAtt = saveDecrAtt;
   }
 
-  void setEncodingFormat (int fmt)
+  void __stdcall setEncodingFormat (int fmt)
   {
     encFormat = fmt; 
   }
 
-  int getEncodingFormat (void) 
+  int __stdcall getEncodingFormat (void) 
   {
     return encFormat;
   }
 
-  void setSignAttachments (bool signAtt)
+  void __stdcall setSignAttachments (bool signAtt)
   {
     this->autoSignAtt = signAtt; 
   }
 
-  bool getSignAttachments (void)
+  bool __stdcall getSignAttachments (void)
   {
     return autoSignAtt;
   }
 
-  void setEnableLogging (bool val)
+  void __stdcall setEnableLogging (bool val)
   {
     this->enableLogging = val;
   }
 
-  bool getEnableLogging (void)
+  bool __stdcall getEnableLogging (void)
   {
     return this->enableLogging;
   }
 
-  int readOptions (void);
-  int writeOptions (void);
+  int __stdcall readOptions (void);
+  int __stdcall writeOptions (void);
 
-  const char* getAttachmentExtension (const char *fname);
-  void freeAttachments (void);
-  int getAttachments (void);
+  const char* __stdcall getAttachmentExtension (const char *fname);
+  void __stdcall freeAttachments (void);
+  int __stdcall getAttachments (void);
   
-  int countAttachments (void) 
+  int __stdcall countAttachments (void) 
   { 
     if (attachRows == NULL)
       return -1;
     return (int) attachRows->cRows; 
   }
 
-  bool hasAttachments (void)
+  bool __stdcall hasAttachments (void)
   {
     if (attachRows == NULL)
       getAttachments ();
@@ -268,14 +268,14 @@ public:
     return has;
   }
 
-  bool deleteAttachment (int pos)
+  bool __stdcall deleteAttachment (int pos)
   {
     if (msg->DeleteAttach (pos, 0, NULL, 0) == S_OK)
       return true;
     return false;
   }
 
-  LPATTACH createAttachment (int &pos)
+  LPATTACH __stdcall createAttachment (int &pos)
   {
     ULONG attnum;      
     LPATTACH newatt = NULL;
@@ -288,24 +288,24 @@ public:
     return NULL;
   }
 
-  int startKeyManager ();
-  void startConfigDialog (HWND parent);
+  int __stdcall startKeyManager ();
+  void __stdcall startConfigDialog (HWND parent);
 
-  int attachPublicKey (const char *keyid);
+  int __stdcall attachPublicKey (const char *keyid);
 
-  void setDefaultKey (const char *key);
-  char* getDefaultKey (void);
+  void __stdcall setDefaultKey (const char *key);
+  char* __stdcall getDefaultKey (void);
 
-  void setMessage (LPMESSAGE msg);
-  void setWindow (HWND hwnd);
+  void __stdcall setMessage (LPMESSAGE msg);
+  void __stdcall setWindow (HWND hwnd);
 
-  const char* getPassphrase (const char *keyid);
-  void storePassphrase (void *itm);
-  outlgpg_type_t getMessageType (const char *body);
+  const char* __stdcall getPassphrase (const char *keyid);
+  void __stdcall storePassphrase (void *itm);
+  outlgpg_type_t __stdcall getMessageType (const char *body);
 
-  void logDebug (const char *fmt, ...);
+  void __stdcall logDebug (const char *fmt, ...);
     
-  void clearPassphrase (void) 
+  void __stdcall clearPassphrase (void) 
   {
     if (passCache != NULL)
       passCache->clear ();
@@ -1021,8 +1021,7 @@ MapiGPGMEImpl::signEncrypt (void)
     char *newBody = NULL;
     char **recipients = getRecipients (TRUE);
     char **unknown = NULL;
-    gpgme_key_t locusr=NULL, *keys = NULL, *keys2 =NULL;       
-    const char *s;
+    gpgme_key_t locusr=NULL, *keys = NULL, *keys2 =NULL;
 
     if (body == NULL || strlen (body) == 0) {
        freeRecipients (recipients);
@@ -1035,7 +1034,7 @@ MapiGPGMEImpl::signEncrypt (void)
        delete_buf (body);
        return 0;
     }
-    logDebug ( "locusr keyid:%s\r\n", keyid_from_key (locusr));
+    logDebug ("locusr keyid:%s\r\n", keyid_from_key (locusr));
 
     size_t all;
     int n = op_lookup_keys (recipients, &keys, &unknown, &all);
index 6b3513b..3f38194 100644 (file)
@@ -63,7 +63,7 @@ public:
   virtual int __stdcall doCmdFile (int action,
                                    const char *in, const char *out) = 0;
 
-  virtual const __stdcall char* getAttachmentExtension (const char *fname) = 0;
+  virtual const char* __stdcall getAttachmentExtension (const char *fname) = 0;
   virtual void __stdcall freeAttachments (void) = 0;
   virtual int __stdcall getAttachments (void) = 0;
   virtual int __stdcall countAttachments (void) = 0;
diff --git a/src/libgpgmedlgs.def b/src/libgpgmedlgs.def
new file mode 100644 (file)
index 0000000..ddca173
--- /dev/null
@@ -0,0 +1,25 @@
+SECTIONS\r
+       .SHARDAT READ WRITE SHARED\r
+\r
+EXPORTS\r
+       recipient_dialog_box\r
+       recipient_dialog_box2\r
+       signer_dialog_box\r
+       config_dialog_box\r
+       passphrase_callback_box\r
+       free_decrypt_key\r
+       verify_dialog_box \r
+       start_key_manager\r
+\r
+       init_keycache_objects\r
+       cleanup_keycache_objects \r
+       find_gpg_key\r
+\r
+       op_init\r
+       op_deinit\r
+       op_strerror\r
+       op_decrypt_start\r
+\r
+       HashTable_free\r
+\r
+       CreateMapiGPGME\r
diff --git a/src/libgpgmedlgs/libgpgmedlgs.dsp b/src/libgpgmedlgs/libgpgmedlgs.dsp
new file mode 100644 (file)
index 0000000..ef3be34
--- /dev/null
@@ -0,0 +1,183 @@
+# Microsoft Developer Studio Project File - Name="libgpgmedlgs" - Package Owner=<4>\r
+# Microsoft Developer Studio Generated Build File, Format Version 6.00\r
+# ** NICHT BEARBEITEN **\r
+\r
+# TARGTYPE "Win32 (x86) Dynamic-Link Library" 0x0102\r
+\r
+CFG=libgpgmedlgs - Win32 Debug\r
+!MESSAGE Dies ist kein gültiges Makefile. Zum Erstellen dieses Projekts mit NMAKE\r
+!MESSAGE verwenden Sie den Befehl "Makefile exportieren" und führen Sie den Befehl\r
+!MESSAGE \r
+!MESSAGE NMAKE /f "libgpgmedlgs.mak".\r
+!MESSAGE \r
+!MESSAGE Sie können beim Ausführen von NMAKE eine Konfiguration angeben\r
+!MESSAGE durch Definieren des Makros CFG in der Befehlszeile. Zum Beispiel:\r
+!MESSAGE \r
+!MESSAGE NMAKE /f "libgpgmedlgs.mak" CFG="libgpgmedlgs - Win32 Debug"\r
+!MESSAGE \r
+!MESSAGE Für die Konfiguration stehen zur Auswahl:\r
+!MESSAGE \r
+!MESSAGE "libgpgmedlgs - Win32 Release" (basierend auf  "Win32 (x86) Dynamic-Link Library")\r
+!MESSAGE "libgpgmedlgs - Win32 Debug" (basierend auf  "Win32 (x86) Dynamic-Link Library")\r
+!MESSAGE \r
+\r
+# Begin Project\r
+# PROP AllowPerConfigDependencies 0\r
+# PROP Scc_ProjName ""\r
+# PROP Scc_LocalPath ""\r
+CPP=cl.exe\r
+MTL=midl.exe\r
+RSC=rc.exe\r
+\r
+!IF  "$(CFG)" == "libgpgmedlgs - Win32 Release"\r
+\r
+# PROP BASE Use_MFC 0\r
+# PROP BASE Use_Debug_Libraries 0\r
+# PROP BASE Output_Dir "Release"\r
+# PROP BASE Intermediate_Dir "Release"\r
+# PROP BASE Target_Dir ""\r
+# PROP Use_MFC 0\r
+# PROP Use_Debug_Libraries 0\r
+# PROP Output_Dir "Release"\r
+# PROP Intermediate_Dir "Release"\r
+# PROP Ignore_Export_Lib 0\r
+# PROP Target_Dir ""\r
+# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "LIBGPGMEDLGS_EXPORTS" /YX /FD /c\r
+# ADD CPP /nologo /MT /W3 /GX /O2 /I ".." /I "C:\OSS\w32root\include" /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "LIBGPGMEDLGS_EXPORTS" /YX /FD /c\r
+# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32\r
+# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32\r
+# ADD BASE RSC /l 0x407 /d "NDEBUG"\r
+# ADD RSC /l 0x407 /d "NDEBUG"\r
+BSC32=bscmake.exe\r
+# ADD BASE BSC32 /nologo\r
+# ADD BSC32 /nologo\r
+LINK32=link.exe\r
+# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /machine:I386\r
+# ADD LINK32 gdi32.lib mapi32.lib kernel32.lib user32.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib C:\OSS\w32root\lib\libgpgme.a C:\OSS\w32root\lib\libgpg-error.a /nologo /dll /machine:I386\r
+\r
+!ELSEIF  "$(CFG)" == "libgpgmedlgs - Win32 Debug"\r
+\r
+# PROP BASE Use_MFC 0\r
+# PROP BASE Use_Debug_Libraries 1\r
+# PROP BASE Output_Dir "Debug"\r
+# PROP BASE Intermediate_Dir "Debug"\r
+# PROP BASE Target_Dir ""\r
+# PROP Use_MFC 0\r
+# PROP Use_Debug_Libraries 1\r
+# PROP Output_Dir "Debug"\r
+# PROP Intermediate_Dir "Debug"\r
+# PROP Ignore_Export_Lib 0\r
+# PROP Target_Dir ""\r
+# ADD BASE CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "LIBGPGMEDLGS_EXPORTS" /YX /FD /GZ /c\r
+# ADD CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /I ".." /I "C:\OSS\w32root\include" /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "LIBGPGMEDLGS_EXPORTS" /YX /FD /GZ /c\r
+# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32\r
+# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32\r
+# ADD BASE RSC /l 0x407 /d "_DEBUG"\r
+# ADD RSC /l 0x407 /d "_DEBUG"\r
+BSC32=bscmake.exe\r
+# ADD BASE BSC32 /nologo\r
+# ADD BSC32 /nologo\r
+LINK32=link.exe\r
+# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /debug /machine:I386 /pdbtype:sept\r
+# ADD LINK32 gdi32.lib mapi32.lib kernel32.lib user32.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib C:\OSS\w32root\lib\libgpgme.a C:\OSS\w32root\lib\libgpg-error.a /nologo /dll /debug /machine:I386 /pdbtype:sept\r
+\r
+!ENDIF \r
+\r
+# Begin Target\r
+\r
+# Name "libgpgmedlgs - Win32 Release"\r
+# Name "libgpgmedlgs - Win32 Debug"\r
+# Begin Group "missing"\r
+\r
+# PROP Default_Filter ""\r
+# Begin Source File\r
+\r
+SOURCE=..\missing\stpcpy.c\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\missing\vasprintf.c\r
+# End Source File\r
+# End Group\r
+# Begin Source File\r
+\r
+SOURCE=..\common.c\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE="..\config-dialog.c"\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE="..\engine-gpgme.c"\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\engine.h\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\gpgmedlgs.rc\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\HashTable.cpp\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\HashTable.h\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\intern.h\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\keycache.c\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\keycache.h\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\keylist.c\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\main.c\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\MapiGPGME.cpp\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\MapiGPGME.h\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE="..\passphrase-dialog.c"\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE="..\recipient-dialog.c"\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\resource.h\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\usermap.c\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE=..\usermap.h\r
+# End Source File\r
+# Begin Source File\r
+\r
+SOURCE="..\verify-dialog.c"\r
+# End Source File\r
+# End Target\r
+# End Project\r
diff --git a/src/missing/stpcpy.c b/src/missing/stpcpy.c
new file mode 100644 (file)
index 0000000..fc22c9b
--- /dev/null
@@ -0,0 +1,47 @@
+/* Copyright (C) 1992, 1995, 1997, 2002, 2004 Free Software Foundation, Inc.\r
+   This file is part of the GNU C Library.\r
+\r
+   The GNU C Library is free software; you can redistribute it and/or\r
+   modify it under the terms of the GNU Lesser General Public\r
+   License as published by the Free Software Foundation; either\r
+   version 2.1 of the License, or (at your option) any later version.\r
+\r
+   The GNU C Library is distributed in the hope that it will be useful,\r
+   but WITHOUT ANY WARRANTY; without even the implied warranty of\r
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU\r
+   Lesser General Public License for more details.\r
+\r
+   You should have received a copy of the GNU Lesser General Public\r
+   License along with the GNU C Library; if not, write to the Free\r
+   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA\r
+   02111-1307 USA.  */\r
+\r
+\r
+#include <string.h>\r
+\r
+/* Copy SRC to DEST, returning the address of the terminating '\0' in DEST.  */\r
+char *\r
+stpcpy (dest, src)\r
+     char *dest;\r
+     const char *src;\r
+{\r
+  register char *d = dest;\r
+  register const char *s = src;\r
+\r
+  do\r
+    *d++ = *s;\r
+  while (*s++ != '\0');\r
+\r
+  return d - 1;\r
+}\r
+\r
+\r
+int strcasecmp(const char *a, const char *b)\r
+{\r
+    return stricmp(a, b);\r
+}\r
+\r
+int strncasecmp(const char *a, const char *b, size_t n)\r
+{\r
+    return strnicmp(a, b, n);\r
+}\r
diff --git a/src/missing/vasprintf.c b/src/missing/vasprintf.c
new file mode 100644 (file)
index 0000000..6adff11
--- /dev/null
@@ -0,0 +1,169 @@
+/* Like vsprintf but provides a pointer to malloc'd storage, which must\r
+   be freed by the caller.\r
+   Copyright (C) 1994, 2002 Free Software Foundation, Inc.\r
+\r
+This file is part of the libiberty library.\r
+Libiberty is free software; you can redistribute it and/or\r
+modify it under the terms of the GNU Library General Public\r
+License as published by the Free Software Foundation; either\r
+version 2 of the License, or (at your option) any later version.\r
+\r
+Libiberty is distributed in the hope that it will be useful,\r
+but WITHOUT ANY WARRANTY; without even the implied warranty of\r
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU\r
+Library General Public License for more details.\r
+\r
+You should have received a copy of the GNU Library General Public\r
+License along with libiberty; see the file COPYING.LIB.  If\r
+not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,\r
+Boston, MA 02111-1307, USA.  */\r
+\r
+#ifdef HAVE_CONFIG_H\r
+#include <config.h>\r
+#endif\r
+#include <stdio.h>\r
+#include <string.h>\r
+#include <stdlib.h>\r
+#include <stdarg.h>\r
+\r
+#ifdef TEST\r
+int global_total_width;\r
+#endif\r
+\r
+int\r
+vasprintf (char **result, const char *format, va_list *args)\r
+{\r
+  const char *p = format;\r
+  /* Add one to make sure that it is never zero, which might cause malloc\r
+     to return NULL.  */\r
+  int total_width = strlen (format) + 1;\r
+  va_list ap;\r
+\r
+#ifdef va_copy\r
+  va_copy (ap, args);\r
+#else\r
+#ifdef __va_copy\r
+  __va_copy (ap, args);\r
+#else\r
+  memcpy (&ap, args, sizeof (va_list));\r
+#endif /* __va_copy */\r
+#endif /* va_copy */\r
+\r
+  while (*p != '\0')\r
+    {\r
+      if (*p++ == '%')\r
+       {\r
+         while (strchr ("-+ #0", *p))\r
+           ++p;\r
+         if (*p == '*')\r
+           {\r
+             ++p;\r
+             total_width += abs (va_arg (ap, int));\r
+           }\r
+         else\r
+           total_width += strtoul (p, (char**)&p, 10);\r
+         if (*p == '.')\r
+           {\r
+             ++p;\r
+             if (*p == '*')\r
+               {\r
+                 ++p;\r
+                 total_width += abs (va_arg (ap, int));\r
+               }\r
+             else\r
+             total_width += strtoul (p, (char**)&p, 10);\r
+           }\r
+         while (strchr ("hlL", *p))\r
+           ++p;\r
+         /* Should be big enough for any format specifier except %s\r
+             and floats.  */\r
+         total_width += 30;\r
+         switch (*p)\r
+           {\r
+           case 'd':\r
+           case 'i':\r
+           case 'o':\r
+           case 'u':\r
+           case 'x':\r
+           case 'X':\r
+           case 'c':\r
+             (void) va_arg (ap, int);\r
+             break;\r
+           case 'f':\r
+           case 'e':\r
+           case 'E':\r
+           case 'g':\r
+           case 'G':\r
+             (void) va_arg (ap, double);\r
+             /* Since an ieee double can have an exponent of 307, we'll\r
+                make the buffer wide enough to cover the gross case. */\r
+             total_width += 307;\r
+             break;\r
+           case 's':\r
+              {\r
+                char *tmp = va_arg (ap, char *);\r
+                if (tmp)\r
+                  total_width += strlen (tmp);\r
+                else /* in case the vsprintf does prints a text */\r
+                  total_width += 25; /* e.g. "(null pointer reference)" */\r
+              }\r
+             break;\r
+           case 'p':\r
+           case 'n':\r
+             (void) va_arg (ap, char *);\r
+             break;\r
+           }\r
+       }\r
+    }\r
+#ifdef TEST\r
+  global_total_width = total_width;\r
+#endif\r
+  *result = malloc (total_width);\r
+  if (*result != NULL)\r
+    return vsprintf (*result, format, *args);\r
+  else\r
+    return 0;\r
+}\r
+\r
+\r
+int\r
+asprintf (char **buf, const char *fmt, ...)\r
+{\r
+  int status;\r
+  va_list ap;\r
+\r
+  va_start (ap, fmt);\r
+  status = vasprintf (buf, fmt, ap);\r
+  va_end (ap);\r
+  return status;\r
+}\r
+\r
+\r
+#ifdef TEST\r
+void\r
+checkit (const char* format, ...)\r
+{\r
+  va_list args;\r
+  char *result;\r
+\r
+  va_start (args, format);\r
+  vasprintf (&result, format, args);\r
+  if (strlen (result) < global_total_width)\r
+    printf ("PASS: ");\r
+  else\r
+    printf ("FAIL: ");\r
+  printf ("%d %s\n", global_total_width, result);\r
+}\r
+\r
+int\r
+main (void)\r
+{\r
+  checkit ("%d", 0x12345678);\r
+  checkit ("%200d", 5);\r
+  checkit ("%.300d", 6);\r
+  checkit ("%100.150d", 7);\r
+  checkit ("%s", "jjjjjjjjjiiiiiiiiiiiiiiioooooooooooooooooppppppppppppaa\n\\r
+777777777777777777333333333333366666666666622222222222777777777777733333");\r
+  checkit ("%f%s%d%s", 1.0, "foo", 77, "asdjffffffffffffffiiiiiiiiiiixxxxx");\r
+}\r
+#endif /* TEST */\r