RPG
Aus informatikvs
Version vom 4. Mai 2017, 13:56 Uhr von Informatikvs (Diskussion | Beiträge) (→Datum - Monatsletzten ermitteln)
- Raten - Programmieren - Gewinnen
- Role - Play - Game
- Report - Program - Generator
Inhaltsverzeichnis
Dekodieren Unicode- / Character-Feld
0000.00 **************************************************************/ 0027.00 h CCSID(*GRAPH : *SRC) 0028.00 h CCSID(*UCS2 : 1200) 0029.00 h CCSID(*CHAR : *JOBRUN) 0030.00 h alwnull(*usrctl) 0031.00 h option(*NoDebugIo:*SrcStmt) ... 0131.00 **************************************************************/ 0132.00 d $256UNIC S 256C CCSID(1200) 0133.00 d $256CHAR S 256A 0134.00 **************************************************************/ ... 0179.00 c Clear $256UNIC 0180.00 c Eval $256UNIC = mytstuc 0181.00 c Eval $256CHAR = $256UNIC 0182.00 c Eval myt2tch = $256CHAR 0183.00 c Clear $256UNIC 0184.00 c Eval $256CHAR = mytstch 0185.00 c Eval $256UNIC = $256CHAR 0186.00 c Eval myt2tuc = $256UNIC ... 0999.00 //**************************************************************/
Datum - Monatsletzten ermitteln
0061.00 //**************************************************************/ 0062.00 BegSr §Ultimo; 0063.00 #Ultimo = %date(); // '2015-03-30' 0064.00 #Ultimo = #Ultimo - %days(%subdt(#Ultimo : *days)-1); // '2015-03-01' 0065.00 #Ultimo = #Ultimo + %months(1); // '2015-04-01' 0066.00 #Ultimo = #Ultimo - %days(1); // '2015-03-31' 0067.00 #Brain = %diff(#ultimo:D'1899-12-30':*days); // 42094 0069.00 EndSr; 0070.00 //**************************************************************/
== mehr Datum == <pre> 0033.00 /free 0034.00 //**************************************************************/ 0035.00 BegSr §Datum; 0036.00 #Date = %date('2016-07-01') + %months(1); 0037.00 #Brain = %diff(#Date:D'1899-12-30':*days); 0038.00 #char2 = %char(%subdt(%date(): *months)); 0039.00 #char4 = %char(%subdt(%date(): *years)); 0040.00 #char8a= %char(%date() : *iso0); 0041.00 #char8b= %char(%date() : *dmy.); 0042.00 #char10= %char(%date() : *iso); 0043.00 #dec6s0= %dec(%date() : *dmy); 0044.00 #dec8s0= %dec(%date() : *iso); 0045.00 #Brain = %diff(%date():D'1899-12-30':*days); 0046.00 #Date = D'1899-12-30' + %days(#Brain); 0047.00 #Date = %date(151224 : *ymd); 0048.00 #Date = %date(20151224 : *iso); 0049.00 #Date = %date('151224' : *ymd0); 0050.00 #Date = %date('20151224' : *iso0); 0051.00 #Date = %date('18.12.14' : *dmy.); 0052.00 #Ultimo = %date(); // '2015-03-30' 0053.00 #Ultimo = #Ultimo - %days(%subdt(#Ultimo : *days)-1); // '2015-03-01' 0054.00 #Ultimo = #Ultimo + %months(1); // '2015-04-01' 0055.00 #Ultimo = #Ultimo - %days(1); // '2015-03-31' 0056.00 #Brain = %diff(#ultimo:D'1899-12-30':*days); // 42094 0057.00 EndSr; 0058.00 //**************************************************************/
Embedded SQL programming
//**************************************************************/ ... exec sql set option commit=*NONE, closqlcsr=*ENDMOD, dlyprp=*YES; ... Exec Sql select v7tgtx into :#feld from v7tabgld where v7apid = 'KW' and v7tbnr = 363 and v7tgid = : #tgid and v7spcd = : #spcd fetch first 1 rows only; If SqlCode = 100; #feld = *blanks; Exec Sql insert into v7tabgld (V7APID, V7TBNR, V7TGID, V7SPCD, V7TGTX) Values('KW', 363, :#tgid, :#spcd, :#FELD); ElseIf SqlCode <> 0; #feld = 'sqlcode: ' + %char(sqlcode); dsply(e) #feld; Endif; ... Exec Sql update v7tabgld set v7tgtx = :#feld where v7apid = 'KW' and v7tbnr = 363 and v7tgid = : #tgid and v7spcd = : #spcd; If SqlCode <> 0; #Feld = 'Fehler beim Update ' + %char(sqlcode); dsply(e) #Feld; Endif; ... //**************************************************************/
Zebra Etikett drucken
0001.00 ***************************************************************** 0002.00 h dftname(hszebrac) 0003.00 h decedit('0,') datedit(*ymd.) 0004.00 h datfmt(*iso) timfmt(*iso) 0005.00 h Option(*NoDebugIo:*SrcStmt) 0006.00 /IF DEFINED(*CRTBNDRPG) 0007.00 h dftactgrp(*no) 0008.00 /ENDIF 0009.00 ***************************************************************** 0010.00 ***************************************************************** 0011.00 * Druckerdatei um Kartonkleber auf Zebradrucker zu drucken 0012.00 * CRTPRTF FILE(LEHRBIB/HSZEBRA) DEVTYPE(*LINE) 0013.00 Fhszebra O F 100 Printer UsrOpn 0014.00 ***************************************************************** 0015.00 d sprintf PR 10i 0 ExtProc('sprintf') 0016.00 d * Value 0017.00 d * Value Options(*string:*nopass) 0018.00 d * Value Options(*string:*nopass) 0019.00 d * Value Options(*string:*nopass) 0020.00 d * Value Options(*string:*nopass) 0021.00 d system PR 10i 0 ExtProc('system') 0022.00 d * Value Options(*string) 0023.00 ***************************************************************** 0024.00 d DrZeile# s 90a 0025.00 d AnzEti# s 5u 0 inz(1) 0026.00 d #dots c 'N,40,55' 0027.00 d #name s 30a 0028.00 d x s 5u 0 0029.00 d #col s like(x) 0030.00 d #row s like(x) 0031.00 ***************************************************************** 0032.00 0033.00 c ExSr Drck2Zebra 0034.00 0035.00 c Eval *inlr = *On 0036.00 c Return 0037.00 ***************************************************************** 0038.00 /free 0039.00 //************************************************************** 0040.00 //*** 0041.00 //************************************************************** 0042.00 BegSr Drck2Zebra; 0043.00 DrZeile# = 'ovrprtf file(HSZEBRA) HOLD(*YES) OUTQ(*JOB)'; 0044.00 If (system(%trim(%trim(DrZeile#))) <> 0); 0045.00 Dsply 'Fehler beim Ovrprtf !'; 0046.00 LeaveSr; 0047.00 EndIf; 0048.00 open HSZEBRA; 0049.00 0050.00 // Kleber initialisieren 0051.00 DrZeile# = '^XA' // start format 0052.00 + '^CFD' // alphanum. Font "D" 0053.00 + '^FWN' // Feld nicht drehen 0054.00 + '^LH0,0' // label home position 0055.00 + '^LRN' // nicht revers drucken 0056.00 + '^MD0' // Schwärzung wie Druckerdefault 0057.00 + '^MMT' // Vorschub nach Druck 0058.00 + '^MNY' // seperate Etiketten 0059.00 + '^MTT' // Thermotransfer-Etiketten 0060.00 + '^PMN' // nicht horizontal spiegeln 0061.00 + '^PON' // nicht auf den Kopf 0062.00 + '^PQ' // Druckqualität 0063.00 + %char(AnzEti#) 0064.00 + ',0,1,Y' // keine Pause, one replicate??, pause 0065.00 + '^PR2'; // langsam drucken 0066.00 Except DrZeile; 0067.00 0068.00 //*** 6 Adressaufkleber für Max Müller in 2 Spalten *** 0069.00 #row = 0; 0070.00 For x=1 to 9; 0071.00 #row += 50; 0072.00 If %rem(x+3 : 3) = 1; 0073.00 #name = 'Max Müller'; 0074.00 #row += 50; 0075.00 ElseIf %rem(x+3 : 3) = 2; 0076.00 #name = 'Maximilianstraße 1'; 0077.00 Else; 0078.00 #name = '80539 München'; 0079.00 EndIf; 0080.00 ExSr EineZeile; 0081.00 EndFor; 0082.00 0083.00 DrZeile# = '^XA'; 0084.00 Except DrZeile; 0085.00 EndSr; 0086.00 0087.00 //************************************************************** 0088.00 BegSr EineZeile; 0089.00 DrZeile# = ''; 0090.00 #col = 100; 0091.00 sprintf( %addr(DrZeile#) 0092.00 : '^A0%s^FO%s^FD%s^FS' 0093.00 : #dots 0094.00 : %char(#col)+','+%char(#row) 0095.00 : %trim(#name) 0096.00 ); 0097.00 Except DrZeile; 0098.00 DrZeile# = ''; 0099.00 #col = 800; 0100.00 sprintf( %addr(DrZeile#) 0101.00 : '^A0%s^FO%s^FD%s^FS' 0102.00 : #dots 0103.00 : %char(#col)+','+%char(#row) 0104.00 : %trim(#name) 0105.00 ); 0106.00 Except DrZeile; 0107.00 EndSr; 0108.00 //************************************************************** 0109.00 /end-free 0110.00 ***************************************************************** 0111.00 * Druckausgabe für Zebradrucker 0112.00 OHSZEBRA E DrZeile 1 0113.00 O DrZeile# 90
return points (endsr)
*DETL Continue at the beginning of detail lines. *GETIN Continue at the get input record routine. *TOTC Continue at the beginning of total calculations. *TOTL Continue at the beginning of total lines. *OFL Continue at the beginning of overflow lines. *DETC Continue at the beginning of detail calculations. *CANCL Cancel the processing of the program.
Funktionstasten
*inka | F01 |
*inkb | F02 |
*inkc | F03 |
*inkd | F04 |
*inke | F05 |
*inkf | F06 |
*inkg | F07 |
*inkh | F08 |
*inki | F09 |
*inkj | F10 |
*inkk | F11 |
*inkl | F12 |
*inkm | F13 |
*inkn | F14 |
*inkp | F15 |
*inkq | F16 |
*inkr | F17 |
*inks | F18 |
*inkt | F19 |
*inku | F20 |
*inkv | F21 |
*inkw | F22 |
*inkx | F23 |
*inky | F24 |
random number
/if defined(*crtbndrpg) h dftactgrp(*no) /endif h option(*srcstmt) //==================================================================// d genrndnum pr ExtProc('CEERAN0') d 10i 0 Const d 8f d 10a Options(*omit) d rndnbr s 8f d result s 5p 0 d message s 52a Varying //==================================================================// /free genrndnum(0 : rndnbr : *omit); result = %int(rndnbr * 6) + 1; message = 'random number (1..6) is ' + %char(result); dsply message; return; /end-free
sprintf (textconcatenation)
/if defined(*crtbndrpg) h dftactgrp(*no) /endif h option(*srcstmt) //==================================================================// d sprintf pr 10i 0 ExtProc('sprintf') d * Value d * Value Options(*string:*nopass) d * Value Options(*string:*nopass) d * Value Options(*string:*nopass) d * Value Options(*string:*nopass) // ... d psds sds Qualified d pgmn *proc d jobu 10a Overlay(psds:254) d message s 52a //==================================================================// /free sprintf( %addr(message) : 'Program %s is used by %s on %s' : %trim(psds.pgmn) : %trim(psds.jobu) : %char(%date()) ); dsply message; return; /end-free
date converting
h datfmt(*ISO) timfmt(*HMS) h datedit(*dmy.) decedit('0,') *---------------------------------------------------------------* d date8s s 8s 0 d date6s s 6s 0 d year4s s 4s 0 d year2s s 2s 0 d dated s d *---------------------------------------------------------------* /free date8s = *date; // => 01092011 [dep. datedit(*dmy.)] date8s = %dec(%date()); // => 20110901 [dep. datfmt(*iso)] date6s = *date; // Receiver value too small year4s = %subdt(%date():*years); // => 2011 year4s = *year; // => 2011 year2s = %subdt(%date():*years); // Receiver value too small year2s = *year; // Receiver value too small dated=%date()+%months(1)-%days(%subdt(%date()+%months(1):*days)); // '2011-09-30 eval *inlr = *on; return; /end-free
merge
H DECEDIT('0,') DATEDIT(*DMY.) H OPTION(*SRCSTMT:*NODEBUGIO) //===========================================================// fL4FPROLL iF E disk infds(rollinf) f rename(l4f0kid:l4f0roll) fL4FL01S uF a E k disk infds(samminf) f rename(l4f0kid:l4f0samm) fQPRINT O F 132 PRINTER OFLIND(*INOA) //===========================================================// d PSDS sds qualified Programmdatenstruk d PGMN *PROC Programmname d JOBU 10a overlay(PSDS:254) JobUser d rollinf ds qualified d rrn 397 400i 0 d samminf ds qualified d rrn 397 400i 0 d rollds e ds extname(l4fproll:*input) d qualified d sammds ds likerec(l4f0samm) d sammout ds likerec(l4f0samm:*output) d d drLine s 80a inz(*all'=') d #zzequal s 5u 0 inz(0) d #zznoteq s like(#zzequal) d #zzstat s like(#zzequal) d #msg s 52a varying //===========================================================// c ExSr §Work c #msg Dsply c Eval *inlr = *On c Return //===========================================================// /free BegSr §Work; Except DrKopf; setll 1 l4f0roll; DoW 1=1; Read l4f0roll rollds; If %EOF(); Leave; Else; chain (rollds.L4KID : rollds.L4AT: rollds.L4NMND :rollds.l4nwhl : rollds.l4van) l4f0samm sammds; If Not %Found(); ExSr §L4Write; Write l4f0samm sammout; Else; If %subst (sammds : 1 : %len(rollds)) = %subst (rollds : 1 : %len(rollds)); #zzequal += 1; unlock l4fl01s; ElseIf sammds.L4STAT <> rollds.L4STAT Or sammds.L4NFLV <> rollds.L4NFLV Or sammds.L4FAK <> rollds.L4FAK Or sammds.L4RKZ <> rollds.L4RKZ Or sammds.L4M <> rollds.L4M Or sammds.L4ATT <> rollds.L4ATT Or sammds.L4AMM <> rollds.L4AMM Or sammds.L4AJA <> rollds.L4AJA Or sammds.L4LB <> rollds.L4LB Or sammds.L4TIME <> rollds.L4TIME; ExSr §L4Updat; #zzstat += 1; #zznoteq += 1; update l4f0samm sammds; Else; #zznoteq += 1; unlock l4fl01s; Endif; EndIf; EndIf; EndDo; Except DrSumme; If #zznoteq = 0; #msg = 'ROLL und SAMM sind identisch !'; Else; #msg = 'Von ' + %char(#zzequal+#zznoteq) + ' ROLL sind ' + %char(#zznoteq) + ' unterschiedlich zur SAMM !'; Endif; EndSr; //===========================================================// BegSr §L4Write; Clear sammds; eval-corr sammds = rollds; sammds.L4Q3LB = psds.pgmn; sammds.L4Q3TT = *day; sammds.L4Q3MM = *month; sammds.L4Q3JA = *year; %subarr (*in : 71 : 5) = *ON; eval-corr sammout = sammds; Except DrZeile; EndSr; //===========================================================// BegSr §L4updat; *IN71 = (sammds.L4STAT <> rollds.L4STAT); *IN72 = (sammds.L4nflv <> rollds.L4nflv); *IN73 = (sammds.L4fak <> rollds.L4fak); *IN74 = (sammds.L4rkz <> rollds.L4rkz); *IN75 = (sammds.L4m <> rollds.L4m); Except DrZeile; sammds.L4STAV = sammds.L4STAT; sammds.L4STAT = rollds.L4STAT; sammds.L4NFLV = rollds.L4NFLV; sammds.L4FAK = rollds.L4FAK; sammds.L4RKZ = rollds.L4RKZ; sammds.L4M = rollds.L4M; sammds.L4ATT = rollds.L4ATT; sammds.L4AMM = rollds.L4AMM; sammds.L4AJA = rollds.L4AJA; sammds.L4LB = rollds.L4LB ; sammds.L4TIME = rollds.L4TIME; sammds.L4Q3LB = psds.pgmn; sammds.L4Q3TT = *day; sammds.L4Q3MM = *month; sammds.L4Q3JA = *year; EndSr; /end-free //===========================================================// oQPRINT E Drkopf 1 01 o drLine 80 oQPRINT E DrKopf 1 o +0 'PGM:' o PSDS.PGMN +1 o + 4 'Korrektur Menge' o + 4 'PER:' o *DATE Y + 1 oQPRINT E DrKopf 1 o drLine 80 //===========================================================// oQPRINT E DrZeile 1 o rollds.L4KID +1 o +1 '//' o 71 rollds.L4STAT +1 o +1 '->' o 71 sammds.L4STAT +1 o +1 '//' o 72 rollds.L4nflv +1 o +1 '->' o 72 sammds.L4nflv +1 o +1 '//' o 73 rollds.L4fak +1 o +1 '->' o 73 sammds.L4fak +1 o +1 '//' o 74 rollds.L4rkz +1 o +1 '->' o 74 sammds.L4rkz +1 o +1 '//' o 75 rollds.L4m +1 o +1 '->' o 75 sammds.L4m +1 o sammds.L4lb +1 //===========================================================// oQPRINT E DrSumme 1 o #zzequal +1 o +1 'DS sind identisch' oQPRINT E DrSumme 1 o #zznoteq +1 o +1 'DS sind unterschiedlich' oQPRINT E DrSumme 1 o #zzstat +1 o +1 'DS wurden angeglichen'