.\" This manpage has been automatically generated by docbook2man .\" from a DocBook document. This tool can be found at: .\" .\" Please send any bug reports, improvements, comments, patches, .\" etc. to Steve Cheng . .TH "GFS_PIO_READLINE" "3" "13 May 2004" "Gfarm" "" .SH NAME gfs_pio_readline \- read one line .SH SYNOPSIS .sp \fB#include .sp char *gfs_pio_readline (GFS_File \fIf\fB, char **\fIbufp\fB, size_t *\fIsizep\fB, size_t *\fIlenp\fB); \fR .SH "DESCRIPTION" .PP \fBgfs_pio_readline()\fR reads one line from the file specified by the parameter \fIgf\fR. .PP Parameter \fIbufp\fR specifies an address of a pointer variable initialzed by NULL at first. \fBgfs_pio_readline()\fR allocates a buffer for I/O dynamically, and stores the address of the buffer to this variable pointed by \fIbufp\fR. Parameter \fIsizep\fR specifies an address of a size_t variable initialized by 0. This size_t variable is used to record the size of the buffer. Or, you can specify a buffer allocated by malloc(3) in the variable pointed by the parameter \fIbufp\fR. In this case, you have to specify the size of the allocated buffer by the parameter \fIsizep\fR. If the length of the line exceeds the size of the buffer, the buffer will be automatically realloc(3)ed, and the variable pointed by \fIbufp\fR and \fIsizep\fR will be updated respectively. Note that you are responsible to free(3) this buffer. .PP This function returns the length of the line to a variable pointed by the parameter \fIlenp\fR. This length includes newline character. .PP Just like gfs_pio_gets(3), this function doesn't remove newline character at the end of lines. Also, this function always appends '\\0' at the end of strings. You can deal with lines which include '\\0' character by using the variable pointed by the parameter \fIlenp\fR. .PP If the file reaches its end, the length of the result string becomes 0. .PP This function is equivalent to gfs_pio_readdelim(f, bufp, sizep, lenp, "\\n", 1). .SH "RETURN VALUES" .TP \fBNULL\fR The function terminated successfully. .TP \fBGFARM_ERR_NO_MEMORY\fR Insufficient memory was available. Note that you need to free(3) the buffer pointed by the parameter \fIbufp\fR .TP \fBOthers\fR An error except the above occurred. The reason is shown by its pointed strings. .SH "EXAMPLES" .SS "EXAMPLE OF GFS_PIO_READLINE FUNCTION" .PP .nf #include #include #include int main(int argc, char **argv) { char *e; GFS_File gf; size_t bufsize = 0, len; char *buffer = NULL; e = gfarm_initialize(&argc, &argv); if (e != NULL) { fprintf(stderr, "gfarm_initialize: %s\\n", e); return (EXIT_FAILURE); } if (argc <= 1) { fprintf(stderr, "missing gfarm filename\\n"); return (EXIT_FAILURE); } e = gfs_pio_open(argv[1], GFARM_FILE_RDONLY, &gf); if (e != NULL) { fprintf(stderr, "%s: %s\\n", argv[1], e); return (EXIT_FAILURE); } e = gfs_pio_set_view_global(gf, 0); if (e != NULL) { fprintf(stderr, "%s: gfs_pio_set_view_global: %s\\n", argv[1], e); return (EXIT_FAILURE); } while ((e = gfs_pio_readline(gf, &buffer, &bufsize, &len)) == NULL && len > 0) { printf("<%6d/%6d >%s", len, bufsize, buffer); } if (buffer != NULL) free(buffer); if (e != NULL) { fprintf(stderr, "ERROR: %s\\n", e); return (EXIT_FAILURE); } e = gfs_pio_close(gf); if (e != NULL) { fprintf(stderr, "gfs_pio_close: %s\\n", e); return (EXIT_FAILURE); } e = gfarm_terminate(); if (e != NULL) { fprintf(stderr, "gfarm_initialize: %s\\n", e); return (EXIT_FAILURE); } return (EXIT_SUCCESS); } .fi .SH "SEE ALSO" .PP \fBgfs_pio_open\fR(3), \fBgfs_pio_getline\fR(3), \fBgfs_pio_gets\fR(3), \fBgfs_pio_readdelim\fR(3)