From bfb471011aaf192bb56d3dc401877d69338e74eb Mon Sep 17 00:00:00 2001 From: james Date: Wed, 17 Sep 2008 18:04:50 +0000 Subject: [PATCH] - Fix a bug where the special awards annealer would overwrite the last jteam - Add an alternative (but commented out) array population for the annealer - Leave in some of the debug statements, they don't hurt anything. --- admin/judges_sa.php | 53 ++++++++++++++++++++++++++++++++------------- 1 file changed, 38 insertions(+), 15 deletions(-) diff --git a/admin/judges_sa.php b/admin/judges_sa.php index 117cebb8..748d6e9d 100644 --- a/admin/judges_sa.php +++ b/admin/judges_sa.php @@ -357,7 +357,7 @@ for($k=0; $knum_buckets; $x++) { $bkt = $a->bucket[$x]; - TRACE(" SubTeam $x:\n"); + TRACE(" SubTeam $x: (jteam $jteam_id)\n"); $jdiv[$jdiv_id]['jteams'][] = $jteam_id; $jteam[$jteam_id]['id'] = $jteam_id; @@ -398,19 +398,19 @@ printf("Judge Willing Chair = Question ID $willing_chair_question_id\n"); TRACE("Deleting autocreated divisional and special award judging teams:"); $q = mysql_query("SELECT * FROM judges_teams WHERE autocreate_type_id=1 AND year={$config['FAIRYEAR']}"); while($r = mysql_fetch_object($q)) { - $jteam_id = $r->id; - print(" $jteam_id"); + $id = $r->id; + print(" $id"); /* Clean out the judges_teams_link */ - mysql_query("DELETE FROM judges_teams_link WHERE judges_teams_id='$jteam_id' AND year={$config['FAIRYEAR']}"); + mysql_query("DELETE FROM judges_teams_link WHERE judges_teams_id='$id' AND year={$config['FAIRYEAR']}"); print mysql_error(); /* Awards */ - mysql_query("DELETE FROM judges_teams_awards_link WHERE judges_teams_id='$jteam_id' AND year={$config['FAIRYEAR']}"); + mysql_query("DELETE FROM judges_teams_awards_link WHERE judges_teams_id='$id' AND year={$config['FAIRYEAR']}"); print mysql_error(); /* Timeslots */ - mysql_query("DELETE FROM judges_teams_timeslots_link WHERE judges_teams_id='$jteam_id' AND year={$config['FAIRYEAR']}"); + mysql_query("DELETE FROM judges_teams_timeslots_link WHERE judges_teams_id='$id' AND year={$config['FAIRYEAR']}"); print mysql_error(); /* Timeslots projects */ - mysql_query("DELETE FROM judges_teams_timeslots_projects_link WHERE judges_teams_id='$jteam_id' AND year={$config['FAIRYEAR']}"); + mysql_query("DELETE FROM judges_teams_timeslots_projects_link WHERE judges_teams_id='$id' AND year={$config['FAIRYEAR']}"); print mysql_error(); } /* Finally, delete all the autocreated judges teams */ @@ -770,6 +770,7 @@ function judges_sa_pick_move($a) if($config['scheduler_enable_sa_scheduling'] == 'yes') { + set_status("Creating Special Award Judging Teams (one team per award)"); $q = "SELECT award_awards.name,award_awards.id FROM award_awards,award_types WHERE @@ -790,6 +791,9 @@ if($config['scheduler_enable_sa_scheduling'] == 'yes') { $sa_jteam[0]['max_judges'] = 0; $sa_jteam[0]['award_ids'] = array(); + /* Reload the jteam_id */ + $jteam_id = count($jteam); + $x=1; while($i = mysql_fetch_object($r)) { $projects = getProjectsNominatedForSpecialAward($i->id); @@ -821,8 +825,6 @@ if($config['scheduler_enable_sa_scheduling'] == 'yes') { $x++; } - - /* ====================================================================*/ set_status("Assigning Judges to Special Award Teams\n"); @@ -834,14 +836,17 @@ if($config['scheduler_enable_sa_scheduling'] == 'yes') { //$a->set_pick_move(judges_sa_pick_move); $a->anneal(); - $x=0; + unset($t); + unset($tid); foreach($sa_jteam as $tid => $t) { if($tid == 0) { $x++; continue; } + print("Judging Team {$t['id']}: cost={$a->bucket_cost[$x]} #=({$t['min_judges']},{$t['max_judges']}) "); + // print("langs=("); /* $langstr=""; for($y=0; $y