本文整理汇总了PHP中game_insert_record函数的典型用法代码示例。如果您正苦于以下问题:PHP game_insert_record函数的具体用法?PHP game_insert_record怎么用?PHP game_insert_record使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了game_insert_record函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: game_millionaire_continue
/**
* This file plays the game millionaire
*
* @author bdaloukas
* @version $Id: play.php,v 1.31 2012/07/25 11:16:05 bdaloukas Exp $
* @package game
**/
function game_millionaire_continue($id, $game, $attempt, $millionaire, $context)
{
// User must select quiz or question as a source module.
if ($game->quizid == 0 and $game->questioncategoryid == 0) {
if ($game->sourcemodule == 'quiz') {
print_error(get_string('millionaire_must_select_quiz', 'game'));
} else {
print_error(get_string('millionaire_must_select_questioncategory', 'game'));
}
}
if ($attempt != false and $millionaire != false) {
// Continue an existing game.
return game_millionaire_play($id, $game, $attempt, $millionaire, $context);
}
if ($attempt == false) {
$attempt = game_addattempt($game);
}
$newrec = new stdClass();
$newrec->id = $attempt->id;
$newrec->queryid = 0;
$newrec->level = 0;
$newrec->state = 0;
if (!game_insert_record('game_millionaire', $newrec)) {
print_error('error inserting in game_millionaire');
}
game_millionaire_play($id, $game, $attempt, $newrec, $context);
}
示例2: save
function save($game, &$crossm, $crossd, $id, $letters)
{
global $USER;
CrossDB::delete_cross($id);
if (CrossDB::save($game, $crossm, $crossd, $id) == false) {
return false;
}
$crossm->id = $id;
$newrec->id = $id;
$newrec->letters = $letters;
if (!($cryptexid = game_insert_record("game_cryptex", $newrec))) {
print_error('Insert page: new page game_cryptex not inserted');
}
return $newrec;
}
示例3: game_bookquiz_continue
function game_bookquiz_continue($id, $game, $attempt, $bookquiz, $chapterid = 0)
{
if ($attempt != false and $bookquiz != false) {
return game_bookquiz_play($id, $game, $attempt, $bookquiz, $chapterid);
}
if ($attempt == false) {
$attempt = game_addattempt($game);
}
unset($bookquiz);
$bookquiz->lastchapterid = 0;
$bookquiz->id = $attempt->id;
if (!game_insert_record('game_bookquiz', $bookquiz)) {
error('game_bookquiz_continue: error inserting in game_bookquiz');
}
return game_bookquiz_play($id, $game, $attempt, $bookquiz, 0);
}
示例4: game_bookquiz_continue
function game_bookquiz_continue($id, $game, $attempt, $bookquiz, $chapterid, $context)
{
if ($attempt != false and $bookquiz != false) {
return game_bookquiz_play($id, $game, $attempt, $bookquiz, $chapterid, $context);
}
if ($attempt == false) {
$attempt = game_addattempt($game);
}
$bookquiz = new stdClass();
$bookquiz->lastchapterid = 0;
$bookquiz->id = $attempt->id;
$bookquiz->bookid = $game->bookid;
if (!game_insert_record('game_bookquiz', $bookquiz)) {
print_error('game_bookquiz_continue: error inserting in game_bookquiz');
}
return game_bookquiz_play($id, $game, $attempt, $bookquiz, 0, $context);
}
示例5: game_snakes_continue
function game_snakes_continue($id, $game, $attempt, $snakes)
{
if ($attempt != false and $snakes != false) {
return game_snakes_play($id, $game, $attempt, $snakes);
}
if ($attempt === false) {
$attempt = game_addattempt($game);
}
$newrec->id = $attempt->id;
$newrec->snakesdatabaseid = $game->param3;
$newrec->position = 1;
$newrec->queryid = 0;
$newrec->dice = rand(1, 6);
if (!game_insert_record('game_snakes', $newrec)) {
error('game_snakes_continue: error inserting in game_snakes');
}
game_updateattempts($game, $attempt, 0, 0);
return game_snakes_play($id, $game, $attempt, $newrec);
}
示例6: save
function save($game, &$crossm, $crossd, $id)
{
global $USER;
$crossm->id = $id;
$crossm->sourcemodule = $game->sourcemodule;
if (!game_insert_record("game_cross", $crossm)) {
error("Insert page: new page game_cross not inserted");
}
foreach ($crossd as $rec) {
$rec->attemptid = $id;
$rec->questiontext = addslashes($rec->questiontext);
$rec->gamekind = $game->gamekind;
$rec->gameid = $game->id;
$rec->userid = $USER->id;
$rec->sourcemodule = $game->sourcemodule;
if (!insert_record("game_queries", $rec)) {
error("Insert page: new page game_queries not inserted");
}
}
return true;
}
示例7: game_millionaire_continue
/**
* This files plays the game millionaire
*
* @author bdaloukas
* @version $Id: play.php,v 1.16 2009/09/12 08:12:56 bdaloukas Exp $
* @package game
**/
function game_millionaire_continue($id, $game, $attempt, $millionaire)
{
//User must select quiz or question as a source module
if ($game->quizid == 0 and $game->questioncategoryid == 0) {
error(get_string($game->sourcemodule == 'quiz' ? 'millionaire_must_select_quiz' : 'millionaire_must_select_questioncategory'));
}
if ($attempt != false and $millionaire != false) {
//continue an existing game
return game_millionaire_play($id, $game, $attempt, $millionaire);
}
if ($attempt == false) {
$attempt = game_addattempt($game);
}
$newrec->id = $attempt->id;
$newrec->queryid = 0;
$newrec->level = 0;
$newrec->state = 0;
if (!game_insert_record('game_millionaire', $newrec)) {
error('error inserting in game_millionaire');
}
game_millionaire_play($id, $game, $attempt, $newrec);
}
示例8: save
function save($game, &$crossm, $crossd, $id)
{
global $DB, $USER;
$crossm->id = $id;
$crossm->sourcemodule = $game->sourcemodule;
if (!game_insert_record("game_cross", $crossm)) {
print_error('Insert page: new page game_cross not inserted');
}
foreach ($crossd as $rec) {
$rec->attemptid = $id;
$rec->questiontext = addslashes($rec->questiontext);
$rec->gamekind = $game->gamekind;
$rec->gameid = $game->id;
$rec->userid = $USER->id;
$rec->sourcemodule = $game->sourcemodule;
if (!$DB->insert_record('game_queries', $rec)) {
print_error('Insert page: new page game_queries not inserted');
}
game_update_repetitions($game->id, $USER->id, $rec->questionid, $rec->glossaryentryid);
}
return true;
}
示例9: game_sudoku_continue
function game_sudoku_continue($id, $game, $attempt, $sudoku, $endofgame, $context)
{
global $CFG, $DB, $USER;
if ($endofgame) {
game_updateattempts($game, $attempt, -1, true);
$endofgame = false;
}
if ($attempt != false and $sudoku != false) {
return game_sudoku_play($id, $game, $attempt, $sudoku, false, false, $context);
}
if ($attempt == false) {
$attempt = game_addattempt($game);
}
//new game
srand((double) microtime() * 1000000);
$recsudoku = getrandomsudoku();
if ($recsudoku == false) {
print_error('Empty sudoku database');
}
$newrec = new stdClass();
$newrec->id = $attempt->id;
$newrec->guess = '';
$newrec->data = $recsudoku->data;
$newrec->opened = $recsudoku->opened;
$need = 81 - $recsudoku->opened;
$closed = game_sudoku_getclosed($newrec->data);
$n = min(count($closed), $need);
//if the teacher set the maximum number of questions
if ($game->param2 > 0) {
if ($game->param2 < $n) {
$n = $game->param2;
}
}
$recs = game_questions_selectrandom($game, CONST_GAME_TRIES_REPETITION * $n);
if ($recs === false) {
mysql_execute("DELETE FROM {game_sudoku} WHERE id={$game->id}");
print_error(get_string('no_questions', 'game'));
}
$closed = array_rand($closed, $n);
$selected_recs = game_select_from_repetitions($game, $recs, $n);
if (!game_insert_record('game_sudoku', $newrec)) {
print_error('error inserting in game_sudoku');
}
$i = 0;
$field = $game->sourcemodule == 'glossary' ? 'glossaryentryid' : 'questionid';
foreach ($recs as $rec) {
if ($game->sourcemodule == 'glossary') {
$key = $rec->glossaryentryid;
} else {
$key = $rec->questionid;
}
if (!array_key_exists($key, $selected_recs)) {
continue;
}
$query = new stdClass();
$query->attemptid = $newrec->id;
$query->gamekind = $game->gamekind;
$query->gameid = $game->id;
$query->userid = $USER->id;
$query->col = $closed[$i++];
$query->sourcemodule = $game->sourcemodule;
$query->questionid = $rec->questionid;
$query->glossaryentryid = $rec->glossaryentryid;
$query->score = 0;
if (($query->id = $DB->insert_record('game_queries', $query)) == 0) {
print_error('error inserting in game_queries');
}
game_update_repetitions($game->id, $USER->id, $query->questionid, $query->glossaryentryid);
}
game_updateattempts($game, $attempt, 0, 0);
game_sudoku_play($id, $game, $attempt, $newrec, false, false, $context);
}
示例10: game_hiddenpicture_selectglossaryentry
function game_hiddenpicture_selectglossaryentry($game, $attempt)
{
global $CFG, $DB, $USER;
srand((double) microtime() * 1000000);
if ($game->glossaryid2 == 0) {
print_error(get_string('must_select_glossary', 'game'));
}
$select = "ge.glossaryid={$game->glossaryid2}";
$table = '{glossary_entries} ge';
if ($game->glossarycategoryid2) {
$table .= ",{glossary_entries_categories} gec";
$select .= " AND gec.entryid = ge.id AND gec.categoryid = {$game->glossarycategoryid2}";
}
if ($game->param7 == 0) {
//Allow spaces
$select .= " AND concept NOT LIKE '% %'";
}
$sql = "SELECT ge.id,attachment FROM {$table} WHERE {$select}";
if (($recs = $DB->get_records_sql($sql)) == false) {
$a->name = "'" . $DB->get_field('glossary', 'name', array('id' => $game->glossaryid2)) . "'";
print_error(get_string('hiddenpicture_nomainquestion', 'game', $a));
return false;
}
$ids = array();
$keys = array();
$fs = get_file_storage();
$cmg = get_coursemodule_from_instance('glossary', $game->glossaryid2, $game->course);
$context = game_get_context_module_instance($cmg->id);
foreach ($recs as $rec) {
$files = $fs->get_area_files($context->id, 'mod_glossary', 'attachment', $rec->id, "timemodified", false);
if ($files) {
foreach ($files as $key => $file) {
$s = strtoupper($file->get_filename());
$s = substr($s, -4);
if ($s == '.GIF' or $s == '.JPG' or $s == '.PNG') {
$ids[] = $rec->id;
$keys[] = $file->get_pathnamehash();
}
}
}
}
if (count($ids) == 0) {
$a->name = "'" . $DB->get_field('glossary', 'name', array('id' => $game->glossaryid2)) . "'";
print_error(get_string('hiddenpicture_nomainquestion', 'game', $a));
return false;
}
//Have to select randomly one glossaryentry
$poss = array();
for ($i = 0; $i < count($ids); $i++) {
$poss[] = $i;
}
shuffle($poss);
$min_num = 0;
$attachement = '';
for ($i = 0; $i < count($ids); $i++) {
$pos = $poss[$i];
$tempid = $ids[$pos];
$a = array('gameid' => $game->id, 'userid' => $USER->id, 'questionid' => 0, 'glossaryentryid' => $tempid);
if (($rec2 = $DB->get_record('game_repetitions', $a, 'id,repetitions r')) != false) {
if ($rec2->r < $min_num or $min_num == 0) {
$min_num = $rec2->r;
$glossaryentryid = $tempid;
$attachement = $keys[$pos];
}
} else {
$glossaryentryid = $tempid;
$attachement = $keys[$pos];
break;
}
}
$sql = 'SELECT id, concept as answertext, definition as questiontext, id as glossaryentryid, 0 as questionid, glossaryid, attachment' . ' FROM {glossary_entries} WHERE id = ' . $glossaryentryid;
if (($rec = $DB->get_record_sql($sql)) == false) {
return false;
}
$query = new stdClass();
$query->attemptid = $attempt->id;
$query->gamekind = $game->gamekind;
$query->gameid = $game->id;
$query->userid = $USER->id;
$query->col = 0;
$query->sourcemodule = 'glossary';
$query->questionid = 0;
$query->glossaryentryid = $rec->glossaryentryid;
$query->attachment = $attachement;
$query->questiontext = $rec->questiontext;
$query->answertext = $rec->answertext;
$query->score = 0;
if (($query->id = $DB->insert_record('game_queries', $query)) == 0) {
print_error('Error inserting in game_queries');
}
$newrec = new stdClass();
$newrec->id = $attempt->id;
$newrec->correct = 0;
if (!game_insert_record('game_hiddenpicture', $newrec)) {
print_error('Error inserting in game_hiddenpicture');
}
game_update_repetitions($game->id, $USER->id, $query->questionid, $query->glossaryentryid);
return $newrec;
}
示例11: unset
unset($html);
$html->id = $game->id;
$html->checkbutton = 1;
$html->printbutton = 1;
game_insert_record('game_export_html', $html);
$html = $DB->get_record('game_export_html', array('id' => $game->id));
}
$html->type = 0;
$mform = new mod_game_exporthtml_form(null, array('id' => $id, 'html' => $html));
} else {
$javame = $DB->get_record('game_export_javame', array('id' => $game->id));
if ($javame == false) {
unset($javame);
$javame->id = $game->id;
$javame->filename = $game->gamekind;
game_insert_record('game_export_javame', $javame);
$javame = $DB->get_record('game_export_javame', array('id' => $game->id));
}
$mform = new mod_game_exportjavame_form(null, array('id' => $id, 'javame' => $javame));
}
if ($mform->is_cancelled()) {
ob_end_flush();
if ($id) {
redirect("view.php?id={$cm->id}&mode=entry&hook={$id}");
} else {
redirect("view.php?id={$cm->id}");
}
} else {
if ($entry = $mform->get_data()) {
$mform->export();
} else {
示例12: game_sudoku_continue
function game_sudoku_continue($id, $game, $attempt, $sudoku, $endofgame = '')
{
global $CFG, $USER;
if ($endofgame) {
game_updateattempts($game, $attempt, -1, true);
$endofgame = false;
}
if ($attempt != false and $sudoku != false) {
return game_sudoku_play($id, $game, $attempt, $sudoku);
}
if ($attempt == false) {
$attempt = game_addattempt($game);
}
//new game
srand((double) microtime() * 1000000);
$recsudoku = getrandomsudoku();
if ($recsudoku == false) {
$link = "<a href=\"{$CFG->wwwroot}/mod/game/db/importsudoku.php\">import</a>";
echo get_string('sudoku_emptydatabase', 'game', $link);
die;
}
$newrec->id = $attempt->id;
$newrec->guess = '';
$newrec->data = $recsudoku->data;
$newrec->opened = $recsudoku->opened;
$need = 81 - $recsudoku->opened;
$recs = game_questions_selectrandom($game, $need);
if ($recs === false) {
error(get_string('sudoku_no_questions', 'game'));
}
$closed = game_sudoku_getclosed($newrec->data);
$n = min(count($closed), count($recs));
//if the teacher set the maximum number of questions
if ($game->param2 > 0) {
if ($game->param2 < $n) {
$n = $game->param2;
}
}
$closed = array_rand($closed, $n);
if (!game_insert_record('game_sudoku', $newrec)) {
error('error inserting in game_sudoku');
}
$i = 0;
foreach ($recs as $rec) {
if ($i >= $n) {
break;
}
unset($query);
$query->attemptid = $newrec->id;
$query->gamekind = $game->gamekind;
$query->gameid = $game->id;
$query->userid = $USER->id;
$query->col = $closed[$i++];
$query->sourcemodule = $game->sourcemodule;
$query->questionid = $rec->questionid;
$query->glossaryentryid = $rec->glossaryentryid;
$query->score = 0;
if (($query->id = insert_record("game_queries", $query)) == 0) {
error('error inserting in game_queries');
}
}
game_updateattempts($game, $attempt, 0, 0);
game_sudoku_play($id, $game, $attempt, $newrec);
}
示例13: game_hiddenpicture_selectglossaryentry
function game_hiddenpicture_selectglossaryentry($game, $attempt)
{
global $CFG, $USER;
srand((double) microtime() * 1000000);
if ($game->glossaryid2 == 0) {
error(get_string('must_select_glossary', 'game'));
}
$select = "ge.glossaryid={$game->glossaryid2}";
$table = 'glossary_entries ge';
if ($game->glossarycategoryid2) {
$table .= ",{$CFG->prefix}glossary_entries_categories gec";
$select .= " AND gec.entryid = ge.id AND gec.categoryid = {$game->glossarycategoryid2}";
}
if ($game->param7 == 0) {
//Allow spaces
$select .= " AND concept NOT LIKE '% %'";
}
$select .= " AND attachment LIKE '%.%'";
if (($recs = get_records_select($table, $select, '', 'ge.id,attachment')) == false) {
$a->name = "'" . get_field_select('glossary', 'name', "id={$game->glossaryid2}") . "'";
error(get_string('hiddenpicture_nomainquestion', 'game', $a));
return false;
}
$ids = array();
foreach ($recs as $rec) {
$s = strtoupper($rec->attachment);
$s = substr($s, -4);
if ($s == '.GIF' or $s == '.JPG' or $s == '.PNG') {
$ids[] = $rec->id;
}
}
if (count($ids) == 0) {
$a->name = "'" . get_field_select('glossary', 'name', "id={$game->glossaryid2}") . "'";
error(get_string('hiddenpicture_nomainquestion', 'game', $a));
return false;
}
$sel = mt_rand(0, count($ids) - 1);
$id = $ids[$sel];
$sql = 'SELECT id, concept as answertext, definition as questiontext, id as glossaryentryid, 0 as questionid, glossaryid, attachment' . " FROM {$CFG->prefix}glossary_entries WHERE id = {$id}";
if (($rec = get_record_sql($sql)) == false) {
return false;
}
$query->attemptid = $attempt->id;
$query->gamekind = $game->gamekind;
$query->gameid = $game->id;
$query->userid = $USER->id;
$query->col = 0;
$query->sourcemodule = 'glossary';
$query->questionid = 0;
$query->glossaryentryid = $rec->glossaryentryid;
$query->attachment = str_replace("\\", '/', $CFG->dataroot) . "/{$game->course}/moddata/glossary/{$game->glossaryid2}/{$query->glossaryentryid}/{$rec->attachment}";
$query->questiontext = $rec->questiontext;
$query->answertext = $rec->answertext;
$query->score = 0;
if (($query->id = insert_record("game_queries", $query)) == 0) {
error('error inserting in game_queries');
}
$newrec->id = $attempt->id;
if (!game_insert_record('game_hiddenpicture', $newrec)) {
error('error inserting in game_hiddenpicture');
}
return $newrec;
}
示例14: game_hangman_continue
//.........这里部分代码省略.........
if ($game->param7 == false) {
// I don't allow spaces.
if (strpos($answer, " ")) {
continue;
}
}
$copy = false;
$select2 = 'gameid=? AND userid=? AND questionid=? AND glossaryentryid=?';
if (($rec2 = $DB->get_record_select('game_repetitions', $select2, array($game->id, $USER->id, $rec->questionid, $rec->glossaryentryid), 'id,repetitions AS r')) != false) {
if ($rec2->r < $minnum or $minnum == 0) {
$minnum = $rec2->r;
$copy = true;
}
} else {
$minnum = 0;
$copy = true;
}
if ($copy) {
$found = true;
$min = new stdClass();
$min->questionid = $rec->questionid;
$min->glossaryentryid = $rec->glossaryentryid;
$min->attachment = $rec->attachment;
$min->questiontext = $rec->questiontext;
$min->answerid = $rec->answerid;
$min->answer = $answer;
$min->language = $game->language;
$min->allletters = $allletters;
if ($minnum == 0) {
break;
// We found an unused word.
}
} else {
$unchanged++;
}
if ($unchanged > 2) {
if ($found) {
break;
}
}
}
if ($found == false) {
print_error(get_string('no_words', 'game'));
}
// Found one word for hangman.
if ($attempt == false) {
$attempt = game_addattempt($game);
}
if (!$DB->set_field('game_attempts', 'language', $min->language, array('id' => $attempt->id))) {
print_error("game_hangman_continue: Can't set language");
}
$query = new stdClass();
$query->attemptid = $attempt->id;
$query->gameid = $game->id;
$query->userid = $USER->id;
$query->sourcemodule = $game->sourcemodule;
$query->questionid = $min->questionid;
$query->glossaryentryid = $min->glossaryentryid;
$query->attachment = $min->attachment;
$query->questiontext = addslashes($min->questiontext);
$query->score = 0;
$query->timelastattempt = time();
$query->answertext = $min->answer;
$query->answerid = $min->answerid;
if (!($query->id = $DB->insert_record('game_queries', $query))) {
print_error("game_hangman_continue: Can't insert to table game_queries");
}
$newrec = new stdClass();
$newrec->id = $attempt->id;
$newrec->queryid = $query->id;
if ($updatehangman == false) {
$newrec->maxtries = $game->param4;
if ($newrec->maxtries == 0) {
$newrec->maxtries = 1;
}
$newrec->finishedword = 0;
$newrec->corrects = 0;
}
$newrec->allletters = $min->allletters;
$letters = '';
if ($game->param1) {
$letters .= game_substr($min->answer, 0, 1);
}
if ($game->param2) {
$letters .= game_substr($min->answer, -1, 1);
}
$newrec->letters = $letters;
if ($updatehangman == false) {
if (!game_insert_record('game_hangman', $newrec)) {
print_error('game_hangman_continue: error inserting in game_hangman');
}
} else {
if (!$DB->update_record('game_hangman', $newrec)) {
print_error('game_hangman_continue: error updating in game_hangman');
}
$newrec = $DB->get_record('game_hangman', array('id' => $newrec->id));
}
game_update_repetitions($game->id, $USER->id, $query->questionid, $query->glossaryentryid);
game_hangman_play($id, $game, $attempt, $newrec, false, false, $context);
}
示例15: game_restore_snakes
function game_restore_snakes($newattemptid, $info, $restore)
{
global $CFG;
$status = true;
//Get the game_snakes array
if (array_key_exists('GAME_SNAKES', $info['#'])) {
$info = $info['#']['GAME_SNAKES'][0];
} else {
return $status;
}
//Now, build the game_snakes record structure
$game_snakes = new stdClass();
$game_snakes->id = $newattemptid;
$fields = array('snakesdatabaseid', 'queryid', 'position', 'dice');
game_restore_record($info, $game_snakes, $fields);
//We have to recode the some
game_recode($restore->backup_unique_code, $game_snakes, 'queryid', 'game_queries');
game_recode($restore->backup_unique_code, $game_snakes, 'snakesdatabaseid', 'game_snakes_database');
//The structure is equal to the db, so insert the game_snakes
if (game_insert_record("game_snakes", $game_snakes) == false) {
$status = false;
}
return $status;
}