| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | // Copyright 2014 Citra Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-21 14:58:59 +01:00
										 |  |  | #include <cstring>
 | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | #include <memory>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2015-05-06 04:06:12 -03:00
										 |  |  | #include "common/logging/log.h"
 | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | #include "common/make_unique.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "core/file_sys/ivfc_archive.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | // FileSys namespace
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FileSys { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  | std::string IVFCArchive::GetName() const { | 
					
						
							|  |  |  |     return "IVFC"; | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | std::unique_ptr<FileBackend> IVFCArchive::OpenFile(const Path& path, const Mode mode) const { | 
					
						
							| 
									
										
										
										
											2015-07-10 00:55:23 +03:00
										 |  |  |     return Common::make_unique<IVFCFile>(romfs_file, data_offset, data_size); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool IVFCArchive::DeleteFile(const Path& path) const { | 
					
						
							| 
									
										
										
										
											2015-01-02 21:39:31 -05:00
										 |  |  |     LOG_CRITICAL(Service_FS, "Attempted to delete a file from an IVFC archive (%s).", GetName().c_str()); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  |     return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool IVFCArchive::RenameFile(const Path& src_path, const Path& dest_path) const { | 
					
						
							| 
									
										
										
										
											2015-01-02 21:39:31 -05:00
										 |  |  |     LOG_CRITICAL(Service_FS, "Attempted to rename a file within an IVFC archive (%s).", GetName().c_str()); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  |     return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool IVFCArchive::DeleteDirectory(const Path& path) const { | 
					
						
							| 
									
										
										
										
											2015-01-02 21:39:31 -05:00
										 |  |  |     LOG_CRITICAL(Service_FS, "Attempted to delete a directory from an IVFC archive (%s).", GetName().c_str()); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  |     return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-28 09:38:10 -05:00
										 |  |  | ResultCode IVFCArchive::CreateFile(const Path& path, u64 size) const { | 
					
						
							| 
									
										
										
										
											2015-01-02 21:39:31 -05:00
										 |  |  |     LOG_CRITICAL(Service_FS, "Attempted to create a file in an IVFC archive (%s).", GetName().c_str()); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  |     // TODO: Verify error code
 | 
					
						
							|  |  |  |     return ResultCode(ErrorDescription::NotAuthorized, ErrorModule::FS, ErrorSummary::NotSupported, ErrorLevel::Permanent); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool IVFCArchive::CreateDirectory(const Path& path) const { | 
					
						
							| 
									
										
										
										
											2015-01-02 21:39:31 -05:00
										 |  |  |     LOG_CRITICAL(Service_FS, "Attempted to create a directory in an IVFC archive (%s).", GetName().c_str()); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  |     return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool IVFCArchive::RenameDirectory(const Path& src_path, const Path& dest_path) const { | 
					
						
							| 
									
										
										
										
											2015-01-02 21:39:31 -05:00
										 |  |  |     LOG_CRITICAL(Service_FS, "Attempted to rename a file within an IVFC archive (%s).", GetName().c_str()); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  |     return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | std::unique_ptr<DirectoryBackend> IVFCArchive::OpenDirectory(const Path& path) const { | 
					
						
							|  |  |  |     return Common::make_unique<IVFCDirectory>(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-18 15:52:37 -07:00
										 |  |  | u64 IVFCArchive::GetFreeBytes() const { | 
					
						
							|  |  |  |     LOG_WARNING(Service_FS, "Attempted to get the free space in an IVFC archive"); | 
					
						
							|  |  |  |     return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | ////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-13 20:43:34 -03:00
										 |  |  | size_t IVFCFile::Read(const u64 offset, const size_t length, u8* buffer) const { | 
					
						
							| 
									
										
										
										
											2015-09-30 08:19:42 -04:00
										 |  |  |     LOG_TRACE(Service_FS, "called offset=%llu, length=%zu", offset, length); | 
					
						
							| 
									
										
										
										
											2015-07-10 00:55:23 +03:00
										 |  |  |     romfs_file->Seek(data_offset + offset, SEEK_SET); | 
					
						
							| 
									
										
										
										
											2015-07-13 20:43:34 -03:00
										 |  |  |     size_t read_length = (size_t)std::min((u64)length, data_size - offset); | 
					
						
							| 
									
										
										
										
											2015-07-10 00:55:23 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return romfs_file->ReadBytes(buffer, read_length); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-13 20:43:34 -03:00
										 |  |  | size_t IVFCFile::Write(const u64 offset, const size_t length, const bool flush, const u8* buffer) const { | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  |     LOG_ERROR(Service_FS, "Attempted to write to IVFC file"); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  |     return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-13 20:43:34 -03:00
										 |  |  | u64 IVFCFile::GetSize() const { | 
					
						
							|  |  |  |     return data_size; | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool IVFCFile::SetSize(const u64 size) const { | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  |     LOG_ERROR(Service_FS, "Attempted to set the size of an IVFC file"); | 
					
						
							| 
									
										
										
										
											2015-01-01 12:39:27 -05:00
										 |  |  |     return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace FileSys
 |