mirror of
https://gitlab.com/Nanolx/homebrewfilter.git
synced 2024-11-01 07:05:10 +01:00
add reinstall option to installer
This commit is contained in:
parent
1d12b08be1
commit
f78c509547
@ -35,7 +35,7 @@ void show_menu_head()
|
||||
{
|
||||
Con_FgColor(6, 1);
|
||||
printf("\x1b[%i;%iH", startpos_x, startpos_y);
|
||||
printf("HBF installer v0.3");
|
||||
printf("HBF installer v0.4");
|
||||
|
||||
Con_FgColor(7, 1);
|
||||
printf("\t\t\t\t\t(C) 2011");
|
||||
@ -55,9 +55,14 @@ void fill_menu_main()
|
||||
buffer << "Install the HomebrewFilter rev" << SvnRev();
|
||||
text1.push_back(buffer.str());
|
||||
if(CheckAppFound(GetTitleID()))
|
||||
{
|
||||
text1.push_back("Reinstall the HomebrewFilter");
|
||||
text1.push_back("Uninstall the HomebrewFilter");
|
||||
}
|
||||
else
|
||||
{
|
||||
text1.push_back("");
|
||||
}
|
||||
text1.push_back("");
|
||||
text1.push_back("Copyright");
|
||||
text1.push_back("");
|
||||
@ -107,6 +112,10 @@ void menu()
|
||||
currentMenu = menu_install_uninstall(1);
|
||||
break;
|
||||
|
||||
case MENU_REINSTALL:
|
||||
currentMenu = menu_install_uninstall(2);
|
||||
break;
|
||||
|
||||
case MENU_UNINSTALL:
|
||||
currentMenu = menu_install_uninstall(0);
|
||||
break;
|
||||
@ -115,6 +124,10 @@ void menu()
|
||||
currentMenu = menu_install();
|
||||
break;
|
||||
|
||||
case MENU_REINSTALLING:
|
||||
currentMenu = menu_reinstall();
|
||||
break;
|
||||
|
||||
case MENU_UNINSTALLING:
|
||||
currentMenu = menu_uninstall();
|
||||
break;
|
||||
@ -202,9 +215,12 @@ int menu_main(int scrollpos)
|
||||
return MENU_INSTALL;
|
||||
|
||||
case 1:
|
||||
return MENU_REINSTALL;
|
||||
|
||||
case 2:
|
||||
return MENU_UNINSTALL;
|
||||
|
||||
case 3:
|
||||
case 4:
|
||||
return MENU_COPYRIGHT;
|
||||
|
||||
default:
|
||||
@ -221,10 +237,12 @@ int menu_install_uninstall(int install)
|
||||
|
||||
Con_FgColor(7, 1);
|
||||
printf("\x1b[%i;%iH", startpos_x +2, startpos_y);
|
||||
if(install)
|
||||
if(install == 0)
|
||||
printf("Install the HomebrewFilter now");
|
||||
else
|
||||
else if(install == 1)
|
||||
printf("Uninstall the HomebrewFilter now");
|
||||
else if(install == 2)
|
||||
printf("Reinstall the HomebrewFilter now");
|
||||
|
||||
for(int i=0; i < (signed)text2.size(); i++)
|
||||
{
|
||||
@ -277,10 +295,12 @@ int menu_install_uninstall(int install)
|
||||
switch(scrollpos)
|
||||
{
|
||||
case 0:
|
||||
if(install)
|
||||
if(install == 0)
|
||||
return MENU_INSTALLING;
|
||||
else
|
||||
else if(install == 1)
|
||||
return MENU_UNINSTALLING;
|
||||
else if(install == 2)
|
||||
return MENU_REINSTALLING;
|
||||
break;
|
||||
|
||||
case 1:
|
||||
@ -351,6 +371,73 @@ int menu_install()
|
||||
}
|
||||
}
|
||||
|
||||
int menu_reinstall()
|
||||
{
|
||||
Con_Clear();
|
||||
show_menu_head();
|
||||
|
||||
Con_FgColor(7, 1);
|
||||
printf("\x1b[%i;%iH", startpos_x +2, startpos_y);
|
||||
printf("Uninstalling the HomebrewFilter");
|
||||
|
||||
Wad_UninstallFromMemory(startpos_x, startpos_y);
|
||||
|
||||
Con_FgColor(7, 1);
|
||||
printf("\x1b[%i;%iH", startpos_x +8, startpos_y);
|
||||
printf("Installing the HomebrewFilter");
|
||||
|
||||
printf("\x1b[%i;%iH", startpos_x +9, startpos_y);
|
||||
if(Wad_InstallFromMemory(startpos_x, startpos_y) >= 0)
|
||||
{
|
||||
if(!getIOS(58))
|
||||
{
|
||||
s32 fd;
|
||||
u32 high = (u32)(GetTitleID() >> 32);
|
||||
u32 low = (u32)(GetTitleID() & 0xFFFFFFFF);
|
||||
|
||||
char filepath[ISFS_MAXPATH];
|
||||
sprintf(filepath, "/title/%08x/%08x/content/title.tmd", high, low);
|
||||
|
||||
static fstats filestats ATTRIBUTE_ALIGN(32);
|
||||
static u8 filearray[1024] ATTRIBUTE_ALIGN(32);
|
||||
|
||||
fd = ISFS_Open(filepath, ISFS_OPEN_READ);
|
||||
if (fd <= 0)
|
||||
ISFS_Close(fd);
|
||||
|
||||
ISFS_GetFileStats(fd, &filestats);
|
||||
ISFS_Read(fd, filearray, filestats.file_length);
|
||||
ISFS_Close(fd);
|
||||
|
||||
if(filestats.file_length >= 0)
|
||||
{
|
||||
fd = ISFS_Open(filepath, ISFS_OPEN_RW);
|
||||
|
||||
if(getIOS(61))
|
||||
filearray[395] = 61;
|
||||
else
|
||||
filearray[395] = IOS_GetVersion();
|
||||
|
||||
ISFS_Write(fd, filearray, sizeof( filearray ));
|
||||
ISFS_Close(fd);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Con_FgColor(7, 1);
|
||||
printf("\x1b[%i;%iH", startpos_x +11, startpos_y);
|
||||
printf(">> Continue");
|
||||
|
||||
while(1)
|
||||
{
|
||||
WPAD_ScanPads();
|
||||
PAD_ScanPads();
|
||||
if( WPAD_ButtonsDown(0) & (WPAD_BUTTON_A | WPAD_CLASSIC_BUTTON_A) || PAD_ButtonsDown(0) & PAD_BUTTON_A )
|
||||
return MENU_MAIN;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
int menu_uninstall()
|
||||
{
|
||||
Con_Clear();
|
||||
|
@ -5,14 +5,17 @@ int menu_install_uninstall(int);
|
||||
int menu_install();
|
||||
int menu_uninstall();
|
||||
int menu_copyright();
|
||||
int menu_reinstall();
|
||||
|
||||
enum
|
||||
{
|
||||
MENU_EXIT = -1,
|
||||
MENU_MAIN,
|
||||
MENU_INSTALL,
|
||||
MENU_REINSTALL,
|
||||
MENU_UNINSTALL,
|
||||
MENU_INSTALLING,
|
||||
MENU_REINSTALLING,
|
||||
MENU_UNINSTALLING,
|
||||
MENU_COPYRIGHT
|
||||
};
|
||||
|
@ -349,7 +349,7 @@ s32 __Wad_Install(int startpos_x, int startpos_y)
|
||||
if (ret >= 0)
|
||||
{
|
||||
Con_FgColor(2, 1);
|
||||
printf("\x1b[%i;%iH", startpos_x +6, startpos_y);
|
||||
printf("\x1b[%i;%iH", startpos_x +9, startpos_y + 42);
|
||||
printf("SUCCESS");
|
||||
|
||||
goto out;
|
||||
|
5
updates
5
updates
@ -15,6 +15,11 @@
|
||||
- BUGFIX: fix compilation with libOGC 1.8.11 and newer
|
||||
- BUGFIX: installer upon exit checks whether THBF channel is installed,
|
||||
if so, it will start the HomebrewFilter, else it enters SysMenu
|
||||
- Add 'Reinstall the HomebrewFilter' option in the installer. If you
|
||||
installation fails for you, when you update from an older version use
|
||||
this option. (the failure is caused by IOS58 not beeing able to
|
||||
downgrade an existing channel - old THBF channel had version 512,
|
||||
new THBF channel has same version than the application.)
|
||||
|
||||
//rev38:
|
||||
- changes to the app-info dialog:
|
||||
|
Loading…
Reference in New Issue
Block a user