Compare commits
	
		
			8 Commits
		
	
	
		
			8cd8b3e342
			...
			3ad2ae4074
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 3ad2ae4074 | |||
| c2ebc0db51 | |||
| 316aabe413 | |||
| 6b379bfaf8 | |||
| ec0fe5c43c | |||
| d4ec04f975 | |||
| 358464f10a | |||
| 6fe4ff5f8e | 
| @ -156,7 +156,9 @@ it looks really uncomfortable! This is why I prefer to tell Emacs to | |||||||
| keep its backup files to itself in a directory it only will access. | keep its backup files to itself in a directory it only will access. | ||||||
| #+begin_src emacs-lisp | #+begin_src emacs-lisp | ||||||
| (setq backup-directory-alist `(("." . ,(expand-file-name ".tmp/backups/" | (setq backup-directory-alist `(("." . ,(expand-file-name ".tmp/backups/" | ||||||
|                                                          user-emacs-directory)))) |                                                          user-emacs-directory))) | ||||||
|  |       tramp-backup-directory-alist `(("." . ,(expand-file-name ".tmp/tramp-backups/" | ||||||
|  |                                                                user-emacs-directory)))) | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
| When using LSP with Typescript projects, my =tsconfig.json= or its | When using LSP with Typescript projects, my =tsconfig.json= or its | ||||||
|  | |||||||
| @ -50,7 +50,6 @@ stuff. | |||||||
| (package-initialize) | (package-initialize) | ||||||
| (unless package-archive-contents | (unless package-archive-contents | ||||||
|   (package-refresh-contents)) |   (package-refresh-contents)) | ||||||
| 
 |  | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
| From time to time, I fork some packages either because I’m trying to | From time to time, I fork some packages either because I’m trying to | ||||||
|  | |||||||
| @ -67,6 +67,13 @@ Let’s give ~calc-mode~ some better defaults. | |||||||
| ** Elcord | ** Elcord | ||||||
| What’s the point of using Emacs if you can’t tell everyone? | What’s the point of using Emacs if you can’t tell everyone? | ||||||
| #+begin_src emacs-lisp | #+begin_src emacs-lisp | ||||||
|  | (defun my/elcord-buffer-details-format () | ||||||
|  |   "Return the buffer details string shown on Discord." | ||||||
|  |   (format "Editing %s" | ||||||
|  |           (if (projectile-project-p default-directory) | ||||||
|  |               (f-relative (buffer-file-name) (projectile-project-root)) | ||||||
|  |             (buffer-name)))) | ||||||
|  | 
 | ||||||
| (use-package elcord | (use-package elcord | ||||||
|   :straight (:built t) |   :straight (:built t) | ||||||
|   :defer t |   :defer t | ||||||
| @ -76,7 +83,8 @@ What’s the point of using Emacs if you can’t tell everyone? | |||||||
|           elcord-boring-buffers-regexp-list  `("^ " |           elcord-boring-buffers-regexp-list  `("^ " | ||||||
|                                                ,(rx "*" (+ any) "*") |                                                ,(rx "*" (+ any) "*") | ||||||
|                                                ,(rx bol (or "Re: " |                                                ,(rx bol (or "Re: " | ||||||
|                                                             "Fwd: "))))) |                                                             "Fwd: "))) | ||||||
|  |           elcord-buffer-details-format-function #'my/elcord-buffer-details-format)) | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
| ** Elpher | ** Elpher | ||||||
|  | |||||||
| @ -64,25 +64,6 @@ it is. | |||||||
|           appwrite-devel t)) |           appwrite-devel t)) | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
| *** Databases |  | ||||||
| A really cool tool in Emacs for manipulating databases is ~emacsql~. |  | ||||||
| It’s able to manipulate SQLite databases by default, but it’s also |  | ||||||
| possible to manipulate MariaDB and PostgreSQL databases by installing |  | ||||||
| additional packages. For now, I just need SQLite and PostgreSQL |  | ||||||
| interfaces, so let’s install the relevant packages. |  | ||||||
| #+begin_src emacs-lisp |  | ||||||
| (use-package emacsql-psql |  | ||||||
|   :defer t |  | ||||||
|   :after (emacsql) |  | ||||||
|   :straight (:build t)) |  | ||||||
| 
 |  | ||||||
| (with-eval-after-load 'emacsql |  | ||||||
|   (phundrak/major-leader-key |  | ||||||
|     :keymaps 'emacs-lisp-mode-map |  | ||||||
|     :packages '(emacsql) |  | ||||||
|     "E" #'emacsql-fix-vector-indentation)) |  | ||||||
| #+end_src |  | ||||||
| 
 |  | ||||||
| *** Flycheck | *** Flycheck | ||||||
| #+begin_src emacs-lisp | #+begin_src emacs-lisp | ||||||
| (use-package flycheck | (use-package flycheck | ||||||
| @ -1297,8 +1278,19 @@ Finally, I’m using [[https://github.com/microsoft/pyright][Pyright]] as my LSP | |||||||
| *** Rust | *** Rust | ||||||
| Rust is a general programming language, akin to C++ in some ways, but | Rust is a general programming language, akin to C++ in some ways, but | ||||||
| much more oriented towards safe code, and much better suited for web | much more oriented towards safe code, and much better suited for web | ||||||
| development. First, let’s install the most important package, | development. | ||||||
| ~rustic~. | 
 | ||||||
|  | First, I’m using =rust-mode= to tell it to use [[https://tree-sitter.github.io/tree-sitter/][tree sitter]]. | ||||||
|  | #+begin_src emacs-lisp | ||||||
|  | (use-package rust-mode | ||||||
|  |   :straight | ||||||
|  |   :defer t | ||||||
|  |   :init | ||||||
|  |   (setq rust-mode-treesitter-derive t)) | ||||||
|  | #+end_src | ||||||
|  | 
 | ||||||
|  | Then, let’s install the most important package, =rustic=, which provides | ||||||
|  | several improvements on top of =rust-mode=. | ||||||
| #+begin_src emacs-lisp | #+begin_src emacs-lisp | ||||||
| (use-package rustic | (use-package rustic | ||||||
|   :defer t |   :defer t | ||||||
|  | |||||||
							
								
								
									
										263
									
								
								docs/git.org
									
									
									
									
									
								
							
							
						
						
									
										263
									
								
								docs/git.org
									
									
									
									
									
								
							| @ -6,10 +6,15 @@ | |||||||
| 
 | 
 | ||||||
| * Git | * Git | ||||||
| ** Basic configuration | ** Basic configuration | ||||||
|  | Just to make Emacs follow the convention in terms of indentation, I’m | ||||||
|  | forcing it to use tabs. | ||||||
| #+begin_src conf-unix | #+begin_src conf-unix | ||||||
| # -*- indent-tabs-mode: t; -*- | # -*- indent-tabs-mode: t; -*- | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
|  | *** Setting Up Personal Information and Preferences | ||||||
|  | Let’s set some of my personal information, namely my name, my email, | ||||||
|  | and which GPG key I sign my commits with. | ||||||
| #+begin_src conf-unix | #+begin_src conf-unix | ||||||
| [user] | [user] | ||||||
| 	email = lucien@phundrak.com | 	email = lucien@phundrak.com | ||||||
| @ -17,31 +22,187 @@ | |||||||
| 	signingkey = BD7789E705CB8DCA | 	signingkey = BD7789E705CB8DCA | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
|  | In terms of core configuration, I simply set Emacs as my default Git | ||||||
|  | editor. I also have my global gitignore file, described below in | ||||||
|  | [[file:./git.md#global-gitignore-file][Global gitignore file]]. | ||||||
| #+begin_src conf-unix | #+begin_src conf-unix | ||||||
| [core] | [core] | ||||||
| 	editor = emacsclient -c -a emacs | 	editor = emacsclient -c -a emacs | ||||||
| 	whitespace = fix,-indent-with-non-tab,trailing-space | 	excludesfile = ~/.config/git/global-ignore | ||||||
| 	excludesfile = /home/phundrak/.gitignore_global |  | ||||||
| #+end_src |  | ||||||
| 
 |  | ||||||
| #+begin_src conf-unix |  | ||||||
| [pull] |  | ||||||
| 	rebase = true |  | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
|  | Let’s not forget to tell Git to use the =main= branch by default. | ||||||
| #+begin_src conf-unix | #+begin_src conf-unix | ||||||
| [init] | [init] | ||||||
| 	defaultBranch = main | 	defaultBranch = main | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
|  | This is entirely a matter of personal preferences, but I like to use | ||||||
|  | [[https://zen-browser.app/][Zen]], a Firefox fork with really nice features. | ||||||
|  | #+begin_src conf-unix | ||||||
|  | [web] | ||||||
|  | 	browser = zen-browser | ||||||
|  | #+end_src | ||||||
|  | 
 | ||||||
|  | *** Better Diffing | ||||||
|  | Git’s diffing algorithm evolved and improved over time, but its | ||||||
|  | default algorithm did not. Take this example, from [[https://blog.gitbutler.com/how-git-core-devs-configure-git/][this Gitbutler | ||||||
|  | article]]: | ||||||
|  | 
 | ||||||
|  | [[file:./img/git/diff-default.png]] | ||||||
|  | 
 | ||||||
|  | Not really readable, I think you’ll agree. I mean, you can sort of see | ||||||
|  | what happens, but really, we just moved the =h2= styling below the | ||||||
|  | =.event= styling. Git seems to think otherwise. However, let’s turn on | ||||||
|  | the =histogram= algorithm on: | ||||||
|  | 
 | ||||||
|  | [[file:./img/git/diff-histogram.png]] | ||||||
|  | 
 | ||||||
|  | Immediately, we have a much clearer picture of what happened! But I’ll | ||||||
|  | let you on another secret: you can make it even clearer by using the | ||||||
|  | =colorMoved= option to color differently lines that were moved from | ||||||
|  | lines that were actually modified! | ||||||
|  | 
 | ||||||
|  | [[file:./img/git/diff-moved.png]] | ||||||
|  | 
 | ||||||
|  | I’ll also add a configuration to make it easier to see what is being | ||||||
|  | compared using =mnemonicPrefix=. As per =man git-config=: | ||||||
|  | #+begin_src text | ||||||
|  | git diff | ||||||
|  |     compares the (i)ndex and the (w)ork tree; | ||||||
|  | 
 | ||||||
|  | git diff HEAD | ||||||
|  |     compares a (c)ommit and the (w)ork tree; | ||||||
|  | 
 | ||||||
|  | git diff --cached | ||||||
|  |     compares a (c)ommit and the (i)ndex; | ||||||
|  | 
 | ||||||
|  | git diff HEAD:<file1> <file2> | ||||||
|  |     compares an (o)bject and a (w)ork tree entity; | ||||||
|  | 
 | ||||||
|  | git diff --no-index <a> <b> | ||||||
|  |     compares two non-git things <a> and <b>. | ||||||
|  | #+end_src | ||||||
|  | 
 | ||||||
|  | That means you can see I was comparing to objects not tracked by git | ||||||
|  | in my screenshot above. | ||||||
|  | 
 | ||||||
|  | Finally, =renames= set to =copies= not only better detects file renames, | ||||||
|  | but also file copies. | ||||||
|  | 
 | ||||||
|  | #+begin_src conf-unix | ||||||
|  | [diff] | ||||||
|  | 	algorithm = histogram | ||||||
|  | 	colorMoved = plain | ||||||
|  | 	mnemonicPrefix = true | ||||||
|  | 	renames = copy | ||||||
|  | #+end_src | ||||||
|  | 
 | ||||||
|  | *** Better Fetching, Pulling, Rebasing, and Pushing | ||||||
|  | By default, when I pull new commits, I do not want to create a merge | ||||||
|  | commit, but rather to rebase my commits on what’s new upstream. | ||||||
|  | #+begin_src conf-unix | ||||||
|  | [pull] | ||||||
|  | 	rebase = true | ||||||
|  | #+end_src | ||||||
|  | 
 | ||||||
|  | However, there is a problem with git’s default behaviour: it wont | ||||||
|  | allow me to pull changes or perform a rebase as long as my worktree is | ||||||
|  | dirty. I either have to commit or stash my changes before I can do | ||||||
|  | something. And you know what? Git can auto stash your changes for you | ||||||
|  | before performing a rebase. In fact, while we’re at it, let’s also | ||||||
|  | automatically squash commits that need to be squashed, and update all | ||||||
|  | refs. | ||||||
|  | #+begin_src conf-unix | ||||||
|  | [rebase] | ||||||
|  | 	autoSquash = true | ||||||
|  | 	autoStash = true | ||||||
|  | 	updateRefs = true | ||||||
|  | #+end_src | ||||||
|  | 
 | ||||||
|  | And oh, buggers, you have a merge conflict! I’m used to it, but since | ||||||
|  | git 2.3, there is a new feature that adds some context to git | ||||||
|  | conflicts: =zdiff3= (which stands for /zealous diff3/). Not only will it | ||||||
|  | show you the conflicting incoming and HEAD changes, but it will also | ||||||
|  | show you what the code was before either modified the conflicting | ||||||
|  | area. Not a must-have feature, but a nice one to have. Compare this: | ||||||
|  | 
 | ||||||
|  | [[file:./img/git/merge-default.png]] | ||||||
|  | 
 | ||||||
|  | To this: | ||||||
|  | 
 | ||||||
|  | [[file:./img/git/merge-zdiff3.png]] | ||||||
|  | 
 | ||||||
|  | We have a new line beginning with =|||||||= with the original line | ||||||
|  | below. Also, it’s nice to see Emacs supports this syntax out of the | ||||||
|  | box! | ||||||
|  | 
 | ||||||
|  | #+begin_src conf-unix | ||||||
|  | [merge] | ||||||
|  | 	conflictstyle = zdiff3 | ||||||
|  | #+end_src | ||||||
|  | 
 | ||||||
|  | Finally, once we’re good to go, we may want to push our changes to the | ||||||
|  | remote repository. Sometimes, git is confused and isn’t sure where it | ||||||
|  | should push your branch. Let’s tell it to simply push your current | ||||||
|  | branch to the branch with the same name on the remote with | ||||||
|  | =push.default=. If the upstream branch is not set yet, you can | ||||||
|  | automatically set it up with =push.autoSetupRemote=. Finally, I don’t | ||||||
|  | want to push separately my tags, so let’s push them with any other | ||||||
|  | push. | ||||||
|  | #+begin_src conf-unix | ||||||
|  | [push] | ||||||
|  | 	default = simple | ||||||
|  | 	autoSetupRemote = true | ||||||
|  | 	followTags = true | ||||||
|  | #+end_src | ||||||
|  | 
 | ||||||
|  | *** Making Git Look Better | ||||||
|  | First, let’s activate colors in git by default when we are in a terminal. | ||||||
| #+begin_src conf-unix | #+begin_src conf-unix | ||||||
| [color] | [color] | ||||||
| 	ui = auto | 	ui = auto | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
|  | Getting a raw list of things –branches, tags, …– is *not nice*. So, | ||||||
|  | let’s make it a bit nicer and split these lists in columns. | ||||||
| #+begin_src conf-unix | #+begin_src conf-unix | ||||||
| [web] | [column] | ||||||
| 	browser = zen-browser | 	ui = auto | ||||||
|  | #+end_src | ||||||
|  | 
 | ||||||
|  | Simply using the =column.ui= option sets everything to use columns when | ||||||
|  | using a terminal. If you want more granularity, you can instead use | ||||||
|  | =column.branch=, =column.status=, etc... Look up =man git-config= for more | ||||||
|  | info. | ||||||
|  | 
 | ||||||
|  | *** Better Sorting Branches and Tags | ||||||
|  | By default, branches are sorted alphabetically. This may be fine for | ||||||
|  | most people, but I prefer something else: sorting them by how recently | ||||||
|  | they were comitted to. This is actually quite easy to configure: | ||||||
|  | #+begin_src conf-unix | ||||||
|  | [branch] | ||||||
|  | 	sort = -committerdate | ||||||
|  | #+end_src | ||||||
|  | 
 | ||||||
|  | Sorting tags is not nice by default. For instance, git will show you | ||||||
|  | version 11 before version 2, because 11 is technically before 2 | ||||||
|  | alphabetically speaking. Let’s fix that. | ||||||
|  | #+begin_src conf-unix | ||||||
|  | [tag] | ||||||
|  | 	sort = version:refname | ||||||
|  | #+end_src | ||||||
|  | 
 | ||||||
|  | *** Did You Mean "Commit"? | ||||||
|  | Sometimes, I fat finger my git commands and white a subcommand that | ||||||
|  | does not exist, like =git pul= or =git comitt=. By default, git will | ||||||
|  | simply tell you that, no, that subcommand does not exist, but will be | ||||||
|  | kind enough to suggest a few commands that may be what you are looking | ||||||
|  | for. Let’s make git not only suggest these, but also ask you if you | ||||||
|  | want to run the one you most likely wanted to run. | ||||||
|  | #+begin_src conf-unix | ||||||
|  | [help] | ||||||
|  | 	autocorrect = prompt | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
| ** Aliases | ** Aliases | ||||||
| @ -178,7 +339,6 @@ | |||||||
| | =l=            | =log --oneline --graph --decorate= | | | =l=            | =log --oneline --graph --decorate= | | ||||||
| | =s=            | =status=                           | | | =s=            | =status=                           | | ||||||
| | =staged=       | =diff --cached=                    | | | =staged=       | =diff --cached=                    | | ||||||
| | =upstream=     | =!git push -u origin HEAD=         | |  | ||||||
| 
 | 
 | ||||||
| #+RESULTS: | #+RESULTS: | ||||||
| :       a = add --all | :       a = add --all | ||||||
| @ -247,30 +407,6 @@ | |||||||
| 	cmd = emacs --eval \" (progn (defun ediff-write-merge-buffer () (let ((file ediff-merge-store-file)) (set-buffer ediff-buffer-C) (write-region (point-min) (point-max) file) (message \\\"Merge buffer saved in: %s\\\" file) (set-buffer-modified-p nil) (sit-for 1))) (setq ediff-quit-hook 'kill-emacs ediff-quit-merge-hook 'ediff-write-merge-buffer) (ediff-merge-files-with-ancestor \\\"$LOCAL\\\" \\\"$REMOTE\\\" \\\"$BASE\\\" nil \\\"$MERGED\\\"))\" | 	cmd = emacs --eval \" (progn (defun ediff-write-merge-buffer () (let ((file ediff-merge-store-file)) (set-buffer ediff-buffer-C) (write-region (point-min) (point-max) file) (message \\\"Merge buffer saved in: %s\\\" file) (set-buffer-modified-p nil) (sit-for 1))) (setq ediff-quit-hook 'kill-emacs ediff-quit-merge-hook 'ediff-write-merge-buffer) (ediff-merge-files-with-ancestor \\\"$LOCAL\\\" \\\"$REMOTE\\\" \\\"$BASE\\\" nil \\\"$MERGED\\\"))\" | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
| *** Pager |  | ||||||
| #+begin_src conf-unix |  | ||||||
| [pager] |  | ||||||
| 	diff = delta |  | ||||||
| 	log = delta |  | ||||||
| 	reflog = delta |  | ||||||
| 	show = delta |  | ||||||
| #+end_src |  | ||||||
| 
 |  | ||||||
| *** Delta |  | ||||||
| #+begin_src conf-unix |  | ||||||
| [delta] |  | ||||||
| 	features = side-by-side line-numbers decorations |  | ||||||
| 	whitespace-error-style = 22 reverse |  | ||||||
| 
 |  | ||||||
| [delta "decorations"] |  | ||||||
| 	commit-decoration-style = bold yellow box ul |  | ||||||
| 	file-style = bold yellow ul |  | ||||||
| 	file-decoration-style = none |  | ||||||
| 
 |  | ||||||
| [interactive] |  | ||||||
| 	diffFilter = delta --color-only |  | ||||||
| #+end_src |  | ||||||
| 
 |  | ||||||
| *** Git forges | *** Git forges | ||||||
| #+begin_src conf-unix | #+begin_src conf-unix | ||||||
| [github] | [github] | ||||||
| @ -283,6 +419,9 @@ | |||||||
| 
 | 
 | ||||||
| [url "https://phundrak@labs.phundrak.com"] | [url "https://phundrak@labs.phundrak.com"] | ||||||
| 	insteadOf = https://labs.phundrak.com | 	insteadOf = https://labs.phundrak.com | ||||||
|  | 
 | ||||||
|  | [url "https://github.com/RustSec/advisory-db"] | ||||||
|  |     insteadOf = https://github.com/RustSec/advisory-db | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
| *** LFS | *** LFS | ||||||
| @ -293,3 +432,59 @@ | |||||||
| 	smudge = git-lfs smudge -- %f | 	smudge = git-lfs smudge -- %f | ||||||
| 	process = git-lfs filter-process | 	process = git-lfs filter-process | ||||||
| #+end_src | #+end_src | ||||||
|  | 
 | ||||||
|  | ** Global gitignore file | ||||||
|  | :PROPERTIES: | ||||||
|  | :HEADER-ARGS: :mkdirp yes :tangle ~/.config/git/global-ignore | ||||||
|  | :END: | ||||||
|  | This is my global gitignore file, specifying files that will always be | ||||||
|  | ignored by Git, as described in [[file:./git.md#basic-configuration][Basic configuration]]. | ||||||
|  | 
 | ||||||
|  | You may see some lines beginning with =,*=. Just read it as a simple =*=, | ||||||
|  | this is done in order to avoid org-mode being confused by a | ||||||
|  | line-initial =*= usually marking headings. | ||||||
|  | 
 | ||||||
|  | First, let’s just ignore dotenv files and direnv’s directories. | ||||||
|  | #+begin_src gitignore | ||||||
|  | .env | ||||||
|  | .direnv/ | ||||||
|  | #+end_src | ||||||
|  | 
 | ||||||
|  | Now, let’s ignore files generated by Emacs. | ||||||
|  | #+begin_src gitignore | ||||||
|  | ,*~ | ||||||
|  | \#*\# | ||||||
|  | ,*.elc | ||||||
|  | auto-save-list | ||||||
|  | .\#* | ||||||
|  | ,*_flymake.* | ||||||
|  | /auto/ | ||||||
|  | .projectile | ||||||
|  | .dir-locals.el | ||||||
|  | 
 | ||||||
|  | # Org mode files | ||||||
|  | .org-id-locations | ||||||
|  | ,*_archive | ||||||
|  | #+end_src | ||||||
|  | 
 | ||||||
|  | Finally, let’s ignore some files we generally do not want. | ||||||
|  | #+begin_src text | ||||||
|  | ,*.out | ||||||
|  | ,*.o | ||||||
|  | ,*.so | ||||||
|  | 
 | ||||||
|  | # Archives | ||||||
|  | ,*.7zz | ||||||
|  | ,*.dmg | ||||||
|  | ,*.gz | ||||||
|  | ,*.iso | ||||||
|  | ,*.jar | ||||||
|  | ,*.rar | ||||||
|  | ,*.tar | ||||||
|  | ,*.zip | ||||||
|  | 
 | ||||||
|  | ,*.log | ||||||
|  | ,*.sqlite | ||||||
|  | 
 | ||||||
|  | dist/ | ||||||
|  | #+end_src | ||||||
|  | |||||||
| @ -26,6 +26,7 @@ input { | |||||||
|     kb_model = |     kb_model = | ||||||
|     kb_options = caps:ctrl_modifier |     kb_options = caps:ctrl_modifier | ||||||
|     kb_rules = |     kb_rules = | ||||||
|  |     numlock_by_default = true | ||||||
| 
 | 
 | ||||||
|     follow_mouse = 1 |     follow_mouse = 1 | ||||||
| 
 | 
 | ||||||
| @ -111,10 +112,12 @@ decoration { | |||||||
|         size = 9 |         size = 9 | ||||||
|         passes = 1 |         passes = 1 | ||||||
|     } |     } | ||||||
|     drop_shadow = true |     shadow { | ||||||
|     shadow_range = 4 |         enabled = true | ||||||
|     shadow_render_power = 3 |         color = rgba(2e3440aa) | ||||||
|     col.shadow = rgba(2e3440aa) |         range = 4 | ||||||
|  |         render_power = 3 | ||||||
|  |     } | ||||||
| } | } | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
| @ -133,14 +136,11 @@ animations { | |||||||
| } | } | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
| Now, we can take care of the configuration of the layouts. The only | Now, we can take care of the configuration of the layouts. | ||||||
| notable thing here is that I prefer to have no gaps when there is only |  | ||||||
| one window in the dwindle layout. |  | ||||||
| #+begin_src conf | #+begin_src conf | ||||||
| dwindle { | dwindle { | ||||||
|     pseudotile = true |     pseudotile = true | ||||||
|     preserve_split = true |     preserve_split = true | ||||||
|     no_gaps_when_only = 1 |  | ||||||
| } | } | ||||||
| #+end_src | #+end_src | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										
											BIN
										
									
								
								docs/img/git/diff-default.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								docs/img/git/diff-default.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 32 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/img/git/diff-histogram.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								docs/img/git/diff-histogram.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 34 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/img/git/diff-moved.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								docs/img/git/diff-moved.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 34 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/img/git/merge-default.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								docs/img/git/merge-default.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 26 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/img/git/merge-zdiff3.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								docs/img/git/merge-zdiff3.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 30 KiB | 
| @ -975,7 +975,3 @@ HOME="$XDG_DATA_HOME"/android /usr/bin/adb "$@" | |||||||
| #+begin_src sh :tangle ~/.local/bin/wget | #+begin_src sh :tangle ~/.local/bin/wget | ||||||
| /usr/bin/wget --hsts-file="$XDG_DATA_HOME"/wget-hsts "$@" | /usr/bin/wget --hsts-file="$XDG_DATA_HOME"/wget-hsts "$@" | ||||||
| #+end_src | #+end_src | ||||||
| 
 |  | ||||||
| #+begin_src sh :tangle ~/.local/bin/yarn |  | ||||||
| /usr/bin/yarn --use-yarnrc "$XDG_CONFIG_HOME"/yarn/config "$@" |  | ||||||
| #+end_src |  | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user