nom-kconfig 0.10.0

A Kconfig parser
Documentation
use nom::{bytes::complete::tag, combinator::map, multi::many0, IResult, Parser};
#[cfg(feature = "deserialize")]
use serde::Deserialize;
#[cfg(feature = "serialize")]
use serde::Serialize;

use crate::{
    attribute::{depends_on::parse_depends_on, prompt::parse_prompt_value, Attribute},
    util::ws,
    KconfigInput,
};

/// This defines a comment which is displayed to the user during the configuration process and is also echoed to the output files. The only possible options are dependencies.
#[derive(Debug, Clone, PartialEq)]
#[cfg_attr(feature = "hash", derive(Hash))]
#[cfg_attr(feature = "serialize", derive(Serialize))]
#[cfg_attr(feature = "deserialize", derive(Deserialize))]
pub struct Comment {
    pub prompt: String,
    pub dependencies: Vec<Attribute>,
}

pub fn parse_comment(input: KconfigInput) -> IResult<KconfigInput, Comment> {
    map(
        (
            ws(tag("comment")),
            ws(parse_prompt_value),
            many0(ws(parse_depends_on)),
        ),
        |(_, prompt, dependencies)| Comment {
            prompt: prompt.to_string(),
            dependencies,
        },
    )
    .parse(input)
}