-
Notifications
You must be signed in to change notification settings - Fork 4
hb_P
-
hb_PathJoin(
<cPathAbsolute>, <cPathRelative>
) ➜ cResultPath
attempts to, safely, join the given paths to form a unified one.
If<cPathRelative>
is not string the returned value is null string""
otherwise,
returns:<cPathRelative>
when it includes a drive letter or starts with a path delimiter (e.g.:\/
) or when<cPathAbsolute>
is empty or not path or not string;
otherwise,
returns:<cPathAbsolute>
properly joined with the<cPathRelelative>
at the end. Both paths should be ending with path-separators, in order to be joined correctly. (to ensure this, use hb_DirSepAdd() if needed). -
hb_PathNormalize(
<cPath>
) ➜ cNormalizedPath -
hb_PathRelativize(
<cPathBase>, <cPathTarget>, <lForceRelative>
) ➜ cRelativizedPath -
hb_PCodeVer()➜ cPCodeVersion
compatibility function. please see/use hb_Version( HB_VERSION_PCODE_VER ). -
hb_PIsByRef(
<nParam>
) ➜ lIsByRef
returns.T.
if thenParam
is passed by reference.nParam
is the number indicating the position of a parameter in the parameter list passed to the function where the check is being done.
-
hb_PRead(
<nPipeHandle>, <@cBuffer>, [<nBytes>], [<nTimeOut>]
) ➜ nBytesRead
It can be used for unblocking read from pipes, i.e. using handles returned byhb_processOpen()
function.<nPipeHandle>
is pipe read handle,<cBuffer>
is string variable passed by reference with read buffer,<nBytes>
is maximum number of bytes which can be read,<nTimeOut>
is timeout in milliseconds to wait for data to read;
this function returns when at least one byte can be read. Returned<nBytesRead>
is number of bytes read from the pipe. On error return-1
. -
hb_processClose(
<hProcess> , [lGentle]
) ➜ lSuccess
closes an opened process. -
hb_processOpen(
<cCommand>, [ @<cStdIn> ], [ @<cStdOut> ], [ @<cStdErr> ], [ <lDetach> ], [@PID]
) ➜ hProcess -
hb_ProcessRun(
<cCommand>, [ <cStdIn> ], [ @<cStdOut> ], [ @<cStdErr> ], [ <lDetach> ]
) ➜ nResult
attempts to execute<cCommand>
(i.e. an external application or O/S command) and stores its output to<cStdOut>
and<cStdErr>
variables (they must be passed by reference).
It's possible to merge stdout and stderr output by using for 3rd and 4th parameters the same variable, for example:nResult := hb_processRun( cCommand,, @cOutErr, @cOutErr )
see also: hb_Run() -
hb_processValue(
<hProcess> , [lWait]
) ➜ nStatus
returns the status (exit code? - OS error?) of<hProcess>
process.
[note: on Windows platform, to obtain the status, this function uses internally the WaitForSingleObject function. See also the source-code of the function, that might (possibly) help to get a more accurate idea about the returned value].
-
hb_ProgName() ➜ cExeName
returns the executable program name. -
hb_ps() ➜ OSpathSepator
returns the character used as path separator; usually backslash\
on Windows, slash/
on *nixes. -
hb_PValue(
<nParam> [, <uNewValue> ]
) ➜ uValue
returns the value passed in the<nParam>
parameter and optionally assigns a new value to it. It returns the current parameter value (which may not necessarily be the original value passed). -
hb_PWrite(
<nPipeHandle>, <cBuffer>, [<nBytes>], [<nTimeOut>]
) ➜ nBytesWritten
TODO: hb_PathNormalize(), hb_PathRelativize()
Harbour Functions Dictionary Many of the entries presented in this wiki, have been obtained from various sources (see References); however, a good number of them have been written «from scratch» (or rewritten/corrected), particularly those referring to newer Harbour functions. Anyway, it's a 'work in progress', so there might be omissions, oversights and / or errors. That said, any suggestion/correction/comment are more than welcome --many thanks, to those few who already have made contributions!
Harbour exclusive functions | Clipper compatible functions |
---|---|
hb_A | A |
hb_B | B |
hb_C | C |
hb_D | D |
hb_E | E |
hb_F | F |
hb_G | G |
hb_H | H |
hb_I | I |
hb_J_K | J K |
hb_L | L |
hb_M | M |
hb_N_O | N O |
hb_P | P |
hb_R | Q R |
hb_S | S |
hb_T | T |
hb_U | U |
hb_V | V W |
hb_W | X Y |
- Contrib. Libraries
HBWIN WinAPI Library | Compress Libraries |
HBHPDF Library (Haru) | Multi Threading |
Harbour Socket API | hbCT (Cl*pper tools) |
Serial API | hbNF (NanForum library) |
HBCURL cURL API Library | Mini-XML docs |
-
praeterea lectio...
Miscellaneous Readings