summaryrefslogtreecommitdiffstats
path: root/src/poem
diff options
context:
space:
mode:
Diffstat (limited to 'src/poem')
-rw-r--r--src/poem/elements/verse/logic.rs10
-rw-r--r--src/poem/recite.rs2
2 files changed, 11 insertions, 1 deletions
diff --git a/src/poem/elements/verse/logic.rs b/src/poem/elements/verse/logic.rs
index c1d3d62..f5efdee 100644
--- a/src/poem/elements/verse/logic.rs
+++ b/src/poem/elements/verse/logic.rs
@@ -28,6 +28,11 @@ macro_rules! incant {
$command.stderr(Stdio::piped());
}
+ // Capture stdout if (f)orce (c)apture is set
+ if $env.fc {
+ $command.stdout(Stdio::piped());
+ }
+
// Detach the process group, if in the [Rune::Quiet] meter
if $self.meter == Rune::Quiet {
$command.process_group(0);
@@ -59,6 +64,9 @@ macro_rules! incant {
$out.append(&mut output.stdout);
err.append(&mut output.stderr);
}
+ if $env.fc {
+ $out.append(&mut output.stdout);
+ }
}
Rune::Couplet => {
output = child.wait_with_output()?;
@@ -210,7 +218,7 @@ macro_rules! incant {
}
err.clear();
- if $self.meter != Rune::Couplet {
+ if $self.meter != Rune::Couplet && $env.fc != true {
$out.clear();
}
diff --git a/src/poem/recite.rs b/src/poem/recite.rs
index b27ef75..7ceecca 100644
--- a/src/poem/recite.rs
+++ b/src/poem/recite.rs
@@ -98,7 +98,9 @@ impl Reciteable for Poem {
Some(poem) => poem,
None => break, // TODO: Return an error
};
+ env.fc = true;
let mut out = poem.recite(env)?;
+ env.fc = false;
match out.last() {
Some(last) => {
if *last == b'\n' {