Package com.e1c.g5.v8.dt.internal.check
Class CheckScheduler
java.lang.Object
com.e1c.g5.v8.dt.internal.check.CheckScheduler
- All Implemented Interfaces:
- IManagedService,- ICheckScheduler,- ICheckSettingsChangeListener
@LifecycleService(name="CHECK_SCHEDULER")
public class CheckScheduler
extends Object
implements ICheckScheduler, ICheckSettingsChangeListener
Check scheduler implementation. Performs direct schedules as well as reactive (in case of resource changes, etc)
- 
Field SummaryFields inherited from interface com.e1c.g5.v8.dt.check.ICheckSchedulerSERVICE_NAME
- 
Constructor SummaryConstructorsConstructorDescriptionCheckScheduler(ICheckRepository checkRepo, IBmModelManager bmModelManager, IMarkerManagerV2 markerManager, IDerivedDataManagerProvider derivedDataManagerProvider, IDependenciesManager depManager, IResourceManager resourceManager) Constructs an instance.
- 
Method SummaryModifier and TypeMethodDescriptionvoidactivate()voidvoiddisposeResourceListener(ProjectContext projectContext) voidinit()booleanisDeactivatedCheckPermitted(Object objectId, org.eclipse.core.resources.IProject project) States if there is an explicit permission was given earlier to perform checks for a provided object.voidonChange(org.eclipse.core.resources.IProject project, Collection<CheckSettingsChange> changedCheckSettings) This method is called on check settings getDiffWithInstanceSettings.voidonPostResourceLoading(ProjectContext projectContext) Marks that initial resource loading for the project was completed.voidonStorageInitialization(ProjectContext projectContext) Checks if there are some language resources are being scheduled during the period of project context unreadiness and schedules the computation if necessary.voidpermitDeactivatedCheckRequest(Object objectId, org.eclipse.core.resources.IProject project) Permits next request to check for a specific object even if massive checks are deactivated for a specified project.voidscheduleClearance(org.eclipse.core.resources.IProject project, Set<String> checkIds, org.eclipse.core.runtime.IProgressMonitor progressMonitor) Schedules the clearance of the check results for the given set of checksvoidscheduleValidation(org.eclipse.core.resources.IProject project, Set<String> checkIds, Collection<Object> topObjectIds, boolean isRecursive, IBmTransaction transaction, org.eclipse.core.runtime.IProgressMonitor progressMonitor) Schedules the model object validation for objects with given object ids by suitable checks with the given check ids.voidscheduleValidation(org.eclipse.core.resources.IProject project, Set<String> checkIds, Collection<Object> topObjectIds, org.eclipse.core.runtime.IProgressMonitor progressMonitor) Schedules the model object validation for objects with given object ids by suitable checks with the given check ids.voidMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface com.e1c.g5.v8.dt.check.ICheckSchedulerscheduleValidationMethods inherited from interface com.e1c.g5.v8.dt.check.settings.ICheckSettingsChangeListeneronPreferenceChange
- 
Constructor Details- 
CheckScheduler@Inject public CheckScheduler(ICheckRepository checkRepo, IBmModelManager bmModelManager, IMarkerManagerV2 markerManager, IDerivedDataManagerProvider derivedDataManagerProvider, IDependenciesManager depManager, IResourceManager resourceManager) Constructs an instance. Not intended for a manual instantiation- Parameters:
- checkRepo-- ICheckRepositoryreference. May not be- null
- bmModelManager-- IBmModelManagerreference. May not be- null
- markerManager-- IMarkerManagerV2reference. May not be- null
- derivedDataManagerProvider-- IDerivedDataManagerProviderreference. May not be- null
- depManager-- IDependenciesManagerreference. May not be- null
- resourceManager-- IResourceManagerreference. May not be- null
 
 
- 
- 
Method Details- 
activatepublic void activate()- Specified by:
- activatein interface- IManagedService
 
- 
deactivatepublic void deactivate()- Specified by:
- deactivatein interface- IManagedService
 
- 
disposeResourceListener@LifecycleParticipant(phase=STORAGE_CLOSING, dependsOn="BM_MODEL_MANAGER") public void disposeResourceListener(ProjectContext projectContext) 
- 
init
- 
onChangepublic void onChange(org.eclipse.core.resources.IProject project, Collection<CheckSettingsChange> changedCheckSettings) Description copied from interface:ICheckSettingsChangeListenerThis method is called on check settings getDiffWithInstanceSettings.- Specified by:
- onChangein interface- ICheckSettingsChangeListener
- Parameters:
- project- project with specific settings or- nullfor instance settings.
- changedCheckSettings- the collection of changed settings, not- null
 
