2022-05-02 22:21:04 +02:00
|
|
|
# About
|
2022-05-02 11:10:45 +02:00
|
|
|
|
2022-05-02 13:57:29 +02:00
|
|
|
Git is a Version Control System.
|
|
|
|
It is an advanced open source project.
|
|
|
|
That is the most popular VCS with his advantage like security, efficiency, speed etc.
|
|
|
|
He was developed in 2005 by Linus Torvalds, the Linux's father.
|
|
|
|
Many companies projects using Git (Google, Gnome, Netflix, etc).
|
|
|
|
In 2016 12 million people were using Git.
|
|
|
|
|
|
|
|
All project histories were saved in the work file.
|
|
|
|
You can publish, with all histories, projects in a Git platform like Gitea, GitHub, Bitbucket, GitLab, etc.
|
|
|
|
With this tool, you can commit projects, compare projects.
|
|
|
|
That is the best tool for teamwork.
|
|
|
|
|
2022-05-02 22:21:04 +02:00
|
|
|
# Git via `bash`
|
|
|
|
|
|
|
|
## Initialing a git repo
|
|
|
|
|
|
|
|
```
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$ git status
|
|
|
|
fatal: not a git repository (or any of the parent directories): .git
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$ git init .
|
|
|
|
hint: Using 'master' as the name for the initial branch. This default branch name
|
|
|
|
hint: is subject to change. To configure the initial branch name to use in all
|
|
|
|
hint: of your new repositories, which will suppress this warning, call:
|
|
|
|
hint:
|
|
|
|
hint: git config --global init.defaultBranch <name>
|
|
|
|
hint:
|
|
|
|
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
|
|
hint: 'development'. The just-created branch can be renamed via this command:
|
|
|
|
hint:
|
|
|
|
hint: git branch -m <name>
|
|
|
|
Initialized empty Git repository in /home/local/waldek/Documents/my_first_git_repository/.git/
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$ git status
|
|
|
|
On branch master
|
|
|
|
|
|
|
|
No commits yet
|
|
|
|
|
|
|
|
nothing to commit (create/copy files and use "git add"
|
|
|
|
```
|
|
|
|
|
|
|
|
## What's in this repo
|
|
|
|
|
|
|
|
```
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$ ls -la
|
|
|
|
total 12
|
|
|
|
drwxr-xr-x 3 waldek waldek 4096 May 2 22:06 .
|
|
|
|
drwxr-xr-x 4 waldek waldek 4096 May 2 22:06 ..
|
|
|
|
drwxr-xr-x 7 waldek waldek 4096 May 2 22:07 .git
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$ ls -la .git/
|
|
|
|
total 40
|
|
|
|
drwxr-xr-x 7 waldek waldek 4096 May 2 22:07 .
|
|
|
|
drwxr-xr-x 3 waldek waldek 4096 May 2 22:06 ..
|
|
|
|
drwxr-xr-x 2 waldek waldek 4096 May 2 22:06 branches
|
|
|
|
-rw-r--r-- 1 waldek waldek 92 May 2 22:06 config
|
|
|
|
-rw-r--r-- 1 waldek waldek 73 May 2 22:06 description
|
|
|
|
-rw-r--r-- 1 waldek waldek 23 May 2 22:06 HEAD
|
|
|
|
drwxr-xr-x 2 waldek waldek 4096 May 2 22:06 hooks
|
|
|
|
drwxr-xr-x 2 waldek waldek 4096 May 2 22:06 info
|
|
|
|
drwxr-xr-x 4 waldek waldek 4096 May 2 22:06 objects
|
|
|
|
drwxr-xr-x 4 waldek waldek 4096 May 2 22:06 refs
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$
|
|
|
|
```
|
|
|
|
|
|
|
|
## Adding and tracking content
|
|
|
|
|
|
|
|
```
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$ cat readme.md
|
|
|
|
# Hello world
|
|
|
|
|
|
|
|
I am a paragraph.
|
|
|
|
I can contain multiple sentences, each on one line.
|
|
|
|
|
|
|
|
A blank line separates multiple paragraphs.
|
|
|
|
|
|
|
|
1. lists
|
|
|
|
1. will
|
|
|
|
1. auto increment in most HTML render engines
|
|
|
|
* sublists
|
|
|
|
* are possible
|
|
|
|
* on multiple
|
|
|
|
* levels
|
|
|
|
1. but I keep counting...
|
|
|
|
|
|
|
|
```python
|
|
|
|
print("hello world")
|
|
|
|
print("I'll be a codeblock...")
|
|
|
|
```
|
|
|
|
|
|
|
|
and [I will become](https://kernel.org) a link.
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$ git status
|
|
|
|
On branch master
|
|
|
|
|
|
|
|
No commits yet
|
|
|
|
|
|
|
|
Untracked files:
|
|
|
|
(use "git add <file>..." to include in what will be committed)
|
|
|
|
readme.md
|
|
|
|
|
|
|
|
nothing added to commit but untracked files present (use "git add" to track)
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$
|
|
|
|
```
|
|
|
|
|
|
|
|
Now we can `add` and `commit` our changes.
|
|
|
|
|
|
|
|
```
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$ git add readme.md
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$ git status
|
|
|
|
On branch master
|
|
|
|
|
|
|
|
No commits yet
|
|
|
|
|
|
|
|
Changes to be committed:
|
|
|
|
(use "git rm --cached <file>..." to unstage)
|
|
|
|
new file: readme.md
|
|
|
|
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$ git commit -m "adds a readme file"
|
|
|
|
[master (root-commit) 8278e12] adds a readme file
|
|
|
|
1 file changed, 22 insertions(+)
|
|
|
|
create mode 100644 readme.md
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$ git status
|
|
|
|
On branch master
|
|
|
|
nothing to commit, working tree clean
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$
|
|
|
|
```
|
|
|
|
|
|
|
|
We can use `git log` to inspect the list of commits.
|
|
|
|
Add the `--no-pager` to bypass `less` and print the output straight to the console.
|
|
|
|
|
|
|
|
```
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$ git --no-pager log
|
|
|
|
commit 8278e1273d1438920c1063cdca179eb70d5926d8 (HEAD -> master)
|
|
|
|
Author: waldek <waldek@mailbox.org>
|
|
|
|
Date: Mon May 2 22:16:50 2022 +0200
|
|
|
|
|
|
|
|
adds a readme file
|
|
|
|
waldek@metal:~/Documents/my_first_git_repository$
|
|
|
|
```
|
|
|
|
|
|
|
|
## The main workflow
|
|
|
|
|
|
|
|
1. edit your files
|
|
|
|
1. `git status` to verify what's new or has been modified
|
|
|
|
1. `git add` the files you want to commit
|
|
|
|
1. `git commit -m "A RELEVANT COMMIT MESSAGE"`
|
|
|
|
1. `git push` to wherever you have your repository
|
|
|
|
1. repeat step one...
|
|
|
|
|
|
|
|
# Git via Atom
|
|
|
|
|
|
|
|
# Git via Pycharm
|
|
|
|
|
|
|
|
## Starting a version controlled project
|
2022-05-02 12:07:01 +02:00
|
|
|
|
2022-05-02 14:58:17 +02:00
|
|
|
In Pycharm, you have to enable a version control integration.
|
|
|
|
There are many choices, but we will use Git.
|
|
|
|
As you can see, Git appears in the toolbar and a git window appear bottom of the window.
|
|
|
|
And you can identify the current branch that you are in.
|
|
|
|
So the default branch name is **master**.
|
|
|
|
|
2022-05-02 11:10:45 +02:00
|
|
|
data:image/s3,"s3://crabby-images/9b909/9b9098e2e898fccfc849bd5045cc65d124cff196" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e95a6/e95a6ef9a635f0b32b84d91874ccbac67786a14b" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1d49e/1d49ec17870ce0cecb9fea179883f97033838182" alt="screenhot"
|
|
|
|
|
2022-05-02 14:58:17 +02:00
|
|
|
Let's try to write some code
|
|
|
|
And add all contents that we write in a git repository.
|
|
|
|
|
2022-05-02 11:10:45 +02:00
|
|
|
data:image/s3,"s3://crabby-images/4cd7e/4cd7e58be337722924aa0fb90f30a3ae794d8b47" alt="screenhot"
|
|
|
|
|
2022-05-02 14:58:17 +02:00
|
|
|
In the commit window, we can see file project.
|
|
|
|
But we had three important things.
|
|
|
|
We have a textBox and two buttons.
|
|
|
|
In the textBox, you can write a comment when you commit.
|
|
|
|
The _Commit_ button is used to save all change in your project.
|
|
|
|
The _Commit and Push_ is used to commit and push the project in a Git.
|
|
|
|
|
2022-05-02 11:10:45 +02:00
|
|
|
data:image/s3,"s3://crabby-images/105cb/105cbc94f6286df5502262d11bc3171de20bd8bc" alt="screenhot"
|
|
|
|
|
2022-05-02 14:58:17 +02:00
|
|
|
When you press the _Commit and Push_, a new window appears.
|
|
|
|
You can see which branch and which commit that you push.
|
|
|
|
|
2022-05-02 11:10:45 +02:00
|
|
|
data:image/s3,"s3://crabby-images/24d7e/24d7eb2760eeeac8e39b3894657241ec0d433898" alt="screenhot"
|
|
|
|
|
2022-05-02 22:21:04 +02:00
|
|
|
## Creating an online repository
|
|
|
|
|
2022-05-02 11:10:45 +02:00
|
|
|
data:image/s3,"s3://crabby-images/5f8eb/5f8eb248fdcd0d0ffde14572f2e64ed0e1cd30db" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ce8da/ce8da9a56aae78a647c7e9437141a405c0c54fe0" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2d752/2d752912fa4673499495f88a788d69f23866e8dc" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/cf592/cf592d1d44f1a05f3f07c6a229f46ab001f06a32" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d8f3f/d8f3f7c69396948614f00aef770028e1c82906e2" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b6615/b6615f09e21c293985071c0ff4b44018fc811e18" alt="screenhot"
|
|
|
|
|
2022-05-02 22:21:04 +02:00
|
|
|
## Adding some changes to our local code
|
2022-05-02 12:07:01 +02:00
|
|
|
|
2022-05-02 11:10:45 +02:00
|
|
|
data:image/s3,"s3://crabby-images/ae1ac/ae1acb37a92dd175dd313ec8ff01ec487710b621" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/3994a/3994a6d953e2ead24f4e700c7e8df4c6002bc300" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/426a4/426a42664a27522d943ce11d52bcc9d791886279" alt="screenhot"
|
|
|
|
|
2022-05-02 11:20:09 +02:00
|
|
|
<!---
|
2022-05-02 11:17:14 +02:00
|
|
|
|
2022-05-02 11:10:45 +02:00
|
|
|
data:image/s3,"s3://crabby-images/75a46/75a4698cb9355984bdc4a2cf904167125b224822" alt="screenhot"
|
|
|
|
|
2022-05-02 11:20:09 +02:00
|
|
|
-->
|
2022-05-02 11:17:14 +02:00
|
|
|
|
2022-05-02 22:21:04 +02:00
|
|
|
## Cloning the remote project into a new project
|
2022-05-02 12:07:01 +02:00
|
|
|
|
2022-05-02 11:15:06 +02:00
|
|
|
data:image/s3,"s3://crabby-images/2a30c/2a30c963d71a7268817b555ae2bc9e914a5d17a2" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ddc99/ddc996cf8a7421dbcf3157578f2af8dd4df8692c" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/26212/26212032887dc2613dead27afd60cdcfc3570488" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/664c7/664c720614c80e99ce00ee0eb9d3a214b757a940" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5f301/5f301979193278989e1b4f3da90cde9cf4a9dc70" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/6ffbb/6ffbb6daaf50792bf373726538bebc1250f09c00" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1b6cc/1b6cc9e821b1adb308f84c755613c935d64f4d75" alt="screenhot"
|
|
|
|
|
2022-05-02 11:20:09 +02:00
|
|
|
<!---
|
2022-05-02 11:17:14 +02:00
|
|
|
|
2022-05-02 11:10:45 +02:00
|
|
|
data:image/s3,"s3://crabby-images/457b2/457b2916820d45b094dc122ae5869146626bfeb6" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/dfef3/dfef38ac50a011f1b10e6130de7121687df91b4a" alt="screenhot"
|
|
|
|
|
2022-05-02 11:20:09 +02:00
|
|
|
-->
|
2022-05-02 11:17:14 +02:00
|
|
|
|
2022-05-02 22:21:04 +02:00
|
|
|
## Updating the original project
|
2022-05-02 12:07:01 +02:00
|
|
|
|
2022-05-02 11:10:45 +02:00
|
|
|
data:image/s3,"s3://crabby-images/24e47/24e47845bcce3139417a08e83e4d229b93ba30a0" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/30e3c/30e3c632eb5c522703b1fec60d622643da048b8d" alt="screenhot"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/11c51/11c5181bdf0f8c1453a29ed3537d019511aced18" alt="screenhot"
|