| 
									
										
										
										
											2014-06-25 18:15:35 -04:00
										 |  |  | // Copyright 2014 Citra Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "common/common_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "core/hle/kernel/kernel.h"
 | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | #include "core/file_sys/archive.h"
 | 
					
						
							| 
									
										
										
										
											2014-06-25 18:15:35 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | // Kernel namespace
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Kernel { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  |  * Opens an archive | 
					
						
							|  |  |  |  * @param id_code IdCode of the archive to open | 
					
						
							|  |  |  |  * @return Handle to archive if it exists, otherwise a null handle (0) | 
					
						
							| 
									
										
										
										
											2014-06-25 18:15:35 -04:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | Handle OpenArchive(FileSys::Archive::IdCode id_code); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-14 11:52:52 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Closes an archive | 
					
						
							|  |  |  |  * @param id_code IdCode of the archive to open | 
					
						
							|  |  |  |  * @return true if it worked fine | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | Result CloseArchive(FileSys::Archive::IdCode id_code); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Creates an Archive | 
					
						
							|  |  |  |  * @param backend File system backend interface to the archive | 
					
						
							|  |  |  |  * @param name Optional name of Archive | 
					
						
							|  |  |  |  * @return Handle to newly created Archive object | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | Handle CreateArchive(FileSys::Archive* backend, const std::string& name); | 
					
						
							| 
									
										
										
										
											2014-06-25 18:15:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-12 00:45:40 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Open a File from an Archive | 
					
						
							|  |  |  |  * @param archive_handle Handle to an open Archive object | 
					
						
							|  |  |  |  * @param path Path to the File inside of the Archive | 
					
						
							|  |  |  |  * @param mode Mode under which to open the File | 
					
						
							|  |  |  |  * @return Opened File object | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-11-11 19:27:35 -05:00
										 |  |  | Handle OpenFileFromArchive(Handle archive_handle, const FileSys::Path& path, const FileSys::Mode mode); | 
					
						
							| 
									
										
										
										
											2014-10-28 22:52:56 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Create a Directory from an Archive | 
					
						
							|  |  |  |  * @param archive_handle Handle to an open Archive object | 
					
						
							|  |  |  |  * @param path Path to the Directory inside of the Archive | 
					
						
							|  |  |  |  * @return Whether creation of directory succeeded | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-11-11 19:27:35 -05:00
										 |  |  | Result CreateDirectoryFromArchive(Handle archive_handle, const FileSys::Path& path); | 
					
						
							| 
									
										
										
										
											2014-09-12 00:45:40 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-12 00:48:04 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Open a Directory from an Archive | 
					
						
							|  |  |  |  * @param archive_handle Handle to an open Archive object | 
					
						
							|  |  |  |  * @param path Path to the Directory inside of the Archive | 
					
						
							|  |  |  |  * @return Opened Directory object | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-11-11 19:27:35 -05:00
										 |  |  | Handle OpenDirectoryFromArchive(Handle archive_handle, const FileSys::Path& path); | 
					
						
							| 
									
										
										
										
											2014-09-12 00:48:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-04 13:38:12 -04:00
										 |  |  | /// Initialize archives
 | 
					
						
							|  |  |  | void ArchiveInit(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// Shutdown archives
 | 
					
						
							|  |  |  | void ArchiveShutdown(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-25 18:15:35 -04:00
										 |  |  | } // namespace FileSys
 |