Package net.minecraft.resource
Class ReloadableResourceManagerImpl
java.lang.Object
net.minecraft.resource.ReloadableResourceManagerImpl
- All Implemented Interfaces:
AutoCloseable
,ReloadableResourceManager
,ResourceManager
public class ReloadableResourceManagerImpl extends Object implements ReloadableResourceManager
-
Nested Class Summary
Nested Classes Modifier and Type Class Description (package private) static class
ReloadableResourceManagerImpl.FailedResourceReloadMonitor
static class
ReloadableResourceManagerImpl.PackAdditionFailedException
Nested classes/interfaces inherited from interface net.minecraft.resource.ResourceManager
ResourceManager.Empty
-
Field Summary
Fields Modifier and Type Field Description private List<ResourceReloadListener>
listeners
private static Logger
LOGGER
private Map<String,NamespaceResourceManager>
namespaceManagers
private Set<String>
namespaces
private List<ResourcePack>
packs
private ResourceType
type
-
Constructor Summary
Constructors Constructor Description ReloadableResourceManagerImpl(ResourceType type)
-
Method Summary
Modifier and Type Method Description void
addPack(ResourcePack pack)
ResourceReloadMonitor
beginMonitoredReload(Executor prepareExecutor, Executor applyExecutor, CompletableFuture<Unit> initialStage, List<ResourcePack> packs)
private void
clear()
void
close()
boolean
containsResource(Identifier id)
Checks whether any of the currently-loaded resource packs contain an entry for the given id.Collection<Identifier>
findResources(String startingPath, Predicate<String> pathPredicate)
Returns a sorted list of identifiers matching a path predicate.Set<String>
getAllNamespaces()
Gets a set of all namespaces offered by the resource packs loaded by this manager.List<Resource>
getAllResources(Identifier id)
Gets all of the available resources to the corresponding resource identifier.Resource
getResource(Identifier id)
Finds and returns the corresponding resource for a resource's identifier.void
registerListener(ResourceReloadListener listener)
Stream<ResourcePack>
streamResourcePacks()
Gets a stream of loaded resource packs in increasing order of priority.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface net.minecraft.resource.ReloadableResourceManager
beginReload
-
Field Details
-
LOGGER
-
namespaceManagers
-
listeners
-
namespaces
-
packs
-
type
-
-
Constructor Details
-
ReloadableResourceManagerImpl
-
-
Method Details
-
addPack
-
getAllNamespaces
Gets a set of all namespaces offered by the resource packs loaded by this manager.- Specified by:
getAllNamespaces
in interfaceResourceManager
-
getResource
Finds and returns the corresponding resource for a resource's identifier.
Starts by scanning each resource pack from highest priority to lowest. If no resource packs were found to contain the requested entry, will throw aFileNotFoundException
.- Specified by:
getResource
in interfaceResourceManager
- Parameters:
id
- the resource identifier to search for- Throws:
FileNotFoundException
- if the identified resource could not be found, or could not be loaded.IOException
- if the identified resource was found but a stream to it could not be opened.
-
containsResource
Checks whether any of the currently-loaded resource packs contain an entry for the given id.
Starts by querying the resource pack with the highest priority to lowest until it finds one that responds to the requested identifier.- Specified by:
containsResource
in interfaceResourceManager
- Parameters:
id
- the resource identifier to search for
-
getAllResources
Gets all of the available resources to the corresponding resource identifier.
Resources are returned in load order, or ascending order of priority, so the last element in the returned list is what would be returned normally bygetResource(net.minecraft.util.Identifier)
- Specified by:
getAllResources
in interfaceResourceManager
- Parameters:
id
- the resource identifier to search for- Throws:
FileNotFoundException
- if no matching resources could be found (i.e. if the list would be empty)IOException
- if resources were found, but any one of them could not be opened to be read.
-
findResources
Returns a sorted list of identifiers matching a path predicate.
Scanning begins instartingPath
and each candidate file present under that directory will be offered up to the predicate to decide whether it should be included or not.
Elements in the returned list may not, necessarily be unique. Additional effort is advised to ensure that duplicates in the returned list are discarded before loading.- Specified by:
findResources
in interfaceResourceManager
- Parameters:
startingPath
- the starting path to begin scanning frompathPredicate
- a predicate to determine whether a path should be included or not- Returns:
- the list matching identifiers
-
clear
private void clear() -
close
public void close()- Specified by:
close
in interfaceAutoCloseable
- Specified by:
close
in interfaceReloadableResourceManager
-
registerListener
- Specified by:
registerListener
in interfaceReloadableResourceManager
-
beginMonitoredReload
public ResourceReloadMonitor beginMonitoredReload(Executor prepareExecutor, Executor applyExecutor, CompletableFuture<Unit> initialStage, List<ResourcePack> packs)- Specified by:
beginMonitoredReload
in interfaceReloadableResourceManager
-
streamResourcePacks
Gets a stream of loaded resource packs in increasing order of priority.- Specified by:
streamResourcePacks
in interfaceResourceManager
-