diff --git a/source/menu.cpp b/source/menu.cpp index 2433928..5e55aee 100644 --- a/source/menu.cpp +++ b/source/menu.cpp @@ -135,6 +135,9 @@ void ResetText() int WindowPrompt(const char *title, const char *msg, const char *btn1Label, const char *btn2Label) { + if(!mainWindow || ExitRequested || ShutdownRequested) + return 0; + int choice = -1; GuiWindow promptWindow(448,288); diff --git a/source/networkop.cpp b/source/networkop.cpp index ef835f7..4fd348e 100644 --- a/source/networkop.cpp +++ b/source/networkop.cpp @@ -47,61 +47,64 @@ bool updateFound = false; // true if an app update was found void UpdateCheck() { - // we can only check for the update if we have internet + SD - if(!updateChecked && networkInit && (isMounted[DEVICE_SD] || isMounted[DEVICE_USB])) + // we only check for an update if we have internet + SD/USB + if(updateChecked || !networkInit) + return; + + if(!isMounted[DEVICE_SD] && !isMounted[DEVICE_USB]) + return; + + updateChecked = true; + u8 tmpbuffer[256]; + + if (http_request("http://fceugc.googlecode.com/svn/trunk/update.xml", NULL, tmpbuffer, 256, SILENT) <= 0) + return; + + mxml_node_t *xml; + mxml_node_t *item; + + xml = mxmlLoadString(NULL, (char *)tmpbuffer, MXML_TEXT_CALLBACK); + + if(!xml) + return; + + // check settings version + item = mxmlFindElement(xml, xml, "app", "version", NULL, MXML_DESCEND); + if(item) // a version entry exists { - updateChecked = true; - u8 tmpbuffer[256]; + const char * version = mxmlElementGetAttr(item, "version"); - if (http_request("http://fceugc.googlecode.com/svn/trunk/update.xml", NULL, tmpbuffer, 256, SILENT) > 0) + if(version && strlen(version) == 5) { - mxml_node_t *xml; - mxml_node_t *item; + int verMajor = version[0] - '0'; + int verMinor = version[2] - '0'; + int verPoint = version[4] - '0'; + int curMajor = APPVERSION[0] - '0'; + int curMinor = APPVERSION[2] - '0'; + int curPoint = APPVERSION[4] - '0'; - xml = mxmlLoadString(NULL, (char *)tmpbuffer, MXML_TEXT_CALLBACK); - - if(xml) + // check that the versioning is valid and is a newer version + if((verMajor >= 0 && verMajor <= 9 && + verMinor >= 0 && verMinor <= 9 && + verPoint >= 0 && verPoint <= 9) && + (verMajor > curMajor || + (verMajor == curMajor && verMinor > curMinor) || + (verMajor == curMajor && verMinor == curMinor && verPoint > curPoint))) { - // check settings version - item = mxmlFindElement(xml, xml, "app", "version", NULL, MXML_DESCEND); - if(item) // a version entry exists + item = mxmlFindElement(xml, xml, "file", NULL, NULL, MXML_DESCEND); + if(item) { - const char * version = mxmlElementGetAttr(item, "version"); - - if(version && strlen(version) == 5) + const char * tmp = mxmlElementGetAttr(item, "url"); + if(tmp) { - int verMajor = version[0] - '0'; - int verMinor = version[2] - '0'; - int verPoint = version[4] - '0'; - int curMajor = APPVERSION[0] - '0'; - int curMinor = APPVERSION[2] - '0'; - int curPoint = APPVERSION[4] - '0'; - - // check that the versioning is valid and is a newer version - if((verMajor >= 0 && verMajor <= 9 && - verMinor >= 0 && verMinor <= 9 && - verPoint >= 0 && verPoint <= 9) && - (verMajor > curMajor || - (verMajor == curMajor && verMinor > curMinor) || - (verMajor == curMajor && verMinor == curMinor && verPoint > curPoint))) - { - item = mxmlFindElement(xml, xml, "file", NULL, NULL, MXML_DESCEND); - if(item) - { - const char * tmp = mxmlElementGetAttr(item, "url"); - if(tmp) - { - snprintf(updateURL, 128, "%s", tmp); - updateFound = true; - } - } - } + snprintf(updateURL, 128, "%s", tmp); + updateFound = true; } } - mxmlDelete(xml); } } } + mxmlDelete(xml); } static bool unzipArchive(char * zipfilepath, char * unzipfolderpath)