Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/denisbuserski/git
Simple documentation on how to use Git
https://github.com/denisbuserski/git
git github githubdesktop intellij
Last synced: about 1 month ago
JSON representation
Simple documentation on how to use Git
- Host: GitHub
- URL: https://github.com/denisbuserski/git
- Owner: DenisBuserski
- License: mit
- Created: 2023-09-09T05:20:17.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-05-19T13:14:37.000Z (9 months ago)
- Last Synced: 2024-05-19T14:29:06.940Z (9 months ago)
- Topics: git, github, githubdesktop, intellij
- Homepage:
- Size: 4.47 MB
- Stars: 0
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Git
data:image/s3,"s3://crabby-images/bf383/bf3837a15d5a3d1941d77e47b1612c7a0e3329df" alt="git"
Overview
- Distributed version control(VC) system designed to track changes in source code and other types of files during software development.
- When several developers write code, the codes of which are then combined into 1 project. VC allows this to be more balanced and controls the whole process.
- Keeps history of the made changes.
- `Conflict` - When 2 people work on the same code and edit the same part of it in a different way.
- `Repository` - The place where the code is stored.| Git | GitHub | Git Bash |
|-----------------|----------|----------------------------------------|
| Version control | Portal | Client we use to upload code to GitHub |There are 2 types of Source-Control Systems
| Distributed Source-Control System | Centralized Source-Control System |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| `Git` | `SVN` |
| Every developer has a full copy of the entire repository on their local PC | A single, centralized repository stored on a server |
| | Developers must connect to the central server to make commits, update, or view history |
| 2 types of repositories | Only 1 repository (Remote repository) - No Local repository |
| Remote - The main project from which the files are downloaded | |
| Local - The copy of the Remote on your local PC | |
| In case of conflict, the individual programmer can download the changes in his repository that the other one has made and make the appropriate changes | Almost always we get conflicts and they are very hard to fix |Simple Git commands
Before following the below commands you would need to set Git with your GitHub profile and a SSH key.
For GitHub:
- [GitHub docs](https://docs.github.com/en/get-started/getting-started-with-git/setting-your-username-in-git)For SSH key:
- [GitHub docs](https://docs.github.com/en/authentication/connecting-to-github-with-ssh)
- [🐱Generate a New SSH Key and Add it to your GitHub](https://www.youtube.com/watch?v=X40b9x9BFGo&list=PLN_xGGp_EzEJvRKWLk0EIRI6sfT36-ACm&index=3)
1. Create a folder on your Desktop named `test`
- Open `Git Bash` on your Desktop and create a folder `test` with the `mkdir` command.
2. Move to the `test` folder - `cd test`
3. In the Git console write the command
```
git init
```
This command initializes a new, empty repository. Git creates a new `.git` directory in your project. Using the
`ls -a` command we can see the mentioned directory.
data:image/s3,"s3://crabby-images/f9cc1/f9cc1b1909ffeb9a63f9dc9d71f2423105a2e165" alt="step_3"
4. Create `file-1.txt` in the `test` folder - `touch file-1.txt`
5. Check the status of your Working directory
```
git status
```
data:image/s3,"s3://crabby-images/22227/22227a3347e751c3f96c912a9187775bb60c9e69" alt="step_5"
From the result, it can be seen that you have 1 untracked file.
6. Move the file to the Staging area
```
git add file-1.txt
```
data:image/s3,"s3://crabby-images/ef268/ef268f0d3cbab8bc69e08db707b2f0d883f6587a" alt="step_6"
7. Commit the changes to you Local repository
```
git commit -m"[MESSAGE]"
git commit -m"Created file-1.txt"
```
data:image/s3,"s3://crabby-images/d83ec/d83ec5de64eb80b0b01c6811eb9773fbe8ca2f1b" alt="step_7"
When you see the above message, that means you are ready to the push the changes and add them to the Remote repository.
8. Add some text to `file-1.txt` - `echo "Sofia" >> file-1.txt`
data:image/s3,"s3://crabby-images/f26f3/f26f371d1d63483babd4a2235c0edc95b975df87" alt="step_8"
From the above message you can either prepare your changes for commit or discard them.
| Restore the previous state of the file | Keep the changes you made and prepare them for commit |
|----------------------------------------|--------------------------------------------------------|
| `git restore file-1.txt` | `git add file-1.txt` |With this command you can add 1 file at a time, but what if you have multiple...
9. Add 2 more files to the `test` folder
data:image/s3,"s3://crabby-images/6755f/6755f3a67fa2a7698638840ee3c4974610fedeff" alt="step_9"
10. Add ALL files at once to the Staging area
```
git add .
```
data:image/s3,"s3://crabby-images/71f9e/71f9efd0d8206a803a3f10d895dfbe4ebcf89084" alt="step_10"
11. Commit the changes
```
git commit -m"Added 2 new files and changed file-1.txt"
```
12. Remove `file-3.txt`
```
rm -i file-3.txt
```
data:image/s3,"s3://crabby-images/f9060/f90606cae2758d75c9f2d457a6bdb78344095c34" alt="step_12"
13. Prepare everything for commit and commit the changes
```
git add .
git commit -m"Deleted file-3.txt"
```
14. Check the history of your commits
```
git log
```
data:image/s3,"s3://crabby-images/aaff6/aaff6ec3d22a5eabac7b94df02e66e8ba6c09d8c" alt="step_14"
15. Use the below command to rename the current branch to `main`
```
git branch -M main
```
data:image/s3,"s3://crabby-images/d2b91/d2b919ab532727ce0087e389ce55247bd6394b4b" alt="step_15"
16. Create a repository on GitHub and connect it to your Local repository
After you have created a repository on GitHub copy the below:
data:image/s3,"s3://crabby-images/e0ebc/e0ebc2f4402f2618f6846e8a6b20437202b368f7" alt="step_16"
17. Push your changes:
```
git push -u origin main
```
data:image/s3,"s3://crabby-images/970c2/970c2cbbba93d25f5f13a4675bd936c653441472" alt="step_17"
We can see the files in GitHub now.
data:image/s3,"s3://crabby-images/5d8cd/5d8cd886c1f4407053d3ea0e9f5b87fd3ec0c360" alt="step_17(1)".png)
18. Add `README.md` in your Remote repository
We don't have this `README.md` file in our Local repository, so let's get it.
| `git fetch` | `git pull` | `git clone` |
|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| Retrieves changes from a Remote repository without merging them into your Local repository | Fetches changes from a Remote repository and automatically merges them into your current branch | Creates a copy of a Remote repository on your Local machine |
| When you want to merge the changes use `git merge` | `git fetch` + `git merge` | `git clone [URL]` |Branches
| Command | Description |
|-----------------------------------------------------|-------------------------------------|
| `git branch` | Show all branches |
| `git branch [BRANCH_NAME]` | Create branch |
| `git branch -m [BRANCH_NAME]` | Rename the current branch |
| `git branch -m [OLD_BRANCH_NAME] [NEW_BRANCH_NAME]` | Rename branch you are not on |
| `git branch -d [BRANCH_NAME]` | Delete branch locally |
| `git switch [BRANCH_NAME]` | Switch branch |
| `git checkout [BRANCH_NAME]` | Old way to switch branch |
| `git checkout -b [BRANCH_NAME]` | Create new branch and switch to it |
| `git pull origin [REMOTE_BRANCH_NAME]` | Fetch Remote branch to Local branch |Additional information
- [Git and Github Essentials](https://app.amigoscode.com/courses/enrolled/1317178)
- [Git and GitHub Tutorial For Beginners | Full Course [2021] [NEW]](https://www.youtube.com/watch?v=3fUbBnN_H2c&list=PLN_xGGp_EzEJvRKWLk0EIRI6sfT36-ACm&index=2&t=3156s)
- [Git Tutorial for Beginners: Learn Git in 1 Hour](https://www.youtube.com/watch?v=8JJ101D3knE&list=PLN_xGGp_EzEJvRKWLk0EIRI6sfT36-ACm&index=2)
- [Fundamentals with C#, Java, JS & Python Jan 21 - Git and GitHub - Kiril Kirilov](https://www.youtube.com/watch?v=LaWZYYuOkeM&list=PLN_xGGp_EzEJvRKWLk0EIRI6sfT36-ACm&index=2)
- [GitHub: The Right Way - Владимир Тасев](https://www.youtube.com/watch?v=kFuQ2f1qb_0&list=PLN_xGGp_EzEJvRKWLk0EIRI6sfT36-ACm&index=6&t=12s)
- [How to setup and use Git and GitHub with IntelliJ IDEA [2024] | Git | GitHub | IntelliJ](https://www.youtube.com/watch?v=qM5BScv1Z-s)
- [Git Explained in 100 Seconds](https://www.youtube.com/watch?v=hwP7WQkmECE)
- [Git Branches Tutorial](https://www.youtube.com/watch?v=e2IbNHi4uCI)
- [Git & GitHub Tutorial for Beginners #8 - Branches](https://www.youtube.com/watch?v=QV0kVNvkMxc)
- [git with Intellij Idea](https://www.youtube.com/playlist?list=PLBb5HFCJVQtsCkbHJK7GWzjnAF00hfr8j)
- [Git and GitHub for Beginners - Crash Course](https://www.youtube.com/watch?v=RGOj5yH7evk&list=WL&index=78&t=1153s)
- [Git Basics](https://www.youtube.com/watch?v=3I2OViah6VE&list=WL&index=81&t=13s)