// /*************************************************************************** // The Disc Image Chef // ---------------------------------------------------------------------------- // // Filename : Destructor.cs // Author(s) : Natalia Portillo // // Component : Direct device access. // // --[ Description ] ---------------------------------------------------------- // // Returns the device to the operating system. // // --[ 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-2018 Natalia Portillo // ****************************************************************************/ using System; using DiscImageChef.Devices.Windows; using Microsoft.Win32.SafeHandles; using PlatformID = DiscImageChef.CommonTypes.Interop.PlatformID; namespace DiscImageChef.Devices { public partial class Device { /// /// Releases unmanaged resources and performs other cleanup operations before the /// is reclaimed by garbage collection. /// ~Device() { Close(); } public void Close() { if(FileHandle == null) return; switch(PlatformId) { case PlatformID.Win32NT: Extern.CloseHandle((SafeFileHandle)FileHandle); break; case PlatformID.Linux: Linux.Extern.close((int)FileHandle); break; case PlatformID.FreeBSD: FreeBSD.Extern.cam_close_device((IntPtr)FileHandle); break; } FileHandle = null; } } }