blob: 1b6a3c2bff2cb15230d6fe0006d2de8d0a4398b7 [file] [log] [blame]
/*
* Copyright 2016 The Bazel Authors. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.google.idea.blaze.base.prefetch;
import com.google.common.collect.ImmutableSet;
import com.google.idea.blaze.base.model.BlazeProjectData;
import com.google.idea.blaze.base.projectview.ProjectViewSet;
import com.google.idea.blaze.base.sync.projectview.ImportRoots;
import com.intellij.openapi.extensions.ExtensionPointName;
import com.intellij.openapi.project.Project;
import java.io.File;
import java.util.Set;
/** Provides a source of files to prefetch */
public interface PrefetchFileSource {
ExtensionPointName<PrefetchFileSource> EP_NAME =
ExtensionPointName.create("com.google.idea.blaze.PrefetchFileSource");
/** Returns all file extensions provided by available PrefetchFileSource implementations. */
static ImmutableSet<String> getAllPrefetchFileExtensions() {
ImmutableSet.Builder<String> extensionsToFetchContent = ImmutableSet.builder();
for (PrefetchFileSource fileSource : PrefetchFileSource.EP_NAME.getExtensions()) {
extensionsToFetchContent.addAll(fileSource.prefetchFileExtensions());
}
return extensionsToFetchContent.build();
}
/**
* Adds any files or directories that we would be interested in prefetching. Project source files
* should not be added here, as they're always prefetched.
*/
void addFilesToPrefetch(
Project project,
ProjectViewSet projectViewSet,
ImportRoots importRoots,
BlazeProjectData blazeProjectData,
Set<File> files);
/** Returns any file extensions that are a good candidate for the {@link Prefetcher}. */
Set<String> prefetchFileExtensions();
}