-
Notifications
You must be signed in to change notification settings - Fork 41
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Copy & Project settings should be per project #287
Comments
To refactor the Scan and Copy settings to be project-specific rather than global, we need to make several changes to the existing codebase. The main idea is to store these settings on a per-project basis rather than in the global application state. Here's a detailed approach to achieve this:
@State(
name = "com.devoxx.genie.ui.SettingsState",
storages = @Storage("DevoxxGenieSettingsPlugin.xml")
)
public final class DevoxxGenieStateService implements PersistentStateComponent<DevoxxGenieStateService> {
// ... existing fields ...
// New field to store project-specific settings
private Map<String, ProjectScanSettings> projectScanSettings = new HashMap<>();
// ... existing methods ...
public ProjectScanSettings getProjectScanSettings(Project project) {
return projectScanSettings.computeIfAbsent(project.getLocationHash(), k -> new ProjectScanSettings());
}
public void setProjectScanSettings(Project project, ProjectScanSettings settings) {
projectScanSettings.put(project.getLocationHash(), settings);
}
// Inner class to hold project-specific scan settings
public static class ProjectScanSettings {
private List<String> excludedDirectories = new ArrayList<>();
private List<String> includedFileExtensions = new ArrayList<>();
private boolean excludeJavaDoc = false;
private boolean useGitIgnore = true;
// Getters and setters for all fields
}
}
@Service
public class ProjectScanSettingsService {
private final Project project;
private final DevoxxGenieStateService stateService;
public ProjectScanSettingsService(Project project) {
this.project = project;
this.stateService = DevoxxGenieStateService.getInstance();
}
public List<String> getExcludedDirectories() {
return stateService.getProjectScanSettings(project).getExcludedDirectories();
}
public void setExcludedDirectories(List<String> excludedDirectories) {
DevoxxGenieStateService.ProjectScanSettings settings = stateService.getProjectScanSettings(project);
settings.setExcludedDirectories(excludedDirectories);
stateService.setProjectScanSettings(project, settings);
}
// Similar methods for other settings (includedFileExtensions, excludeJavaDoc, useGitIgnore)
}
public class ProjectScannerService {
// ... existing fields ...
public CompletableFuture<ScanContentResult> scanProject(Project project,
VirtualFile startDirectory,
int windowContextMaxTokens,
boolean isTokenCalculation) {
// ... existing code ...
ProjectScanSettingsService settingsService = project.getService(ProjectScanSettingsService.class);
// Use project-specific settings
List<String> excludedDirectories = settingsService.getExcludedDirectories();
List<String> includedFileExtensions = settingsService.getIncludedFileExtensions();
boolean excludeJavaDoc = settingsService.isExcludeJavaDoc();
boolean useGitIgnore = settingsService.isUseGitIgnore();
// ... rest of the method using these settings ...
}
// Update other methods to use ProjectScanSettingsService as well
}
public class CopyProjectSettingsComponent extends AbstractSettingsComponent {
private final Project project;
private final ProjectScanSettingsService settingsService;
public CopyProjectSettingsComponent(Project project) {
this.project = project;
this.settingsService = project.getService(ProjectScanSettingsService.class);
// Initialize UI components with project-specific settings
}
// ... modify other methods to use settingsService instead of global settings ...
}
public class CopyProjectSettingsConfigurable implements Configurable {
private final Project project;
private CopyProjectSettingsComponent copyProjectSettingsComponent;
public CopyProjectSettingsConfigurable(Project project) {
this.project = project;
}
@Override
public JComponent createComponent() {
copyProjectSettingsComponent = new CopyProjectSettingsComponent(project);
return copyProjectSettingsComponent.createPanel();
}
@Override
public boolean isModified() {
ProjectScanSettingsService settings = project.getService(ProjectScanSettingsService.class);
return !copyProjectSettingsComponent.getExcludedDirectories().equals(settings.getExcludedDirectories()) ||
!copyProjectSettingsComponent.getIncludedFileExtensions().equals(settings.getIncludedFileExtensions()) ||
copyProjectSettingsComponent.getExcludeJavadoc() != settings.isExcludeJavaDoc() ||
copyProjectSettingsComponent.getUseGitIgnore() != settings.isUseGitIgnore();
}
@Override
public void apply() {
ProjectScanSettingsService settings = project.getService(ProjectScanSettingsService.class);
settings.setExcludedDirectories(copyProjectSettingsComponent.getExcludedDirectories());
settings.setIncludedFileExtensions(copyProjectSettingsComponent.getIncludedFileExtensions());
settings.setExcludeJavaDoc(copyProjectSettingsComponent.getExcludeJavadoc());
settings.setUseGitIgnore(copyProjectSettingsComponent.getUseGitIgnore());
}
// ... other methods ...
}
<idea-plugin>
<!-- ... other configurations ... -->
<projectService serviceImplementation="com.devoxx.genie.service.ProjectScanSettingsService"/>
</idea-plugin>
public class SettingsMigrationService {
public static void migrateToProjectSettings(Project project) {
DevoxxGenieStateService globalSettings = DevoxxGenieStateService.getInstance();
ProjectScanSettingsService projectSettings = project.getService(ProjectScanSettingsService.class);
// Only migrate if project settings are empty
if (projectSettings.getExcludedDirectories().isEmpty()) {
projectSettings.setExcludedDirectories(new ArrayList<>(globalSettings.getExcludedDirectories()));
projectSettings.setIncludedFileExtensions(new ArrayList<>(globalSettings.getIncludedFileExtensions()));
projectSettings.setExcludeJavaDoc(globalSettings.getExcludeJavaDoc());
projectSettings.setUseGitIgnore(globalSettings.getUseGitIgnore());
}
}
} Call this migration method when a project is opened, perhaps in a PostStartupActivity: public class PostStartupActivity implements ProjectActivity {
@Nullable
@Override
public Object execute(@NotNull Project project, @NotNull Continuation<? super Unit> continuation) {
ChatMemoryService.getInstance().init(project);
SettingsMigrationService.migrateToProjectSettings(project);
return continuation;
}
} These changes will refactor the Scan and Copy settings to be project-specific. Each project will now have its own set of excluded directories, included file extensions, and other related settings. This approach ensures that different projects can have different scanning configurations, providing more flexibility to users working on multiple projects with varying requirements. |
The current Scan & Copy is the same for all projects, this should however be per project.
The text was updated successfully, but these errors were encountered: