* contrib/directx/w32_ddrw.cpp
* contrib/directx/w32_ddrw.h
! Cleanup, formatting.
! Tabs converted to spaces.
* contrib/libnf/aading.prg
* contrib/libnf/aavg.prg
* contrib/libnf/acctadj.prg
* contrib/libnf/acctmnth.prg
* contrib/libnf/acctqtr.prg
* contrib/libnf/acctweek.prg
* contrib/libnf/acctyear.prg
* contrib/libnf/adessort.prg
* contrib/libnf/aemaxlen.prg
* contrib/libnf/aeminlen.prg
* contrib/libnf/amedian.prg
* contrib/libnf/anomatch.prg
* contrib/libnf/any2any.prg
* contrib/libnf/aredit.prg
* contrib/libnf/asum.prg
* contrib/libnf/at2.prg
* contrib/libnf/bitclr.prg
* contrib/libnf/bitset.prg
* contrib/libnf/blink.prg
* contrib/libnf/byt2bit.prg
* contrib/libnf/byt2hex.prg
* contrib/libnf/byteand.prg
* contrib/libnf/byteneg.prg
* contrib/libnf/bytenot.prg
* contrib/libnf/byteor.prg
* contrib/libnf/bytexor.prg
* contrib/libnf/calendar.prg
* contrib/libnf/clrsel.prg
* contrib/libnf/cntryset.prg
* contrib/libnf/d2e.prg
* contrib/libnf/datecnfg.prg
* contrib/libnf/dayofyr.prg
* contrib/libnf/daytobow.prg
* contrib/libnf/dectobin.prg
* contrib/libnf/descend.c
* contrib/libnf/dfile.prg
* contrib/libnf/dhkey.h
* contrib/libnf/diskfunc.prg
* contrib/libnf/dispmsg.prg
* contrib/libnf/dosver.prg
* contrib/libnf/e2d.prg
* contrib/libnf/easter.prg
* contrib/libnf/elapmil.prg
* contrib/libnf/elapsed.prg
* contrib/libnf/eltime.prg
* contrib/libnf/findith.prg
* contrib/libnf/firstday.prg
* contrib/libnf/floptst.prg
* contrib/libnf/ftattr.c
* contrib/libnf/ftint86.ch
* contrib/libnf/ftmenuto.ch
* contrib/libnf/fttext.c
* contrib/libnf/gcd.prg
* contrib/libnf/getenvrn.c
* contrib/libnf/getver.c
* contrib/libnf/getvid.c
* contrib/libnf/hex2dec.prg
* contrib/libnf/idle.c
* contrib/libnf/invclr.prg
* contrib/libnf/isbit.prg
* contrib/libnf/isbiton.prg
* contrib/libnf/isshare.prg
* contrib/libnf/kspeed.c
* contrib/libnf/lastday.prg
* contrib/libnf/linked.prg
* contrib/libnf/madd.prg
* contrib/libnf/menu1.prg
* contrib/libnf/menuto.prg
* contrib/libnf/metaph.prg
* contrib/libnf/miltime.prg
* contrib/libnf/min2dhm.prg
* contrib/libnf/month.prg
* contrib/libnf/mouse.c
* contrib/libnf/mouse1.prg
* contrib/libnf/mouse2.prg
* contrib/libnf/netpv.prg
* contrib/libnf/nooccur.prg
* contrib/libnf/ntow.prg
* contrib/libnf/nwlstat.prg
* contrib/libnf/nwsem.prg
* contrib/libnf/nwuid.prg
* contrib/libnf/ontick.c
* contrib/libnf/origin.c
* contrib/libnf/page.prg
* contrib/libnf/pchr.prg
* contrib/libnf/peek.c
* contrib/libnf/pegs.prg
* contrib/libnf/pending.prg
* contrib/libnf/pickday.prg
* contrib/libnf/poke.c
* contrib/libnf/popadder.prg
* contrib/libnf/prtesc.prg
* contrib/libnf/prtscr.c
* contrib/libnf/pvid.prg
* contrib/libnf/qtr.prg
* contrib/libnf/rand1.prg
* contrib/libnf/readme.txt
* contrib/libnf/restsets.prg
* contrib/libnf/round.prg
* contrib/libnf/savearr.prg
* contrib/libnf/savesets.prg
* contrib/libnf/scancode.prg
* contrib/libnf/scregion.prg
* contrib/libnf/setdate.prg
* contrib/libnf/settime.prg
* contrib/libnf/sinkey.prg
* contrib/libnf/sleep.prg
* contrib/libnf/sqzn.prg
* contrib/libnf/sysmem.prg
* contrib/libnf/tbwhile.prg
* contrib/libnf/test.prg
* contrib/libnf/vertmenu.prg
* contrib/libnf/vidcur.prg
* contrib/libnf/vidmode.prg
* contrib/libnf/wda.prg
* contrib/libnf/week.prg
* contrib/libnf/workdays.prg
* contrib/libnf/woy.prg
* contrib/libnf/xbox.prg
* contrib/libnf/year.prg
- contrib/libnf/idle.c
+ contrib/libnf/ftidle.c
+ contrib/libnf/iamidle.c
* contrib/libnf/Makefile
* contrib/libnf/makefile.bc
* contrib/libnf/makefile.vc
+ Added svn headers.
! Fixed FT_IDLE()
! Renamed idle.c to not clash with core idle.obj.
! FT_F*() functions fully ported from original NFLIB.
Pls test.
* Some minor cleanups, formatting.
* include/filesys.api
! _fsRead(), _fsWrite() now more compatible.
* include/hbundoc.api
+ Added _lcopy(), _ncopyuc(), _ncopylc() compatibility
functions.
* include/hbapi.h
* source/common/hbstr.c
+ Added hb_strncpyLower()
270 lines
7.5 KiB
C
270 lines
7.5 KiB
C
/*
|
|
* $Id$
|
|
*/
|
|
|
|
/*
|
|
* File......: GETENVRN.C
|
|
* Author....: Rick Whitt
|
|
* CIS ID....: 70672,605
|
|
*
|
|
* This is an original work by Rick Whitt and is placed in the
|
|
* public domain.
|
|
*
|
|
* Modification history:
|
|
* ---------------------
|
|
* Rev 1.2a 09 Sep 1996 JO
|
|
* Added underscore prefix to environ() calls for MSC 8.0
|
|
* Note: 5.2e version will work if linked with MSC OldNames.lib
|
|
*
|
|
* Rev 1.2 01 Jan 1996 03:01:00 TED
|
|
* Added prototypes to kill compiler warning.
|
|
*
|
|
* Rev 1.1 15 Aug 1991 23:08:42 GLENN
|
|
* Forest Belt proofread/edited/cleaned up doc
|
|
*
|
|
* Rev 1.0 17 Jul 1991 22:08:12 GLENN
|
|
* Initial revision.
|
|
*
|
|
*/
|
|
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* FT_GETE()
|
|
* $CATEGORY$
|
|
* Environment
|
|
* $ONELINER$
|
|
* Return the entire current environment
|
|
* $SYNTAX$
|
|
* FT_GETE( [ @<xReceiveVar> ] ) -> nNumStrings
|
|
* $ARGUMENTS$
|
|
* <xReceiveVar> is the variable to receive the environment data.
|
|
*
|
|
* <xReceiveVar> can be a character type variable, in which case
|
|
* the function will place all environment strings in the variable
|
|
* separated by carriage return/line feeds (chr 13 + chr(10)).
|
|
*
|
|
* <xReceiveVar> can be an array type, in which case the function
|
|
* will place each string in an array element. The array MUST be
|
|
* declared with the proper number of elements prior to passing it
|
|
* to the function. This can be done by calling FT_GETE() without
|
|
* parameters first to get the number of strings in the environment.
|
|
*
|
|
* Note that the argument MUST be passed by reference. Since arrays
|
|
* are by nature passed by reference, the "@" symbol is optional when
|
|
* passing an array.
|
|
*
|
|
* If no argument is passed, FT_GETE() merely returns the number
|
|
* of strings in the environment.
|
|
* $RETURNS$
|
|
* FT_GETE() returns the total number of strings found in the
|
|
* current program's environment.
|
|
* $DESCRIPTION$
|
|
* This function stores ALL of the current program's environment
|
|
* variables in either a block of text lines or in an array. It is
|
|
* useful for looking at the entire environment at once, or recording
|
|
* a snapshot of it to a file for later inspection, such as when a
|
|
* program error occurs. If the value of ONE SPECIFIC variable is
|
|
* desired, use Clipper's built-in GETE() function.
|
|
*
|
|
* This function uses the undocumented internal variable "_environ",
|
|
* as well as the functions _strcpy(), _strcat(), and _strlen() from
|
|
* CLIPPER.LIB
|
|
* $EXAMPLES$
|
|
* Get the environment in text form and browse it:
|
|
*
|
|
* cEnvBlock := ""
|
|
* nNumStrings := FT_GETE(@cEnvBlock)
|
|
* @ 0, 0 to MAXROW() - 1, MAXCOL()
|
|
* @ MAXROW(), 0 say 'Browse strings, press ESC to exit...'
|
|
* MEMOWRIT(cEnvBlock, 1, 1, MAXROW() - 2,MAXCOL() - 1, .F.)
|
|
*
|
|
* Get the environment in text form and write it to a file:
|
|
*
|
|
* cEnvBlock := ""
|
|
* FT_GETE(@cEnvBlock)
|
|
* MEMOWRIT("ENVIRON.TXT", cEnvBlock)
|
|
*
|
|
* Get the environment in Array form:
|
|
*
|
|
* aEnvArray := ARRAY(FT_GETE())
|
|
* FT_GETE(aEnvArray)
|
|
* ? aEnvArray[1] // "COMSPEC=C:\COMMAND.COM"
|
|
* ? aEnvArray[2] // "PATH=C:\;C:\DOS;C:\UTIL;C:\CLIP50\BIN"
|
|
* ... etc ...
|
|
* $END$
|
|
*/
|
|
|
|
/* NOTE: we need this to prevent base types redefinition */
|
|
/*
|
|
#define _CLIPDEFS_H
|
|
#include "extend.api"
|
|
#include "fm.api"
|
|
*/
|
|
#include "hbapi.h"
|
|
|
|
#if defined(OS_UNIX_COMPATIBLE)
|
|
# include <unistd.h>
|
|
# if defined( HB_OS_DARWIN )
|
|
# include <crt_externs.h>
|
|
# define environ (*_NSGetEnviron())
|
|
# elif !defined( __WATCOMC__ )
|
|
extern char **environ;
|
|
# endif
|
|
#elif defined(HB_OS_DOS)
|
|
# define environ _environ
|
|
extern char **_environ;
|
|
#elif defined(HB_OS_WIN_32)
|
|
# include <windows.h>
|
|
#endif
|
|
|
|
#define NORETURN 0
|
|
#define CHARTYPE 1
|
|
#define ARRAYTYPE 2
|
|
#define CRLF "\x0D\x0A"
|
|
/*
|
|
unsigned int strlen( char * );
|
|
char * strcpy( char *, char * );
|
|
char * strcat( char *, char * );
|
|
*/
|
|
HB_FUNC( FT_GETE )
|
|
{
|
|
/* INTERNALS WARNING: All references to 'environ', strlen(), ;
|
|
strcpy(), and strcat() are undocumented Clipper 5.0 internals.
|
|
*/
|
|
#if defined(HB_OS_DOS) || defined(OS_UNIX_COMPATIBLE)
|
|
{
|
|
|
|
char *buffer = NULL;
|
|
int x;
|
|
int buffsize = 0;
|
|
int rettype = NORETURN;
|
|
|
|
if( ISCHAR( 1 ) )
|
|
rettype = CHARTYPE;
|
|
if( ISARRAY( 1 ) )
|
|
rettype = ARRAYTYPE;
|
|
|
|
/* scan strings first and add up total size */
|
|
if( rettype == CHARTYPE )
|
|
{
|
|
for( x = 0; environ[x]; x++ )
|
|
{
|
|
/* add length of this string plus 2 for the crlf */
|
|
buffsize += ( strlen( environ[x] ) + 2 );
|
|
}
|
|
/* add 1 more byte for final nul character */
|
|
buffsize++;
|
|
/* now allocate that much memory and make sure 1st byte is a nul */
|
|
buffer = ( char * ) hb_xalloc( buffsize + 1 );
|
|
buffer[0] = '\0';
|
|
}
|
|
|
|
for( x = 0; environ[x]; x++ )
|
|
{
|
|
if( !environ[x] )
|
|
/* null string, we're done */
|
|
break;
|
|
|
|
if( rettype == CHARTYPE )
|
|
{
|
|
/* tack string onto end of buffer */
|
|
strcat( buffer, environ[x] );
|
|
/* add crlf at end of each string */
|
|
strcat( buffer, CRLF );
|
|
}
|
|
else if( rettype == ARRAYTYPE )
|
|
/* store string to next array element */
|
|
hb_storc( environ[x], 1, x + 1 );
|
|
}
|
|
|
|
if( rettype == CHARTYPE )
|
|
{
|
|
/* return buffer to app and free memory */
|
|
hb_storc( buffer, 1 );
|
|
hb_xfree( buffer );
|
|
}
|
|
|
|
/* return number of strings found */
|
|
hb_retni( x );
|
|
}
|
|
#elif defined(HB_OS_WIN_32)
|
|
{
|
|
|
|
|
|
char *buffer = NULL;
|
|
LPVOID lpEnviron = GetEnvironmentStringsA();
|
|
char *sCurEnv;
|
|
int x;
|
|
int buffsize = 0;
|
|
int rettype = NORETURN;
|
|
|
|
if( ISCHAR( 1 ) )
|
|
rettype = CHARTYPE;
|
|
if( ISARRAY( 1 ) )
|
|
rettype = ARRAYTYPE;
|
|
|
|
if( rettype == CHARTYPE )
|
|
/* scan strings first and add up total size */
|
|
{
|
|
for( sCurEnv = ( LPSTR ) lpEnviron; *sCurEnv; sCurEnv++ )
|
|
{
|
|
|
|
{
|
|
if( !*sCurEnv )
|
|
/* null string, we're done */
|
|
break;
|
|
/* add length of this string plus 2 for the crlf */
|
|
buffsize += ( strlen( ( char * ) sCurEnv ) + 2 );
|
|
}
|
|
/* add 1 more byte for final nul character */
|
|
buffsize++;
|
|
|
|
/* now allocate that much memory and make sure 1st byte is a nul */
|
|
buffer = ( char * ) hb_xalloc( buffsize );
|
|
strcpy( buffer, "\0" );
|
|
while( *sCurEnv )
|
|
sCurEnv++;
|
|
}
|
|
}
|
|
x = 0;
|
|
for( sCurEnv = ( LPSTR ) lpEnviron; *sCurEnv; sCurEnv++ )
|
|
{
|
|
|
|
|
|
if( !*sCurEnv )
|
|
/* null string, we're done */
|
|
break;
|
|
|
|
if( rettype == CHARTYPE )
|
|
{
|
|
/* tack string onto end of buffer */
|
|
strcat( buffer, ( char * ) sCurEnv );
|
|
/* add crlf at end of each string */
|
|
strcat( buffer, CRLF );
|
|
}
|
|
|
|
if( rettype == ARRAYTYPE )
|
|
/* store string to next array element */
|
|
hb_storc( ( char * ) sCurEnv, 1, x + 1 );
|
|
x++;
|
|
while( *sCurEnv )
|
|
sCurEnv++;
|
|
}
|
|
|
|
if( rettype == CHARTYPE )
|
|
{
|
|
/* return buffer to app and free memory */
|
|
hb_storc( buffer, 1 );
|
|
hb_xfree( buffer );
|
|
}
|
|
|
|
/* return number of strings found */
|
|
hb_retni( x );
|
|
|
|
FreeEnvironmentStrings( ( LPTSTR ) lpEnviron );
|
|
}
|
|
|
|
#endif
|
|
}
|