Control: eliminate "self" naming convention
This commit is contained in:
parent
3077074329
commit
82a40725f9
@ -14,7 +14,7 @@
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
const Self = @This();
|
||||
const Control = @This();
|
||||
|
||||
const std = @import("std");
|
||||
const mem = std.mem;
|
||||
@ -38,47 +38,47 @@ args_map: ArgMap,
|
||||
|
||||
server_destroy: wl.Listener(*wl.Server) = wl.Listener(*wl.Server).init(handleServerDestroy),
|
||||
|
||||
pub fn init(self: *Self) !void {
|
||||
self.* = .{
|
||||
.global = try wl.Global.create(server.wl_server, zriver.ControlV1, 1, *Self, self, bind),
|
||||
pub fn init(control: *Control) !void {
|
||||
control.* = .{
|
||||
.global = try wl.Global.create(server.wl_server, zriver.ControlV1, 1, *Control, control, bind),
|
||||
.args_map = ArgMap.init(util.gpa),
|
||||
};
|
||||
|
||||
server.wl_server.addDestroyListener(&self.server_destroy);
|
||||
server.wl_server.addDestroyListener(&control.server_destroy);
|
||||
}
|
||||
|
||||
fn handleServerDestroy(listener: *wl.Listener(*wl.Server), _: *wl.Server) void {
|
||||
const self = @fieldParentPtr(Self, "server_destroy", listener);
|
||||
self.global.destroy();
|
||||
self.args_map.deinit();
|
||||
const control = @fieldParentPtr(Control, "server_destroy", listener);
|
||||
control.global.destroy();
|
||||
control.args_map.deinit();
|
||||
}
|
||||
|
||||
/// Called when a client binds our global
|
||||
fn bind(client: *wl.Client, self: *Self, version: u32, id: u32) void {
|
||||
const control = zriver.ControlV1.create(client, version, id) catch {
|
||||
fn bind(client: *wl.Client, control: *Control, version: u32, id: u32) void {
|
||||
const control_v1 = zriver.ControlV1.create(client, version, id) catch {
|
||||
client.postNoMemory();
|
||||
return;
|
||||
};
|
||||
self.args_map.putNoClobber(.{ .client = client, .id = id }, .{}) catch {
|
||||
control.destroy();
|
||||
control.args_map.putNoClobber(.{ .client = client, .id = id }, .{}) catch {
|
||||
control_v1.destroy();
|
||||
client.postNoMemory();
|
||||
return;
|
||||
};
|
||||
control.setHandler(*Self, handleRequest, handleDestroy, self);
|
||||
control_v1.setHandler(*Control, handleRequest, handleDestroy, control);
|
||||
}
|
||||
|
||||
fn handleRequest(control: *zriver.ControlV1, request: zriver.ControlV1.Request, self: *Self) void {
|
||||
fn handleRequest(control_v1: *zriver.ControlV1, request: zriver.ControlV1.Request, control: *Control) void {
|
||||
switch (request) {
|
||||
.destroy => control.destroy(),
|
||||
.destroy => control_v1.destroy(),
|
||||
.add_argument => |add_argument| {
|
||||
const owned_slice = util.gpa.dupeZ(u8, mem.sliceTo(add_argument.argument, 0)) catch {
|
||||
control.getClient().postNoMemory();
|
||||
control_v1.getClient().postNoMemory();
|
||||
return;
|
||||
};
|
||||
|
||||
const args = self.args_map.getPtr(.{ .client = control.getClient(), .id = control.getId() }).?;
|
||||
const args = control.args_map.getPtr(.{ .client = control_v1.getClient(), .id = control_v1.getId() }).?;
|
||||
args.append(util.gpa, owned_slice) catch {
|
||||
control.getClient().postNoMemory();
|
||||
control_v1.getClient().postNoMemory();
|
||||
util.gpa.free(owned_slice);
|
||||
return;
|
||||
};
|
||||
@ -87,15 +87,15 @@ fn handleRequest(control: *zriver.ControlV1, request: zriver.ControlV1.Request,
|
||||
const seat: *Seat = @ptrFromInt(wlr.Seat.Client.fromWlSeat(run_command.seat).?.seat.data);
|
||||
|
||||
const callback = zriver.CommandCallbackV1.create(
|
||||
control.getClient(),
|
||||
control.getVersion(),
|
||||
control_v1.getClient(),
|
||||
control_v1.getVersion(),
|
||||
run_command.callback,
|
||||
) catch {
|
||||
control.getClient().postNoMemory();
|
||||
control_v1.getClient().postNoMemory();
|
||||
return;
|
||||
};
|
||||
|
||||
const args = self.args_map.getPtr(.{ .client = control.getClient(), .id = control.getId() }).?;
|
||||
const args = control.args_map.getPtr(.{ .client = control_v1.getClient(), .id = control_v1.getId() }).?;
|
||||
defer {
|
||||
for (args.items) |arg| util.gpa.free(arg);
|
||||
args.items.len = 0;
|
||||
@ -134,9 +134,9 @@ fn handleRequest(control: *zriver.ControlV1, request: zriver.ControlV1.Request,
|
||||
}
|
||||
|
||||
/// Remove the resource from the hash map and free all stored args
|
||||
fn handleDestroy(control: *zriver.ControlV1, self: *Self) void {
|
||||
var args = self.args_map.fetchRemove(
|
||||
.{ .client = control.getClient(), .id = control.getId() },
|
||||
fn handleDestroy(control_v1: *zriver.ControlV1, control: *Control) void {
|
||||
var args = control.args_map.fetchRemove(
|
||||
.{ .client = control_v1.getClient(), .id = control_v1.getId() },
|
||||
).?.value;
|
||||
for (args.items) |arg| util.gpa.free(arg);
|
||||
args.deinit(util.gpa);
|
||||
|
Loading…
Reference in New Issue
Block a user