|
That is in incredible example of mixed coding. My gosh, that's nasty stuff (nothing personal). But you go to the trouble of using the /FREE as well as embedded SQL and then you use a fixed-format CALL. Guess what your problem is... it is the fixed format call. You can't pass a varying length field to QCMDEXC using the fixed format call. You'd have to prototype QCMDEXC and specify CONST for the parms, then you can use CALLP and pass the varying length field without a problem. Bob Cozzi Cozzi Consulting www.rpgiv.com -----Original Message----- From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of fkany@xxxxxxxxxxxxxxxxxx Sent: Friday, May 30, 2003 2:08 PM To: RPG400-L@xxxxxxxxxxxx Subject: Maximum size for Varying length field Is there a maximum size for a program field when using the Varying keyword? I get an error message when the program below trys to execute the call to QCMDEXC in the SNDEMAIL subroutine. The error message says something about how the varying length field might be too long. This is my first program using embedded SQL. Did I code it right? I tried following the "Using SQL in RPG Programs: An Introduction" guide by Susan M. Gantner from Partner400. I like the guide. I'm going to keep it around awhile until I get more familiar with using embedded SQL. TIA, Frank ****************************************************************** * * FAX log file FQAFFTLOG IF E DISK * D WKLOOP01 S 1A * D P1DATE S 8A D P1FAXNBR S 12A D P1USER S 10A D P1EMAIL S 40A VARYING * D DATE S 8A D FAXNBR S 12A D USER S 10A D STATUS S 1A * D CMDPART1 S 29A D CMDPART2 S 8A D CMDPART3 S 9A D CMDPART4 S 1A D EMAILSUBJ S 31A D EMAILBODY S 245A * D COUNTER S 4S 0 * D AS400CMD S 500A VARYING D CMDLENGTH S 15P 5 * D AS400CMD2 S 10 D CMDLENGTH2 S 15P 5 * * --------------------- * Start Main Processing * --------------------- C EXSR MAINPRCS * * ------------------- * End Main Processing * ------------------- C EVAL *INLR = *ON C RETURN * ****************************************************************** * Main Processing Subroutine * ****************************************************************** C MAINPRCS BEGSR * * C EVAL COUNTER = *ZEROS C EVAL WKLOOP01 = 'Y' C DOU WKLOOP01 = 'N' * * Only Process a Maximum of 4 times C EVAL COUNTER = COUNTER + 1 C IF COUNTER >= 4 C EXSR SNDEMAIL C LEAVE C ENDIF * * Wait 3 minutes C EVAL AS400CMD2 = 'DLYJOB 180' C EVAL CMDLENGTH2 = 10 C CALL 'QCMDEXC' CMDPARMS2 * * Find row from table(QAFFTLOG) C/EXEC SQL C+ SELECT QFCDAT, QFDEST, QFUSER, QFSU C+ INTO :DATE, :FAXNBR, :USER, :STATUS C+ FROM QFAX/QAFFTLOG C+ WHERE QFCDAT = :P1DATE AND QFDEST = :P1FAXNBR AND C+ QFUSER = :P1USER C/END-EXEC * * Did NOT find Row; Process again C IF STATUS = *BLANK C ITER C ENDIF * * Fax Successful C IF STATUS = 'S' C LEAVE C ENDIF * * Fax Unsuccessful C IF STATUS = 'U' C EXSR SNDEMAIL C LEAVE C ENDIF * C ENDDO * C ENDSR * ****************************************************************** * SNDEMAIL - Sends "Failed Fax" Email to User ****************************************************************** C SNDEMAIL BEGSR * /FREE CMDPART1 = 'SNDDST TYPE(*LMSG) TOINTNET(('; CMDPART2 = ')) DSTD('; CMDPART3 = ') LONGMSG('; CMDPART4 = ')'; EMAILSUBJ = 'Your Fax to' + '(' + %SUBST(P1FAXNBR:3:3) + ')' + %SUBST(P1FAXNBR:6:3) + '-' + %SUBST(P1FAXNBR:9:4) + ' Failed'; EMAILBODY = 'Your Fax to' + '(' + %SUBST(P1FAXNBR:3:3) + ')' + %SUBST(P1FAXNBR:6:3) + '-' + %SUBST(P1FAXNBR:9:4) + ' Failed. ' + 'Call the customer and ask if they have ' + 'received the fax you had tried to send. If not,'+ ' make sure the fax number is correct. Then ' + 'resubmit the fax through the same program that ' + 'it was sent or detach the copies that were sent '+ 'to your email address and print them out and ' + 'fax them manually.'; AS400CMD = CMDPART1 + P1EMAIL + CMDPART2 + EMAILSUBJ + CMDPART3 + EMAILBODY + CMDPART4; CMDLENGTH = %LEN(%TRIM(AS400CMD)); /END-FREE * C CALL 'QCMDEXC' CMDPARMS * C ENDSR * ****************************************************************** * *INZSR ****************************************************************** C *INZSR BEGSR * C *ENTRY PLIST C PARM P1DATE C PARM P1FAXNBR C PARM P1USER C PARM P1EMAIL * C CMDPARMS PLIST C PARM AS400CMD C PARM CMDLENGTH * C CMDPARMS2 PLIST C PARM AS400CMD2 C PARM CMDLENGTH2 * C ENDSR * ****************************************************************** _______________________________________________ This is the RPG programming on the AS400 / iSeries (RPG400-L) mailing list To post a message email: RPG400-L@xxxxxxxxxxxx To subscribe, unsubscribe, or change list options, visit: http://lists.midrange.com/mailman/listinfo/rpg400-l or email: RPG400-L-request@xxxxxxxxxxxx Before posting, please take a moment to review the archives at http://archive.midrange.com/rpg400-l.
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.