There are a few suggestions I'd make here. The first is to make your code a little *less* paranoid about newlines. You control all the form input already, so those chomps aren't going to do anything. The *only* place where you're going to potentially have extra newlines is on the end of each line, i.e. at the end of $record[6]. Just chomp each line as you read it in, and you can leave the rest. Since the DB and the CGI are running on the same OS, they should have the same "concept" of a newline. One trick you can use to find out if there are lingering characters is to print out the value within delimiters, i.e. print "<p>color is '$color'</p>\n";, so if it is a newline problem you can track it down a little quicker.
Which reminds me, for ($record[6]) { s/\r\n//; } is an *odd* piece of code -- you're not iterating over anything. Just do $record[6] =~ tr/\r\n//d; instead (if chomping doesn't help).
More importantly, I'd suggest using a different logic to generate matches. That if is long and hard to maintain. But that would take a lot of thought and effort, and it's rather late in the day.
HTH!
perl -e 'print "How sweet does a rose smell? "; chomp ($n = <STDIN>); +$rose = "smells sweet to degree $n"; *other_name = *rose; print "$oth +er_name\n"'
In reply to Re: Adding features to a CGI search engine
by arturo
in thread Adding features to a CGI search engine
by wiz
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |