aboutsummaryrefslogtreecommitdiffstats
path: root/inc/savegame.inc
diff options
context:
space:
mode:
authorpiernov <piernov@piernov.org>2016-05-04 14:39:10 +0200
committerpiernov <piernov@piernov.org>2016-05-04 14:39:10 +0200
commit30e4f5f70aef5de687bc021f8f7a1b34f209063f (patch)
treeffa3187c93dabafdb5a4ce9c1159381b297e3c1a /inc/savegame.inc
parent676ea92ed1c88b7490feb17f90978f613783293d (diff)
parentec7771705d62d09fcd142c87f4941604f31c1d76 (diff)
downloadcandybox-30e4f5f70aef5de687bc021f8f7a1b34f209063f.tar.gz
candybox-30e4f5f70aef5de687bc021f8f7a1b34f209063f.tar.bz2
candybox-30e4f5f70aef5de687bc021f8f7a1b34f209063f.tar.xz
candybox-30e4f5f70aef5de687bc021f8f7a1b34f209063f.zip
Merge branch 'feat/savegame' into piernov
Diffstat (limited to 'inc/savegame.inc')
-rw-r--r--inc/savegame.inc20
1 files changed, 20 insertions, 0 deletions
diff --git a/inc/savegame.inc b/inc/savegame.inc
index 1fa95b0..8772585 100644
--- a/inc/savegame.inc
+++ b/inc/savegame.inc
@@ -89,4 +89,24 @@ function loadSave() {
$_SESSION = array(); // drop current game
parseSave($xml, $_SESSION);
}
+
+function uploadSave() {
+ $fname = basename($_FILES['savefile']['name']);
+ $src = $_FILES['savefile']['tmp_name'];
+
+ libxml_use_internal_errors(true); // Ignore errors when loading the received file
+ $xml = simplexml_load_file($src);
+ libxml_use_internal_errors(false);
+ if(!$xml) {
+ sendError("upload_fail");
+ return;
+ }
+ $table = array();
+ parseSave($xml, $table); // Parse received file
+
+ $save = new SimpleXMLElement("<save/>");
+ genXML($table, $save); // Regenerate it
+ if($save->asXML(SAVEDIR."/".$fname)) sendInfo("upload_success", array($fname));
+ else sendError("upload_error");
+}
?>