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