hpcflow.sdk.persistence.pending.CommitResourceMap#
- class hpcflow.sdk.persistence.pending.CommitResourceMap(commit_tasks=(), commit_loops=(), commit_submissions=(), commit_submission_attempts=(), commit_elem_IDs=(), commit_elements=(), commit_element_sets=(), commit_elem_iter_IDs=(), commit_elem_iters=(), commit_elem_iter_EAR_IDs=(), commit_EARs=(), commit_EAR_submission_indices=(), commit_EAR_skips=(), commit_EAR_starts=(), commit_EAR_ends=(), commit_js_metadata=(), commit_parameters=(), commit_files=(), commit_template_components=(), commit_param_sources=(), commit_loop_indices=(), commit_loop_num_iters=())#
Bases:
object
Map of PendingChanges commit method names to store resource labels, representing the store resources required by each commit method, for a given PersistentStore
When PendingChanges.commit_all is called, the resources specified will be opened in “update” mode, for each commit_ method.
Methods
Return a dict whose keys are tuples of resource labels and whose values are lists of PendingChanges commit method names that require those resource.
Attributes
- Parameters:
- group_by_resource()#
Return a dict whose keys are tuples of resource labels and whose values are lists of PendingChanges commit method names that require those resource.
This grouping allows us to batch up commit methods by resource requirements, which in turn means we can potentially minimise e.g. the number of network requests.