Tech Articles


Sorting a string array


I had a need to sort a string array and I found some code on Real Gagnon’s website that sorted numbers by creating a DataStore/DataWindow on the fly and used that to sort. Someone added a comment that for strings you need to define the column as char to avoid errors. I improved the code by adding a loop to determine the longest string in the array and using that when defining the DataWindow source.

 

public function boolean of_sortarray (ref string as_array[], string as_order);// —————————————————————————–

// SCRIPT:     of_SortArray

//

// PURPOSE:    This function sorts the passed array using a DataStore created

// on-the-fly.

//

// This is based on code from Real Gagnon:

// http://www.rgagnon.com/pbdetails/pb-0114.html

//

// ARGUMENTS:  as_array – Array of values to sort

// as_order – The sort order:

//

// Order value Resulting sort order

// ———————— —————————

// a, asc, ascending, ai, i Case-insensitive ascending

// d, desc, descending, di Case-insensitive descending

// as, s Case-sensitive ascending

// ds Case-sensitive descending

//

// DATE        PROG/ID DESCRIPTION OF CHANGE / REASON

// ———-  ——– —————————————————–

// 09/27/2016 RolandS Initial Coding

// —————————————————————————–

 

DataStore lds_sort

String ls_source, ls_error

Long ll_idx, ll_max, ll_len, ll_maxlen

Integer li_rc

 

// determine maximum length of values

ll_max = UpperBound(as_array)

For ll_idx = 1 To ll_max

  ll_len = Len(as_array[ll_idx])

  If ll_len > ll_maxlen Then

  ll_maxlen = ll_len

  End If

Next

 

// build DataWindow source code

ls_source = “release 6; datawindow( processing=0 ) ” + &

  “table(column=(type=char(” + String(ll_maxlen) + &

  “) name=array dbname=~”array~” ) )”

 

// create DataStore

lds_sort = Create DataStore

li_rc = lds_sort.Create(ls_source, ls_error)

If li_rc = 1 Then

  // put data into DataStore

  lds_sort.Object.array.Current = as_array

  // sort the data

  lds_sort.SetSort(“array ” + as_order)

  lds_sort.Sort()

  // set array to sorted data

  as_array = lds_sort.Object.array.Current

Else

  Return False

End If

 

// destroy DataStore

Destroy lds_sort

 

Return True

 

end function

Comments (2)
Wednesday, Jun 12 2019

ls_source = “release 6; datawindow( processing=0 ) ” + &

Instead of hardcodidng release number, you can create a function uf_get_pb_version() with this code:

/**********************************************************************************************************************
Dscr: returns the major version number of PowerBuilder, for example: "9" (not "9.0"!)
***********************************************************************************************************************
Ret: PB version as string
**********************************************************************************************************************/
int li_rc
string ls_pb_version
environment lenv

li_rc = GetEnvironment(ref lenv)
if li_rc 1 then
MessageBox(this.ClassName() + ".uf_get_pb_version", "GetEnvironment() failed.", StopSign!)
return ""
end if

ls_pb_version = String(lenv.pbmajorrevision)

return ls_pb_version

Comment was last edited 6 years ago by Michael Zuskin
0

Wednesday, Jun 12 2019

The release version of a DataWindow object does not have to match the version of PowerBuilder you are using, it only has to be lower. You could make it match with GetEnvironment but it is not necessary.

0

Find Articles by Tag

Error SDK CI/CD GhostScript PostgreSQL ODBC driver Model Oracle OAuth 2.0 TFS Encryption Web API JSON SqlExecutor Database Connection Variable OAuth Database Table Schema Outlook Event Installation Icon NativePDF Jenkins HTTPClient Debug Web Service Proxy .NET DataStore PowerServer Mobile Authorization Database Table Data PowerScript (PS) OLE PFC CoderObject OrcaScript Azure PostgreSQL Export Class Visual Studio Migration C# WebBrowser Performance Testing COM Import JSON DataWindow JSON RESTClient Graph Deployment Data Database Object File Mobile PowerBuilder (Appeon) Git Expression PBVM License DevOps Syntax RichTextEdit Control SVN Encoding PowerBuilder Compiler Configuration Validation Bug TortoiseGit Database Table Filter Design ODBC Array Stored Procedure iOS TLS/SSL Automated Testing Interface UI Service API SQL JSONParser PBNI Debugger Debugging Database Painter Script IDE Branch & Merge Database Profile Resize Windows OS SQL Server ActiveX Import Sort Elevate Conference Export JSON PBDOM Transaction .NET Std Framework Source Control Excel XML CrypterObject Authentication Menu Application PDFlib SnapObjects DataType UI Modernization Source Code PDF DataWindow DLL PowerBuilder Linux OS Open Source MessageBox RibbonBar 32-bit Event Handling SOAP Window RibbonBar Builder External Functions JSONGenerator Event Handler Trial WinAPI DragDrop SqlModelMapper BLOB SnapDevelop TreeView Platform Messagging Text Windows 10 Icons Charts Android .NET Assembly PowerServer Web 64-bit InfoMaker REST Database UI Themes Repository