NAME
Games::QuizTaker - Take your own quizzes and tests
SYNAPSIS
use Games::QuizTaker;
my $GQ=Games::QuizTaker->new(FileName=>'test.psv');
$GQ->load;
$GQ->set_MaxQuestions(2) # Set the number of questions you wish to answer on the test. This is optional.
$GQ->generate;
$GQ->test;
DESCRIPTION
- new
-
C<< my $GQT=Games::QuizTaker->new(FileName=>"File",Delimiter=>",",AnswerDelimiter=>"|",Score=>1); >> This method creates the Games::QuizTaker object as an inside out object. The method can take up to four arguments, and one of them (FileName) is mandatory. If the FileName argument is not passed, the method will croak. The Delimiter argument is the separator within the file that separates the question number, the question, its answers, and the correct answer. The AnswerDelimiter is used to separate the answers of questions that have multiple answers. The Score method takes a numeric argument. If set to 1, it will print out an overall score at the end of the test. If left undefined(the default), it will not print the results. This is useful if setup in a login script to do a single question at login. The default for the Delimiter parameter is the pipe "|" chararcter, and the default for the AnswerDelimiter is a space. Also note that while the method names are case-sensitive, the parameter names are not, so the parameters can be spelled in all lower case and the object will still put the parameters and their arguments exactly where they belong.
- load
-
C<< $GQT->load; >> This method loads the question file into the object, and sets the internal FileLength parameter.
- generate
-
C<< $GQT->generate; >> This method will load all of the questions and answers into the test hashes by default, unless the MaxQuestions internal parameter has been set. This is checked for at the beginning of the method
- test
-
$GQT->test;
This method actually prints the questions out and waits for the answer input. It will check the user's input against the correct answer and report back if they match or not.
- get/set methods
-
The purpose of these methods should be self-explanatory, so I won't go into them other than to provide a list of them: get_FileName,set_FileName get_AnswerDelimeter,set_AnswerDelimeter get_Delimeter,set_Delimeter get_Score,set_Score get_FileLength,set_FileLength get_MaxQuestions,set_MaxQuestions
EXPORT
None by default
DEBUGGING
None by default
TODO LIST
None by default
ACKNOWLEDGEMENTS
Thanks to Jerry D. Heden for creating the Object::InsideOut module which I used to create this version of Games::QuizTaker. Thanks to Damian Conway for his book "Perl Best Practices" which gave me the initial idea to use an insideout object to implement the module
AUTHOR
Thomas Stanley
Thomas_J_Stanley@msn.com
I can also be found at http://www.perlmonks.org as TStanley. You can also direct any questions relating to this module there.
COPYRIGHT
Copyright E2001-2006 Thomas Stanley. All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.SEE ALSO
perl(1) Object::InsideOut