- 
onStorageInitialization@LifecycleParticipant(phase=STORAGE_INITIALIZATION, dependsOn="DerivedDataManager") public void onStorageInitialization(ProjectContext projectContext) Checks if there are some language resources are being scheduled during the period of project context unreadiness and schedules the computation if necessary.- Parameters:
- projectContext- The project context. May not be- null
 
- 
onPostResourceLoading@LifecycleParticipant(phase=POST_RESOURCE_LOADING, dependsOn={"BM_MODEL_MANAGER","MARKER_MANAGER_V2"}) public void onPostResourceLoading(ProjectContext projectContext) Marks that initial resource loading for the project was completed.Also processes a potential crash from IMarkerManagerV2and schedules recheck of the affected objects.- Parameters:
- projectContext- The project context. May not be- null
 
- 
scheduleClearancepublic void scheduleClearance(org.eclipse.core.resources.IProject project, Set<String> checkIds, org.eclipse.core.runtime.IProgressMonitor progressMonitor) Description copied from interface:ICheckSchedulerSchedules the clearance of the check results for the given set of checks- Specified by:
- scheduleClearancein interface- ICheckScheduler
- Parameters:
- project- Target project, not- null
- checkIds- The set of target check identifeirs. If empty set is applied - all applicable checks will be cleared, not- null
- progressMonitor- progress monitor, not- null
 
- 
scheduleValidationpublic void scheduleValidation(org.eclipse.core.resources.IProject project, Set<String> checkIds, Collection<Object> topObjectIds, boolean isRecursive, IBmTransaction transaction, org.eclipse.core.runtime.IProgressMonitor progressMonitor) Description copied from interface:ICheckSchedulerSchedules the model object validation for objects with given object ids by suitable checks with the given check ids. It will probably be executed asynchronously. It can be canceled using the progress monitor.- Specified by:
- scheduleValidationin interface- ICheckScheduler
- Parameters:
- project- Target project, not- null
- checkIds- The set of target check identifeirs. If empty set is applied - all applicable checks will be scheduled, not- null
- topObjectIds- Identifiers of checked objects, all available objects if left empty, not- null
- isRecursive- if- trueall the dependencies (including modules) of objects provided by topObjectIds are processed. If- falsethen it's supposed that all required objects are passed via topObjectIds
- transaction- The active read-only transaction to perform the scheduling of checks (e.g. context collection)
- progressMonitor- progress monitor, not- null
 
- 
scheduleValidationpublic void scheduleValidation(org.eclipse.core.resources.IProject project, Set<String> checkIds, Collection<Object> topObjectIds, org.eclipse.core.runtime.IProgressMonitor progressMonitor) Description copied from interface:ICheckSchedulerSchedules the model object validation for objects with given object ids by suitable checks with the given check ids. It will probably be executed asynchronously. It can be canceled using the progress monitor.- Specified by:
- scheduleValidationin interface- ICheckScheduler
- Parameters:
- project- Target project, not- null
- checkIds- The set of target check identifeirs. If empty set is applied - all applicable checks will be scheduled, not- null
- topObjectIds- Identifiers of checked objects, all available objects if left empty, not- null
- progressMonitor- progress monitor, not- null
 
- 
unlinking
- 
permitDeactivatedCheckRequestpublic void permitDeactivatedCheckRequest(Object objectId, org.eclipse.core.resources.IProject project) Description copied from interface:ICheckSchedulerPermits next request to check for a specific object even if massive checks are deactivated for a specified project. This method allows active editors to perform limited number of checks independenly of the mode- Specified by:
- permitDeactivatedCheckRequestin interface- ICheckScheduler
- Parameters:
- objectId- Target object identifier. Accepts both resource URI's and BM object ids
- project- Target project, not- null
 
- 
isDeactivatedCheckPermittedpublic boolean isDeactivatedCheckPermitted(Object objectId, org.eclipse.core.resources.IProject project) Description copied from interface:ICheckSchedulerStates if there is an explicit permission was given earlier to perform checks for a provided object. The permission is retracted after a check so it is a single-time permission effectively- Specified by:
- isDeactivatedCheckPermittedin interface- ICheckScheduler
- Parameters:
- objectId- The object to check permission for. Cannot be- null. Must be compliant with- ICheckScheduler#permitDeactivatedCheckRequest(IProject, Object)requirements
- project- Target project, not- null
- Returns:
- True if a permission was given earlier
 
 
-