jupyter_protocol/
kernelspec.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
//! Defines structures for working with Jupyter kernel specifications.
//!
//! This module provides types for representing and working with Jupyter kernel
//! specifications, which describe the properties and launch parameters for
//! Jupyter kernels.
//!
//! The main struct in this module is `JupyterKernelspec`, which corresponds to
//! the contents of a Jupyter JSON kernelspec file.
//!
//! # Examples
//!
//! ```rust
//! use jupyter_protocol::JupyterKernelspec;
//! use std::collections::HashMap;
//!
//! let kernelspec = JupyterKernelspec {
//!     argv: vec!["python3", "-m", "ipykernel_launcher", "-f", "{connection_file}"].into_iter().map(String::from).collect(),
//!     display_name: "Python 3".to_string(),
//!     language: "python".to_string(),
//!     metadata: None,
//!     interrupt_mode: Some("signal".to_string()),
//!     env: Some(HashMap::new()),
//! };
//! ```
use std::collections::HashMap;

use serde::{Deserialize, Serialize};
use serde_json::Value;

/// Represents the contents of a Jupyter JSON kernelspec file.
///
/// A kernelspec file defines the properties and launch parameters for a Jupyter kernel.
/// This struct is used to serialize and deserialize kernelspec data.
///
/// # Examples
///
/// ```rust
/// use jupyter_protocol::JupyterKernelspec;
/// use std::collections::HashMap;
///
/// let kernelspec = JupyterKernelspec {
///     argv: vec![
///         "python3".to_string(),
///         "-m".to_string(),
///         "ipykernel_launcher".to_string(),
///         "-f".to_string(),
///         "{connection_file}".to_string()
///     ],
///     display_name: "Python 3".to_string(),
///     language: "python".to_string(),
///     metadata: None,
///     interrupt_mode: Some("signal".to_string()),
///     env: Some(HashMap::new()),
/// };
/// ```
#[derive(Serialize, Deserialize, Clone, Debug)]
pub struct JupyterKernelspec {
    /// The command line arguments used to launch the kernel.
    ///
    /// This vector must contain `{connection_file}` as a placeholder, which will be
    /// replaced by the actual connection file path when the client launches the kernel.
    #[serde(default)]
    pub argv: Vec<String>,
    /// The human-readable name for the kernel.
    ///
    /// This name is typically displayed in the Jupyter interface when selecting a kernel.
    pub display_name: String,
    /// The programming language supported by the kernel.
    ///
    /// This should be a string identifier for the language, such as "python", "r", or "julia".
    pub language: String,
    /// Additional metadata associated with the kernel.
    ///
    /// This field can contain arbitrary key-value pairs for kernel-specific information.
    /// The values can be of any JSON-compatible type.
    pub metadata: Option<HashMap<String, Value>>,
    /// Specifies how the kernel should be interrupted.
    ///
    /// Common values are "signal" (use SIGINT) or "message" (use kernel protocol).
    /// If not specified, the client will use a default interrupt method.
    pub interrupt_mode: Option<String>,
    /// Environment variables to set for the kernel process.
    ///
    /// These key-value pairs will be added to the environment when launching the kernel.
    pub env: Option<HashMap<String, String>>,
}