// /*************************************************************************** // The Disc Image Chef // ---------------------------------------------------------------------------- // // Filename : File.cs // Author(s) : Natalia Portillo // // Component : Microsoft FAT filesystem plugin. // // --[ Description ] ---------------------------------------------------------- // // Methods to handle files. // // --[ License ] -------------------------------------------------------------- // // This library is free software; you can redistribute it and/or modify // it under the terms of the GNU Lesser General Public License as // published by the Free Software Foundation; either version 2.1 of the // License, or (at your option) any later version. // // This library 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 // Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public // License along with this library; if not, see . // // ---------------------------------------------------------------------------- // Copyright © 2011-2019 Natalia Portillo // ****************************************************************************/ using System; using System.Collections.Generic; using DiscImageChef.CommonTypes.Structs; namespace DiscImageChef.Filesystems.FAT { public partial class FAT { public Errno MapBlock(string path, long fileBlock, out long deviceBlock) { deviceBlock = 0; if(!mounted) return Errno.AccessDenied; throw new NotImplementedException(); } public Errno GetAttributes(string path, out FileAttributes attributes) { attributes = new FileAttributes(); if(!mounted) return Errno.AccessDenied; throw new NotImplementedException(); } public Errno Read(string path, long offset, long size, ref byte[] buf) { if(!mounted) return Errno.AccessDenied; throw new NotImplementedException(); } public Errno Stat(string path, out FileEntryInfo stat) { stat = null; if(!mounted) return Errno.AccessDenied; throw new NotImplementedException(); } uint[] GetClusters(uint startCluster) { if(startCluster == 0) return null; if(startCluster >= XmlFsType.Clusters) return null; List clusters = new List(); uint nextCluster = startCluster; if(fat12) return null; ulong nextSector = nextCluster / fatEntriesPerSector + fatFirstSector + (useFirstFat ? 0 : sectorsPerFat); int nextEntry = (int)(nextCluster % fatEntriesPerSector); ulong currentSector = nextSector; byte[] fatData = image.ReadSector(currentSector); if(fat32) while((nextCluster & FAT32_MASK) > 0 && (nextCluster & FAT32_MASK) <= FAT32_BAD) { clusters.Add(nextCluster); if(currentSector != nextSector) { fatData = image.ReadSector(nextSector); currentSector = nextSector; } nextCluster = BitConverter.ToUInt32(fatData, nextEntry * 4); nextSector = nextCluster / fatEntriesPerSector + fatFirstSector + (useFirstFat ? 0 : sectorsPerFat); nextEntry = (int)(nextCluster % fatEntriesPerSector); } else if(fat16) while(nextCluster > 0 && nextCluster <= FAT16_BAD) { clusters.Add(nextCluster); if(currentSector != nextSector) { fatData = image.ReadSector(nextSector); currentSector = nextSector; } nextCluster = BitConverter.ToUInt16(fatData, nextEntry * 2); nextSector = nextCluster / fatEntriesPerSector + fatFirstSector + (useFirstFat ? 0 : sectorsPerFat); nextEntry = (int)(nextCluster % fatEntriesPerSector); } return clusters.ToArray(); } } }