[NEWSboard IBMi Forum]

Hybrid View

  1. #1
    Registriert seit
    Mar 2002
    Beiträge
    5.365
    ... da gibt es mehrere Ebenen
    - Maschinenweit
    - User bezogen (geht normal über ein property File im User Home)
    - Job bezogen (muss dann im SBMJOB, oder beim init, oder vor dem Programm eingestellt werden

    D*B

    Zitat Zitat von chrisssiie Beitrag anzeigen
    jap es war die Umgebungsvariable....

    Bei uns war die auf
    LANG='QSYS.LIB/DE_DE.LOCALE

    gesetzt....

    auf der anderen Maschine war diese leer....


    Mit

    ADDENVVAR ENVVAR(LANG) VALUE('QSYS.LIB/DE_DE.LOCALE')

    ham sich dann beide gleich verhalten....

    Aber so ist es mir dann schon klar... die Zeichen waren alle in deutscher CCSID codiert und dann hat er sich in den C Routinen irgend eine andere gezogen.... aber welche nimmt er dann, wenn die Umgebungsvariable LANG nicht gesetzt ist?


    wie steuert man das dann am besten, wenn man das Programm auf verschiedenen Maschinen laufen lassen will??
    überall die Umgebungsvariable setzen??
    AS400 Freeware
    http://www.bender-dv.de
    Mit embedded SQL in RPG auf Datenbanken von ADABAS bis XBASE zugreifen
    http://sourceforge.net/projects/appserver4rpg/

  2. #2
    Registriert seit
    Jan 2007
    Beiträge
    75
    welche Auswirkungen hat es denn, wenn man das Systemweit macht?

    Also kann man dann mit irgendetwas Probleme kriegen?

  3. #3
    Registriert seit
    Mar 2002
    Beiträge
    5.365
    ... das kann Bob Dylan beantworten: the answer my friend, is blowing in the wind...
    Sicherlich keine gute Idee, am defensivsten ist es, das innerhalb des Programmes zu regeln

    D*B

    Zitat Zitat von chrisssiie Beitrag anzeigen
    welche Auswirkungen hat es denn, wenn man das Systemweit macht?

    Also kann man dann mit irgendetwas Probleme kriegen?
    AS400 Freeware
    http://www.bender-dv.de
    Mit embedded SQL in RPG auf Datenbanken von ADABAS bis XBASE zugreifen
    http://sourceforge.net/projects/appserver4rpg/

  4. #4
    Registriert seit
    Jan 2007
    Beiträge
    75
    lol, na dann frag ich mal bob dylan



    Im Programm kann ichs doch dann aber nur so regeln, dass ich vor jeder REGEX Prüfung einen ADDENVVAR auf Jobebene mach und danach einen RMVENVVAR...
    oder gibts da bessere Methoden?

  5. #5
    Registriert seit
    Feb 2001
    Beiträge
    20.695
    Stimmt, allerdings würde ich die CCSID des Jobs abfragen und die dazu passende Lokale wählen (falls es tatsächlich mal nicht 273 DE ist).
    Dienstleistungen? Die gibt es hier: http://www.fuerchau.de
    Das Excel-AddIn: https://www.ftsolutions.de/index.php/downloads
    BI? Da war doch noch was: http://www.ftsolutions.de

  6. #6
    Registriert seit
    Jan 2007
    Beiträge
    75
    ok, das hat mir mal wieder sehr geholfen



    Dankeschön ihr beiden

  7. #7
    Registriert seit
    Feb 2001
    Beiträge
    20.695
    Alternativ gibts noch die C-Funktion setlocale().
    Vielleicht kommst du ja damit weiter und benötigst dann keine ENVVAR mehr.
    Wenn setlocale() nicht funktioniert, kannst du auch mit putenv() die Variable setzen.
    Vorteil bei putenv():
    - gilt nur für das aktive Prgrammobjekt
    - keine ENVVAR's im Job
    Dienstleistungen? Die gibt es hier: http://www.fuerchau.de
    Das Excel-AddIn: https://www.ftsolutions.de/index.php/downloads
    BI? Da war doch noch was: http://www.ftsolutions.de

  8. #8
    Registriert seit
    Jan 2007
    Beiträge
    75
    hmm.....

    ich hab das jetzt mal mit putenv probiert....

    Code:
    D putenv          PR            10i 0 ExtProc('putenv')           
    D envvar                          *   VALUE OPTIONS(*STRING:*TRIM)
    D cp              s           1024a
    
    
    // set LANG                                    
      cp = %trim(var) + '=' + %trim(value);        
                                                   
       if (putenv(cp) < 0);                        
        err = errno;                               
       endif;
    Er scheint auch was zu machen, weil wenn ich mit STRQSH echo $LANG die Variable anschaue, zeigt er mit das richtig an.... aber die Regex-Funktionen gehen irgendwie nicht richtig....



    mach ich vorher einen ADDENVVAR ENVVAR(LANG) VALUE('/QSYS.LIB/DE_DE.LOCALE') REPLACE(*YES)

    klappt alles.....

  9. #9
    Registriert seit
    Jan 2007
    Beiträge
    75
    Hallo,

    ich hole das Thema noch einmal hoch, da ich es damals nicht hingebracht habe vernünftig zum laufen zu kriegen....

    Ich habe jetzt noch einmal etwas rumprobiert und habe folgendes herausgefunden:


    Die Regex-Befehle arbeiten mit der CCSID von der Umgebungsvariable LANG....

    LANG ist meistens mit dem Wert aus dem Systemwert QLOCALE festgelegt...
    Kann man im USerprofile angeben(Wert LOCALE)...

    Steht in der Umgebungsvariable nichts drin(wegen QLOCALE = *NONE), dann arbeiten die Regex Routinen mit CCSID 37...


    d.h. für mich, wenn ich meinen Regex in einer Source, welche in CCSID 273 gespeichert ist habe, muss ich diesen in die CCSID, welche der aktuellen Umgebungsvariable LANG entspricht umwandeln...

    In der Umgebungsvariable LANG steht aber z.B. /QSYS.LIB/DE_DE.LOCALE....



    Wie bekommt man jetzt raus, welche CCSID dem Objekt /QSYS.LIB/DE_DE.LOCALE entspricht, ohne die hart im Programm umzuschlüsseln??


    Oder gibt es eine Umgebungsvariable, welche mir die CCSID zurückgibt, welche der Umgebungsvariable LANG entspricht??


    Gruß

    chrisssiie

  10. #10
    Registriert seit
    Feb 2001
    Beiträge
    20.695
    Auch hierfür gibt es wieder C-Funktionen, dies abzufragen:
    http://publib.boulder.ibm.com/infoce...07.pdf#LOCCONV
    http://publib.boulder.ibm.com/infoce...607.pdf#LINFOP

    localeconv - C++ Reference
    ILE C/C++ Run-Time Library Functions - nl_langinfo() --Retrieve Locale Information

    Wobei es hier durchaus Diskrepanzen geben kann wenn die C-Funktionen die tatsächliche Einstellung liefern (bis hin zu QCCSID) aber regex() diese Funktionen nicht verwendet sondern fix auf die ENV-Variable zugreift.
    Dienstleistungen? Die gibt es hier: http://www.fuerchau.de
    Das Excel-AddIn: https://www.ftsolutions.de/index.php/downloads
    BI? Da war doch noch was: http://www.ftsolutions.de

  11. #11
    Registriert seit
    Jan 2007
    Beiträge
    75
    hmmm... wenn es hier natürlich Diskrepanzen geben kann codiere ich es denke ich doch hart um...

    also DE_DE.LOCALE = 1141, HU_HU.LOCALE = 870 usw....


    Die meisten haben eh entweder DE_DE.LOCALE oder gar nichts drin stehen... wenn noch weitere hinzukommen muss ich das halt reinschreiben...


    Jetzt habe ich aber wenigstens auf den meisten Systemen lauffähge regex Version


    Ist das eigentlich bei allen C-Routinen so, dass die mit der Umgebungsvariable LANG und nicht mit der JOB-CCSID arbeiten?

    Dann müssten doch schon einige vor mir vor dem Problem gestanden haben

Similar Threads

  1. Konvertierung nach Graphic --> CCSID Problem
    By codierknecht in forum NEWSboard SAP
    Antworten: 32
    Letzter Beitrag: 09-02-18, 13:00
  2. Windowstabelle wird im IFS in CCSID 1252 erstellt
    By umeis in forum NEWSboard Windows
    Antworten: 3
    Letzter Beitrag: 11-08-06, 12:45
  3. CCSID ändern
    By schaaf in forum IBM i Hauptforum
    Antworten: 3
    Letzter Beitrag: 04-05-06, 11:18
  4. CPYTOIMPF und CCSID
    By Muchi in forum IBM i Hauptforum
    Antworten: 7
    Letzter Beitrag: 21-04-06, 13:54
  5. CCSID eines Files
    By Binford in forum IBM i Hauptforum
    Antworten: 6
    Letzter Beitrag: 07-03-06, 08:58

Berechtigungen

  • Neue Themen erstellen: Nein
  • Themen beantworten: Nein
  • You may not post attachments
  • You may not edit your posts
  •