Tim,

To be honest, I'm not sure.  I'd have to dig around to find out details.

Again, the better idea is to use qsort and bsearch.  Heck, here's the
code:
(Prototypes for bsearch and qsort taken from Hans post here: 
http://archive.midrange.com/rpg400-l/200207/msg00386.html)


     H dftactgrp(*no) bnddir('QC2LE')

     D qsort           pr                  extproc('qsort')
     D   base                          *   value
     D   num                         10i 0 value
     D   width                       10i 0 value
     D   compare                       *   procptr value

     D bsearch         pr              *   extproc('bsearch')
     D   key                           *   value
     D   base                          *   value
     D   num                         10i 0 value
     D   size                        10i 0 value
     D   compare                       *   procptr value

     d CompareByCode...
     d                 pr            10i 0
     d  element1                           const likeds(dlrDs)
     d  element2                           const likeds(dlrds)

     d CompareByName...
     d                 pr            10i 0
     d  element1                           const likeds(dlrDs)
     d  element2                           const likeds(dlrds)

     D DlrDs           Ds                  Qualified based( TEMPLATE )
     D  Idx                                Like(Int10)
     D  Code                               Like(CsRecd.CsDele)
     D  Type                               Like(A_1)
     D  Grp#                               Like(CsRecd.CsGrp#)
     D  Dlr#                               Like(CsRecd.CsDlr#)
     D  Name                               Like(CsRecd.CsName)
     D  Stat                               Like(DaRecd.DaStat)
     D  City                               Like(DaRecd.DaCity)

     d myArray         ds                  likeds(dlrDs) dim(2500)
     d searchValue     ds                  likeds(dlrDs)
     d returnedEntry   ds                  likeds(dlrDs)
based(returnedEntryPtr)


     d currentNumberOfEntries...
     d                 s             10u 0

      // Begin Mainline
      /free
         //load array, make sure currentNumberOfEntries is updated

         // bsearch = binary search, must have a sorted array
         //now sort, then search by Code subfield
         qsort(myArray
               : currentNumberEntries
               : %size(DlrDs)
               : %paddr(CompareByCode));
         searchValue.code = 10;
         returnedEntryPointer = bsearch(searchValue
                                       : myArray
                                       : currentNumberEntries
                                       : %size(DlrDs)
                                       : %paddr(CompareByCode));
         if returnEntryPoint <> *NULL;
           //found it do something with returnedEntry
         endif;

         //now sort, then search by Name subfield
         qsort(myArray
               : currentNumberEntries
               : %size(DlrDs)
               : %paddr(CompareByName));
         searchValue.name = 'Charles';
         returnedEntryPointer = bsearch(searchValue
                                       : myArray
                                       : currentNumberEntries
                                       : %size(DlrDs)
                                       : %paddr(CompareByName));
         if returnEntryPoint <> *NULL;
           //found it do something with returnedEntry
         endif;

         *INLR = *ON
         return;
      /end-free
      //end mainline

     p CompareByCode...
     p                 b
     d CompareByCode...
     d                 pi            10i 0
     d  element1                           const likeds(dlrDs)
     d  element2                           const likeds(dlrds)
      /free
          if element1.code < element2.code;
             return -1;
          elseif element1.code > element2.code;
             return 1;
          endif;
          return 0;
      /end-free
     p CompareByCode...
     p                 e

     p CompareByName...
     p                 b
     d CompareByName...
     d                 pi            10i 0
     d  element1                           const likeds(dlrDs)
     d  element2                           const likeds(dlrds)
      /free
          if element1.name < element2.name;
             return -1;
          elseif element1.name > element2.name;
             return 1;
          endif;
          return 0;
      /end-free
     p CompareByCode...
     p                 e
 
HTH,


Charles Wilt
--
iSeries Systems Administrator / Developer
Mitsubishi Electric Automotive America
ph: 513-573-4343
fax: 513-398-1121
  

> -----Original Message-----
> From: rpg400-l-bounces@xxxxxxxxxxxx 
> [mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Tim Kredlo
> Sent: Thursday, February 09, 2006 11:12 AM
> To: 'RPG programming on the AS400 / iSeries'
> Subject: RE: Problem with based data structures
> 
> Charles,
> 
> Thanks for the suggestion. I will look into both sort methods.
> 
> I know I can sort the data structures by sub-fields if I go 
> through the
> hoops of declaring the sub-fields using 'overlay' instead of the much
> simpler 'likeds'. (Don't you end up with identical data 
> structures using
> either method?) This isn't one of those methods that 'don't 
> work' is it?
> 
> 
> Thanks for your help.
> 
> Tim Kredlo
> 
> 
> 
> -----Original Message-----
> From: rpg400-l-bounces@xxxxxxxxxxxx 
> [mailto:rpg400-l-bounces@xxxxxxxxxxxx]
> On Behalf Of Wilt, Charles
> Sent: Thursday, February 09, 2006 4:59 AM
> To: RPG programming on the AS400 / iSeries
> Subject: RE: Problem with based data structures
> 
> Tim,
> 
> Why other to do the copy from the fixed version of the array to the
> variable size one?
> 
> Instead of trying to use %lookup and SORTA, which don't work well with
> DS arrays ( you _CAN'T_ sort/search on subfields)*, use the 
> bsearch and
> qsort C runtime functions.
> 
> There are plenty of examples on the web and in the archives 
> of using the
> bsearch and qsort from within RPGLE.
> 
> *note: I've seen some interesting hoops here on the people have jumped
> through trying to work around this, some work, some don't really.
> However, using qsort and bsearch are the best solutions.  
> They are easy
> and 100% effective.  
> 
> HTH,
> 
> Charles Wilt
> --
> iSeries Systems Administrator / Developer
> Mitsubishi Electric Automotive America
> ph: 513-573-4343
> fax: 513-398-1121
>   
> 
> > -----Original Message-----
> > From: rpg400-l-bounces@xxxxxxxxxxxx 
> > [mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Tim Kredlo
> > Sent: Wednesday, February 08, 2006 9:19 PM
> > To: RPG400-L@xxxxxxxxxxxx
> > Subject: Problem with based data structures
> > 
> > Help!
> > 
> >  
> > 
> > I am having difficulty accomplishing the following:
> > 
> > I need to create and fill a data structure that will hold an 
> > array of up to
> > approximately 2500 elements.
> > 
> > The exact number will not be known until run time.
> > 
> > Each element of the array will be like (likeds) a 94 character data
> > structure.
> > 
> > I need to be able to resize the 2500 element data structure 
> > to remove any
> > unfilled elements.
> > 
> > I need to be able to sort the data structure by any of the 
> sub-fields.
> > 
> >  
> > 
> > This is what I have done so far:
> > 
> >  
> > 
> > Declared a data structure 'template' for each element of both 
> > arrays (Dlr
> > and Dlr1):
> > 
> > D DlrDs           Ds                  Qualified          
> > 
> > D  Idx                                Like(Int10)        
> > 
> > D  Code                               Like(CsRecd.CsDele)
> > 
> > D  Type                               Like(A_1)          
> > 
> > D  Grp#                               Like(CsRecd.CsGrp#)
> > 
> > D  Dlr#                               Like(CsRecd.CsDlr#)
> > 
> > D  Name                               Like(CsRecd.CsName)
> > 
> > D  Stat                               Like(DaRecd.DaStat)
> > 
> > D  City                               Like(DaRecd.DaCity)
> > 
> > A_1 is declared as 1A
> > 
> > CsRecd.CsDele is declared as 1A
> > 
> > CsRecd.CsGrp# is declared as 6P 0
> > 
> > CsRecd.CsDlr# is declared as 6P 0
> > 
> > CsRecd.CsName is declared as 40A
> > 
> > DaRecd.DaStat is declared as 10A
> > 
> > DaRecd.DaCity is declared as 20A
> > 
> >  
> > 
> > Declared 2 pointers:
> > 
> > D DlrBase         S               *   Inz 
> > 
> > D DlrBas1         S               *   Inz
> > 
> >  
> > 
> > Declared two data structures based on the above pointers:
> > 
> > D                 Ds                  Based(DlrBase)      
> > 
> > D  Dlr                          94A   Varying             
> > 
> > D                                     Dim(2500)           
> > 
> > D                                     Ascend              
> > 
> > D  DlrIdx                             Like(DlrDs.Idx)     
> > 
> > D                                     Overlay(Dlr : 1)    
> > 
> > D  DlrCode                            Like(DlrDs.Code)    
> > 
> > D                                     Overlay(Dlr : *Next)
> > 
> > D  DlrType                            Like(DlrDs.Type)    
> > 
> > D                                     Overlay(Dlr : *Next)
> > 
> > D  DlrGrp#                            Like(DlrDs.Grp#)    
> > 
> > D                                     Overlay(Dlr : *Next)
> > 
> > D  DlrDlr#                            Like(DlrDs.Dlr#)    
> > 
> > D                                     Overlay(Dlr : *Next)
> > 
> > D  DlrName                            Like(DlrDs.Name)    
> > 
> > D                                     Overlay(Dlr : *Next)
> > 
> > D  DlrCity                            Like(DlrDs.City)    
> > 
> > D                                     Overlay(Dlr : *Next)
> > 
> > D  DlrStat                            Like(DlrDs.Stat)    
> > 
> > D                                     Overlay(Dlr : *Next)
> > 
> >  
> > 
> > D                 Ds                  Based(DlrBas1)       
> > 
> > D  Dlr1                         94A   Dim(2500)            
> > 
> > D                                     Ascend               
> > 
> > D  Dlr1Idx                            Like(DlrDs.Idx)      
> > 
> > D                                     Overlay(Dlr1 : 1)    
> > 
> > D  Dlr1Code                           Like(DlrDs.Code)     
> > 
> > D                                     Overlay(Dlr1 : *Next)
> > 
> > D  Dlr1Type                           Like(DlrDs.Type)     
> > 
> > D                                     Overlay(Dlr1 : *Next)
> > 
> > D  Dlr1Grp#                           Like(DlrDs.Grp#)     
> > 
> > D                                     Overlay(Dlr1 : *Next)
> > 
> > D  Dlr1Dlr#                           Like(DlrDs.Dlr#)     
> > 
> > D                                     Overlay(Dlr1 : *Next)
> > 
> > D  Dlr1Name                           Like(DlrDs.Name)     
> > 
> > D                                     Overlay(Dlr1 : *Next)
> > 
> > D  Dlr1City                           Like(DlrDs.City)     
> > 
> > D                                     Overlay(Dlr1 : *Next)
> > 
> > D  Dlr1Stat                           Like(DlrDs.Stat)     
> > 
> > D                                     Overlay(Dlr1 : *Next)
> > 
> >  
> > 
> > I had hoped that I could have declared these using 'likeds', 
> > but I don't
> > think I could have made them 'varying' or been able to sort by the
> > sub-fields. Please tell me I am wrong about that, because it 
> > sure would make
> > maintenance easier.
> > 
> > What I would really like to be able to do is "SortArray
> > (QlfdDs((QlfdDs.Field1:Ascend)(QlfdDs.Field2:Descend)))".
> > 
> > (In my dreams)
> > 
> >  
> > 
> > I then created 2 user spaces, initialized with blanks('x'40') 
> > and retrieved
> > their pointers (DlrBase and DlrBas1).
> > 
> > I filled elements of Dlr1, the non-varying array, from files 
> > till done and
> > kept the number of elements filled (Idx = 1820 today).
> > 
> >  
> > 
> > The following statement was then executed to fill Dlr and 
> > resize it to only
> > contain the filled elements:
> > 
> > %SubArr( Dlr : 1 : Idx ) = %SubArr ( Dlr1 : 1 : Idx );
> > 
> >  
> > 
> > Immediately after that statement was executed, debug evals 
> showed the
> > following:
> > 
> > > EVAL dlr1(1)                                                
> >            
> > 
> >   DLR1(1) =                                                   
> >            
> > 
> >             
> > ....5...10...15...20...25...30...35...40...45...50...55...60 
> > 
> >        1   '   -AA000000000050MISCELLANEOUS                   
> >           '
> > 
> >       61   '                                  '               
> >            
> > 
> > > EVAL dlr(1)                                                 
> >            
> > 
> >   DLR(1) =                                                    
> >            
> > 
> >             
> > ....5...10...15...20...25...30...35...40...45...50...55...60 
> > 
> >        1   '   -AA000000000050MISCELLANEOUS                   
> >           '
> > 
> >       61   '                                    ' 
> > 
> > I don't know if the e-mail formatting will show this 
> > correctly, but the end
> > "'" for DLR(1) is in position 95 and the end "'" for DLR(1) 
> > is in position
> > 97.
> > 
> >  
> > 
> > I then did the following debug evals:                       
> > 
> > > EVAL dlr1name(1)                                        
> > 
> >   DLR1NAME(1) = 'MISCELLANEOUS                           '
> > 
> > > EVAL dlrname(1)                                         
> > 
> >   DLRNAME(1) = '50MISCELLANEOUS                         '
> > 
> >  
> > 
> > Notice that the two data structures (Dlr and Dlr1) are 
> > declared identically,
> > but the DlrName field now appears to start 2 characters prior 
> > to Dlr1name
> > field.
> > 
> >  
> > 
> > I thought that perhaps this was an 'align' issue, so stuck 
> > 'align' on the
> > declaration for both Dlr and Dlr1 and recompiled. (I don't 
> > know if there is
> > more that I would need to do.)There were no warnings in the 
> > compile listing
> > about mis-aligned fields. I re-ran and received the same results.
> > 
> >  
> > 
> > I am stuck as to where to look next.
> > 
> >  
> > 
> > All code and debug info was 'cut and pasted' into this email. 
> > So if you see
> > what appears to be a typo, it is probably wrong in my code 
> > and needs to be
> > pointed out.
> > 
> > Thanks in advance for any help. 
> > 
> >  
> > 
> >  
> > 
> >  
> > 
> >  
> > 
> >  
> > 
> >  
> > 
> >  
> > 
> >  
> > 
> >  
> > 
> >  
> > 
> > -- 
> > 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.
> > 
> > 
> 
> -- 
> 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.
> 
> 
> 
> -- 
> 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 thread ...

Follow-Ups:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

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.