Копирует в буфер одну строку из заданного файла, начиная с текущей позиции в файле.
unsigned int _FGets(FCHAN chan, char FAR *buffer, int maxlen) FCHAN chan; /* Канал файла с которого копируем. */ char FAR *buffer; /* Адрес буфера. */ int maxlen; /*Максимальная длина строки в байтах. */ |
Примечания
_FGets( ) копирует строку длиной maxlen, заканчивающуюся возвратом каретки. Возврат каретки транслируется в нуль-символ, служащий признаком окончания строки, и сохраняется в буфере. Переводы строки игнорируются и не заносятся в буфер. _FGets( ) возвращает число байтов, скопированных в буфер.
Для получения дополнительной информации о том, как создавать библиотеку API и интегрировать её в Visual FoxPro, смотрите Доступ к API Visual FoxPro.
Пример
В следующем примере открывается файл, заданный параметром, а затем каждая его строка копируется и выводится на экран.
Код Visual FoxPro
Copy Code | |
|---|---|
SET LIBRARY TO FGETS
fc = FCREATE("x", 0)
= FPUTS(fc, REPL("X", 512), 512)
= FCLOSE(fc)
= XFGETS("x")
DELETE FILE x | |
Код C
Copy Code | |
|---|---|
#include <pro_ext.h>
#define BUFFSIZE 256
static char lineBuffer[BUFFSIZE];
void putLong(long n)
{
Value val;
val.ev_type = 'I';
val.ev_long = n;
val.ev_width = 10;
_PutValue(&val);
}
FAR Example(ParamBlk FAR *parm)
{
FCHAN fchan;
// Null terminate file name
if (!_SetHandSize(parm->p[0].val.ev_handle,
parm->p[0].val.ev_length+1))
{
_Error(182); // "Insufficient memory"
}
_HLock(parm->p[0].val.ev_handle);
((char FAR *) _HandToPtr(parm->p[0].val.ev_handle))
[parm->p[0].val.ev_length] = '\0';
if ((fchan=_FOpen((char FAR*)_HandToPtr(parm->p[0].val.ev_handle),
FC_NORMAL)) < 0)
{
_UserError("Could not open file.");
}
_HUnLock(parm->p[0].val.ev_handle);
while (!_FEOF(fchan))
{
_FGets(fchan, lineBuffer, BUFFSIZE);
_PutStr(lineBuffer); _PutChr('\n');
}
_FClose(fchan);
}
FoxInfo myFoxInfo[] = {
{"XFGETS", (FPFI) Example, 1, "C"},
};
FoxTable _FoxTable = {
(FoxTable FAR *) 0, sizeof(myFoxInfo)/sizeof(FoxInfo), myFoxInfo
}; | |
Смотрите также
Справочное руководство
Процедура библиотеки API _FRead( )Процедура библиотеки API _FSeek( )
Прочие ресурсы
Конструкции библиотеки APIДоступ к API Visual FoxPro