O xmobar não aparece no topo da pilha de janelas quando o xmonad é iniciado

16

Estou tendo um comportamento estranho xmobarlogo após entrar xmonad. Quando i xmonad(de .xinitrc, eu uso o XDM), meu xmobaraparece, mas não está na parte superior ou inferior da pilha de janelas . Depois de iniciar um aplicativo (por exemplo, emulador de terminal pressionando Mod + Shift + Return), o aplicativo usa a tela inteira, como se xmobarestivesse na parte inferior. Então eu pressiono Mod + Be nada acontece, uma vez que pressiono Mod + Buma segunda vez xmobaré levantado para o topo, reduzindo o tamanho da janela do aplicativo.

Depois disso, Mod + Bfunciona corretamente para o restante da xmonadsessão, ou seja, diminui / aumenta (oculta / mostra) o xmobar.

Estou confiante de ter configurado algo errado. Minha xmonad.hsaparência é:

import XMonad
import XMonad.Hooks.SetWMName
import XMonad.Hooks.DynamicLog

main = do
  xmonad =<< statusBar "xmobar" myPP toggleStrutsKey defaultConfig
    { terminal           = "urxvt"
    , focusFollowsMouse  = True
    , clickJustFocuses   = False
    , borderWidth        = 1
    , modMask            = mod4Mask
    , workspaces         = myworkspaces
    , normalBorderColor  = "#dddddd"
    , focusedBorderColor = "#00dd00"
    , manageHook         = mymanager
    , startupHook        = setWMName "LG3D"
    }

myPP = xmobarPP { ppOutput          = putStrLn
                , ppCurrent         = xmobarColor "#336433" "" . wrap "[" "]"
                --, ppHiddenNoWindows = xmobarColor "grey" ""
                , ppTitle           = xmobarColor "darkgreen"  "" . shorten 20
                , ppLayout          = shorten 6
                --, ppVisible         = wrap "(" ")"
                , ppUrgent          = xmobarColor "red" "yellow"
                }

toggleStrutsKey XConfig { XMonad.modMask = modMask } = (modMask, xK_b)

myworkspaces = [ "code"
               , "web"
               , "media"
               , "irc"
               , "random"
               , "mail"
               , "docs"
               , "music"
               , "root"
               ]

mymanager = composeAll
  [ className =? "gimp" --> doFloat
  , className =? "vlc"  --> doFloat
  ]

Enquanto o começo da minha .xmobarrcaparência é o seguinte:

Config {
  -- appearance
    font =         "xft:Bitstream Vera Sans Mono:size=9:bold:antialias=true"
  , bgColor =      "black"
  , fgColor =      "#646464"
  , position =     Top
  , border =       BottomB
  , borderColor =  "#646464"

  -- layout
  , sepChar =  "%"   -- delineator between plugin names and straight text
  , alignSep = "}{"  -- separator between left-right alignment
  , template = "%battery% | %multicpu% | %coretemp% | %memory% | %dynnetwork% | %StdinReader% }{ %date% || %kbd% "

  -- general behavior
  , lowerOnStart =     False   -- send to bottom of window stack on start
  , hideOnStart =      False   -- start with window unmapped (hidden)
  , allDesktops =      True    -- show on all desktops
  , overrideRedirect = True    -- set the Override Redirect flag (Xlib)
  , pickBroadest =     False   -- choose widest display (multi-monitor)
  , persistent =       True    -- enable/disable hiding (True = disabled)

  -- plugins (i do not use any)

  , commands = [  -- actually several commands are in here
  ]
}

Eu tentei várias combinações de:

, lowerOnStart =
, hideOnStart =

(Verdadeiro / Verdadeiro, Verdadeiro / Falso, Falso / Verdadeiro e Falso / Falso, como mostrado agora). Mas o comportamento antes de pressionar Mod + Bduas vezes não muda. Acredito que tenha configurado mal xmonadde alguma forma, xmobarmas isso é apenas um palpite.

Meu .xinitrcpode ser de ajuda:

