Skip to content

Commit

Permalink
Move answer stringification after content post processing.
Browse files Browse the repository at this point in the history
This is so that the content post processor methods have access to the
full answer objects.  This gives this approach a whole lot more power
than the (soon to be eliminated) results table has.
  • Loading branch information
drgrice1 committed Oct 23, 2023
1 parent b5b2eb0 commit c01a16b
Show file tree
Hide file tree
Showing 2 changed files with 5 additions and 4 deletions.
7 changes: 4 additions & 3 deletions lib/WeBWorK/PG.pm
Original file line number Diff line number Diff line change
Expand Up @@ -173,9 +173,9 @@ sub new_helper ($invocant, %options) {
);
}

# HTML_dpng uses an ImageGenerator. We have to render the queued equations.
# This must be done before the post processing, since the image tags output by the image generator initially
# include markers which are invalid html. Mojo::DOM will change these markers into attributes and this will fail.
# HTML_dpng uses an ImageGenerator. We have to render the queued equations. This must be done before the post
# processing, since the image tags output by the image generator initially include markers which are invalid html.
# Mojo::DOM will change these markers into attributes with values and this will fail.
if ($image_generator) {
my $sourceFile = "$options{templateDirectory}$options{sourceFilePath}";
$image_generator->render(
Expand All @@ -185,6 +185,7 @@ sub new_helper ($invocant, %options) {
}

$translator->post_process_content if ref($translator->{rh_pgcore}) eq 'PGcore';
$translator->stringify_answers;

return bless {
translator => $translator,
Expand Down
2 changes: 1 addition & 1 deletion lib/WeBWorK/PG/Translator.pm
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ WeBWorK::PG::Translator - Evaluate PG code and evaluate answers safely
my $rh_problem_result = $pt->grade_problem(%options); # grades the problem.
$pt->post_process_content; # Execute macro or problem hooks that further modify the problem content.
$pt->stringify_answers; # Convert objects to strings in the answer hash
=head1 DESCRIPTION
Expand Down Expand Up @@ -1036,7 +1037,6 @@ sub grade_problem {
use strict;

die $@ if $@;
$self->stringify_answers;
return ($self->{rh_problem_result}, $self->{rh_problem_state});
}

Expand Down

0 comments on commit c01a16b

Please sign in to comment.