Thread: Borland c++ compile problems...

Borland c++ compile problems...

From
Steve Holdoway
Date:
Hi folks,

It seems that Borland C++ ( I'm using the command line version 5.5 )
takes exception to #defines like the following...

#define open(a, b...) win32_open ( a, b, ##__VA_ARGS__ )
  [ to be found in port.h on the current development snapshot ]

This causes compilation to fail. I'm after a version of blibpq.dll that
supports ssl connections, and the one I compiled previously ( 7.4.2 I
think ) doesn't seem to.

Can anyone suggest a solution. I speak C fluently... it's this pesky
windows stuff that causes me grief!

Cheers,

Steve

Re: Borland c++ compile problems...

From
Bruce Momjian
Date:
OK, patch attached that fixes it.  Should that define just check for GCC
instead of checking if the compiler isn't MS or Borland?

---------------------------------------------------------------------------

Steve Holdoway wrote:
> Hi folks,
> 
> It seems that Borland C++ ( I'm using the command line version 5.5 ) 
> takes exception to #defines like the following...
> 
> #define open(a, b...) win32_open ( a, b, ##__VA_ARGS__ )
>   [ to be found in port.h on the current development snapshot ]
> 
> This causes compilation to fail. I'm after a version of blibpq.dll that 
> supports ssl connections, and the one I compiled previously ( 7.4.2 I 
> think ) doesn't seem to.
> 
> Can anyone suggest a solution. I speak C fluently... it's this pesky 
> windows stuff that causes me grief!
> 
> Cheers,
> 
> Steve
> 
> ---------------------------(end of broadcast)---------------------------
> TIP 8: explain analyze is your friend
> 

-- 
  Bruce Momjian                        |  http://candle.pha.pa.us
  pgman@candle.pha.pa.us               |  (610) 359-1001
  +  If your life is a hard drive,     |  13 Roberts Road
  +  Christ can be your backup.        |  Newtown Square, Pennsylvania 19073
Index: src/include/port.h
===================================================================
RCS file: /cvsroot/pgsql-server/src/include/port.h,v
retrieving revision 1.43
diff -c -c -r1.43 port.h
*** src/include/port.h    11 Jun 2004 16:10:09 -0000    1.43
--- src/include/port.h    21 Jul 2004 03:01:33 -0000
***************
*** 151,157 ****
  #ifdef WIN32
  
  /* open() replacement to allow delete of held files */
! #ifndef _MSC_VER
  extern int    win32_open(const char*,int,...);
  #define     open(a,b,...)    win32_open(a,b,##__VA_ARGS__)
  #endif
--- 151,157 ----
  #ifdef WIN32
  
  /* open() replacement to allow delete of held files */
! #if !defined(_MSC_VER) && !defined(__BORLANDC__)
  extern int    win32_open(const char*,int,...);
  #define     open(a,b,...)    win32_open(a,b,##__VA_ARGS__)
  #endif

Re: Borland c++ compile problems...

From
Steve Holdoway
Date:
Bruce Momjian wrote:

>OK, patch attached that fixes it.  Should that define just check for GCC
>instead of checking if the compiler isn't MS or Borland?
>
>---------------------------------------------------------------------------
>
>Steve Holdoway wrote:
>
>
>>Hi folks,
>>
>>It seems that Borland C++ ( I'm using the command line version 5.5 )
>>takes exception to #defines like the following...
>>
>>#define open(a, b...) win32_open ( a, b, ##__VA_ARGS__ )
>>  [ to be found in port.h on the current development snapshot ]
>>
>>This causes compilation to fail. I'm after a version of blibpq.dll that
>>supports ssl connections, and the one I compiled previously ( 7.4.2 I
>>think ) doesn't seem to.
>>
>>Can anyone suggest a solution. I speak C fluently... it's this pesky
>>windows stuff that causes me grief!
>>
>>Cheers,
>>
>>Steve
>>
>>---------------------------(end of broadcast)---------------------------
>>TIP 8: explain analyze is your friend
>>
>>
>>
>
>
>
>------------------------------------------------------------------------
>
>Index: src/include/port.h
>===================================================================
>RCS file: /cvsroot/pgsql-server/src/include/port.h,v
>retrieving revision 1.43
>diff -c -c -r1.43 port.h
>*** src/include/port.h    11 Jun 2004 16:10:09 -0000    1.43
>--- src/include/port.h    21 Jul 2004 03:01:33 -0000
>***************
>*** 151,157 ****
>  #ifdef WIN32
>
>  /* open() replacement to allow delete of held files */
>! #ifndef _MSC_VER
>  extern int    win32_open(const char*,int,...);
>  #define     open(a,b,...)    win32_open(a,b,##__VA_ARGS__)
>  #endif
>--- 151,157 ----
>  #ifdef WIN32
>
>  /* open() replacement to allow delete of held files */
>! #if !defined(_MSC_VER) && !defined(__BORLANDC__)
>  extern int    win32_open(const char*,int,...);
>  #define     open(a,b,...)    win32_open(a,b,##__VA_ARGS__)
>  #endif
>
>
>------------------------------------------------------------------------
>
>
>---------------------------(end of broadcast)---------------------------
>TIP 4: Don't 'kill -9' the postmaster
>
>
Sorry to be a pest, and all that. However, it looks like make needs to
be run in src\port, to create pg_config_paths.h, and compile stuff to
resolve externals _set_noblock, _pg_strcasecmp, _pg_tolower, and _popen
(? bit worried about that one!)

I had a go at rewriting an existing bcc32.mak, but just seemed to
generate more errors!

Cheers,

Steve

Re: Borland c++ compile problems...

From
Bruce Momjian
Date:
Steve Holdoway wrote:
> Sorry to be a pest, and all that. However, it looks like make needs to
> be run in src\port, to create pg_config_paths.h, and compile stuff to
> resolve externals _set_noblock, _pg_strcasecmp, _pg_tolower, and _popen
> (? bit worried about that one!)
>
> I had a go at rewriting an existing bcc32.mak, but just seemed to
> generate more errors!

Uh, I don't see how those would fail.  What errors are you seeing?

--
  Bruce Momjian                        |  http://candle.pha.pa.us
  pgman@candle.pha.pa.us               |  (610) 359-1001
  +  If your life is a hard drive,     |  13 Roberts Road
  +  Christ can be your backup.        |  Newtown Square, Pennsylvania 19073

Re: Borland c++ compile problems...

From
Steve Holdoway
Date:
Bruce Momjian wrote:

>Steve Holdoway wrote:
>
>
>>Sorry to be a pest, and all that. However, it looks like make needs to
>>be run in src\port, to create pg_config_paths.h, and compile stuff to
>>resolve externals _set_noblock, _pg_strcasecmp, _pg_tolower, and _popen
>>(? bit worried about that one!)
>>
>>I had a go at rewriting an existing bcc32.mak, but just seemed to
>>generate more errors!
>>
>>
>
>Uh, I don't see how those would fail.  What errors are you seeing?
>
>
>
Well, in the port subdirectory, one of the things that is generated by
the makefile is pg_config_paths.h. Without this, libpq will not compile.
As I stated above, cobbling this together manually then gets me to the
place where the aforementioned external references are not resolved. All
are in source files in the port directory.

The errors I'm seeing are all caused by includes not being found, etc. I
don't know what to do when they are ones like strings.h, which I do not
have either in the snapshot source tree, or in the Borland bcc 5.5 tree.

I also don't know how you want the above files building... into a
library, static or dynamic/straight object code, etc. There is also no
listing in the current bcc32.mak files to include them into the libpq
dll generation.


Re: Borland c++ compile problems...

From
Bruce Momjian
Date:
Steve Holdoway wrote:
> Bruce Momjian wrote:
>
> >Steve Holdoway wrote:
> >
> >
> >>Sorry to be a pest, and all that. However, it looks like make needs to
> >>be run in src\port, to create pg_config_paths.h, and compile stuff to
> >>resolve externals _set_noblock, _pg_strcasecmp, _pg_tolower, and _popen
> >>(? bit worried about that one!)
> >>
> >>I had a go at rewriting an existing bcc32.mak, but just seemed to
> >>generate more errors!
> >>
> >>
> >
> >Uh, I don't see how those would fail.  What errors are you seeing?
> >
> >
> >
> Well, in the port subdirectory, one of the things that is generated by
> the makefile is pg_config_paths.h. Without this, libpq will not compile.
> As I stated above, cobbling this together manually then gets me to the
> place where the aforementioned external references are not resolved. All
> are in source files in the port directory.
>
> The errors I'm seeing are all caused by includes not being found, etc. I
> don't know what to do when they are ones like strings.h, which I do not
> have either in the snapshot source tree, or in the Borland bcc 5.5 tree.
>
> I also don't know how you want the above files building... into a
> library, static or dynamic/straight object code, etc. There is also no
> listing in the current bcc32.mak files to include them into the libpq
> dll generation.

OK, if you look at the last few commits to interfaces/libpq/win32.mak,
you will see changes for pg_config_paths.h and for thread safety.  Can
you look at those changes, merge them into bcc.mak.  There might be
other changes in there you want to add to bcc.mak too.

--
  Bruce Momjian                        |  http://candle.pha.pa.us
  pgman@candle.pha.pa.us               |  (610) 359-1001
  +  If your life is a hard drive,     |  13 Roberts Road
  +  Christ can be your backup.        |  Newtown Square, Pennsylvania 19073

Re: Borland c++ compile problems...

From
Steve Holdoway
Date:
Bruce Momjian wrote:

>Steve Holdoway wrote:
>  
>
>>Bruce Momjian wrote:
>>
>>    
>>
>>>Steve Holdoway wrote:
>>> 
>>>
>>>      
>>>
>>>>Sorry to be a pest, and all that. However, it looks like make needs to 
>>>>be run in src\port, to create pg_config_paths.h, and compile stuff to 
>>>>resolve externals _set_noblock, _pg_strcasecmp, _pg_tolower, and _popen 
>>>>(? bit worried about that one!)
>>>>
>>>>I had a go at rewriting an existing bcc32.mak, but just seemed to 
>>>>generate more errors!
>>>>   
>>>>
>>>>        
>>>>
>>>Uh, I don't see how those would fail.  What errors are you seeing?
>>>
>>> 
>>>
>>>      
>>>
>>Well, in the port subdirectory, one of the things that is generated by 
>>the makefile is pg_config_paths.h. Without this, libpq will not compile. 
>>As I stated above, cobbling this together manually then gets me to the 
>>place where the aforementioned external references are not resolved. All 
>>are in source files in the port directory.
>>
>>The errors I'm seeing are all caused by includes not being found, etc. I 
>>don't know what to do when they are ones like strings.h, which I do not 
>>have either in the snapshot source tree, or in the Borland bcc 5.5 tree.
>>
>>I also don't know how you want the above files building... into a 
>>library, static or dynamic/straight object code, etc. There is also no 
>>listing in the current bcc32.mak files to include them into the libpq 
>>dll generation.
>>    
>>
>
>OK, if you look at the last few commits to interfaces/libpq/win32.mak,
>you will see changes for pg_config_paths.h and for thread safety.  Can
>you look at those changes, merge them into bcc.mak.  There might be
>other changes in there you want to add to bcc.mak too.
>
>  
>
OK, having no M$ diff, I attach files src\interfaces\libpq\bcc32.mak and 
src\interfaces\libpq\win32.h

bcc32.mak incorporates the changes in win32.mak, and adds a couple of 
extra source files from the ..\..\port directory, and win32.h was used 
to #define popen -> _popen.

All seems to work after a *very* cursory test!

Can I get back to the land of proper slashes now???

Cheers,

Steve
# Makefile for Borland C++ 5.5

# Will build a Win32 static library libpq.lib
#        and a Win32 dynamic library libpq.dll with import library libpqdll.lib

# Borland C++ base install directory goes here
BCB=c:\Borland\Bcc55

!MESSAGE Building the Win32 DLL and Static Library...
!MESSAGE
!IF "$(CFG)" == ""
CFG=Release
!MESSAGE No configuration specified. Defaulting to Release.
!MESSAGE
!ELSE
!MESSAGE Configuration "$(CFG)"
!MESSAGE
!ENDIF

!IF "$(CFG)" != "Release" && "$(CFG)" != "Debug"
!MESSAGE Invalid configuration "$(CFG)" specified.
!MESSAGE You can specify a configuration when running MAKE
!MESSAGE by defining the macro CFG on the command line. For example:
!MESSAGE
!MESSAGE make  -DCFG=[Release | Debug] /f bcc32.mak
!MESSAGE
!MESSAGE Possible choices for configuration are:
!MESSAGE
!MESSAGE "Release" (Win32 Release DLL and Static Library)
!MESSAGE "Debug" (Win32 Debug DLL and Static Library)
!MESSAGE
!ERROR An invalid configuration was specified.
!ENDIF

!IF "$(OS)" == "Windows_NT"
NULL=
!ELSE 
NULL=nul
!ENDIF 

!IF "$(CFG)" == "Debug"
DEBUG=1
OUTDIR=.\Debug
INTDIR=.\Debug
!else
OUTDIR=.\Release
INTDIR=.\Release
!endif

USERDEFINES=FRONTEND;NDEBUG;WIN32;_WINDOWS;HAVE_VSNPRINTF;HAVE_STRDUP;

CPP=bcc32.exe
CPP_PROJ = -I$(BCB)\include;..\..\include -WD -c -D$(USERDEFINES) -tWM \
        -a8 -X -w-use -w-par -w-pia -w-csu -w-aus -w-ccc

!IFDEF DEBUG
CPP_PROJ    = $(CPP_PROJ) -Od -r- -k -v -y -vi- -D_DEBUG
!else
CPP_PROJ        = $(CPP_PROJ) -O -Oi -OS -DNDEBU
!endif

LIB32=tlib.exe
LIB32_FLAGS= 
LIB32_OBJS= \
    "$(OUTDIR)\win32.obj" \
    "$(INTDIR)\getaddrinfo.obj" \
    "$(INTDIR)\thread.obj" \
    "$(INTDIR)\inet_aton.obj" \
    "$(INTDIR)\crypt.obj" \
    "$(INTDIR)\path.obj" \
        "$(INTDIR)\noblock.obj" \
        "$(INTDIR)\pgstrcasecmp.obj" \
    "$(INTDIR)\dllist.obj" \
    "$(INTDIR)\md5.obj" \
    "$(INTDIR)\ip.obj" \
    "$(INTDIR)\fe-auth.obj" \
    "$(INTDIR)\fe-protocol2.obj" \
    "$(INTDIR)\fe-protocol3.obj" \
    "$(INTDIR)\fe-connect.obj" \
    "$(INTDIR)\fe-exec.obj" \
    "$(INTDIR)\fe-lobj.obj" \
    "$(INTDIR)\fe-misc.obj" \
    "$(INTDIR)\fe-print.obj" \
    "$(INTDIR)\fe-secure.obj" \
    "$(INTDIR)\pqexpbuffer.obj" \
    "$(INTDIR)\wchar.obj" \
        "$(INTDIR)\encnames.obj"


RSC=brcc32.exe
RSC_PROJ=-l 0x409 -i$(BCB)\include -fo"$(INTDIR)\libpq.res"

LINK32=ilink32.exe
LINK32_FLAGS = -Gn -L$(BCB)\lib;$(INTDIR); -x -Tpd -v
LINK32_OBJS= "$(INTDIR)\libpqdll.obj"
    
# ---------------------------------------------------------------------------

.path.obj = $(INTDIR)
.path.c = .;..\..\port;..\..\backend\libpq;..\..\backend\lib;..\..\backend\utils\mb

# ---------------------------------------------------------------------------

ALL: config "$(OUTDIR)" "$(OUTDIR)\blibpq.dll" "$(OUTDIR)\blibpq.lib"

CLEAN :
    -@erase "$(INTDIR)\getaddrinfo.obj"
    -@erase "$(INTDIR)\thread.obj"
    -@erase "$(INTDIR)\inet_aton.obj"
    -@erase "$(INTDIR)\crypt.obj"
    -@erase "$(INTDIR)\path.obj"
    -@erase "$(INTDIR)\dllist.obj"
    -@erase "$(INTDIR)\md5.obj"
    -@erase "$(INTDIR)\ip.obj"
    -@erase "$(INTDIR)\fe-auth.obj"
    -@erase "$(INTDIR)\fe-protocol2.obj"
    -@erase "$(INTDIR)\fe-protocol3.obj"
    -@erase "$(INTDIR)\fe-connect.obj"
    -@erase "$(INTDIR)\fe-exec.obj"
    -@erase "$(INTDIR)\fe-lobj.obj"
    -@erase "$(INTDIR)\fe-misc.obj"
    -@erase "$(INTDIR)\fe-print.obj"
    -@erase "$(INTDIR)\fe-secure.obj"
    -@erase "$(INTDIR)\pqexpbuffer.obj"
    -@erase "$(OUTDIR)\libpqdll.obj"
    -@erase "$(OUTDIR)\win32.obj"
    -@erase "$(INTDIR)\wchar.obj"
    -@erase "$(INTDIR)\encnames.obj"
        -@erase "$(INTDIR)\noblock.obj"
        -@erase "$(INTDIR)\pgstrcasecmp.obj"
    -@erase "$(OUTDIR)\libpq.res"
    -@erase "$(OUTDIR)\blibpq.lib"
    -@erase "$(OUTDIR)\blibpqdll.lib"
    -@erase "$(OUTDIR)\blibpq.dll"
    -@erase "$(OUTDIR)\blibpq.tds"

config: ..\..\include\pg_config.h pthread.h pg_config_paths.h

..\..\include\pg_config.h: ..\..\include\pg_config.h.win32
    copy ..\..\include\pg_config.h.win32 ..\..\include\pg_config.h

pthread.h: pthread.h.win32
    copy pthread.h.win32 pthread.h

pg_config_paths.h: win32.mak
    echo #define SYSCONFDIR "" >pg_config_paths.h

"$(OUTDIR)" :
    @if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)"

"$(OUTDIR)\blibpq.dll": "$(OUTDIR)\blibpq.lib" $(LINK32_OBJS) "$(INTDIR)\libpq.res" blibpqdll.def 
    $(LINK32) @&&!
    $(LINK32_FLAGS) +
        c0d32.obj $(LINK32_OBJS), +
    $@,, +
        "$(OUTDIR)\blibpq.lib" import32.lib cw32mti.lib, +
    blibpqdll.def,"$(INTDIR)\libpq.res"
!
    implib -w "$(OUTDIR)\blibpqdll.lib" blibpqdll.def $@

"$(INTDIR)\libpq.res" : "$(INTDIR)" libpq.rc
    $(RSC) $(RSC_PROJ) libpq.rc

"$(OUTDIR)\blibpq.lib": $(LIB32_OBJS)
    $(LIB32) $@ @&&!
+-"$(**: =" &^
+-")"
!


.c.obj:
    $(CPP) -o"$(INTDIR)\$&" $(CPP_PROJ) $<

#ifndef __win32_h_included
#define __win32_h_included

/*
 * Some compatibility functions
 */
#ifdef __BORLANDC__
#define _timeb timeb
#define _ftime(a) ftime(a)
#define _errno errno
#define popen(a,b) _popen(a,b)
#else
/* open provided elsewhere */
#define close(a) _close(a)
#define read(a,b,c) _read(a,b,c)
#define write(a,b,c) _write(a,b,c)
#endif

#define vsnprintf(a,b,c,d) _vsnprintf(a,b,c,d)
#define snprintf _snprintf

#undef EAGAIN                    /* doesn't apply on sockets */
#undef EINTR
#define EINTR WSAEINTR
#define EWOULDBLOCK WSAEWOULDBLOCK
#define ECONNRESET WSAECONNRESET
#define EINPROGRESS WSAEINPROGRESS

/*
 * support for handling Windows Socket errors
 */
extern const char *winsock_strerror(int err, char *strerrbuf, size_t buflen);

#endif

Re: Borland c++ compile problems...

From
Bruce Momjian
Date:
Your patch has been added to the PostgreSQL unapplied patches list at:

    http://momjian.postgresql.org/cgi-bin/pgpatches

It will be applied as soon as one of the PostgreSQL committers reviews
and approves it.

---------------------------------------------------------------------------


Steve Holdoway wrote:
> Bruce Momjian wrote:
>
> >Steve Holdoway wrote:
> >
> >
> >>Bruce Momjian wrote:
> >>
> >>
> >>
> >>>Steve Holdoway wrote:
> >>>
> >>>
> >>>
> >>>
> >>>>Sorry to be a pest, and all that. However, it looks like make needs to
> >>>>be run in src\port, to create pg_config_paths.h, and compile stuff to
> >>>>resolve externals _set_noblock, _pg_strcasecmp, _pg_tolower, and _popen
> >>>>(? bit worried about that one!)
> >>>>
> >>>>I had a go at rewriting an existing bcc32.mak, but just seemed to
> >>>>generate more errors!
> >>>>
> >>>>
> >>>>
> >>>>
> >>>Uh, I don't see how those would fail.  What errors are you seeing?
> >>>
> >>>
> >>>
> >>>
> >>>
> >>Well, in the port subdirectory, one of the things that is generated by
> >>the makefile is pg_config_paths.h. Without this, libpq will not compile.
> >>As I stated above, cobbling this together manually then gets me to the
> >>place where the aforementioned external references are not resolved. All
> >>are in source files in the port directory.
> >>
> >>The errors I'm seeing are all caused by includes not being found, etc. I
> >>don't know what to do when they are ones like strings.h, which I do not
> >>have either in the snapshot source tree, or in the Borland bcc 5.5 tree.
> >>
> >>I also don't know how you want the above files building... into a
> >>library, static or dynamic/straight object code, etc. There is also no
> >>listing in the current bcc32.mak files to include them into the libpq
> >>dll generation.
> >>
> >>
> >
> >OK, if you look at the last few commits to interfaces/libpq/win32.mak,
> >you will see changes for pg_config_paths.h and for thread safety.  Can
> >you look at those changes, merge them into bcc.mak.  There might be
> >other changes in there you want to add to bcc.mak too.
> >
> >
> >
> OK, having no M$ diff, I attach files src\interfaces\libpq\bcc32.mak and
> src\interfaces\libpq\win32.h
>
> bcc32.mak incorporates the changes in win32.mak, and adds a couple of
> extra source files from the ..\..\port directory, and win32.h was used
> to #define popen -> _popen.
>
> All seems to work after a *very* cursory test!
>
> Can I get back to the land of proper slashes now???
>
> Cheers,
>
> Steve

> # Makefile for Borland C++ 5.5
>
> # Will build a Win32 static library libpq.lib
> #        and a Win32 dynamic library libpq.dll with import library libpqdll.lib
>
> # Borland C++ base install directory goes here
> BCB=c:\Borland\Bcc55
>
> !MESSAGE Building the Win32 DLL and Static Library...
> !MESSAGE
> !IF "$(CFG)" == ""
> CFG=Release
> !MESSAGE No configuration specified. Defaulting to Release.
> !MESSAGE
> !ELSE
> !MESSAGE Configuration "$(CFG)"
> !MESSAGE
> !ENDIF
>
> !IF "$(CFG)" != "Release" && "$(CFG)" != "Debug"
> !MESSAGE Invalid configuration "$(CFG)" specified.
> !MESSAGE You can specify a configuration when running MAKE
> !MESSAGE by defining the macro CFG on the command line. For example:
> !MESSAGE
> !MESSAGE make  -DCFG=[Release | Debug] /f bcc32.mak
> !MESSAGE
> !MESSAGE Possible choices for configuration are:
> !MESSAGE
> !MESSAGE "Release" (Win32 Release DLL and Static Library)
> !MESSAGE "Debug" (Win32 Debug DLL and Static Library)
> !MESSAGE
> !ERROR An invalid configuration was specified.
> !ENDIF
>
> !IF "$(OS)" == "Windows_NT"
> NULL=
> !ELSE
> NULL=nul
> !ENDIF
>
> !IF "$(CFG)" == "Debug"
> DEBUG=1
> OUTDIR=.\Debug
> INTDIR=.\Debug
> !else
> OUTDIR=.\Release
> INTDIR=.\Release
> !endif
>
> USERDEFINES=FRONTEND;NDEBUG;WIN32;_WINDOWS;HAVE_VSNPRINTF;HAVE_STRDUP;
>
> CPP=bcc32.exe
> CPP_PROJ = -I$(BCB)\include;..\..\include -WD -c -D$(USERDEFINES) -tWM \
>         -a8 -X -w-use -w-par -w-pia -w-csu -w-aus -w-ccc
>
> !IFDEF DEBUG
> CPP_PROJ    = $(CPP_PROJ) -Od -r- -k -v -y -vi- -D_DEBUG
> !else
> CPP_PROJ        = $(CPP_PROJ) -O -Oi -OS -DNDEBU
> !endif
>
> LIB32=tlib.exe
> LIB32_FLAGS=
> LIB32_OBJS= \
>     "$(OUTDIR)\win32.obj" \
>     "$(INTDIR)\getaddrinfo.obj" \
>     "$(INTDIR)\thread.obj" \
>     "$(INTDIR)\inet_aton.obj" \
>     "$(INTDIR)\crypt.obj" \
>     "$(INTDIR)\path.obj" \
>         "$(INTDIR)\noblock.obj" \
>         "$(INTDIR)\pgstrcasecmp.obj" \
>     "$(INTDIR)\dllist.obj" \
>     "$(INTDIR)\md5.obj" \
>     "$(INTDIR)\ip.obj" \
>     "$(INTDIR)\fe-auth.obj" \
>     "$(INTDIR)\fe-protocol2.obj" \
>     "$(INTDIR)\fe-protocol3.obj" \
>     "$(INTDIR)\fe-connect.obj" \
>     "$(INTDIR)\fe-exec.obj" \
>     "$(INTDIR)\fe-lobj.obj" \
>     "$(INTDIR)\fe-misc.obj" \
>     "$(INTDIR)\fe-print.obj" \
>     "$(INTDIR)\fe-secure.obj" \
>     "$(INTDIR)\pqexpbuffer.obj" \
>     "$(INTDIR)\wchar.obj" \
>         "$(INTDIR)\encnames.obj"
>
>
> RSC=brcc32.exe
> RSC_PROJ=-l 0x409 -i$(BCB)\include -fo"$(INTDIR)\libpq.res"
>
> LINK32=ilink32.exe
> LINK32_FLAGS = -Gn -L$(BCB)\lib;$(INTDIR); -x -Tpd -v
> LINK32_OBJS= "$(INTDIR)\libpqdll.obj"
>
> # ---------------------------------------------------------------------------
>
> .path.obj = $(INTDIR)
> .path.c = .;..\..\port;..\..\backend\libpq;..\..\backend\lib;..\..\backend\utils\mb
>
> # ---------------------------------------------------------------------------
>
> ALL: config "$(OUTDIR)" "$(OUTDIR)\blibpq.dll" "$(OUTDIR)\blibpq.lib"
>
> CLEAN :
>     -@erase "$(INTDIR)\getaddrinfo.obj"
>     -@erase "$(INTDIR)\thread.obj"
>     -@erase "$(INTDIR)\inet_aton.obj"
>     -@erase "$(INTDIR)\crypt.obj"
>     -@erase "$(INTDIR)\path.obj"
>     -@erase "$(INTDIR)\dllist.obj"
>     -@erase "$(INTDIR)\md5.obj"
>     -@erase "$(INTDIR)\ip.obj"
>     -@erase "$(INTDIR)\fe-auth.obj"
>     -@erase "$(INTDIR)\fe-protocol2.obj"
>     -@erase "$(INTDIR)\fe-protocol3.obj"
>     -@erase "$(INTDIR)\fe-connect.obj"
>     -@erase "$(INTDIR)\fe-exec.obj"
>     -@erase "$(INTDIR)\fe-lobj.obj"
>     -@erase "$(INTDIR)\fe-misc.obj"
>     -@erase "$(INTDIR)\fe-print.obj"
>     -@erase "$(INTDIR)\fe-secure.obj"
>     -@erase "$(INTDIR)\pqexpbuffer.obj"
>     -@erase "$(OUTDIR)\libpqdll.obj"
>     -@erase "$(OUTDIR)\win32.obj"
>     -@erase "$(INTDIR)\wchar.obj"
>     -@erase "$(INTDIR)\encnames.obj"
>         -@erase "$(INTDIR)\noblock.obj"
>         -@erase "$(INTDIR)\pgstrcasecmp.obj"
>     -@erase "$(OUTDIR)\libpq.res"
>     -@erase "$(OUTDIR)\blibpq.lib"
>     -@erase "$(OUTDIR)\blibpqdll.lib"
>     -@erase "$(OUTDIR)\blibpq.dll"
>     -@erase "$(OUTDIR)\blibpq.tds"
>
> config: ..\..\include\pg_config.h pthread.h pg_config_paths.h
>
> ..\..\include\pg_config.h: ..\..\include\pg_config.h.win32
>     copy ..\..\include\pg_config.h.win32 ..\..\include\pg_config.h
>
> pthread.h: pthread.h.win32
>     copy pthread.h.win32 pthread.h
>
> pg_config_paths.h: win32.mak
>     echo #define SYSCONFDIR "" >pg_config_paths.h
>
> "$(OUTDIR)" :
>     @if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)"
>
> "$(OUTDIR)\blibpq.dll": "$(OUTDIR)\blibpq.lib" $(LINK32_OBJS) "$(INTDIR)\libpq.res" blibpqdll.def
>     $(LINK32) @&&!
>     $(LINK32_FLAGS) +
>         c0d32.obj $(LINK32_OBJS), +
>     $@,, +
>         "$(OUTDIR)\blibpq.lib" import32.lib cw32mti.lib, +
>     blibpqdll.def,"$(INTDIR)\libpq.res"
> !
>     implib -w "$(OUTDIR)\blibpqdll.lib" blibpqdll.def $@
>
> "$(INTDIR)\libpq.res" : "$(INTDIR)" libpq.rc
>     $(RSC) $(RSC_PROJ) libpq.rc
>
> "$(OUTDIR)\blibpq.lib": $(LIB32_OBJS)
>     $(LIB32) $@ @&&!
> +-"$(**: =" &^
> +-")"
> !
>
>
> .c.obj:
>     $(CPP) -o"$(INTDIR)\$&" $(CPP_PROJ) $<
>


>
> ---------------------------(end of broadcast)---------------------------
> TIP 3: if posting/reading through Usenet, please send an appropriate
>       subscribe-nomail command to majordomo@postgresql.org so that your
>       message can get through to the mailing list cleanly

--
  Bruce Momjian                        |  http://candle.pha.pa.us
  pgman@candle.pha.pa.us               |  (610) 359-1001
  +  If your life is a hard drive,     |  13 Roberts Road
  +  Christ can be your backup.        |  Newtown Square, Pennsylvania 19073

Re: Borland c++ compile problems...

From
Bruce Momjian
Date:
I have not heard back from you so I removed the parts of your patch which
looked wrong and have applied the attached version of the patch.

---------------------------------------------------------------------------

Steve Holdoway wrote:
> Bruce Momjian wrote:
> 
> >Steve Holdoway wrote:
> >  
> >
> >>Bruce Momjian wrote:
> >>
> >>    
> >>
> >>>Steve Holdoway wrote:
> >>> 
> >>>
> >>>      
> >>>
> >>>>Sorry to be a pest, and all that. However, it looks like make needs to 
> >>>>be run in src\port, to create pg_config_paths.h, and compile stuff to 
> >>>>resolve externals _set_noblock, _pg_strcasecmp, _pg_tolower, and _popen 
> >>>>(? bit worried about that one!)
> >>>>
> >>>>I had a go at rewriting an existing bcc32.mak, but just seemed to 
> >>>>generate more errors!
> >>>>   
> >>>>
> >>>>        
> >>>>
> >>>Uh, I don't see how those would fail.  What errors are you seeing?
> >>>
> >>> 
> >>>
> >>>      
> >>>
> >>Well, in the port subdirectory, one of the things that is generated by 
> >>the makefile is pg_config_paths.h. Without this, libpq will not compile. 
> >>As I stated above, cobbling this together manually then gets me to the 
> >>place where the aforementioned external references are not resolved. All 
> >>are in source files in the port directory.
> >>
> >>The errors I'm seeing are all caused by includes not being found, etc. I 
> >>don't know what to do when they are ones like strings.h, which I do not 
> >>have either in the snapshot source tree, or in the Borland bcc 5.5 tree.
> >>
> >>I also don't know how you want the above files building... into a 
> >>library, static or dynamic/straight object code, etc. There is also no 
> >>listing in the current bcc32.mak files to include them into the libpq 
> >>dll generation.
> >>    
> >>
> >
> >OK, if you look at the last few commits to interfaces/libpq/win32.mak,
> >you will see changes for pg_config_paths.h and for thread safety.  Can
> >you look at those changes, merge them into bcc.mak.  There might be
> >other changes in there you want to add to bcc.mak too.
> >
> >  
> >
> OK, having no M$ diff, I attach files src\interfaces\libpq\bcc32.mak and 
> src\interfaces\libpq\win32.h
> 
> bcc32.mak incorporates the changes in win32.mak, and adds a couple of 
> extra source files from the ..\..\port directory, and win32.h was used 
> to #define popen -> _popen.
> 
> All seems to work after a *very* cursory test!
> 
> Can I get back to the land of proper slashes now???
> 
> Cheers,
> 
> Steve

> # Makefile for Borland C++ 5.5
> 
> # Will build a Win32 static library libpq.lib
> #        and a Win32 dynamic library libpq.dll with import library libpqdll.lib
> 
> # Borland C++ base install directory goes here
> BCB=c:\Borland\Bcc55
> 
> !MESSAGE Building the Win32 DLL and Static Library...
> !MESSAGE
> !IF "$(CFG)" == ""
> CFG=Release
> !MESSAGE No configuration specified. Defaulting to Release.
> !MESSAGE
> !ELSE
> !MESSAGE Configuration "$(CFG)"
> !MESSAGE
> !ENDIF
> 
> !IF "$(CFG)" != "Release" && "$(CFG)" != "Debug"
> !MESSAGE Invalid configuration "$(CFG)" specified.
> !MESSAGE You can specify a configuration when running MAKE
> !MESSAGE by defining the macro CFG on the command line. For example:
> !MESSAGE
> !MESSAGE make  -DCFG=[Release | Debug] /f bcc32.mak
> !MESSAGE
> !MESSAGE Possible choices for configuration are:
> !MESSAGE
> !MESSAGE "Release" (Win32 Release DLL and Static Library)
> !MESSAGE "Debug" (Win32 Debug DLL and Static Library)
> !MESSAGE
> !ERROR An invalid configuration was specified.
> !ENDIF
> 
> !IF "$(OS)" == "Windows_NT"
> NULL=
> !ELSE 
> NULL=nul
> !ENDIF 
> 
> !IF "$(CFG)" == "Debug"
> DEBUG=1
> OUTDIR=.\Debug
> INTDIR=.\Debug
> !else
> OUTDIR=.\Release
> INTDIR=.\Release
> !endif
> 
> USERDEFINES=FRONTEND;NDEBUG;WIN32;_WINDOWS;HAVE_VSNPRINTF;HAVE_STRDUP;
> 
> CPP=bcc32.exe
> CPP_PROJ = -I$(BCB)\include;..\..\include -WD -c -D$(USERDEFINES) -tWM \
>         -a8 -X -w-use -w-par -w-pia -w-csu -w-aus -w-ccc
> 
> !IFDEF DEBUG
> CPP_PROJ    = $(CPP_PROJ) -Od -r- -k -v -y -vi- -D_DEBUG
> !else
> CPP_PROJ        = $(CPP_PROJ) -O -Oi -OS -DNDEBU
> !endif
> 
> LIB32=tlib.exe
> LIB32_FLAGS= 
> LIB32_OBJS= \
>     "$(OUTDIR)\win32.obj" \
>     "$(INTDIR)\getaddrinfo.obj" \
>     "$(INTDIR)\thread.obj" \
>     "$(INTDIR)\inet_aton.obj" \
>     "$(INTDIR)\crypt.obj" \
>     "$(INTDIR)\path.obj" \
>         "$(INTDIR)\noblock.obj" \
>         "$(INTDIR)\pgstrcasecmp.obj" \
>     "$(INTDIR)\dllist.obj" \
>     "$(INTDIR)\md5.obj" \
>     "$(INTDIR)\ip.obj" \
>     "$(INTDIR)\fe-auth.obj" \
>     "$(INTDIR)\fe-protocol2.obj" \
>     "$(INTDIR)\fe-protocol3.obj" \
>     "$(INTDIR)\fe-connect.obj" \
>     "$(INTDIR)\fe-exec.obj" \
>     "$(INTDIR)\fe-lobj.obj" \
>     "$(INTDIR)\fe-misc.obj" \
>     "$(INTDIR)\fe-print.obj" \
>     "$(INTDIR)\fe-secure.obj" \
>     "$(INTDIR)\pqexpbuffer.obj" \
>     "$(INTDIR)\wchar.obj" \
>         "$(INTDIR)\encnames.obj"
> 
> 
> RSC=brcc32.exe
> RSC_PROJ=-l 0x409 -i$(BCB)\include -fo"$(INTDIR)\libpq.res"
> 
> LINK32=ilink32.exe
> LINK32_FLAGS = -Gn -L$(BCB)\lib;$(INTDIR); -x -Tpd -v
> LINK32_OBJS= "$(INTDIR)\libpqdll.obj"
>     
> # ---------------------------------------------------------------------------
> 
> .path.obj = $(INTDIR)
> .path.c = .;..\..\port;..\..\backend\libpq;..\..\backend\lib;..\..\backend\utils\mb
> 
> # ---------------------------------------------------------------------------
> 
> ALL: config "$(OUTDIR)" "$(OUTDIR)\blibpq.dll" "$(OUTDIR)\blibpq.lib"
> 
> CLEAN :
>     -@erase "$(INTDIR)\getaddrinfo.obj"
>     -@erase "$(INTDIR)\thread.obj"
>     -@erase "$(INTDIR)\inet_aton.obj"
>     -@erase "$(INTDIR)\crypt.obj"
>     -@erase "$(INTDIR)\path.obj"
>     -@erase "$(INTDIR)\dllist.obj"
>     -@erase "$(INTDIR)\md5.obj"
>     -@erase "$(INTDIR)\ip.obj"
>     -@erase "$(INTDIR)\fe-auth.obj"
>     -@erase "$(INTDIR)\fe-protocol2.obj"
>     -@erase "$(INTDIR)\fe-protocol3.obj"
>     -@erase "$(INTDIR)\fe-connect.obj"
>     -@erase "$(INTDIR)\fe-exec.obj"
>     -@erase "$(INTDIR)\fe-lobj.obj"
>     -@erase "$(INTDIR)\fe-misc.obj"
>     -@erase "$(INTDIR)\fe-print.obj"
>     -@erase "$(INTDIR)\fe-secure.obj"
>     -@erase "$(INTDIR)\pqexpbuffer.obj"
>     -@erase "$(OUTDIR)\libpqdll.obj"
>     -@erase "$(OUTDIR)\win32.obj"
>     -@erase "$(INTDIR)\wchar.obj"
>     -@erase "$(INTDIR)\encnames.obj"
>         -@erase "$(INTDIR)\noblock.obj"
>         -@erase "$(INTDIR)\pgstrcasecmp.obj"
>     -@erase "$(OUTDIR)\libpq.res"
>     -@erase "$(OUTDIR)\blibpq.lib"
>     -@erase "$(OUTDIR)\blibpqdll.lib"
>     -@erase "$(OUTDIR)\blibpq.dll"
>     -@erase "$(OUTDIR)\blibpq.tds"
> 
> config: ..\..\include\pg_config.h pthread.h pg_config_paths.h
> 
> ..\..\include\pg_config.h: ..\..\include\pg_config.h.win32
>     copy ..\..\include\pg_config.h.win32 ..\..\include\pg_config.h
> 
> pthread.h: pthread.h.win32
>     copy pthread.h.win32 pthread.h
> 
> pg_config_paths.h: win32.mak
>     echo #define SYSCONFDIR "" >pg_config_paths.h
> 
> "$(OUTDIR)" :
>     @if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)"
> 
> "$(OUTDIR)\blibpq.dll": "$(OUTDIR)\blibpq.lib" $(LINK32_OBJS) "$(INTDIR)\libpq.res" blibpqdll.def 
>     $(LINK32) @&&!
>     $(LINK32_FLAGS) +
>         c0d32.obj $(LINK32_OBJS), +
>     $@,, +
>         "$(OUTDIR)\blibpq.lib" import32.lib cw32mti.lib, +
>     blibpqdll.def,"$(INTDIR)\libpq.res"
> !
>     implib -w "$(OUTDIR)\blibpqdll.lib" blibpqdll.def $@
> 
> "$(INTDIR)\libpq.res" : "$(INTDIR)" libpq.rc
>     $(RSC) $(RSC_PROJ) libpq.rc
> 
> "$(OUTDIR)\blibpq.lib": $(LIB32_OBJS)
>     $(LIB32) $@ @&&!
> +-"$(**: =" &^
> +-")"
> !
> 
> 
> .c.obj:
>     $(CPP) -o"$(INTDIR)\$&" $(CPP_PROJ) $<
> 


