⚡️ Speed up function get_patches_metadata by 45% in PR #690 (worktree/persist-optimization-patches)
          #691
        
          
      
  Add this suggestion to a batch that can be applied as a single commit.
  This suggestion is invalid because no changes were made to the code.
  Suggestions cannot be applied while the pull request is closed.
  Suggestions cannot be applied while viewing a subset of changes.
  Only one suggestion per line can be applied in a batch.
  Add this suggestion to a batch that can be applied as a single commit.
  Applying suggestions on deleted lines is not supported.
  You must change the existing code in this line in order to create a valid suggestion.
  Outdated suggestions cannot be applied.
  This suggestion has been applied or marked resolved.
  Suggestions cannot be applied from pending reviews.
  Suggestions cannot be applied on multi-line comments.
  Suggestions cannot be applied while the pull request is queued to merge.
  Suggestion cannot be applied right now. Please check back later.
  
    
  
    
⚡️ This pull request contains optimizations for PR #690
If you approve this dependent PR, these changes will be merged into the original PR branch
worktree/persist-optimization-patches.📄 45% (0.45x) speedup for
get_patches_metadataincodeflash/code_utils/git_utils.py⏱️ Runtime :
716 microseconds→495 microseconds(best of39runs)📝 Explanation and details
The optimized code achieves a 44% speedup through two key optimizations:
1. Added
@lru_cache(maxsize=1)toget_patches_dir_for_project()get_git_project_id()andPath()creationget_patches_metadata()get_git_project_id()was already cached but still being called repeatedly, this second-level caching eliminates that redundancy2. Replaced
read_text()+json.loads()withopen()+json.load()json.load()with a file handle is more efficient than reading the entire file into memory first withread_text()then parsing itPerformance Impact by Test Type:
The caching optimization provides the most consistent gains across all scenarios since it eliminates repeated expensive operations, while the file I/O optimization scales with file size.
✅ Correctness verification report:
🌀 Generated Regression Tests and Runtime
To edit these changes
git checkout codeflash/optimize-pr690-2025-08-27T15.58.44and push.