*!****************************************************************************** FUNCTION aparser * Description.......: Function parses a text string into an array. * : Each element of the array contains one word... * Calling Samples...: dimension laWords[1] * : lcWordString = "Some text string" * : lnWords = aparser(@laWords, lcWordString) * Parameter List....: paWords, pcWordString, pcDelimiter ******************************************************************** lparameter paWords, pcWordString, pcDelimiter local lnWords, lni external array paWords if not "FOXTOOLS.FLL" $ upper(set("library")) set library to foxtools.fll additive endif pcDelimiter = iif(empty(pcDelimiter), space(1), pcDelimiter) lnWords = Words(pcWordString, pcDelimiter) IF lnWords>0 && Not empty string dimension paWords[lnWords] for lni = 1 to lnWords paWords[lni] = WordNum(pcWordString, lni, pcDelimiter) && Array of words endfor ELSE dimension paWords[1] && For empty string lnWords=0 paWords[1]="" ENDIF return lnWordsWhile ago somebody asked an algorithm to parse a string and I post this program.