#!/usr/bin/perl #______________________________________________________________________________________ # these variables will need to be changed to fit the host machine configuration/directories. # # this is where the linux.dat files live; currently /home/usr/ftp/pub/data/memtests $directory_root = "/u/twalker/memtest/results/daily"; # $host_server = "smoketest1"; # # note: the /plots_tmp directory under $results_dir will need to be cleaned out periodically # because this is where the .png files will be put on creation (it could become a memory hog) $results_dir = "/usr/local/apache/htdocs"; # this is where gnuplot app lives $gnuplot = "/usr/bin/gnuplot"; # #-------------------------------------------------------------------------------------- # take in form info and convert it to usable variables -------------------------------- $query_string = $ENV{'QUERY_STRING'}; @key_value_pairs = split (/&/, $query_string); foreach $key_value (@key_value_pairs) { ($key, $value) = split (/=/, $key_value); $value =~ tr/+/ /; $value =~ s/%([\dA-Fa-f][\dA-Fa-f])/pack ("C", hex ($1))/eg; $form_data{$key} = $value; @list_keys = keys(%form_data); @values_keys = values(%form_data); } # error check for user selecting all three fields ------------------------------------ $number_of_values = @key_value_pairs; if ($number_of_values != 3) { print "Content-type: text/html", "\n\n"; print "", "\n"; print "Plotting Error", "\n"; print "", "\n"; print "

", "Plotting Error", "

", "
", "\n"; print "Please close this window and make a selection from each of the three fields.", "\n"; print "", "\n"; } # create variables to point to directories containg the linux.dat files --------------- else { ($month, $day, $year) = split (/\//, $form_data{"first_date"}); $first_date = "$year$month$day"; ($month, $day, $year) = split (/\//, $form_data{"compare_date"}); $compare_date = "$year$month$day"; $test_list_in = $form_data{"test_list"}; if ($test_list_in eq "large to small") { $test_list = "static41x3_gtol"; } elsif ($test_list_in eq "small to large") { $test_list = "static41x3_ltog"; } elsif ($test_list_in eq "plain text") { $test_list = "static_vanillaX100"; } elsif ($test_list_in eq "memory hog") { $test_list = "static_iplanetX100"; } open(FIRST_DATE_DIR,"$directory_root/$test_list/$first_date/linux.dat") || die "could not create directory\n"; open(COMPARE_DATE_DIR,"$directory_root/$test_list/$compare_date/linux.dat") || die "could not create directory\n"; $first_date_dir = join ("/",$directory_root , $test_list, $first_date, "linux.dat"); $compare_date_dir = join ("/", $directory_root, $test_list, $compare_date, "linux.dat"); # get slope of first date line--------------------------------------------------------- while () { $line = $_; } @slope_array_first = split (' ',$line); $slope_first = $slope_array_first[1]; $label_placement_first = $slope_array_first[5]; $line_formula_first = join (" ", $slope_array_first[3], $slope_array_first[2], $slope_array_first[1], $slope_array_first[4], $slope_array_first[5]); chop($slope_first);chop($slope_first);chop($slope_first); close (FIRST_DATE_DIR); # get slope of compare date line--------------------------------------------------------- while () { $line = $_; } @slope_array_compare = split (' ',$line); $slope_compare = $slope_array_compare[1]; $label_placement_compare = $slope_array_compare[5]; $line_formula_compare = join (" ", $slope_array_compare[3], $slope_array_compare[2], $slope_array_compare[1], $slope_array_compare[4], $slope_array_compare[5]); chop($slope_compare);chop($slope_compare);chop($slope_compare); close(COMPARE_DATE_DIR); # generate gnuplot graph -------------------------------------------------------------- $process_id = $$; $output_file = join ("", $results_dir, "/plots_tmp/", $process_id, ".png"); $output_location = join ("", "http://", $host_server, "/plots_tmp/", $process_id, ".png"); open(GNUPLOT, "|$gnuplot"); print GNUPLOT <