> 
> ---------------------------(end of broadcast)---------------------------
> TIP 3: if posting/reading through Usenet, please send an appropriate
>       subscribe-nomail command to majordomo@postgresql.org so that your
>       message can get through to the mailing list cleanly

-- 
  Bruce Momjian                        |  http://candle.pha.pa.us
  pgman@candle.pha.pa.us               |  (610) 359-1001
  +  If your life is a hard drive,     |  13 Roberts Road
  +  Christ can be your backup.        |  Newtown Square, Pennsylvania 19073
*** bcc32.mak    Sun Nov 30 01:01:15 2003
--- /users/pgman/bcc32.mak    Sun Jul 25 21:57:20 2004
***************
*** 68,73 ****
--- 68,75 ----
      "$(INTDIR)\inet_aton.obj" \
      "$(INTDIR)\crypt.obj" \
      "$(INTDIR)\path.obj" \
+     "$(INTDIR)\noblock.obj" \
+     "$(INTDIR)\pgstrcasecmp.obj" \
      "$(INTDIR)\dllist.obj" \
      "$(INTDIR)\md5.obj" \
      "$(INTDIR)\ip.obj" \
***************
*** 82,88 ****
      "$(INTDIR)\fe-secure.obj" \
      "$(INTDIR)\pqexpbuffer.obj" \
      "$(INTDIR)\wchar.obj" \
!     "$(INTDIR)\encnames.obj"
  
  RSC=brcc32.exe
  RSC_PROJ=-l 0x409 -i$(BCB)\include -fo"$(INTDIR)\libpq.res"
--- 84,91 ----
      "$(INTDIR)\fe-secure.obj" \
      "$(INTDIR)\pqexpbuffer.obj" \
      "$(INTDIR)\wchar.obj" \
!     "$(INTDIR)\encnames.obj"
! 
  
  RSC=brcc32.exe
  RSC_PROJ=-l 0x409 -i$(BCB)\include -fo"$(INTDIR)\libpq.res"
***************
*** 98,104 ****
  
  # ---------------------------------------------------------------------------
  
! ALL: "$(OUTDIR)" "$(OUTDIR)\blibpq.dll" "$(OUTDIR)\blibpq.lib"
  
  CLEAN :
      -@erase "$(INTDIR)\getaddrinfo.obj"
--- 101,107 ----
  
  # ---------------------------------------------------------------------------
  
! ALL: config "$(OUTDIR)" "$(OUTDIR)\blibpq.dll" "$(OUTDIR)\blibpq.lib"
  
  CLEAN :
      -@erase "$(INTDIR)\getaddrinfo.obj"
***************
*** 123,134 ****
--- 126,149 ----
      -@erase "$(OUTDIR)\win32.obj"
      -@erase "$(INTDIR)\wchar.obj"
      -@erase "$(INTDIR)\encnames.obj"
+     -@erase "$(INTDIR)\noblock.obj"
+     -@erase "$(INTDIR)\pgstrcasecmp.obj"
      -@erase "$(OUTDIR)\libpq.res"
      -@erase "$(OUTDIR)\blibpq.lib"
      -@erase "$(OUTDIR)\blibpqdll.lib"
      -@erase "$(OUTDIR)\blibpq.dll"
      -@erase "$(OUTDIR)\blibpq.tds"
  
+ config: ..\..\include\pg_config.h pthread.h pg_config_paths.h
+ 
+ ..\..\include\pg_config.h: ..\..\include\pg_config.h.win32
+     copy ..\..\include\pg_config.h.win32 ..\..\include\pg_config.h
+ 
+ pthread.h: pthread.h.win32
+     copy pthread.h.win32 pthread.h
+ 
+ pg_config_paths.h: win32.mak
+     echo #define SYSCONFDIR "" >pg_config_paths.h
  
  "$(OUTDIR)" :
      @if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)"
***************
*** 136,144 ****
  "$(OUTDIR)\blibpq.dll": "$(OUTDIR)\blibpq.lib" $(LINK32_OBJS) "$(INTDIR)\libpq.res" blibpqdll.def 
      $(LINK32) @&&!
      $(LINK32_FLAGS) +
