All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.schlichtherle.truezip.file.ExpertFeature Maven / Gradle / Ivy

Go to download

This module provides the TFile* classes for simple, uniform, transparent, thread-safe, read/write access to archive files as if they were virtual directories in a file system path. This module also provides Swing GUI classes for viewing file trees and choosing entries in archive files.

The newest version!
/*
 * Copyright (C) 2005-2015 Schlichtherle IT Services.
 * All rights reserved. Use is subject to license terms.
 */
package de.schlichtherle.truezip.file;

import de.schlichtherle.truezip.fs.*;
import java.lang.annotation.*;
import static java.lang.annotation.ElementType.*;
import java.util.Locale;

/**
 * Indicates a feature which requires a certain experience level for safe use.
 * In most cases, using an expert feature is a code smell and you should
 * refactor your code to avoid it in order to stay safe.
 * However, some valid use cases exist for an expert feature
 * (otherwise it should have been {@code @Deprecated}).
 * These use cases are not explained here because a true expert will know them!
 * 

* As of TrueZIP 7.7, using an expert feature is not checked. * However, future versions of TrueZIP might include tools to issue a warning * whenever an expert feature is unintentionally used - similar to the way * {@code javac} treats the {@code @Deprecated} annotation. * * @since TrueZIP 7.7 * @author Christian Schlichtherle */ @Documented @Inherited @Target({ CONSTRUCTOR, METHOD }) public @interface ExpertFeature { /** Returns the experience level required to safely use this feature. */ Level level() default Level.MASTER; /** Returns the reasons why this feature should only be used by an expert. */ Reason[] value(); /** * Returns a warning message for future use, for example in static code * analysis. */ String warning() default "Using this %s requires %s experience because %s!"; /** The experience level required to safely use an expert feature. */ enum Level { INTERMEDIATE, MASTER; @Override public String toString() { return name().toLowerCase(Locale.ROOT).replace('_', ' '); } } /** The reason why a feature should only be used by an expert. */ enum Reason { /** * Injecting a different archive detector for the same virtual file * system path may cause data corruption. * This is because the behavior of the virtual file system is not only * a pure function of the operation parameters, but also depends on the * {@linkplain TConfig#get() current configuration}, the state * of the virtual file system and ultimately the state of the * underlying host or network file system. *

* The state of the virtual file system very much depends on the * archive detector which has been previously used to access the same * virtual file system path. * If there is a mismatch between the injected archive detector and the * previously used archive detector, then the result of an operation * is hard to predict but you can expect to see spurious * false positive or * false negative archive file detection or even * data corruption up to the point of * total data loss! *

* This is particularly true for multithreaded applications: If a * thread changes the archive detector which is associated with a given * virtual file system path, then another thread may get an unexpected * result when accessing the same virtual file system path, with all * the after effects described above. *

* Now that you have been warned, here is a high-level strategy for * effectively associating a different archive detector to a given * virtual file system path: *

    *
  1. Lock out any other thread from concurrently accessing the * virtual file system path. *
  2. Totally clear the state associated with the virtual file system * path in the Kernel by calling the method {@link TVFS#umount()}. * Your best choice is the umount method with no parameters. * However, if you have to do this selectively, make sure the * filter parameter really covers the virtual file system path you * want to access and the effective options are * {@link FsSyncOptions#UMOUNT}. *
  3. Now access the virtual file system path with the new archive * detector. * Depending on the particular archive detector, this will trigger * mounting the archive file system by the Kernel. * The new archive detector is then associated with the given file * system path. *
  4. Depending on which operation you have performed and whether the * change of the archive detector shall be persistent or not, you * may need to repeat the second step. *
  5. Unlock access to the virtual file system path for other threads * to see the result. * Mind you that these threads may still be using the old archive * detector. *
*

* I leave it up to you to figure the details - again, this is an * expert feature! * * @see Third Party Access */ INJECTING_A_DIFFERENT_DETECTOR_FOR_THE_SAME_PATH_MAY_CORRUPT_DATA, /** * The presence or absence of some synchronization options may yield * unwanted side effects. * For example, if the {@link FsSyncOption#CLEAR_CACHE} is absent, then * the selective entry cache doesn' get cleared and hence the state * associated with a particular file system path may not get totally * cleared. * On the other hand, the presence of the * {@link FsSyncOption#FORCE_CLOSE_INPUT} or * {@link FsSyncOption#FORCE_CLOSE_OUTPUT} will forcibly close any open * streams and channels (after some timeout), regardless if they are * currently used by other threads or not. */ THE_PRESENCE_OR_ABSENCE_OF_SOME_OPTIONS_MAY_YIELD_UNWANTED_SIDE_EFFECTS; @Override public String toString() { return name().toLowerCase(Locale.ROOT).replace('_', ' '); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy