Skip to content

Commit

Permalink
Merge pull request #11400 from MicrosoftDocs/main
Browse files Browse the repository at this point in the history
9/5/2024 PM Publish
  • Loading branch information
Taojunshen authored Sep 5, 2024
2 parents 50e9b60 + f95e142 commit 02c2242
Show file tree
Hide file tree
Showing 15 changed files with 260 additions and 137 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -869,4 +869,4 @@ Displays information about PowerShell cmdlets and concepts.
- [about_Functions](about_Functions.md)
- [about_Functions_Advanced_Parameters](about_Functions_Advanced_Parameters.md)
- [about_Scripts](about_Scripts.md)
- [How to Write Cmdlet Help](https://go.microsoft.com/fwlink/?LinkID=123415)
- [Writing Comment-Based Help Topics](/powershell/scripting/developer/help/writing-comment-based-help-topics)
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
---
description: Describes how to access and manage environment variables in PowerShell.
Locale: en-US
ms.date: 04/22/2024
ms.date: 09/05/2024
online version: https://learn.microsoft.com/powershell/module/microsoft.powershell.core/about/about_environment_variables?view=powershell-5.1&WT.mc_id=ps-gethelp
schema: 2.0.0
title: about_Environment_Variables
Expand All @@ -14,10 +14,10 @@ Describes how to access and manage environment variables in PowerShell.
Environment variables store data that's used by the operating system and other
programs. PowerShell creates the following environment variables:

- **PSExecutionPolicyPreference**
- **PSModulePath**
- **PSModuleAnalysisCachePath**
- **PSDisableModuleAnalysisCacheCleanup**
- `PSExecutionPolicyPreference`
- `PSModulePath`
- `PSModuleAnalysisCachePath`
- `PSDisableModuleAnalysisCacheCleanup`

For full descriptions of these variables, see the
[PowerShell environment variables][03] of this article.
Expand Down Expand Up @@ -308,7 +308,7 @@ preference variables, see [about_Preference_Variables][06].

The environment variables that store preferences include:

- **PSExecutionPolicyPreference**
- `PSExecutionPolicyPreference`

Stores the execution policy set for the current session. This environment
variable exists only when you set an execution policy for a single session.
Expand All @@ -326,7 +326,7 @@ The environment variables that store preferences include:
This information only applies to the Windows platform. For more information,
see [about_Execution_Policies][05].

- **PSModulePath**
- `PSModulePath`

The `$env:PSModulePath` environment variable contains a list of folder
locations that are searched to find modules and resources.
Expand All @@ -352,7 +352,7 @@ The environment variables that store preferences include:

For more information, see [about_PSModulePath][08].

- **PSModuleAnalysisCachePath**
- `PSModuleAnalysisCachePath`

PowerShell provides control over the file that's used to cache data about
modules and their cmdlets. The cache is read at startup while searching for a
Expand Down Expand Up @@ -396,7 +396,7 @@ The environment variables that store preferences include:
}
```

- **PSDisableModuleAnalysisCacheCleanup**
- `PSDisableModuleAnalysisCacheCleanup`

When writing out the module analysis cache, PowerShell checks for modules
that no longer exist to avoid an unnecessarily large cache. Sometimes these
Expand All @@ -413,13 +413,13 @@ The environment variables that store preferences include:

### Path information

- **PATH**
- `PATH`

The `$env:PATH` environment variable contains a list of folder locations that
the operating system searches for executable files. On Windows, the list of
folder locations is separated by the semi-colon (`;`) character.

- **PATHEXT**
- `PATHEXT`

The `$env:PATHEXT` variable contains a list of file extensions that Windows
considers to be executable files. When a script file with one of the listed
Expand Down
42 changes: 33 additions & 9 deletions reference/5.1/Microsoft.PowerShell.Core/About/about_Path_Syntax.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
---
description: Describes the full and relative path formats in PowerShell.
Locale: en-US
ms.date: 09/16/2023
ms.date: 09/05/2024
online version: https://learn.microsoft.com/powershell/module/microsoft.powershell.core/about/about_path_syntax?view=powershell-5.1&WT.mc_id=ps-gethelp
schema: 2.0.0
title: about_Path_Syntax
Expand All @@ -18,9 +18,9 @@ uniquely identified by their path names. A path is a combination of the
item name, the container and subcontainers in which the item is located, and
the PowerShell drive through which the containers are accessed.

In PowerShell, pathnames can be one of two types: _fully qualified_ and
In PowerShell, path names can be one of two types: _fully qualified_ and
_relative_. A fully qualified path consists of all elements that make up a
path. The following syntax shows the elements in a fully qualified path name:
path. The following syntax shows the elements in a fully qualified path:

```Syntax
[<provider>::]<drive>:[\<container>[\<subcontainer>...]]\<item>
Expand Down Expand Up @@ -115,11 +115,35 @@ first file (`C:\TechDocs\Jan\Results.txt`) and the path for the second file
(`C:\TechDocs\Feb\Results.txt`) allow you to clearly distinguish between the
two files.

