/// <summary> /// Initializes a new content file using an already existing file from an addon as storage. /// </summary> /// <param name="reader">The reader of the addon.</param> /// <param name="index">The index of the file to use.</param> public ContentFile(Reader reader, Reader.IndexEntry index) { Path = index.Path; _storage = ContentStorageType.AddonInstance; _associatedReader = reader; _readerFileEntry = index.FileNumber; }
/// <summary> /// Switches the current ContentFile to represent a file saved into an addon. /// Used after saving addons so that previous externally-saved entries are dropped in time. /// </summary> /// <param name="reader">The reader of the addon.</param> /// <param name="index">The index of the file to use.</param> public void SwitchToAddonInstance(Reader reader, Reader.IndexEntry index) { switch (_storage) { case ContentStorageType.Filesystem: _associatedReader = reader; _readerFileEntry = index.FileNumber; DisposeExternal(); _storage = ContentStorageType.AddonInstance; break; case ContentStorageType.AddonInstance: // Update the entry itself. There is no need to touch files on disk. _associatedReader = reader; _readerFileEntry = index.FileNumber; break; } }