!     c0d32.obj $(LINK32_OBJS), +
      $@,, +
!     "$(OUTDIR)\blibpq.lib" import32.lib cw32mti.lib, +
      blibpqdll.def,"$(INTDIR)\libpq.res"
  !
      implib -w "$(OUTDIR)\blibpqdll.lib" blibpqdll.def $@
--- 151,159 ----
  "$(OUTDIR)\blibpq.dll": "$(OUTDIR)\blibpq.lib" $(LINK32_OBJS) "$(INTDIR)\libpq.res" blibpqdll.def 
      $(LINK32) @&&!
      $(LINK32_FLAGS) +
!     c0d32.obj $(LINK32_OBJS), +
      $@,, +
!     "$(OUTDIR)\blibpq.lib" import32.lib cw32mti.lib, +
      blibpqdll.def,"$(INTDIR)\libpq.res"
  !
      implib -w "$(OUTDIR)\blibpqdll.lib" blibpqdll.def $@
***************
*** 151,156 ****
--- 166,172 ----
  +-"$(**: =" &^
  +-")"
  !
+ 
  
  .c.obj:
      $(CPP) -o"$(INTDIR)\$&" $(CPP_PROJ) $<
*** win32.h    Thu May  6 20:57:59 2004
--- /users/pgman/win32.h    Sun Jul 25 21:57:26 2004
***************
*** 8,13 ****
--- 8,14 ----
  #define _timeb timeb
  #define _ftime(a) ftime(a)
  #define _errno errno
+ #define popen(a,b) _popen(a,b)
  #else
  /* open provided elsewhere */
  #define close(a) _close(a)