#!/bin/sh

if test -d /etc/X11/xinit/xinitrc.d
then
    # /etc/X11/xinit/xinitrc.d is actually empty
    for f in /etc/X11/xinit/xinitrc.d/*
    do
        [ -x "$f" ] && source "$f"
    done
    unset f
fi

# uk keyboard
setxkbmap gb

xrdb .Xresources
xscreensaver -no-splash &

# java behaves badly in non-reparenting window managers (e.g. xmonad)
export _JAVA_AWT_WM_NONREPARENTING=1

# set the background (again, because qiv uses a different buffer)
/usr/bin/feh --bg-scale --no-fehbg -z /usr/share/archlinux/wallpaper/a*.jpg

# pulse audio for alsa
then
    /usr/bin/start-pulseaudio-x11
fi

exec xmonad
grochmal
fonte

Respostas:

24

Dois meses depois, eu descobri. O problema é que statusBarnão registra os eventos Hooks.manageDockscorretamente. Uma vez que xmonadestá sendo executado, tudo funciona bem porque manageDocksé capaz de atualizar o Strutsevento em cada janela. Mas, no momento que xmonadestá iniciando, o evento de tornar as primeiras janelas em tela cheia acontece antes dos eventos manageDocks. Isso altera a primeira janela aberta para ignorar a existência de xmobar.

manageDockspossui seu manipulador de eventos que deve ser definido como o último manipulador de eventos, portanto, não statusBarpode ser usado. Em vez disso, é necessário para fazer xmonadchamadas e configure xmobarmanualmente através de dynamicLog, manageHook, layoutHooke handleEventHook. Uma configuração minimalista para isso seria:

main = do
    xmproc <- spawnPipe "xmobar"
    xmonad $ defaultConfig
      { modMask            = mod4Mask
      , manageHook         = manageDocks <+> manageHook defaultConfig
      , layoutHook         = avoidStruts  $ layoutHook defaultConfig
      -- this must be in this order, docksEventHook must be last
      , handleEventHook    = handleEventHook defaultConfig <+> docksEventHook
      , logHook            = dynamicLogWithPP xmobarPP
          { ppOutput          = hPutStrLn xmproc
          , ppTitle           = xmobarColor "darkgreen"  "" . shorten 20
          , ppHiddenNoWindows = xmobarColor "grey" ""
          }
      , startupHook        = setWMName "LG3D"
      } `additionalKeys`
      [ ((mod4Mask, xK_b), sendMessage ToggleStruts) ]

Isso faz com que todos os eventos sejam processados docsEventHooke garante que as alterações no layout feitas docsEventHooksejam as últimas aplicadas. Agora

lowerOnStart = False

(ou True) funciona como esperado em todos os casos dentro xmobarrc.

grochmal
fonte
11
Você também pode usar statusBare substituir apenas handleEventHook = handleEventHook defaultConfig <+> docksEventHookaté que o pacote DynamicLog seja corrigido.
Timakro 27/12/2017
2

Comparando sua configuração, com a minha mais simples, que funciona corretamente a esse respeito, vejo uma diferença que pode fazer algo:

de todas as general behaviouropções que você tem eu só tenho

lowerOnStart = True

e nem um hideOnStart, overrideRedirectetc.

A maneira como você adiciona o xmobar xmonad.hsé, até onde eu sei, o mesmo que o meu.

Nesse caso, eu tentaria com o máximo de configurações padrão possível, por exemplo, renomeie .xmobarrcpara que ele não seja selecionado e mude xmonad.hspara

main = xmonad =<< statusBar "xmobar" xmobarPP toggleStrutsKey defaultConfig
toggleStrutsKey XConfig { XMonad.modMask = modMask } = (modMask, xK_b)

e veja se funciona. Mais tarde, adicione pouco a pouco e veja quando ele quebra.

Torinthiel
fonte
Obrigado, sua resposta me lembrou que eu deveria depurá-lo a partir de um vazio xmonad.hs. Isso me fez encontrar o problema real :)
grochmal