git add with patterns and directories - Time & Space Complexity
Start learning this pattern below
Jump into concepts and practice - no test required
When using git add with patterns or directories, Git must find all matching files to stage. Understanding how the time grows as the number of files increases helps us know how long this command might take.
We want to see how the work Git does changes when there are more files or complex patterns.
Analyze the time complexity of the following git command:
git add src/**/*.js
This command stages all JavaScript files inside the src directory and its subdirectories matching the pattern.
Git must look through files and folders to find matches.
- Primary operation: Traversing the directory tree and checking each file against the pattern.
- How many times: Once for each file and folder inside
srcand its subfolders.
As the number of files grows, Git must check more files to see if they match the pattern.
| Input Size (n files) | Approx. Operations |
|---|---|
| 10 | Checks about 10 files |
| 100 | Checks about 100 files |
| 1000 | Checks about 1000 files |
Pattern observation: The work grows roughly in direct proportion to the number of files Git must check.
Time Complexity: O(n)
This means the time Git takes grows linearly with the number of files it needs to examine.
[X] Wrong: "Git instantly knows which files match the pattern without checking each one."
[OK] Correct: Git must look at each file to see if it fits the pattern, so more files mean more work.
Knowing how commands like git add scale helps you understand real-world tool performance and prepares you to explain efficiency clearly and confidently.
"What if we changed the pattern to add only files in a single directory without recursion? How would the time complexity change?"
Practice
git add src/ do?Solution
Step 1: Understand the command context
The commandgit add src/targets the directory named 'src'.Step 2: Know how git add works with directories
Git stages all files and subdirectories inside 'src' recursively when adding a directory.Final Answer:
Stages all changes in the 'src' directory and its subdirectories. -> Option DQuick Check:
git add directory = stage all inside [OK]
- Thinking it stages only the directory, not contents
- Confusing add with commit
- Assuming it deletes files
.txt files in the current directory using a pattern?Solution
Step 1: Understand wildcard usage in git add
The asterisk (*) matches any characters, so*.txtmatches all files ending with '.txt'.Step 2: Check each option's pattern
git add *.txt correctly matches all '.txt' files. Others do not match the intended pattern.Final Answer:
git add *.txt -> Option CQuick Check:
Use * before extension to match all files [OK]
- Placing * after extension instead of before
- Using wrong order of characters in pattern
- Confusing dot placement in patterns
project/
├─ app.js
├─ README.md
└─ docs/
├─ intro.md
└─ setup.mdWhat files will be staged after running
git add docs/*.md?Solution
Step 1: Analyze the pattern used
The patterndocs/*.mdmatches all files ending with '.md' inside the 'docs' directory only.Step 2: Identify matching files
Inside 'docs', 'intro.md' and 'setup.md' match. Files outside 'docs' are not matched.Final Answer:
Only docs/intro.md and docs/setup.md -> Option AQuick Check:
Pattern matches files only inside specified directory [OK]
- Assuming files outside 'docs' are staged
- Thinking pattern matches recursively
- Believing command fails if pattern matches multiple files
git add docs/*.md but only docs/intro.md is staged, not docs/setup.md. What is the most likely cause?Solution
Step 1: Understand why some files are not staged
If a file is ignored by .gitignore, git add will skip it even if the pattern matches.Step 2: Check other options for correctness
Patterns can match multiple files; git add works recursively for directories; manual adding is not required.Final Answer:
The file docs/setup.md is ignored by .gitignore. -> Option BQuick Check:
Ignored files are skipped by git add [OK]
- Believing patterns match only one file
- Thinking git add can't stage multiple files
- Assuming manual add is always needed
Solution
Step 1: Understand how to add multiple patterns in one command
Git add accepts multiple paths or patterns separated by spaces without quotes.Step 2: Evaluate each option
git add src/*.js docs/*.md correctly lists both patterns separated by space. git add 'src/*.js docs/*.md' quotes patterns unnecessarily, which may cause shell to treat them literally. git add src/*.js && git add docs/*.md runs two commands, not one. git add src/ docs/ *.js *.md mixes directories and patterns incorrectly.Final Answer:
git add src/*.js docs/*.md -> Option AQuick Check:
Multiple patterns separated by space work in one git add [OK]
- Using quotes that prevent shell expansion
- Trying to combine commands with && instead of one command
- Mixing directories and patterns incorrectly
