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 7 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

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