I am reading from a file and need to find the exact line $(eval $(call CreateTest KEYWORD
and everything following after the line (as the rest is all random). This is how I am currently trying to find it but it always reports back as nothing found to match.
proc listFromFile {$path1} {
set find {$(eval $(call CreateTest, KEYWORD}
upvar path1 path1
set f [open $path1 r]
set data [split [string trim [read $f]] \n]
close $f
# return [lsearch -all -inline $data *KEYWORD*]
return [lsearch -exact -all -inline $data $find*]
}
The commented out line is the closest I can get it to work but it pulls anything with KEYWORD anywhere in the file. the KEYWORD could appear in lines I do not want to read therefore I need to pull the exact line as stated above
EDIT I should have mentioned that the file is formatted like so;
$(eval $(call CreateTest, KEYWORD ...
$(eval $(call CreateTest, NOT_KEYWORD ...
$(eval $(call CreateTest, KEYWORD ...
$(eval $(call CreateTest, KEYWORD ...
$(eval $(call CreateTest, NOT_KEYWORD ...
$(eval $(call CreateTest, KEYWORD ...
which means I only want to pull the lines containing the exact string and the keyword. But there are lines between what I am looking for that I do not want to display
I think you should just apply your match to each line as you read them.
You could build up a list of results or do something immediately for each matching line as appropriate for your application. The main difference is that
string match
doesn't have many meta characters unlike regexp. Only*
and?
are special so it is simple to match for a line matching your string followed by anything ie:${find}*
.I think in your code you have used
*
as a glob pattern.When
-exact
flag used, it will treat that*
as a literal*
thereby failing to get the desired result. Removing that*
will solve the problem.This should work:
In my answer to your earlier question, I suggested
lsearch
(without-exact
) andKEYWORD*
as a pattern because that seemed to be what you were after. Considering the lines you show here, searching for a space character followed by the stringKEYWORD
seems more likely to work.Another thing: your problem with the parameter (which you tried to solve with
upvar
) was that you had a dollar sign attached to the parameter name. If you leave out the dollar sign you get a usable parameter name like in the code above (it is possible to use it even with the dollar sign, but it's a lot harder).Documentation: close, lsearch, open, proc, read, return, set, split, string
Use
string first
andstring range
instead:Test: