「Ion3」の版間の差分

提供: ArchWiki
ナビゲーションに移動 検索に移動
(アーカイブ)
タグ: 新規リダイレクト
 
(他の1人の利用者による、間の1版が非表示)
1行目: 1行目:
  +
#redirect [[ArchWiki:アーカイブ]]
[[Category:タイル型ウィンドウマネージャ]]
 
  +
[[Category:アーカイブ]]
[[en:Ion3]]
 
[[zh-CN:Ion3]]
 
== イントロダクション ==
 
[http://tuomov.iki.fi/software/ Ion] はタブフレームを備えたタイル型ウィンドウマネージャです。内蔵インタプリタとして Lua を使って全ての設定を管理しています。主としてキーボードを使って操作をするようになっていますが、マウスで操作することもできます。
 
 
== インストール ==
 
Ion3 は [https://www.archlinux.org/news/374/ こちらのニュース] で書かれているように公式リポジトリには含まれていません。そのため {{AUR|ion3}} パッケージを使って[[インストール]]する必要があります。
 
 
設定ファイルをホームディレクトリにコピーしてください:
 
$ cp /etc/ion3/* ~/.ion3
 
Ion3 を起動するには {{ic|~/.xinitrc}} に以下の行を追加:
 
exec ion3
 
後は以下で記述しているように Ion を設定してください。
 
 
== 設定 ==
 
 
{{Note|以下のファイルはデフォルトから大分修正が加えられています。}}
 
 
=== cfg_ion.lua ===
 
Ion3 のメイン設定ファイルです。
 
{{bc|1=
 
-- Ion main configuration file
 
--
 
 
--
 
-- Some basic setup
 
--
 
 
-- Set default modifiers. Alt should usually be mapped to Mod1 on
 
-- XFree86-based systems. The flying window keys are probably Mod3
 
-- or Mod4; see the output of 'xmodmap'.
 
MOD1="Mod4+"
 
MOD2="Mod1+"
 
 
ioncore.set{
 
-- Maximum delay between clicks in milliseconds to be considered a
 
-- double click.
 
dblclick_delay=250,
 
 
-- For keyboard resize, time (in milliseconds) to wait after latest
 
-- key press before automatically leaving resize mode (and doing
 
-- the resize in case of non-opaque move).
 
kbresize_delay=1500,
 
 
-- Opaque resize?
 
opaque_resize=false,
 
 
-- Movement commands warp the pointer to frames instead of just
 
-- changing focus. Enabled by default.
 
warp=true,
 
 
-- Default workspace type.
 
default_ws_type="WIonWS",
 
}
 
 
--
 
-- Load some modules, extensions and other configuration files
 
--
 
 
-- Load some modules.
 
dopath("mod_query")
 
dopath("mod_menu")
 
dopath("mod_ionws")
 
dopath("mod_floatws")
 
dopath("mod_panews")
 
--dopath("mod_statusbar")
 
--dopath("mod_dock")
 
dopath("mod_sp")
 
 
-- Load some kludges to make apps behave better.
 
dopath("cfg_kludges")
 
 
-- Make some bindings.
 
dopath("cfg_bindings")
 
 
-- Define some menus (mod_menu required)
 
dopath("cfg_menus")
 
 
-- Load additional user configuration. 'true' as second parameter asks
 
-- Ion not to complain if the file is not found.
 
dopath("cfg_user", true)
 
}}
 
{{ic|dopath}} コマンドには起動時に Ion でロードするモジュールを記述します。ロードしたくないモジュールはアンコメントしてください。
 
 
=== cfg_bindings.lua ===
 
基本的なキーバインドを設定するファイルです。
 
{{bc|1=
 
--
 
-- Ion bindings configuration file. Global bindings and bindings common
 
-- to screens and all types of frames only. See modules' configuration
 
-- files for other bindings.
 
--
 
 
-- WScreen context bindings
 
--
 
-- The bindings in this context are available all the time.
 
--
 
-- The variable MOD1 should contain a string of the form 'Mod1+'
 
-- where Mod1 maybe replaced with the modifier you want to use for most
 
-- of the bindings. Similarly MOD2 may be redefined to add a
 
-- modifier to some of the F-key bindings.
 
 
defbindings("WScreen", {
 
bdoc("Switch to n:th object (workspace, full screen client window) "..
 
"within current screen."),
 
kpress(MOD1.."1", "WScreen.switch_nth(_, 0)"),
 
kpress(MOD1.."2", "WScreen.switch_nth(_, 1)"),
 
kpress(MOD1.."3", "WScreen.switch_nth(_, 2)"),
 
kpress(MOD1.."4", "WScreen.switch_nth(_, 3)"),
 
kpress(MOD1.."5", "WScreen.switch_nth(_, 4)"),
 
kpress(MOD1.."6", "WScreen.switch_nth(_, 5)"),
 
kpress(MOD1.."7", "WScreen.switch_nth(_, 6)"),
 
kpress(MOD1.."8", "WScreen.switch_nth(_, 7)"),
 
kpress(MOD1.."9", "WScreen.switch_nth(_, 8)"),
 
kpress(MOD1.."0", "WScreen.switch_nth(_, 9)"),
 
 
-- bdoc("Switch to next/previous object within current screen."),
 
-- kpress(MOD2.."comma", "ioncore.goto_previous()"),
 
-- kpress(MOD2.."period", "ioncore.goto_next()"),
 
 
kpress(MOD1.."Left", "WScreen.switch_prev(_)"),
 
kpress(MOD1.."Right", "WScreen.switch_next(_)"),
 
 
 
 
submap(MOD1.."K", {
 
bdoc("Go to previous active object."),
 
kpress("K", "ioncore.goto_previous()"),
 
 
bdoc("Clear all tags."),
 
kpress("T", "ioncore.clear_tags()"),
 
}),
 
 
bdoc("Go to n:th screen on multihead setup."),
 
kpress(MOD1.."Shift+1", "ioncore.goto_nth_screen(0)"),
 
kpress(MOD1.."Shift+2", "ioncore.goto_nth_screen(1)"),
 
 
bdoc("Go to next/previous screen on multihead setup."),
 
kpress(MOD1.."Shift+Left", "ioncore.goto_next_screen()"),
 
kpress(MOD1.."Shift+Right", "ioncore.goto_prev_screen()"),
 
 
bdoc("Create a new workspace of chosen default type."),
 
kpress(MOD1.."F9", "ioncore.create_ws(_)"),
 
 
bdoc("Display the main menu."),
 
kpress(MOD1.."F12", "mod_menu.bigmenu(_, _sub, 'mainmenu')"),
 
mpress("Button3", "mod_menu.pmenu(_, _sub, 'mainmenu')"),
 
 
bdoc("Display the window list menu."),
 
mpress("Button2", "mod_menu.pmenu(_, _sub, 'windowlist')"),
 
})
 
 
-- WMPlex context bindings
 
--
 
-- These bindings work in frames and on screens. The innermost of such
 
-- contexts/objects always gets to handle the key press. Most of these
 
-- bindings define actions on client windows. (Remember that client windows
 
-- can be put in fullscreen mode and therefore may not have a frame.)
 
--
 
-- The "_sub:WClientWin" guards are used to ensure that _sub is a client
 
-- window in order to stop Ion from executing the callback with an invalid
 
-- parameter if it is not and then complaining.
 
 
defbindings("WMPlex", {
 
bdoc("Close current object."),
 
kpress_wait(MOD1.."C", "WRegion.rqclose_propagate(_, _sub)"),
 
 
bdoc("Nudge current client window. This might help with some "..
 
"programs' resizing problems."),
 
kpress_wait(MOD1.."L",
 
"WClientWin.nudge(_sub)", "_sub:WClientWin"),
 
 
bdoc("Toggle fullscreen mode of current client window."),
 
kpress_wait(MOD1.."Return",
 
"WClientWin.set_fullscreen(_sub, 'toggle')",
 
"_sub:WClientWin"),
 
 
submap(MOD1.."K", {
 
bdoc("Kill client owning current client window."),
 
kpress("C", "WClientWin.kill(_sub)", "_sub:WClientWin"),
 
 
bdoc("Send next key press to current client window. "..
 
"Some programs may not allow this by default."),
 
kpress("Q", "WClientWin.quote_next(_sub)", "_sub:WClientWin"),
 
}),
 
 
bdoc("Query for manual page to be displayed."),
 
kpress(MOD2.."F1", "mod_query.query_man(_, ':man')"),
 
 
bdoc("Show the Ion manual page."),
 
kpress(MOD1.."F1", "ioncore.exec_on(_, ':man ion3')"),
 
 
bdoc("Run a terminal emulator."),
 
kpress(MOD1.."F2", "ioncore.exec_on(_, 'urxvt')"),
 
 
bdoc("Query for command line to execute."),
 
kpress(MOD2.."F3", "mod_query.query_exec(_)"),
 
 
bdoc("Query for Lua code to execute."),
 
kpress(MOD1.."F3", "mod_query.query_lua(_)"),
 
 
bdoc("Query for host to connect to with SSH."),
 
kpress(MOD2.."F4", "mod_query.query_ssh(_, ':ssh')"),
 
 
bdoc("Query for file to edit."),
 
kpress(MOD2.."F5",
 
"mod_query.query_editfile(_, 'run-mailcap --action=edit')"),
 
 
bdoc("Query for file to view."),
 
kpress(MOD2.."F6",
 
"mod_query.query_runfile(_, 'run-mailcap --action=view')"),
 
 
bdoc("Query for workspace to go to or create a new one."),
 
kpress(MOD2.."F9", "mod_query.query_workspace(_)"),
 
 
bdoc("Query for a client window to go to."),
 
kpress(MOD1.."G", "mod_query.query_gotoclient(_)"),
 
})
 
 
-- WFrame context bindings
 
--
 
-- These bindings are common to all types of frames. The rest of frame
 
-- bindings that differ between frame types are defined in the modules'
 
-- configuration files.
 
 
defbindings("WFrame", {
 
bdoc("Tag current object within the frame."),
 
kpress(MOD1.."T", "WRegion.set_tagged(_sub, 'toggle')", "_sub:non-nil"),
 
 
submap(MOD1.."K", {
 
bdoc("Switch to n:th object within the frame."),
 
kpress("1", "WFrame.switch_nth(_, 0)"),
 
kpress("2", "WFrame.switch_nth(_, 1)"),
 
kpress("3", "WFrame.switch_nth(_, 2)"),
 
kpress("4", "WFrame.switch_nth(_, 3)"),
 
kpress("5", "WFrame.switch_nth(_, 4)"),
 
kpress("6", "WFrame.switch_nth(_, 5)"),
 
kpress("7", "WFrame.switch_nth(_, 6)"),
 
kpress("8", "WFrame.switch_nth(_, 7)"),
 
kpress("9", "WFrame.switch_nth(_, 8)"),
 
kpress("0", "WFrame.switch_nth(_, 9)"),
 
 
bdoc("Switch to next/previous object within the frame."),
 
kpress("N", "WFrame.switch_next(_)"),
 
kpress("P", "WFrame.switch_prev(_)"),
 
 
bdoc("Move current object within the frame left/right."),
 
kpress("comma", "WFrame.dec_index(_, _sub)", "_sub:non-nil"),
 
kpress("period", "WFrame.inc_index(_, _sub)", "_sub:non-nil"),
 
 
bdoc("Maximize the frame horizontally/vertically."),
 
kpress("H", "WFrame.maximize_horiz(_)"),
 
kpress("V", "WFrame.maximize_vert(_)"),
 
 
bdoc("Attach tagged objects to this frame."),
 
kpress("A", "WFrame.attach_tagged(_)"),
 
}),
 
 
kpress(MOD1.."comma", "WFrame.switch_prev(_)"),
 
kpress(MOD1.."period", "WFrame.switch_next(_)"),
 
 
bdoc("Query for a client window to attach to active frame."),
 
kpress(MOD1.."A", "mod_query.query_attachclient(_)"),
 
 
bdoc("Display frame context menu."),
 
kpress(MOD1.."M", "mod_menu.menu(_, _sub, 'ctxmenu')"),
 
mpress("Button3", "mod_menu.pmenu(_, _sub, 'ctxmenu')"),
 
 
bdoc("Begin move/resize mode."),
 
kpress(MOD1.."R", "WFrame.begin_kbresize(_)"),
 
 
bdoc("Switch the frame to display the object indicated by the tab."),
 
mclick("Button1@tab", "WFrame.p_switch_tab(_)"),
 
mclick("Button2@tab", "WFrame.p_switch_tab(_)"),
 
 
bdoc("Resize the frame."),
 
mdrag("Button1@border", "WFrame.p_resize(_)"),
 
mdrag(MOD1.."Button3", "WFrame.p_resize(_)"),
 
 
bdoc("Move the frame."),
 
mdrag(MOD1.."Button1", "WFrame.p_move(_)"),
 
 
bdoc("Move objects between frames by dragging and dropping the tab."),
 
mdrag("Button1@tab", "WFrame.p_tabdrag(_)"),
 
mdrag("Button2@tab", "WFrame.p_tabdrag(_)"),
 
 
})
 
 
-- WMoveresMode context bindings
 
--
 
-- These bindings are available keyboard move/resize mode. The mode
 
-- is activated on frames with the command begin_kbresize (bound to
 
-- MOD1.."R" above by default).
 
 
defbindings("WMoveresMode", {
 
bdoc("Cancel the resize mode."),
 
kpress("AnyModifier+Escape","WMoveresMode.cancel(_)"),
 
 
bdoc("End the resize mode."),
 
kpress("AnyModifier+Return","WMoveresMode.finish(_)"),
 
 
bdoc("Grow in specified direction."),
 
kpress("Left", "WMoveresMode.resize(_, 1, 0, 0, 0)"),
 
kpress("Right", "WMoveresMode.resize(_, 0, 1, 0, 0)"),
 
kpress("Up", "WMoveresMode.resize(_, 0, 0, 1, 0)"),
 
kpress("Down", "WMoveresMode.resize(_, 0, 0, 0, 1)"),
 
kpress("F", "WMoveresMode.resize(_, 1, 0, 0, 0)"),
 
kpress("B", "WMoveresMode.resize(_, 0, 1, 0, 0)"),
 
kpress("P", "WMoveresMode.resize(_, 0, 0, 1, 0)"),
 
kpress("N", "WMoveresMode.resize(_, 0, 0, 0, 1)"),
 
 
bdoc("Shrink in specified direction."),
 
kpress("Shift+Left", "WMoveresMode.resize(_,-1, 0, 0, 0)"),
 
kpress("Shift+Right", "WMoveresMode.resize(_, 0,-1, 0, 0)"),
 
kpress("Shift+Up", "WMoveresMode.resize(_, 0, 0,-1, 0)"),
 
kpress("Shift+Down", "WMoveresMode.resize(_, 0, 0, 0,-1)"),
 
kpress("Shift+F", "WMoveresMode.resize(_,-1, 0, 0, 0)"),
 
kpress("Shift+B", "WMoveresMode.resize(_, 0,-1, 0, 0)"),
 
kpress("Shift+P", "WMoveresMode.resize(_, 0, 0,-1, 0)"),
 
kpress("Shift+N", "WMoveresMode.resize(_, 0, 0, 0,-1)"),
 
 
bdoc("Move in specified direction."),
 
kpress(MOD1.."Left", "WMoveresMode.move(_,-1, 0)"),
 
kpress(MOD1.."Right", "WMoveresMode.move(_, 1, 0)"),
 
kpress(MOD1.."Up", "WMoveresMode.move(_, 0,-1)"),
 
kpress(MOD1.."Down", "WMoveresMode.move(_, 0, 1)"),
 
kpress(MOD1.."F", "WMoveresMode.move(_,-1, 0)"),
 
kpress(MOD1.."B", "WMoveresMode.move(_, 1, 0)"),
 
kpress(MOD1.."P", "WMoveresMode.move(_, 0,-1)"),
 
kpress(MOD1.."N", "WMoveresMode.move(_, 0, 1)"),
 
})
 
}}
 
 
=== cfg_menus.lua ===
 
メインメニューを設定するファイルです。
 
{{bc|
 
--
 
-- Ion menu definitions
 
--
 
 
-- Main menu
 
defmenu("mainmenu", {
 
submenu("Programs", "appmenu"),
 
menuentry("Lock screen", "ioncore.exec_on(_, 'xlock')"),
 
menuentry("Help", "mod_query.query_man(_)"),
 
menuentry("About Ion", "mod_query.show_about_ion(_)"),
 
submenu("Styles", "stylemenu"),
 
submenu("Session", "sessionmenu"),
 
})
 
 
-- Application menu
 
defmenu("appmenu", {
 
menuentry("Firefox","ioncore.exec_on(_, 'firefox')"),
 
menuentry("Thunderbird","ioncore.exec_on(_, 'thunderbird')"),
 
menuentry("Editor","ioncore.exec_on(_, 'lazy-edit')"),
 
menuentry("Player","ioncore.exec_on(_, 'lazy-player')"),
 
menuentry("FTP","ioncore.exec_on(_, 'lazy-ftp')"),
 
menuentry("GVim","ioncore.exec_on(_, 'gvim')"),
 
menuentry("Run...", "mod_query.query_exec(_)"),
 
})
 
 
-- Session control menu
 
defmenu("sessionmenu", {
 
menuentry("Save", "ioncore.snapshot()"),
 
menuentry("Restart", "ioncore.restart()"),
 
menuentry("Restart PWM", "ioncore.restart_other('pwm')"),
 
menuentry("Restart TWM", "ioncore.restart_other('twm')"),
 
menuentry("Exit", "ioncore.shutdown()"),
 
})
 
 
-- Context menu (frame/client window actions)
 
defctxmenu("WFrame", {
 
menuentry("Close", "WRegion.rqclose_propagate(_, _sub)"),
 
menuentry("Kill", "WClientWin.kill(_sub)",
 
"_sub:WClientWin"),
 
menuentry("(Un)tag", "WRegion.set_tagged(_sub, 'toggle')",
 
"_sub:non-nil"),
 
menuentry("Attach tagged", "WFrame.attach_tagged(_)"),
 
menuentry("Clear tags", "ioncore.clear_tags()"),
 
menuentry("Window info", "mod_query.show_clientwin(_, _sub)",
 
"_sub:WClientWin"),
 
})
 
}}
 
 
=== cfg_ionws.lua ===
 
Ion のワークスペースを設定するファイルです。
 
{{bc|
 
--
 
-- Ion ionws module configuration file
 
--
 
 
-- Bindings for the tiled workspaces (ionws). These should work on any
 
-- object on the workspace.
 
 
defbindings("WIonWS", {
 
bdoc("Split current frame vertically."),
 
kpress(MOD1.."V", "WIonWS.split_at(_, _sub, 'bottom', true)"),
 
 
bdoc("Split current frame horizontally."),
 
kpress(MOD1.."H", "WIonWS.split_at(_, _sub, 'right', true)"),
 
 
bdoc("Destroy current frame."),
 
kpress(MOD1.."Tab", "WIonWS.unsplit_at(_, _sub)"),
 
 
bdoc("Go to frame above/below/right/left of current frame."),
 
kpress(MOD2.."Up", "WIonWS.goto_dir(_, 'above')"),
 
kpress(MOD2.."Down", "WIonWS.goto_dir(_, 'below')"),
 
kpress(MOD2.."Right", "WIonWS.goto_dir(_, 'right')"),
 
kpress(MOD2.."Left", "WIonWS.goto_dir(_, 'left')"),
 
submap(MOD1.."K", {
 
bdoc("Split current frame horizontally."),
 
kpress("S", "WIonWS.split_at(_, _sub, 'right', true)"),
 
 
bdoc("Destroy current frame."),
 
kpress("X", "WIonWS.unsplit_at(_, _sub)"),
 
}),
 
})
 
 
-- Frame bindings. These work in (Ion/tiled-style) frames. Some bindings
 
-- that are common to all frame types and multiplexes are defined in
 
-- ion-bindings.lua.
 
 
--defbindings("WFrame-on-WIonWS", {
 
--})
 
 
-- WFloatFrame context menu extras
 
 
if mod_menu then
 
defctxmenu("WIonWS", {
 
menuentry("Destroy frame",
 
"WIonWS.unsplit_at(_, _sub)"),
 
menuentry("Split vertically",
 
"WIonWS.split_at(_, _sub, 'bottom', true)"),
 
menuentry("Split horizontally",
 
"WIonWS.split_at(_, _sub, 'right', true)"),
 
menuentry("Flip", "WIonWS.flip_at(_, _sub)"),
 
menuentry("Transpose", "WIonWS.transpose_at(_, _sub)"),
 
submenu("Float split", {
 
menuentry("At left",
 
"WIonWS.set_floating_at(_, _sub, 'toggle', 'left')"),
 
menuentry("At right",
 
"WIonWS.set_floating_at(_, _sub, 'toggle', 'right')"),
 
menuentry("Above",
 
"WIonWS.set_floating_at(_, _sub, 'toggle', 'up')"),
 
menuentry("Below",
 
"WIonWS.set_floating_at(_, _sub, 'toggle', 'down')"),
 
}),
 
submenu("At root", {
 
menuentry("Split vertically",
 
"WIonWS.split_top(_, 'bottom')"),
 
menuentry("Split horizontally",
 
"WIonWS.split_top(_, 'right')"),
 
menuentry("Flip", "WIonWS.flip_at(_)"),
 
menuentry("Transpose", "WIonWS.transpose_at(_)"),
 
}),
 
})
 
end
 
}}
 
 
=== look.lua ===
 
テーマを設定するファイルです。デフォルトテーマは末尾で設定されています:
 
dopath("look_xerxes")
 
テーマの名前は {{ic|look_<name>.lua}} で、自分でテーマを作成してテーマを切り替えることもできます。
 

2020年7月11日 (土) 18:34時点における最新版