X-Git-Url: https://arthur.barton.de/gitweb/?p=ax-zsh.git;a=blobdiff_plain;f=ax.zsh;h=1936327986e8e241bea0880b6e06ab20447c4c9a;hp=fbacf6cb2ad1a5e1c1910bc31e9c3974165a2b63;hb=0166eb3325e612f676008026994c6c1cad965bb5;hpb=3ab7568a61944c75e90c6e21279fa47b8348975e diff --git a/ax.zsh b/ax.zsh index fbacf6c..1936327 100644 --- a/ax.zsh +++ b/ax.zsh @@ -77,17 +77,17 @@ function axzsh_load_plugin { [[ -n "$AXZSH_DEBUG" ]] \ && echo " - $plugin ($type) ..." - # Note for "external" ("repo/*") plugins and "dumb" terminals: - # These (modern?) plugins most probably don't expect such an - # unusual old terminal configuration and don't behave well - # (echo color sequences, for example). Therefore we DON'T load - # any external plugins at all when running on such a terminal: - # this results in reduced/disabled functionality, but hopefully - # in readable output ... + # Note for "external" ("repo/*") plugins and unusual ("not so + # modern") terminals: These (modern?) plugins most probably + # don't expect such a terminal configuration and don't behave + # well (echo color sequences, for example). Therefore we DON'T + # load any external plugins at all in that case: this results in + # reduced/disabled functionality, but hopefully in readable + # output ... case "$fname" in *"/repos/"*) - axzsh_is_dumb_terminal || source "$fname" + axzsh_is_modern_terminal && source "$fname" ;; *) source "$fname" @@ -99,7 +99,7 @@ function axzsh_load_plugin { case "$fname" in *"/repos/"*) echo "[[ -n \"\$AXZSH_DEBUG\" ]] && echo ' - $plugin ($type): \"$fname\" ...'" >>$cache_file - echo "axzsh_is_dumb_terminal || source '$fname'" >>$cache_file + echo "axzsh_is_modern_terminal && source '$fname'" >>$cache_file ;; *) echo "[[ -n \"\$AXZSH_DEBUG\" ]] && echo ' - $plugin ($type, cached) ...'" >>$cache_file @@ -175,6 +175,19 @@ else # Read in all the plugins for the current "type": for plugin ($plugin_list); do + # Read the "theme file", if any and in "zshrc" stage. + # This must be done before 99_cleanup is run! + if [[ "$plugin:t" == "99_cleanup" && "$script_type" = "zshrc" ]]; then + if [[ -r "$AXZSH_THEME" ]]; then + source "$AXZSH_THEME" + if [[ -n "$cache_file" ]]; then + # Source the theme in the new cache file: + echo "# BEGIN Theme" >>"$cache_file" + echo 'source "$AXZSH_THEME"' >>"$cache_file" + echo "# END Theme" >>"$cache_file" + fi + fi + fi axzsh_load_plugin "$plugin" "$script_type" "$cache_file" done fi