|
On Wed, 15 Mar 2000, Bale, Dan wrote: > I searched for "stream file" and did not find any reference in the ILE-RPG > manuals. Will I just have to output to a regular flatfile with, say, a > record length of 500, output one record per print line and use CPYTOSTMF? "Stream File" is more of a concept than anything else. What you probably want to search for is "Integrated File System" or "IFS". You can write data directly to a stream file using the API's for IFS that are described in the "Unix-Type API's" manual. Unfortunately, I think they only explain how to use the API's in C, not RPG. (but, what else is new, right?) The "Who Knew You Could Do That . . ." Redbook does give RPG examples. You can find this online at: http://www.redbooks.ibm.com/abstracts/sg245402.html Or, if you want a quick example, heres the same example I always give as a quick example :) * TO COMPILE: * CRTBNDRPG PGM(xxxxx) SRCFILE(xxx/xxxx) DFTACTGRP(*NO) ACTGRP(*NEW) * D********************************************************************** D* Flags for use in open() D* D* More than one can be used -- add them together. D********************************************************************** D* Reading Only D O_RDONLY C 1 D* Writing Only D O_WRONLY C 2 D* Reading & Writing D O_RDWR C 4 D* Create File if not exist D O_CREAT C 8 D* Exclusively create D O_EXCL C 16 D* Truncate File to 0 bytes D O_TRUNC C 64 D* Append to File D O_APPEND C 256 D* Convert text by code-page D O_CODEPAGE C 8388608 D* Open in text-mode D O_TEXTDATA C 16777216 D********************************************************************** D* Mode Flags. D* basically, the mode parm of open(), creat(), chmod(),etc D* uses 9 least significant bits to determine the D* file's mode. (peoples access rights to the file) D* D* user: owner group other D* access: R W X R W X R W X D* bit: 8 7 6 5 4 3 2 1 0 D* D* (This is accomplished by adding the flags below to get the mode) D********************************************************************** D* owner authority D S_IRUSR C 256 D S_IWUSR C 128 D S_IXUSR C 64 D S_IRWXU C 448 D* group authority D S_IRGRP C 32 D S_IWGRP C 16 D S_IXGRP C 8 D S_IRWXG C 56 D* other people D S_IROTH C 4 D S_IWOTH C 2 D S_IXOTH C 1 D S_IRWXO C 7 D********************************************************************** D* "whence" constants for use with lseek() D********************************************************************** D SEEK_SET C CONST(0) D SEEK_CUR C CONST(1) D SEEK_END C CONST(2) D* ascii code-page D CP_ASCII C 819 D*-------------------------------------------------------------------- D* Open a File D* D* int open(const char *path, int oflag, . . .); D*-------------------------------------------------------------------- D open PR 10I 0 ExtProc('open') D filename * value D openflags 10I 0 value D mode 10U 0 value options(*nopass) D codepage 10U 0 value options(*nopass) D*-------------------------------------------------------------------- D* Read From a File D* D* ssize_t read(int handle, void *buffer, size_t bytes); D*-------------------------------------------------------------------- D read PR 10I 0 ExtProc('read') D handle 10i 0 value D buffer * value D bytes 10U 0 value D*-------------------------------------------------------------------- D* Write to a file D* D* ssize_t write(int fildes, const void *buf, size_t bytes) D*-------------------------------------------------------------------- D write PR 10I 0 ExtProc('write') D handle 10I 0 value D buffer * value D bytes 10U 0 value D*-------------------------------------------------------------------- D* Close a file D* D* int close(int fildes) D*-------------------------------------------------------------------- D close PR 10I 0 ExtProc('close') D handle 10I 0 value D*-------------------------------------------------------------------- D* Set File Read/Write Offset D* D* off_t lseek(int fildes, off_t offset, int whence) D*-------------------------------------------------------------------- D lseek PR 10I 0 ExtProc('lseek') D fildes 10I 0 value D offset 10I 0 value D whence 10I 0 value D filename S 64A D p_filename S * INZ(%addr(filename)) D oflag S 10U 0 D omode S 10U 0 D buffer S 128A D p_Buffer s * INZ(%addr(buffer)) D buflen S 10U 0 D fd S 10I 0 c exsr MakeFile c exsr WriteFile c exsr ReadFile c eval *INLR = *On C*=============================================================== C* This creates a file with an ASCII codepage. C* C* By creating it with a codepage, and then closing it C* again, we assign it a codepage. C* C* Next time we open it, we can use O_TEXTDATA which will C* make it automatically translate from this jobs codepage C* (whatever it happens to be) to ASCII. C*=============================================================== csr MakeFile begsr C*----------------------- C* make filename c eval filename = '/QOpenSys/test.file' + x'00' C* set open flags to "create" for "read/write" with a codepage. c eval oflag = O_CREAT+O_RDWR + O_CODEPAGE C* set mode to User=RW, Group=R, Other=R (RW-R--R--) c eval omode = S_IRUSR+S_IWUSR+S_IRGRP+S_IROTH c eval fd = open(p_filename: oflag: omode: c CP_ASCII) c if fd < 0 c eval Msg = 'Cant create file!' c dsply Msg 50 c eval *INLR = *On c Return c endif c callp close(fd) C*----------------------- csr endsr C*=============================================================== C* This opens the file and writes some data into it. C* C* We use O_TEXTDATA when we open the file so it will translate C* whatever we write to whichever codepage was assigned to the C* file when it was created... C* C* Note that we use x'0D25' which when translated to ASCII will C* become CR/LF, the correct end-of-line for a DOS/Windows file C*=============================================================== csr WriteFile begsr C*----------------------- c eval fd = open(p_filename: O_RDWR+O_TEXTDATA) c if fd < 0 c eval Msg = 'Cant open file to write to it.' c dsply Msg c eval *INLR = *On c Return c endif c eval Buffer = 'This data will be written as - c ASCII data.' + x'0D25' c ' ' checkr Buffer BufLen c if write(fd: p_buffer: BufLen) < 0 c eval Msg = 'write() failed!' c dsply Msg c eval *INLR = *On c Return c endif c callp close(fd) C*----------------------- csr endsr C*=============================================================== C* This opens the file and reads the data inside. C* C* Again, we use O_TEXTDATA to convert the data to our codepage C* C* Before displaying the text, we strip off the end-of-line stuff C*=============================================================== csr ReadFile begsr C*----------------------- c eval fd = open(p_filename: O_RDWR+O_TEXTDATA) c if fd < 0 c eval Msg = 'Cant open file to read from it.' c dsply Msg c eval *INLR = *On c Return c endif c eval buffer = *blanks c if read(fd: p_buffer: BufLen) < 0 c eval Msg = 'read() failed!' c dsply Msg c eval *INLR = *On c Return c endif c x'0D25' scan Buffer pos 2 0 c eval Msg = %subst(Buffer:1:pos-1) c dsply Msg c callp close(fd) C*----------------------- csr endsr +--- | This is the RPG/400 Mailing List! | To submit a new message, send your mail to RPG400-L@midrange.com. | To subscribe to this list send email to RPG400-L-SUB@midrange.com. | To unsubscribe from this list send email to RPG400-L-UNSUB@midrange.com. | Questions should be directed to the list owner/operator: david@midrange.com +---
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.