diff --git a/.config/.tmux.conf b/.config/.tmux.conf index 14ebe29..38a682b 100644 --- a/.config/.tmux.conf +++ b/.config/.tmux.conf @@ -1,94 +1,73 @@ +# Terminal colors set -g default-terminal "tmux-256color" -set -ag terminal-overrides ",xterm-256color:RGB" - -set-option -g focus-events on - +set -sag terminal-features ",*:RGB" +set -sag terminal-features ",*:usstyle" +# set-option -g focus-events on # -- general ------------------------------------------------------------------- +# Activity +# set -g monitor-activity on +# set -g visual-activity on +# set -g monitor-activity off +# set -g bell-action none +# set -g visual-bell off -set -g mouse on -setw -g xterm-keys on -set -s escape-time 10 # faster command sequences -set -sg repeat-time 500 # increase repeat timeout -set -s focus-events on - -set -g prefix2 C-b # GNU-Screen compatible prefix -bind C-b send-prefix -2 - -set -q -g status-utf8 on # expect UTF-8 (tmux < 2.2) -setw -q -g utf8 on - +# Status +set -g status-interval 1 +set -sg escape-time 10 +set -g repeat-time 500 +set -g display-time 1500 set -g history-limit 5000 # boost history +set -g mouse on +set -g xterm-keys on + bind-key -T copy-mode-vi 'v' send -X begin-selection # start selecting text with "v" bind-key -T copy-mode-vi 'y' send -X copy-selection # copy text with "y" unbind -T copy-mode-vi MouseDragEnd1Pane # don't exit copy mode when dragging with mouse -# remove delay for exiting insert mode with ESC in Neovim -set -sg escape-time 10 +# choose tree format +set -g @custom_choose_tree_format "\ +#{?pane_format,\ +#{?pane_marked,#[bg=#{@thm_surface_1}],}\ +#[fg=#{@thm_green}]  #{session_name} \ +#{E:#{@custom_separator}}#[fg=#{@thm_maroon}]  #{pane_current_command} \ +#{E:#{@custom_separator}}#[fg=#{@thm_blue}]  #{pane_current_path} \ +#{?window_zoomed_flag,#{?pane_active,#{E:#{@custom_separator}}#[fg=#{@thm_yellow}]  zoom ,},}\ +#{?pane_marked,#{E:#{@custom_separator}}#[fg=#{@thm_yellow}]  marked ,}\ +#{?pane_active,#{E:#{@custom_separator}}#[fg=#{@thm_yellow}]  active ,}\ +,}\ +#{?window_format,\ +#{?window_marked_flag,#[bg=#{@thm_surface_1}],}\ +#{?window_active,#{#[fg=#{@thm_peach},reverse]},\ +#{?window_last_flag,#[fg=#{@thm_peach}],#[fg=#{@thm_rosewater}]}\ +}\ +  #I #{window_name} \ +#{#[fg=#{@thm_rosewater},none]}\ +#{?#{==:#{window_panes},1},\ +#[fg=#{@thm_green}]  #{session_name} \ +#{E:#{@custom_separator}}#[fg=#{@thm_maroon}]  #{pane_current_command} \ +#{E:#{@custom_separator}}#[fg=#{@thm_blue}]  #{pane_current_path} \ +#{?window_marked_flag,#{E:#{@custom_separator}}#[fg=#{@thm_yellow}]  marked ,}\ +,}\ +,}\ +#{?session_format,\ +#{session_windows} windows\ +#{?session_grouped, (group #{session_group}: #{session_group_list}),}\ +#{?session_attached, (attached),}\ +,} +" -# edit configuration -%if #{>=:#{version},3.0} -bind e new-window -n "#{TMUX_CONF_LOCAL}" -e EDITOR="$EDITOR" sh -c 'case "${EDITOR:-vim}" in *vim*) ${EDITOR:-vim} -c ":set syntax=tmux" "$TMUX_CONF_LOCAL";; *) $EDITOR "$TMUX_CONF_LOCAL";; esac && "$TMUX_PROGRAM" ${TMUX_SOCKET:+-S "$TMUX_SOCKET"} source "$TMUX_CONF" \; display "$TMUX_CONF_LOCAL sourced"' -%else -set-environment -g EDITOR "$EDITOR" -bind e new-window -n "#{TMUX_CONF_LOCAL}" sh -c 'case "${EDITOR:-vim}" in *vim*) ${EDITOR:-vim} -c ":set syntax=tmux" "$TMUX_CONF_LOCAL";; *) $EDITOR "$TMUX_CONF_LOCAL";; esac && "$TMUX_PROGRAM" ${TMUX_SOCKET:+-S "$TMUX_SOCKET"} source "$TMUX_CONF" \; display "$TMUX_CONF_LOCAL sourced"' -%endif +# Windows +bind-key -T copy-mode-vi 'v' send -X begin-selection # start selecting text with "v" +bind-key -T copy-mode-vi 'y' send -X copy-selection # copy text with "y" -# reload configuration -bind r run "sh -c '\"\$TMUX_PROGRAM\" \${TMUX_SOCKET:+-S \"\$TMUX_SOCKET\"} source \"\$TMUX_CONF\"'" \; display "#{TMUX_CONF} sourced" - -set-window-option -g mode-keys vi - -# -- display ------------------------------------------------------------------- - -set -g base-index 1 # start windows numbering at 1 -setw -g pane-base-index 1 # make pane numbering consistent with windows - -setw -g automatic-rename on # rename window to reflect current program -set -g renumber-windows on # renumber windows when a window is closed - -set -g set-titles on # set terminal title - -set -g display-panes-time 800 # slightly longer pane indicators display time -set -g display-time 1000 # slightly longer status messages display time - -set -g status-interval 10 # redraw status line every 10 seconds - -# activity -set -g monitor-activity on -set -g visual-activity off - -set -g monitor-activity off -set -g bell-action none -set -g visual-bell off -# -- navigation ---------------------------------------------------------------- - -# create session -# bind C-c new-session - -# find session -bind C-f command-prompt -p find-session 'switch-client -t %%' - -# session navigation -bind BTab switch-client -l # move to last session - -# split current window horizontally -bind - split-window -v -c "#{pane_current_path}" -# split current window vertically -bind _ split-window -h -c "#{pane_current_path}" - -# pane navigation +# Panes bind -r h select-pane -L # move left bind -r j select-pane -D # move down bind -r k select-pane -U # move up bind -r l select-pane -R # move right -bind C-q swap-pane -D # swap current pane with the next one -bind C-e swap-pane -U # swap current pane with the previous one - -# maximize current pane -bind + run "cut -c3- '#{TMUX_CONF}' | sh -s _maximize_pane '#{session_name}' '#D'" # pane resizing bind -r H resize-pane -L 2 @@ -96,11 +75,29 @@ bind -r J resize-pane -D 2 bind -r K resize-pane -U 2 bind -r L resize-pane -R 2 +# bind -r \} swap-pane -D +# bind -r \{ swap-pane -U +# bind -r space select-layout -n + +bind V split-window -h -c "#{pane_current_path}" +bind v split-window -v -c "#{pane_current_path}" + +# bind j choose-tree -F "#{E:@custom_choose_tree_format}" -Z "join-pane -h -s "%%"" +# bind J choose-tree -F "#{E:@custom_choose_tree_format}" -Z "join-pane -v -s "%%"" +bind w choose-tree -F "#{E:@custom_choose_tree_format}" -Z "select-window -t "%%"" + +# find session +bind C-f command-prompt -p find-session 'switch-client -t %%' + +# maximize current pane +# bind + run "cut -c3- '#{TMUX_CONF}' | sh -s _maximize_pane '#{session_name}' '#D'" + # window navigation unbind n unbind p -bind -r C-h previous-window # select previous window -bind -r C-l next-window # select next window +unbind C-l +bind -r h previous-window # select previous window +bind -r l next-window bind Tab last-window # move to last active window @@ -115,60 +112,158 @@ bind -T copy-mode-vi Escape send -X cancel bind -T copy-mode-vi H send -X start-of-line bind -T copy-mode-vi L send -X end-of-line - - - -# NOTE: -------------------------------------------------------------------------------------------------------------------- -# tpm plugin -set -g @plugin 'catppuccin/tmux' -# set -g @plugin 'xamut/tmux-weather' +# reload config file +bind r source-file ~/.tmux.conf \; display-message "~/.tmux.conf reloaded" +# List of plugins set -g @plugin 'tmux-plugins/tpm' -# list of tmux plugins +set -g @plugin 'catppuccin/tmux' set -g @plugin 'christoomey/vim-tmux-navigator' set -g @plugin 'tmux-plugins/tmux-resurrect' # persist tmux sessions after computer restart set -g @plugin 'tmux-plugins/tmux-continuum' # automatically saves sessions for you every 15 minutes -# set -g @plugin 'fabioluciano/tmux-tokyo-night' -# run ~/.tmux/plugins/catppuccin/catppuccin.tmux - -# NOTE: ...alongside -set -g @catppuccin_flavour "mocha" -set -g @catppuccin_window_left_separator " " -set -g @catppuccin_window_right_separator " " -set -g @catppuccin_window_middle_separator "|" -# set -g @catppuccin_window_middle_separator "" - -set -g @catppuccin_window_number_position "right" - -set -g @catppuccin_window_default_fill "all" -set -g @catppuccin_window_default_text "#W" - -set -g @catppuccin_window_current_fill "number" -set -g @catppuccin_window_current_text "#W" - -set -g @catppuccin_status_modules_right "user host" -set -g @catppuccin_status_modules_left "session " -set -g @catppuccin_status_right_separator "" - -set -g @catppuccin_status_left_separator " " -# set -g @catppuccin_status_right_separator " " -set -g @catppuccin_status_middle_separator "|" - -set -g @catppuccin_status_fill "all" -set -g @catppuccin_status_connect_separator "yes" -set -g @catppuccin_window_status_icon_enable "yes" -set -g @catppuccin_window_status_enable "yes" -set -g @catppuccin_status_default "on" -# icons -set -g @catppuccin_icon_window_last "󰃀 " -set -g @catppuccin_icon_window_current " " - -set -g status-position top - -# set -g @catppuccin_directory_text "#{pane_current_path}" -# end it +# Configure Catppuccin +set -g @catppuccin_flavor "macchiato" +set -g @catppuccin_status_background "none" # none == default +set -g @catppuccin_pane_status_enabled "off" +set -g @catppuccin_pane_border_status "off" + set -g @resurrect-capture-pane-contents 'on' set -g @continuum-restore 'on' +set-window-option -g mode-keys vi +# Configure battery +# set -g @batt_icon_charge_tier8 '' +# set -g @batt_icon_charge_tier7 '' +# set -g @batt_icon_charge_tier6 '' +# set -g @batt_icon_charge_tier5 '' +# set -g @batt_icon_charge_tier4 '' +# set -g @batt_icon_charge_tier3 '' +# set -g @batt_icon_charge_tier2 '' +# set -g @batt_icon_charge_tier1 '' +# set -g @batt_icon_status_charged '' +# set -g @batt_icon_status_charging '' +# set -g @batt_icon_status_discharging '' +# set -g @batt_icon_status_attached '' +# set -g @batt_icon_status_unknown '' + +# Configure Cpu +set -g @cpu_percentage_format "%03d%%" + +# Configure Mem +set -g @ram_percentage_format "%03d%%" + +# status left look and feel +set -g status-left-length 80 +set -g status-left "" + +# status right look and feel +set -g status-right-length 160 +set -g status-right "" + +# custom var +set -g @custom_separator "#[fg=#{@thm_overlay_0},none]|" + +# session +set -ga status-right "#[fg=#{@thm_green},bg=default]" +set -ga status-right "#{?client_prefix,#[#{fg=#{@thm_green}}]#[reverse]#[bold],}" +set -ga status-right " #{?#{e|>:#{window_width},90}, #S,} " +set -ga status-right "#{?client_prefix,#[none],}" +set -ga status-right "#{E:#{@custom_separator}}" + +# application +set -ga status-right "#[fg=#{@thm_maroon},bg=default]" +set -ga status-right " #{?#{e|>:#{window_width},80}, #{pane_current_command},} " +set -ga status-right "#{E:#{@custom_separator}}" + +# directory +set -ga status-right "#[fg=#{@thm_blue},bg=default]" +set -ga status-right " #{?#{e|>:#{window_width},80}, #{=/24/...:#{b:pane_current_path}},} " +set -ga status-right "#{E:#{@custom_separator}}" + +# window zoom flag +set -ga status-right "#{?window_zoomed_flag," +set -ga status-right "#[fg=#{@thm_yellow}]#[bg=default]" +set -ga status-right " #{?#{e|>:#{window_width},110}, zoom,} " +set -ga status-right "#{E:#{@custom_separator}}" +set -ga status-right ",}" + +# pane marked flag +set -ga status-right "#{?pane_marked," +set -ga status-right "#[fg=#{@thm_yellow}]#[bg=default]" +set -ga status-right " #{?#{e|>:#{window_width},110}, marked,} " +set -ga status-right "#{E:#{@custom_separator}}" +set -ga status-right ",}" + +# cpu +# set -ga status-right "#[fg=#{@thm_teal},bg=default]" +# set -ga status-right " #{?#{e|>:#{window_width},115}, #{cpu_percentage},} " +# set -ga status-right "#{E:#{@custom_separator}}" + +# ram +# set -ga status-right "#[fg=#{@thm_sky},bg=default]" +# set -ga status-right " #{?#{e|>:#{window_width},115}, #{ram_percentage},} " +# set -ga status-right "#{E:#{@custom_separator}}" + +# battery +# set -ga status-right "#[fg=#{@thm_pink},bg=default]" +# set -ga status-right "#{?#{e|>:#{window_width},105}," +# set -ga status-right " #{?#{battery_percentage},#{battery_icon} #{battery_percentage},#{@batt_icon_status_charged} cable} " +# set -ga status-right "," +# set -ga status-right " #{?#{battery_percentage},#{battery_icon},#{@batt_icon_status_charged}} " +# set -ga status-right "}" +# set -ga status-right "#{E:#{@custom_separator}}" + +# date +set -ga status-right "#[fg=#{@thm_lavender},bg=default]" +set -ga status-right " #{?#{e|>:#{window_width},95}, %Y-%m-%d,} " +set -ga status-right "#{E:#{@custom_separator}}" + + +# time +# set -ga status-right "#[fg=#{@thm_fg},bg=default]" +# set -ga status-right " #{?#{e|>:#{window_width},85}, %H:%M,} " + +# bootstrap tpm +if "test ! -d ~/.tmux/plugins/tpm" \ + "run 'git clone https://github.com/tmux-plugins/tpm ~/.tmux/plugins/tpm && ~/.tmux/plugins/tpm/bin/install_plugins'" # Initialize TMUX plugin manager (keep this line at the very bottom of tmux.conf) run '~/.tmux/plugins/tpm/tpm' + +# Configure Tmux +set -g status 2 +set -g status-position top +set -g status-style "bg=#{@thm_mantle}" +set -g status-justify "left" + +set -gF status-format[1] "#[fg=#{@thm_surface_2},bg=#{@thm_bg}]\ +───────────────────────────────────────────────────────────────────────────────\ +───────────────────────────────────────────────────────────────────────────────\ +───────────────────────────────────────────────────────────────────────────────\ +───────────────────────────────────────────────────────────────────────────────\ +───────────────────────────────────────────────────────────────────────────────\ +───────────────────────────────────────────────────────────────────────────────\ +" + +# pane border look and feel +setw -g pane-border-status off +setw -g pane-border-format "" +setw -g pane-active-border-style "bg=default,fg=#{@thm_peach}" +setw -g pane-border-style "bg=default,fg=#{@thm_overlay_1}" +setw -g pane-border-lines single + +# window look and feel +set -gF window-status-separator "#[fg=#{@thm_overlay_0}]" +set -wg automatic-rename on +set -g automatic-rename-format "window" + +set -g window-status-format " #{?#{==:#{window_name},window},#I,#W} " +set -g window-status-style "fg=#{@thm_rosewater},bg=default" +set -g window-status-last-style "fg=#{@thm_peach}" +set -g window-status-activity-style "fg=#{@thm_red},bold" +set -g window-status-bell-style "fg=#{@thm_red},bold" + +set -g window-status-current-format " #{?#{==:#{window_name},window},#I,#W} " +set -g window-status-current-style "fg=#{@thm_peach},bold,reverse" +# show startup screen +# hook to run fastfetch on session jreation +# set-hook -g after-new-session 'send-keys " clear && fastfetch" C-m' diff --git a/.config/.zshrc b/.config/.zshrc index c7a8b40..54a6fc2 100644 --- a/.config/.zshrc +++ b/.config/.zshrc @@ -1,41 +1,37 @@ +export QT_IM_MODULE=fcitx # For those who bundle qt im module, e.g. WPS, Anki, you should find a .so file with fcitx in the file name +export QT_IM_MODULE=ibus # For those who bundle ibus im module shipped with Qt, you should find libibusplatforminputcontextplugin.so in the package. +export QT_QPA_PLATFORM=xcb QT_IM_MODULE=ibus # Enforce it to run on X11/XWayland and use ibus im module +export QT_IM_MODULES="wayland;fcitx;ibus" +export SETUPTOOLS_USE_DISTUTILS=1 +export DISABLE_AUTO_UPDATE="true" + +# HACK: Export ENV +export ZINIT_HOME="${XDG_DATA_HOME:-${HOME}/.local/share}/zinit/zinit.git" export PYOPENGL_PLATFORM=osmesa export PRIMARY_MONITOR_WORKSPACE=1 export SECONDARY_MONITOR_WORKSPACE=2 export VIRTUAL_ENV_DISABLE_PROMPT=1 export MYPYPATH="/home/duckq1u/miniconda3/envs/pytorch" -export ROCM_PATH="/opt/rocm" -# export CMAKE_PREFIX_PATH="/home/duckq1u/miniconda3/envs/pytorch/lib/cmake" -export PYTORCH_ROCM_ARCH="gfx1010" -# export HSA_OVERRIDE_GFX_VERSION=10.1.0 -# export HIP_VISIBLE_DEVICES=0 -export LD_LIBRARY_PATH="/opt/rocm/" +# Added by LM Studio CLI (lms) +export PATH="$PATH:/home/duckq1u/.cache/lm-studio/bin" + +# Added by LM Studio CLI (lms) +export PATH="$PATH:/home/duckq1/.lmstudio/bin" + +# HACK:: Show up startup packaging +# zmodload zsh/zprof + # HACK: Config auto-suggestion as well as oh-my-posh eval "$(oh-my-posh init zsh --config ~/montys.omp.json)" -# HACK: Export ENV -ZINIT_HOME="${XDG_DATA_HOME:-${HOME}/.local/share}/zinit/zinit.git" # HACK: Config Zinit [ ! -d $ZINIT_HOME ] && mkdir -p "$(dirname $ZINIT_HOME)" [ ! -d $ZINIT_HOME/.git ] && git clone https://github.com/zdharma-continuum/zinit.git "$ZINIT_HOME" source "${ZINIT_HOME}/zinit.zsh" -# HACK: NVM config init -# Initialize fast node manager (fnm) -export NVM_LAZY=1 -export NVM_AUTO_USE=false - -[[ $(command -v "fnm") ]] && eval "$(fnm env --use-on-cd --log-level=quiet)" -# load my nvm to fnm shim -export NVM_DIR="$([ -z "${XDG_CONFIG_HOME-}" ] && printf %s "${HOME}/.nvm" || printf %s "${XDG_CONFIG_HOME}/nvm")" -[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" - - -# HACK: Shell intergrations -eval eval "$(fzf --zsh)" - # NOTE: Add in zsh plugins zinit light zsh-users/zsh-syntax-highlighting zinit light zsh-users/zsh-completions @@ -43,6 +39,16 @@ zinit light zsh-users/zsh-autosuggestions zinit light Aloxaf/fzf-tab zinit light agkozak/zsh-z + +# HACK: NVM config init +# Initialize fast node manager (fnm) +[[ $(command -v "fnm") ]] && eval "$(fnm env --use-on-cd --log-level=quiet)" + + +# HACK: Shell intergrations +eval eval "$(fzf --zsh)" + + # HACK: Load completions autoload -U compinit && compinit @@ -103,7 +109,7 @@ jointmux(){ appearance(){ # pokemon-colorscripts -n charizard -f mega-x - pokemon-colorscripts -n darkrai --no-title + # pokemon-colorscripts -n darkrai --no-title cat ~/.conda/environments.txt } @@ -138,10 +144,12 @@ bindkey '^p' history-search-backward bindkey '^n' history-search-forward bindkey '^[w' kill-region bindkey "^H" backward-delete-word +bindkey -s "^L" "/C-l" + # zprof # conda env list -[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm bash_completion +# [ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm bash_completion # >>> conda initialize >>> # !! Contents within this block are managed by 'conda init' !! @@ -156,9 +164,6 @@ else fi fi unset __conda_setup -# <<< conda initialize <<< -conda activate pytorch -# Added by LM Studio CLI (lms) -export PATH="$PATH:/home/duckq1u/.cache/lm-studio/bin" +# zprof diff --git a/.config/grub.cfg b/.config/grub.cfg new file mode 100755 index 0000000..f76be78 --- /dev/null +++ b/.config/grub.cfg @@ -0,0 +1,317 @@ +# +# DO NOT EDIT THIS FILE +# +# It is automatically generated by grub-mkconfig using templates +# from /etc/grub.d and settings from /etc/default/grub +# + +### BEGIN /etc/grub.d/00_header ### +insmod part_gpt +insmod part_msdos +if [ -s $prefix/grubenv ]; then + load_env +fi +if [ "${next_entry}" ] ; then + set default="${next_entry}" + set next_entry= + save_env next_entry + set boot_once=true +else + set default="${saved_entry}" +fi + +if [ x"${feature_menuentry_id}" = xy ]; then + menuentry_id_option="--id" +else + menuentry_id_option="" +fi + +export menuentry_id_option + +if [ "${prev_saved_entry}" ]; then + set saved_entry="${prev_saved_entry}" + save_env saved_entry + set prev_saved_entry= + save_env prev_saved_entry + set boot_once=true +fi + +function savedefault { + if [ -z "${boot_once}" ]; then + saved_entry="${chosen}" + save_env saved_entry + fi +} + +function load_video { + if [ x$feature_all_video_module = xy ]; then + insmod all_video + else + insmod efi_gop + insmod efi_uga + insmod ieee1275_fb + insmod vbe + insmod vga + insmod video_bochs + insmod video_cirrus + fi +} + +if [ x$feature_default_font_path = xy ] ; then + font=unicode +else +insmod part_gpt +insmod ext2 +set root='hd0,gpt2' +if [ x$feature_platform_search_hint = xy ]; then + search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt2 --hint-efi=hd0,gpt2 --hint-baremetal=ahci0,gpt2 5f72f8a3-568f-41f4-8303-572f5e1e01a5 +else + search --no-floppy --fs-uuid --set=root 5f72f8a3-568f-41f4-8303-572f5e1e01a5 +fi + font="/usr/share/grub/unicode.pf2" +fi + +if loadfont $font ; then + set gfxmode=1280x1024x32,auto + load_video + insmod gfxterm + set locale_dir=$prefix/locale + set lang=en_US + insmod gettext +fi +terminal_input console +terminal_output gfxterm +insmod part_gpt +insmod ext2 +set root='hd0,gpt2' +if [ x$feature_platform_search_hint = xy ]; then + search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt2 --hint-efi=hd0,gpt2 --hint-baremetal=ahci0,gpt2 5f72f8a3-568f-41f4-8303-572f5e1e01a5 +else + search --no-floppy --fs-uuid --set=root 5f72f8a3-568f-41f4-8303-572f5e1e01a5 +fi +insmod gfxmenu +loadfont ($root)/usr/share/grub/themes/Retroboot/font.pf2 +insmod png +set theme=($root)/usr/share/grub/themes/Retroboot/theme.txt +export theme +if [ x$feature_timeout_style = xy ] ; then + set timeout_style=menu + set timeout=5 +# Fallback normal timeout code in case the timeout_style feature is +# unavailable. +else + set timeout=5 +fi +### END /etc/grub.d/00_header ### + +### BEGIN /etc/grub.d/10_linux ### +menuentry 'Arch Linux' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-simple-5f72f8a3-568f-41f4-8303-572f5e1e01a5' { + savedefault + load_video + set gfxpayload=keep + insmod gzio + insmod part_gpt + insmod fat + set root='hd0,gpt1' + if [ x$feature_platform_search_hint = xy ]; then + search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt1 --hint-efi=hd0,gpt1 --hint-baremetal=ahci0,gpt1 0B21-9075 + else + search --no-floppy --fs-uuid --set=root 0B21-9075 + fi + echo 'Loading Linux linux-zen ...' + linux /vmlinuz-linux-zen root=UUID=5f72f8a3-568f-41f4-8303-572f5e1e01a5 rw zswap.enabled=0 rootfstype=ext4 loglevel=3 quiet nvidia_drm.modeset=1 + echo 'Loading initial ramdisk ...' + initrd /amd-ucode.img /initramfs-linux-zen.img +} +menuentry "Windows" --class windows --class os { + search --fs-uuid --no-floppy --set=root 3D02-6B08 + chainloader (${root})/EFI/Microsoft/Boot/bootmgfw.efi +} +submenu 'Advanced options for Arch Linux' $menuentry_id_option 'gnulinux-advanced-5f72f8a3-568f-41f4-8303-572f5e1e01a5' { + menuentry 'Arch Linux, with Linux linux-zen' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-linux-zen-advanced-5f72f8a3-568f-41f4-8303-572f5e1e01a5' { + savedefault + load_video + set gfxpayload=keep + insmod gzio + insmod part_gpt + insmod fat + set root='hd0,gpt1' + if [ x$feature_platform_search_hint = xy ]; then + search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt1 --hint-efi=hd0,gpt1 --hint-baremetal=ahci0,gpt1 0B21-9075 + else + search --no-floppy --fs-uuid --set=root 0B21-9075 + fi + echo 'Loading Linux linux-zen ...' + linux /vmlinuz-linux-zen root=UUID=5f72f8a3-568f-41f4-8303-572f5e1e01a5 rw zswap.enabled=0 rootfstype=ext4 loglevel=3 quiet nvidia_drm.modeset=1 + echo 'Loading initial ramdisk ...' + initrd /amd-ucode.img /initramfs-linux-zen.img + } + menuentry 'Arch Linux, with Linux linux-zen (fallback initramfs)' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-linux-zen-fallback-5f72f8a3-568f-41f4-8303-572f5e1e01a5' { + savedefault + load_video + set gfxpayload=keep + insmod gzio + insmod part_gpt + insmod fat + set root='hd0,gpt1' + if [ x$feature_platform_search_hint = xy ]; then + search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt1 --hint-efi=hd0,gpt1 --hint-baremetal=ahci0,gpt1 0B21-9075 + else + search --no-floppy --fs-uuid --set=root 0B21-9075 + fi + echo 'Loading Linux linux-zen ...' + linux /vmlinuz-linux-zen root=UUID=5f72f8a3-568f-41f4-8303-572f5e1e01a5 rw zswap.enabled=0 rootfstype=ext4 loglevel=3 quiet nvidia_drm.modeset=1 + echo 'Loading initial ramdisk ...' + initrd /amd-ucode.img /initramfs-linux-zen-fallback.img + } + menuentry 'Arch Linux, with Linux linux-lts' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-linux-lts-advanced-5f72f8a3-568f-41f4-8303-572f5e1e01a5' { + savedefault + load_video + set gfxpayload=keep + insmod gzio + insmod part_gpt + insmod fat + set root='hd0,gpt1' + if [ x$feature_platform_search_hint = xy ]; then + search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt1 --hint-efi=hd0,gpt1 --hint-baremetal=ahci0,gpt1 0B21-9075 + else + search --no-floppy --fs-uuid --set=root 0B21-9075 + fi + echo 'Loading Linux linux-lts ...' + linux /vmlinuz-linux-lts root=UUID=5f72f8a3-568f-41f4-8303-572f5e1e01a5 rw zswap.enabled=0 rootfstype=ext4 loglevel=3 quiet nvidia_drm.modeset=1 + echo 'Loading initial ramdisk ...' + initrd /amd-ucode.img /initramfs-linux-lts.img + } + menuentry 'Arch Linux, with Linux linux-lts (fallback initramfs)' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-linux-lts-fallback-5f72f8a3-568f-41f4-8303-572f5e1e01a5' { + savedefault + load_video + set gfxpayload=keep + insmod gzio + insmod part_gpt + insmod fat + set root='hd0,gpt1' + if [ x$feature_platform_search_hint = xy ]; then + search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt1 --hint-efi=hd0,gpt1 --hint-baremetal=ahci0,gpt1 0B21-9075 + else + search --no-floppy --fs-uuid --set=root 0B21-9075 + fi + echo 'Loading Linux linux-lts ...' + linux /vmlinuz-linux-lts root=UUID=5f72f8a3-568f-41f4-8303-572f5e1e01a5 rw zswap.enabled=0 rootfstype=ext4 loglevel=3 quiet nvidia_drm.modeset=1 + echo 'Loading initial ramdisk ...' + initrd /amd-ucode.img /initramfs-linux-lts-fallback.img + } + menuentry 'Arch Linux, with Linux linux-hardened' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-linux-hardened-advanced-5f72f8a3-568f-41f4-8303-572f5e1e01a5' { + savedefault + load_video + set gfxpayload=keep + insmod gzio + insmod part_gpt + insmod fat + set root='hd0,gpt1' + if [ x$feature_platform_search_hint = xy ]; then + search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt1 --hint-efi=hd0,gpt1 --hint-baremetal=ahci0,gpt1 0B21-9075 + else + search --no-floppy --fs-uuid --set=root 0B21-9075 + fi + echo 'Loading Linux linux-hardened ...' + linux /vmlinuz-linux-hardened root=UUID=5f72f8a3-568f-41f4-8303-572f5e1e01a5 rw zswap.enabled=0 rootfstype=ext4 loglevel=3 quiet nvidia_drm.modeset=1 + echo 'Loading initial ramdisk ...' + initrd /amd-ucode.img /initramfs-linux-hardened.img + } + menuentry 'Arch Linux, with Linux linux-hardened (fallback initramfs)' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-linux-hardened-fallback-5f72f8a3-568f-41f4-8303-572f5e1e01a5' { + savedefault + load_video + set gfxpayload=keep + insmod gzio + insmod part_gpt + insmod fat + set root='hd0,gpt1' + if [ x$feature_platform_search_hint = xy ]; then + search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt1 --hint-efi=hd0,gpt1 --hint-baremetal=ahci0,gpt1 0B21-9075 + else + search --no-floppy --fs-uuid --set=root 0B21-9075 + fi + echo 'Loading Linux linux-hardened ...' + linux /vmlinuz-linux-hardened root=UUID=5f72f8a3-568f-41f4-8303-572f5e1e01a5 rw zswap.enabled=0 rootfstype=ext4 loglevel=3 quiet nvidia_drm.modeset=1 + echo 'Loading initial ramdisk ...' + initrd /amd-ucode.img /initramfs-linux-hardened-fallback.img + } + menuentry 'Arch Linux, with Linux linux' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-linux-advanced-5f72f8a3-568f-41f4-8303-572f5e1e01a5' { + savedefault + load_video + set gfxpayload=keep + insmod gzio + insmod part_gpt + insmod fat + set root='hd0,gpt1' + if [ x$feature_platform_search_hint = xy ]; then + search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt1 --hint-efi=hd0,gpt1 --hint-baremetal=ahci0,gpt1 0B21-9075 + else + search --no-floppy --fs-uuid --set=root 0B21-9075 + fi + echo 'Loading Linux linux ...' + linux /vmlinuz-linux root=UUID=5f72f8a3-568f-41f4-8303-572f5e1e01a5 rw zswap.enabled=0 rootfstype=ext4 loglevel=3 quiet nvidia_drm.modeset=1 + echo 'Loading initial ramdisk ...' + initrd /amd-ucode.img /initramfs-linux.img + } + menuentry 'Arch Linux, with Linux linux (fallback initramfs)' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-linux-fallback-5f72f8a3-568f-41f4-8303-572f5e1e01a5' { + savedefault + load_video + set gfxpayload=keep + insmod gzio + insmod part_gpt + insmod fat + set root='hd0,gpt1' + if [ x$feature_platform_search_hint = xy ]; then + search --no-floppy --fs-uuid --set=root --hint-bios=hd0,gpt1 --hint-efi=hd0,gpt1 --hint-baremetal=ahci0,gpt1 0B21-9075 + else + search --no-floppy --fs-uuid --set=root 0B21-9075 + fi + echo 'Loading Linux linux ...' + linux /vmlinuz-linux root=UUID=5f72f8a3-568f-41f4-8303-572f5e1e01a5 rw zswap.enabled=0 rootfstype=ext4 loglevel=3 quiet nvidia_drm.modeset=1 + echo 'Loading initial ramdisk ...' + initrd /amd-ucode.img /initramfs-linux-fallback.img + } +} + +### END /etc/grub.d/10_linux ### + +### BEGIN /etc/grub.d/15_ostree ### +### END /etc/grub.d/15_ostree ### + +### BEGIN /etc/grub.d/20_linux_xen ### +### END /etc/grub.d/20_linux_xen ### + +### BEGIN /etc/grub.d/25_bli ### +if [ "$grub_platform" = "efi" ]; then + insmod bli +fi +### END /etc/grub.d/25_bli ### + +### BEGIN /etc/grub.d/30_os-prober ### +### END /etc/grub.d/30_os-prober ### + +### BEGIN /etc/grub.d/30_uefi-firmware ### +if [ "$grub_platform" = "efi" ]; then + fwsetup --is-supported + if [ "$?" = 0 ]; then + menuentry 'UEFI Firmware Settings' $menuentry_id_option 'uefi-firmware' { + fwsetup + } + fi +fi +### END /etc/grub.d/30_uefi-firmware ### + +### BEGIN /etc/grub.d/40_custom ### +# This file provides an easy way to add custom menu entries. Simply type the +# menu entries you want to add after this comment. Be careful not to change +# the 'exec tail' line above. +### END /etc/grub.d/40_custom ### + +### BEGIN /etc/grub.d/41_custom ### +if [ -f ${config_directory}/custom.cfg ]; then + source ${config_directory}/custom.cfg +elif [ -z "${config_directory}" -a -f $prefix/custom.cfg ]; then + source $prefix/custom.cfg +fi +### END /etc/grub.d/41_custom ###