awful.mouse: Implement read-only properties

Signed-off-by: Uli Schlachter <psychon@znc.in>
This commit is contained in:
Uli Schlachter 2016-06-04 15:51:58 +02:00
parent 6956b9f6fa
commit cdf16d4660
1 changed files with 4 additions and 11 deletions

View File

@ -265,8 +265,6 @@ function mouse.object.get_current_client()
end end
end end
function mouse.object.set_current_client() end
--- Get the wibox currently under the mouse cursor. --- Get the wibox currently under the mouse cursor.
-- @property current_wibox -- @property current_wibox
-- @tparam wibox|nil The wibox -- @tparam wibox|nil The wibox
@ -278,8 +276,6 @@ function mouse.object.get_current_wibox()
end end
end end
function mouse.object.set_current_wibox() end
--- Get the widgets currently under the mouse cursor. --- Get the widgets currently under the mouse cursor.
-- --
-- @property current_widgets -- @property current_widgets
@ -307,8 +303,6 @@ function mouse.object.get_current_widgets()
end end
end end
function mouse.object.set_current_widgets() end
--- Get the topmost widget currently under the mouse cursor. --- Get the topmost widget currently under the mouse cursor.
-- @property current_widget -- @property current_widget
-- @tparam widget|nil widget The widget -- @tparam widget|nil widget The widget
@ -324,8 +318,6 @@ function mouse.object.get_current_widget()
end end
end end
function mouse.object.set_current_widget() end
--- True if the left mouse button is pressed. --- True if the left mouse button is pressed.
-- @property is_left_mouse_button_pressed -- @property is_left_mouse_button_pressed
-- @param boolean -- @param boolean
@ -342,8 +334,6 @@ for _, b in ipairs {"left", "right", "middle"} do
mouse.object["is_".. b .."_mouse_button_pressed"] = function() mouse.object["is_".. b .."_mouse_button_pressed"] = function()
return capi.mouse.coords().buttons[1] return capi.mouse.coords().buttons[1]
end end
mouse.object["set_is_".. b .."_mouse_button_pressed"] = function() end
end end
capi.client.connect_signal("request::geometry", mouse.resize_handler) capi.client.connect_signal("request::geometry", mouse.resize_handler)
@ -357,8 +347,11 @@ local props = {}
capi.mouse.set_newindex_miss_handler(function(_,key,value) capi.mouse.set_newindex_miss_handler(function(_,key,value)
if mouse.object["set_"..key] then if mouse.object["set_"..key] then
mouse.object["set_"..key](value) mouse.object["set_"..key](value)
else elseif not mouse.object["get_"..key] then
props[key] = value props[key] = value
else
-- If there is a getter, but no setter, then the property is read-only
error("Cannot set '" .. tostring(key) .. " because it is read-only")
end end
end) end)