/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at https://mozilla.org/MPL/2.0/. */ //! Handles highlighting selected DOM nodes in the inspector. At the moment it only replies and //! changes nothing on Servo's side. use std::net::TcpStream; use serde::Serialize; use serde_json::{self, Map, Value}; use crate::actor::{Actor, ActorMessageStatus, ActorRegistry}; use crate::protocol::JsonPacketStream; use crate::{EmptyReplyMsg, StreamId}; #[derive(Serialize)] pub struct HighlighterMsg { pub actor: String, } pub struct HighlighterActor { pub name: String, } #[derive(Serialize)] struct ShowReply { from: String, value: bool, } impl Actor for HighlighterActor { fn name(&self) -> String { self.name.clone() } /// The highligher actor can handle the following messages: /// /// - `show`: Enables highlighting for the selected node /// /// - `hide`: Disables highlighting for the selected node fn handle_message( &self, _registry: &ActorRegistry, msg_type: &str, _msg: &Map, stream: &mut TcpStream, _id: StreamId, ) -> Result { Ok(match msg_type { "show" => { let msg = ShowReply { from: self.name(), value: true, }; let _ = stream.write_json_packet(&msg); ActorMessageStatus::Processed }, "hide" => { let msg = EmptyReplyMsg { from: self.name() }; let _ = stream.write_json_packet(&msg); ActorMessageStatus::Processed }, _ => ActorMessageStatus::Ignored, }) } }