## Support for the Win32 File namespace

On Windows, the cmdlets that support the FileSystem provider also support the
paths that use the Win32 File namespace format. You can only use these paths
with the **LiteralPath** parameter of the cmdlets.

Paths in Win32 File namespace are prefixed with `\\?\`. The prefix tells the
Windows APIs to disable all string parsing and send the string that follows
directly to the file system. For example, if the file system supports large
paths and file names, you can exceed the **MAX_PATH** limits that are otherwise
enforced by the Windows APIs.

For more information, see _Win32 File Namespaces_ in
[Naming Files, Paths, and Namespaces][01].

## See also

- [about_Locations](about_Locations.md)
- [Convert-Path](xref:Microsoft.PowerShell.Management.Convert-Path)
- [Join-Path](xref:Microsoft.PowerShell.Management.Join-Path)
- [Resolve-Path](xref:Microsoft.PowerShell.Management.Resolve-Path)
- [Split-Path](xref:Microsoft.PowerShell.Management.Split-Path)
- [Test-Path](xref:Microsoft.PowerShell.Management.Test-Path)
- [about_Locations][02]
- [Convert-Path][03]
- [Join-Path][04]
- [Resolve-Path][05]
- [Split-Path][06]
- [Test-Path][07]

<!-- link references -->
[01]: /windows/win32/fileio/naming-a-file#win32-file-namespaces
[02]: about_Locations.md
[03]: xref:Microsoft.PowerShell.Management.Convert-Path
[04]: xref:Microsoft.PowerShell.Management.Join-Path
[05]: xref:Microsoft.PowerShell.Management.Resolve-Path
[06]: xref:Microsoft.PowerShell.Management.Split-Path
[07]: xref:Microsoft.PowerShell.Management.Test-Path
Original file line number Diff line number Diff line change
Expand Up @@ -869,4 +869,4 @@ Displays information about PowerShell cmdlets and concepts.
- [about_Functions](about_Functions.md)
- [about_Functions_Advanced_Parameters](about_Functions_Advanced_Parameters.md)
- [about_Scripts](about_Scripts.md)
- [How to Write Cmdlet Help](https://go.microsoft.com/fwlink/?LinkID=123415)
- [Writing Comment-Based Help Topics](/powershell/scripting/developer/help/writing-comment-based-help-topics)
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
---
description: Describes how to access and manage environment variables in PowerShell.
Locale: en-US
ms.date: 04/22/2024
ms.date: 09/05/2024
online version: https://learn.microsoft.com/powershell/module/microsoft.powershell.core/about/about_environment_variables?view=powershell-7.2&WT.mc_id=ps-gethelp
schema: 2.0.0
title: about_Environment_Variables
Expand All @@ -14,13 +14,13 @@ Describes how to access and manage environment variables in PowerShell.
Environment variables store data that's used by the operating system and other
programs. PowerShell creates the following environment variables:

- **POWERSHELL_TELEMETRY_OPTOUT**
- **POWERSHELL_DISTRIBUTION_CHANNEL**
- **POWERSHELL_UPDATECHECK**
- **PSExecutionPolicyPreference**
- **PSModulePath**
- **PSModuleAnalysisCachePath**
- **PSDisableModuleAnalysisCacheCleanup**
- `POWERSHELL_TELEMETRY_OPTOUT`
- `POWERSHELL_DISTRIBUTION_CHANNEL`
- `POWERSHELL_UPDATECHECK`
- `PSExecutionPolicyPreference`
- `PSModulePath`
- `PSModuleAnalysisCachePath`
- `PSDisableModuleAnalysisCacheCleanup`

For full descriptions of these variables, see the
[PowerShell environment variables][03] of this article.
Expand Down Expand Up @@ -339,7 +339,7 @@ preference variables, see [about_Preference_Variables][06].

The environment variables that store preferences include:

- **POWERSHELL_TELEMETRY_OPTOUT**
- `POWERSHELL_TELEMETRY_OPTOUT`

To opt-out of telemetry, set the environment variable to `true`, `yes`, or
`1`. For more information, see [about_Telemetry][09].
Expand All @@ -348,7 +348,7 @@ The environment variables that store preferences include:
starting the PowerShell process. See the previous sections for information
about creating persistent environment variables.

- **POWERSHELL_DISTRIBUTION_CHANNEL**
- `POWERSHELL_DISTRIBUTION_CHANNEL`

Beginning in PowerShell 7.2, this environment variable is set by the
installer packages to record the method and source of installation for
Expand All @@ -357,7 +357,7 @@ The environment variables that store preferences include:
This information is included in the telemetry data sent to Microsoft. Users
shouldn't change this value.

- **POWERSHELL_UPDATECHECK**
- `POWERSHELL_UPDATECHECK`

The update notification behavior can be changed using the
`POWERSHELL_UPDATECHECK` environment variable. For more information, see
Expand All @@ -375,7 +375,7 @@ The environment variables that store preferences include:
PowerShell process. See the previous sections for information about creating
persistent environment variables.

- **PSExecutionPolicyPreference**
- `PSExecutionPolicyPreference`

Stores the execution policy set for the current session. This environment
variable exists only when you set an execution policy for a single session.
Expand All @@ -393,7 +393,7 @@ The environment variables that store preferences include:
This information only applies to the Windows platform. For more information,
see [about_Execution_Policies][05].

- **PSModulePath**
- `PSModulePath`

The `$env:PSModulePath` environment variable contains a list of folder
locations that are searched to find modules and resources. On Windows, the
Expand Down Expand Up @@ -425,7 +425,7 @@ The environment variables that store preferences include:

For more information, see [about_PSModulePath][08].

- **PSModuleAnalysisCachePath**
- `PSModuleAnalysisCachePath`

PowerShell provides control over the file that's used to cache data about
modules and their cmdlets. The cache is read at startup while searching for a
Expand Down Expand Up @@ -474,7 +474,7 @@ The environment variables that store preferences include:
}
```

