pub struct PowerShell { /* private fields */ }Expand description
A Shell implementation for PowerShell.
Trait Implementations§
Source§impl Clone for PowerShell
impl Clone for PowerShell
Source§fn clone(&self) -> PowerShell
fn clone(&self) -> PowerShell
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for PowerShell
impl Debug for PowerShell
Source§impl Default for PowerShell
impl Default for PowerShell
Source§impl From<PowerShell> for ShellEnum
impl From<PowerShell> for ShellEnum
Source§fn from(v: PowerShell) -> ShellEnum
fn from(v: PowerShell) -> ShellEnum
Converts to this type from the input type.
Source§impl Shell for PowerShell
impl Shell for PowerShell
Source§fn print_env(&self, f: &mut impl Write) -> Result
fn print_env(&self, f: &mut impl Write) -> Result
Emits writing all current environment variables to stdout.
Source§fn force_utf8(&self, f: &mut impl Write) -> Result<(), ShellError>
fn force_utf8(&self, f: &mut impl Write) -> Result<(), ShellError>
Write a command to the script that forces the usage of UTF8-encoding for
the shell script.
Source§fn set_env_var(
&self,
f: &mut impl Write,
env_var: &str,
value: &str,
) -> Result<(), ShellError>
fn set_env_var( &self, f: &mut impl Write, env_var: &str, value: &str, ) -> Result<(), ShellError>
Set an env var by
export-ing it.Source§fn unset_env_var(
&self,
f: &mut impl Write,
env_var: &str,
) -> Result<(), ShellError>
fn unset_env_var( &self, f: &mut impl Write, env_var: &str, ) -> Result<(), ShellError>
Unset an env var by
unset-ing it.Source§fn run_script(&self, f: &mut impl Write, path: &Path) -> Result<(), ShellError>
fn run_script(&self, f: &mut impl Write, path: &Path) -> Result<(), ShellError>
Run a script in the current shell.
Source§fn extension(&self) -> &str
fn extension(&self) -> &str
The extension that shell scripts for this interpreter usually use.
Source§fn executable(&self) -> &str
fn executable(&self) -> &str
The executable that can be called to start this shell.
Source§fn create_run_script_command(&self, path: &Path) -> Command
fn create_run_script_command(&self, path: &Path) -> Command
Constructs a
Command that will execute the specified script by this
shell.Source§fn format_env_var(&self, var_name: &str) -> String
fn format_env_var(&self, var_name: &str) -> String
Format the environment variable for the shell.
Source§fn restore_env_var(
&self,
f: &mut impl Write,
key: &str,
backup_key: &str,
) -> Result<(), ShellError>
fn restore_env_var( &self, f: &mut impl Write, key: &str, backup_key: &str, ) -> Result<(), ShellError>
Restores an environment variable from its backup if it exists, otherwise
unsets it. Read more
Source§fn source_completions(
&self,
_f: &mut impl Write,
_completions_dir: &Path,
) -> Result<(), ShellError>
fn source_completions( &self, _f: &mut impl Write, _completions_dir: &Path, ) -> Result<(), ShellError>
Source completion scripts for the shell from a given prefix path.
Note: the
completions_dir is the directory where the completions are
stored. You can use Self::completion_script_location to get the
correct location for a given shell type.Source§fn can_run_script(&self, path: &Path) -> bool
fn can_run_script(&self, path: &Path) -> bool
Test to see if the path can be executed by the shell, based on the
extension of the path.
Source§fn run_command<'a>(
&self,
f: &mut impl Write,
command: impl IntoIterator<Item = &'a str> + 'a,
) -> Result
fn run_command<'a>( &self, f: &mut impl Write, command: impl IntoIterator<Item = &'a str> + 'a, ) -> Result
Executes a command in the current shell. Use
Self::run_script when
you want to run another shell script.Source§fn set_path(
&self,
f: &mut impl Write,
paths: &[PathBuf],
modification_behavior: PathModificationBehavior,
platform: &Platform,
) -> Result<(), ShellError>
fn set_path( &self, f: &mut impl Write, paths: &[PathBuf], modification_behavior: PathModificationBehavior, platform: &Platform, ) -> Result<(), ShellError>
Set the PATH variable to the given paths.
Source§fn path_separator(&self, platform: &Platform) -> &str
fn path_separator(&self, platform: &Platform) -> &str
Path separator
Source§fn path_var(&self, platform: &Platform) -> &str
fn path_var(&self, platform: &Platform) -> &str
Returns the name of the PATH variable for the given platform. On
Windows, path variables are case-insensitive but not all shells treat
them case-insensitive.
Source§fn echo(&self, f: &mut impl Write, text: &str) -> Result
fn echo(&self, f: &mut impl Write, text: &str) -> Result
Emits echoing certain text to stdout.
Source§fn write_script(&self, f: &mut impl Write, script: &str) -> Result<()>
fn write_script(&self, f: &mut impl Write, script: &str) -> Result<()>
Write the script to the writer and do some post-processing for
line-endings. Only really relevant for cmd.exe scripts.
Source§fn parse_env<'i>(&self, env: &'i str) -> HashMap<&'i str, &'i str>
fn parse_env<'i>(&self, env: &'i str) -> HashMap<&'i str, &'i str>
Parses environment variables emitted by the
Shell::env command.Source§fn line_ending(&self) -> &str
fn line_ending(&self) -> &str
Get the line ending for this shell. Only
CmdExe uses \r\n.Auto Trait Implementations§
impl Freeze for PowerShell
impl RefUnwindSafe for PowerShell
impl Send for PowerShell
impl Sync for PowerShell
impl Unpin for PowerShell
impl UnsafeUnpin for PowerShell
impl UnwindSafe for PowerShell
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more