aboutsummaryrefslogtreecommitdiff
path: root/src/makefile/input.rs
diff options
context:
space:
mode:
authorMelody Horn <melody@boringcactus.com>2024-12-16 23:33:22 -0700
committerMelody Horn <melody@boringcactus.com>2024-12-16 23:34:45 -0700
commit5411a125821c67db5cff29142ff39b207a2637f7 (patch)
tree2cdf0f5bcd499c6d0fdba005d935cfe75b6a26b3 /src/makefile/input.rs
parent35ebe14f47d692f17ec04b7d94f4ac490b297e3e (diff)
downloadmakers-5411a125821c67db5cff29142ff39b207a2637f7.tar.gz
makers-5411a125821c67db5cff29142ff39b207a2637f7.zip
don't strip comments in continued lines
i'm not actually sure if this is how GNU make works but it appears to be the behavior GNU make exhibits
Diffstat (limited to 'src/makefile/input.rs')
-rw-r--r--src/makefile/input.rs46
1 files changed, 35 insertions, 11 deletions
diff --git a/src/makefile/input.rs b/src/makefile/input.rs
index 74742f9..345f465 100644
--- a/src/makefile/input.rs
+++ b/src/makefile/input.rs
@@ -439,15 +439,7 @@ impl<'a, 'parent, R: BufRead> MakefileReader<'a, 'parent, R> {
Ok(x) => x,
Err(err) => return Some((n, Err(err))),
};
- let line = if settings.strip_comments {
- COMMENT
- .replace(&line, "$1")
- .replace(r"\#", "#")
- .trim_end()
- .to_owned()
- } else {
- line
- };
+ // TODO strip comments if it's correct to
line_pieces.push(line.trim_start().to_owned());
}
}
@@ -1150,10 +1142,11 @@ pub struct FinishedMakefileReader {
#[cfg(test)]
mod test {
- use super::*;
-
use std::io::Cursor;
+ use super::*;
+ use crate::makefile::token::Token;
+
type R = Result<()>;
#[test]
@@ -1485,4 +1478,35 @@ test: c
);
Ok(())
}
+
+ #[cfg(feature = "full")]
+ #[test]
+ fn shell_comment() -> R {
+ let file = r#"
+FOO=$(shell \
+echo \
+#abc)
+ "#;
+ let args = Args::empty();
+ let makefile = MakefileReader::read(
+ &args,
+ MacroScopeStack::default(),
+ MacroSet::new(),
+ Cursor::new(file),
+ "",
+ Default::default(),
+ )?;
+ let makefile = makefile.finish();
+ assert_eq!(
+ makefile.macros.get_non_recursive("FOO").map(|x| &x.text),
+ Some(&TokenString::from(vec![
+ Token::Text(String::new()),
+ Token::FunctionCall {
+ name: TokenString::text("shell"),
+ args: vec![TokenString::text("echo #abc")],
+ },
+ ]))
+ );
+ Ok(())
+ }
}