- **PSDisableModuleAnalysisCacheCleanup**
- `PSDisableModuleAnalysisCacheCleanup`

When writing out the module analysis cache, PowerShell checks for modules
that no longer exist to avoid an unnecessarily large cache. Sometimes these
Expand All @@ -491,15 +491,15 @@ The environment variables that store preferences include:

### Path information

- **PATH**
- `PATH`

The `$env:PATH` environment variable contains a list of folder locations that
the operating system searches for executable files. On Windows, the list of
folder locations is separated by the semi-colon (`;`) character. On
non-Windows platforms, the colon (`:`) separates the folder locations in the
environment variable.

- **PATHEXT**
- `PATHEXT`

The `$env:PATHEXT` variable contains a list of file extensions that Windows
considers to be executable files. When a script file with one of the listed
Expand All @@ -519,34 +519,34 @@ The environment variables that store preferences include:
PowerShell scripts always start in the current console session. You don't
need to add the `.PS1` extension.

- **XDG** variables
- `XDG` variables

On non-Windows platforms, PowerShell uses the following XDG environment
variables as defined by the [XDG Base Directory Specification][13].

- **XDG_CONFIG_HOME**
- **XDG_DATA_HOME**
- **XDG_CACHE_HOME**
- `XDG_CONFIG_HOME`
- `XDG_DATA_HOME`
- `XDG_CACHE_HOME`

### Terminal features

Beginning in PowerShell 7.2, the following environment variables can be used to
control the Virtual Terminal features like ANSI escape sequences that colorize
output. Support for ANSI escape sequences can be turned off using the **TERM**
or **NO_COLOR** environment variables.
output. Support for ANSI escape sequences can be turned off using the `TERM`
or `NO_COLOR` environment variables.

- **TERM**
- `TERM`

The following values of `$env:TERM` change the behavior as follows:

- `dumb` - sets `$Host.UI.SupportsVirtualTerminal = $false`
- `xterm-mono` - sets `$PSStyle.OutputRendering = PlainText`
- `xtermm` - sets `$PSStyle.OutputRendering = PlainText`

- **NO_COLOR**
- `NO_COLOR`

If `$env:NO_COLOR` exists, then `$PSStyle.OutputRendering` is set to
**PlainText**. For more information about the **NO_COLOR** environment
`PlainText`. For more information about the `NO_COLOR` environment
variable, see [https://no-color.org/][12].

## See also
Expand Down
42 changes: 33 additions & 9 deletions reference/7.2/Microsoft.PowerShell.Core/About/about_Path_Syntax.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
---
description: Describes the full and relative path formats in PowerShell.
Locale: en-US
ms.date: 09/16/2023
ms.date: 09/05/2024
online version: https://learn.microsoft.com/powershell/module/microsoft.powershell.core/about/about_path_syntax?view=powershell-7.2&WT.mc_id=ps-gethelp
schema: 2.0.0
title: about_Path_Syntax
Expand All @@ -18,9 +18,9 @@ uniquely identified by their path names. A path is a combination of the
item name, the container and subcontainers in which the item is located, and
the PowerShell drive through which the containers are accessed.

In PowerShell, pathnames can be one of two types: _fully qualified_ and
In PowerShell, path names can be one of two types: _fully qualified_ and
_relative_. A fully qualified path consists of all elements that make up a
path. The following syntax shows the elements in a fully qualified path name:
path. The following syntax shows the elements in a fully qualified path:

```Syntax
[<provider>::]<drive>:[\<container>[\<subcontainer>...]]\<item>
Expand Down Expand Up @@ -115,11 +115,35 @@ first file (`C:\TechDocs\Jan\Results.txt`) and the path for the second file
(`C:\TechDocs\Feb\Results.txt`) allow you to clearly distinguish between the
two files.

## Support for the Win32 File namespace

On Windows, the cmdlets that support the FileSystem provider also support the
paths that use the Win32 File namespace format. You can only use these paths
with the **LiteralPath** parameter of the cmdlets.

Paths in Win32 File namespace are prefixed with `\\?\`. The prefix tells the
Windows APIs to disable all string parsing and send the string that follows
directly to the file system. For example, if the file system supports large
paths and file names, you can exceed the **MAX_PATH** limits that are otherwise
enforced by the Windows APIs.

For more information, see _Win32 File Namespaces_ in
[Naming Files, Paths, and Namespaces][01].

## See also

- [about_Locations](about_Locations.md)
- [Convert-Path](xref:Microsoft.PowerShell.Management.Convert-Path)
- [Join-Path](xref:Microsoft.PowerShell.Management.Join-Path)
- [Resolve-Path](xref:Microsoft.PowerShell.Management.Resolve-Path)
- [Split-Path](xref:Microsoft.PowerShell.Management.Split-Path)
- [Test-Path](xref:Microsoft.PowerShell.Management.Test-Path)
- [about_Locations][02]
- [Convert-Path][03]
- [Join-Path][04]
- [Resolve-Path][05]
- [Split-Path][06]
- [Test-Path][07]

<!-- link references -->
[01]: /windows/win32/fileio/naming-a-file#win32-file-namespaces
[02]: about_Locations.md
[03]: xref:Microsoft.PowerShell.Management.Convert-Path
[04]: xref:Microsoft.PowerShell.Management.Join-Path
[05]: xref:Microsoft.PowerShell.Management.Resolve-Path
[06]: xref:Microsoft.PowerShell.Management.Split-Path
[07]: xref:Microsoft.PowerShell.Management.Test-Path
Original file line number Diff line number Diff line change
Expand Up @@ -869,4 +869,4 @@ Displays information about PowerShell cmdlets and concepts.
- [about_Functions](about_Functions.md)
- [about_Functions_Advanced_Parameters](about_Functions_Advanced_Parameters.md)
- [about_Scripts](about_Scripts.md)
- [How to Write Cmdlet Help](https://go.microsoft.com/fwlink/?LinkID=123415)
- [Writing Comment-Based Help Topics](/powershell/scripting/developer/help/writing-comment-based-help-topics)
Loading

0 comments on commit 02c2242

Please sign in to comment.