| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | // Copyright (C) 2003-2008 Dolphin Project.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // This program is free software: you can redistribute it and/or modify
 | 
					
						
							|  |  |  | // it under the terms of the GNU General Public License as published by
 | 
					
						
							|  |  |  | // the Free Software Foundation, version 2.0.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // This program is distributed in the hope that it will be useful,
 | 
					
						
							|  |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
					
						
							|  |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
					
						
							|  |  |  | // GNU General Public License 2.0 for more details.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // A copy of the GPL 2.0 should have been included with the program.
 | 
					
						
							|  |  |  | // If not, see http://www.gnu.org/licenses/
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Official SVN repository and contact information can be found at
 | 
					
						
							|  |  |  | // http://code.google.com/p/dolphin-emu/
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-06 00:11:16 +00:00
										 |  |  | // -----------
 | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | // Include
 | 
					
						
							| 
									
										
										
										
											2009-09-06 00:11:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-04 13:46:04 +00:00
										 |  |  | #include "stdafx.h"
 | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | #include <iostream>
 | 
					
						
							|  |  |  | #include <vector>
 | 
					
						
							|  |  |  | #include <string>
 | 
					
						
							|  |  |  | #include <algorithm>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-04 13:46:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | #include "Common.h"	// Common
 | 
					
						
							|  |  |  | #include "IniFile.h"
 | 
					
						
							|  |  |  | #include "LogManager.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-06 16:06:49 +00:00
										 |  |  | #include "../../Core/Src/Core.h"
 | 
					
						
							| 
									
										
										
										
											2009-09-04 13:50:22 +00:00
										 |  |  | #include "../../Core/Src/ConfigManager.h"
 | 
					
						
							| 
									
										
										
										
											2009-09-04 13:46:04 +00:00
										 |  |  | #include "FileSystemGCWii.h"
 | 
					
						
							|  |  |  | #include "VolumeCreator.h"
 | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace FileMon | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-06 00:11:16 +00:00
										 |  |  | // -----------
 | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | // Declarations and definitions
 | 
					
						
							| 
									
										
										
										
											2009-09-06 00:11:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | DiscIO::IVolume *OpenISO; | 
					
						
							|  |  |  | DiscIO::IFileSystem *pFileSystem = NULL; | 
					
						
							|  |  |  | std::vector<const DiscIO::SFileInfo *> GCFiles; | 
					
						
							|  |  |  | std::string ISOFile, CurrentFile; | 
					
						
							|  |  |  | bool FileAccess = true; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-06 00:11:16 +00:00
										 |  |  | // -----------
 | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | // Filtered files
 | 
					
						
							| 
									
										
										
										
											2009-09-06 00:11:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | bool ShowSound(std::string FileName) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	std::string Ending; | 
					
						
							|  |  |  | 	SplitPath(FileName, NULL, NULL, &Ending); | 
					
						
							|  |  |  | 	std::transform(Ending.begin(),Ending.end(),Ending.begin(),::tolower); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (   | 
					
						
							|  |  |  | 		   (Ending == ".adp") // 1080 Avalanche, Crash Bandicoot, etc
 | 
					
						
							|  |  |  | 		|| (Ending == ".afc") // Zelda WW
 | 
					
						
							|  |  |  | 		|| (Ending == ".ast") // Zelda TP, Mario Kart
 | 
					
						
							|  |  |  | 		|| (Ending == ".dsp") // Metroid Prime
 | 
					
						
							|  |  |  | 		|| (Ending == ".hps") // SSB Melee
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		|| (Ending == ".brstm") // Wii Sports, Wario Land, etc
 | 
					
						
							|  |  |  | 		|| (Ending == ".sad") // Disaster
 | 
					
						
							|  |  |  | 		) | 
					
						
							|  |  |  | 		return true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-06 00:11:16 +00:00
										 |  |  | // -----------
 | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | // Read the GC file system
 | 
					
						
							| 
									
										
										
										
											2009-09-06 00:11:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | void ReadGC(std::string FileName) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-09-04 18:25:43 +00:00
										 |  |  | 	GCFiles.clear(); | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | 	OpenISO = DiscIO::CreateVolumeFromFilename(FileName); | 
					
						
							| 
									
										
										
										
											2009-09-04 18:21:10 +00:00
										 |  |  | 	if (!OpenISO) return; | 
					
						
							| 
									
										
										
										
											2009-09-11 06:55:43 +00:00
										 |  |  | 	if (!DiscIO::IsVolumeWiiDisc(OpenISO) && !DiscIO::IsVolumeWadFile(OpenISO)) | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		pFileSystem = DiscIO::CreateFileSystem(OpenISO); | 
					
						
							|  |  |  | 		pFileSystem->GetFileList(GCFiles); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	FileAccess = true; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-06 00:11:16 +00:00
										 |  |  | // -----------
 | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | // Check if we should play this file
 | 
					
						
							| 
									
										
										
										
											2009-09-06 00:11:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | void CheckFile(std::string File, int Size) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	// Don't do anything if the log is unselected
 | 
					
						
							| 
									
										
										
										
											2009-09-04 11:34:21 +00:00
										 |  |  | 	if (!LogManager::GetInstance()->isEnable(LogTypes::FILEMON)) return; | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | 	// Do nothing if we found the same file again
 | 
					
						
							|  |  |  | 	if (CurrentFile == File) return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (Size > 0) Size = (Size / 1000); | 
					
						
							|  |  |  | 	std::string Str = StringFromFormat("%s kB %s", ThS(Size, true, 7).c_str(), File.c_str()); | 
					
						
							|  |  |  | 	if (ShowSound(File)) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		NOTICE_LOG(FILEMON, Str.c_str()); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		WARN_LOG(FILEMON, Str.c_str()); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Update the current file
 | 
					
						
							|  |  |  | 	CurrentFile = File; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-06 00:11:16 +00:00
										 |  |  | // -----------
 | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | // Find the GC filename
 | 
					
						
							|  |  |  | void FindFilename(u64 offset) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-09-06 16:06:49 +00:00
										 |  |  | 	// Don't do anything if a game is not running
 | 
					
						
							|  |  |  | 	if (Core::GetState() != Core::CORE_RUN) return; | 
					
						
							|  |  |  | 	// Or if the log is unselected
 | 
					
						
							| 
									
										
										
										
											2009-09-04 11:34:21 +00:00
										 |  |  | 	if (!LogManager::GetInstance()->isEnable(LogTypes::FILEMON)) return; | 
					
						
							| 
									
										
										
										
											2009-09-03 20:13:50 +00:00
										 |  |  | 	if (!FileAccess) return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!pFileSystem || ISOFile != SConfig::GetInstance().m_LastFilename) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		FileAccess = false; | 
					
						
							|  |  |  | 		ReadGC(SConfig::GetInstance().m_LastFilename); | 
					
						
							|  |  |  | 		ISOFile = SConfig::GetInstance().m_LastFilename; | 
					
						
							|  |  |  | 		NOTICE_LOG(FILEMON, "Opening '%s'", ISOFile.c_str()); | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// File
 | 
					
						
							|  |  |  | 	if (!pFileSystem->GetFileName(offset)) return; | 
					
						
							|  |  |  | 	std::string File = std::string(pFileSystem->GetFileName(offset)); | 
					
						
							|  |  |  | 	// There's something wrong with the paths
 | 
					
						
							|  |  |  | 	if (File.length() == 512) return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int Size = (int)pFileSystem->GetFileSize(File.c_str()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	CheckFile(File, Size); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // FileMon
 |