Skip to content

Commit

Permalink
Fixed issue #06239: Ranking style questions can't be used to filter o…
Browse files Browse the repository at this point in the history
…ther questions
  • Loading branch information
TMSWhite committed Jun 19, 2012
1 parent cec93c9 commit db517d4
Showing 1 changed file with 46 additions and 4 deletions.
50 changes: 46 additions & 4 deletions application/helpers/expressions/em_manager_helper.php
Expand Up @@ -1120,12 +1120,33 @@ public function _CreateSubQLevelRelevanceAndValidationEqns($onlyThisQseq=NULL)
continue;
}
$fqid = $fqid[2];
if ($this->q2subqInfo[$fqid]['type'] == 'R')
{
$rankables = array();
foreach ($this->qans[$fqid] as $k=>$v)
{
$rankable = explode('~',$k);
$rankables[] = '_' . $rankable[1];
}
if (array_search($sq['sqsuffix'],$rankables) === false)
{
continue;
}
}
$fsqs = array();
foreach ($this->q2subqInfo[$fqid]['subqs'] as $fsq)
{
if ($fsq['sqsuffix'] == $sq['sqsuffix'])
if ($this->q2subqInfo[$fqid]['type'] == 'R')
{
// we know the suffix exists
$fsqs[] = '(' . $sgq . $fsq['csuffix'] . ".NAOK == '" . substr($sq['sqsuffix'],1) . "')";
}
else
{
$fsqs[] = '!is_empty(' . $sgq . $fsq['csuffix'] . '.NAOK)';
if ($fsq['sqsuffix'] == $sq['sqsuffix'])
{
$fsqs[] = '!is_empty(' . $sgq . $fsq['csuffix'] . '.NAOK)';
}
}
}
if (count($fsqs) > 0)
Expand All @@ -1142,12 +1163,33 @@ public function _CreateSubQLevelRelevanceAndValidationEqns($onlyThisQseq=NULL)
continue;
}
$fqid = $fqid[2];
if ($this->q2subqInfo[$fqid]['type'] == 'R')
{
$rankables = array();
foreach ($this->qans[$fqid] as $k=>$v)
{
$rankable = explode('~',$k);
$rankables[] = '_' . $rankable[1];
}
if (array_search($sq['sqsuffix'],$rankables) === false)
{
continue;
}
}
$fsqs = array();
foreach ($this->q2subqInfo[$fqid]['subqs'] as $fsq)
{
if ($fsq['sqsuffix'] == $sq['sqsuffix'])
if ($this->q2subqInfo[$fqid]['type'] == 'R')
{
// we know the suffix exists
$fsqs[] = '(' . $sgq . $fsq['csuffix'] . ".NAOK != '" . substr($sq['sqsuffix'],1) . "')";
}
else
{
$fsqs[] = 'is_empty(' . $sgq . $fsq['csuffix'] . '.NAOK)';
if ($fsq['sqsuffix'] == $sq['sqsuffix'])
{
$fsqs[] = 'is_empty(' . $sgq . $fsq['csuffix'] . '.NAOK)';
}
}
}
if (count($fsqs) > 0)
Expand Down

0 comments on commit db517d4

Please sign in to comment.