Esempio n. 1
0
        /// <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;
        }
Esempio n. 2
0
        /// <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;
            }
        }