Go to file
2020-11-16 19:57:48 +05:00
.devcontainer Bump .NET to version 5.0.100-rtm.20526.5 (#13920) 2020-11-02 16:51:35 -08:00
.github Enable CodeQL Security scanning (#13894) 2020-10-27 10:20:15 -07:00
.poshchan Update @PoshChan config to include SSH (#12526) 2020-05-05 21:48:37 +05:00
.vscode vscode: Add editorconfig to recommended extensions (#13537) 2020-09-01 09:48:32 +05:00
.vsts-ci Enable CodeQL Security scanning (#13894) 2020-10-27 10:20:15 -07:00
assets Bump .NET to version 5.0.100-rtm.20526.5 (#13920) 2020-11-02 16:51:35 -08:00
CHANGELOG Update the Change Log for v7.1.0 release (#14035) 2020-11-11 10:48:41 -08:00
demos Fix crontab formatting in example doc (#13712) 2020-10-02 05:54:15 -06:00
docker Update copyright notice to latest guidance (#12190) 2020-03-24 11:08:37 -07:00
docs Enable CA1825: Avoid zero-length array allocations (#13961) 2020-11-04 08:56:26 +05:00
src Enable IDE0041: UseIsNullCheck (#14041) 2020-11-16 19:57:48 +05:00
test Enable IDE0082: ConvertTypeOfToNameOf (#14042) 2020-11-16 19:56:07 +05:00
tools Move windows package signing to use ESRP (#14060) 2020-11-13 14:16:06 -08:00
.editorconfig Add copyright header to .editorconfig and update files (#13306) 2020-07-30 09:47:21 -07:00
.gitattributes Add VSTS CI for Windows (#7536) 2018-08-17 22:06:51 -07:00
.gitignore Discover assemblies loaded by 'Assembly.Load(byte[])' and 'Assembly.LoadFile' (#12203) 2020-03-28 20:25:59 +05:00
.globalconfig Enable IDE0041: UseIsNullCheck (#14041) 2020-11-16 19:57:48 +05:00
.markdownlint.json Update CHANGELOG.md for 'v6.0.0-beta.1' release (#3736) 2017-05-08 17:58:12 -07:00
.spelling Update the Change Log for v7.1.0 release (#14035) 2020-11-11 10:48:41 -08:00
ADOPTERS.md Add "GitHub Actions Python builds" to ADOPTERS.md (#13228) 2020-07-21 14:54:32 -07:00
build.psm1 Remove workarounds for .NET 5 RTM builds (#14038) 2020-11-11 14:53:33 -08:00
CHANGELOG.md Refactor change logs into one log per release (#11165) 2019-12-02 17:47:08 -08:00
CODE_OF_CONDUCT.md Promote https (#8160) 2018-11-01 11:55:53 +05:00
codecov.yml Make OpenCover merge and upload more reliable/usable (#3078) 2017-02-01 15:45:03 -08:00
DotnetRuntimeMetadata.json Update script to use .NET RTM feeds (#13927) 2020-10-29 17:35:34 -07:00
global.json Bump .NET to version 5.0.100-rtm.20526.5 (#13920) 2020-11-02 16:51:35 -08:00
LICENSE.txt Update LICENSE.txt so that it's recognized as MIT (#12729) 2020-05-19 13:13:37 -07:00
nuget.config Remove workarounds for .NET 5 RTM builds (#14038) 2020-11-11 14:53:33 -08:00
PowerShell.Common.props Enforce code style in build (#13957) 2020-11-01 12:33:18 +05:00
PowerShell.sln Fix unix project mappings (#9892) 2019-06-17 11:36:48 -07:00
README.md Fix links to LTS versions for Windows (#14070) 2020-11-12 14:19:39 -08:00
Settings.StyleCop Disable NonPrivateReadonlyFieldsMustBeginWithUpperCaseLetter rule in StyleCop (#12855) 2020-06-12 11:02:21 -07:00
stylecop.json Update copyright notice to latest guidance (#12190) 2020-03-24 11:08:37 -07:00
ThirdPartyNotices.txt Update ThirdPartyNotices.txt (#10834) 2019-10-18 16:25:08 -07:00

logo PowerShell

Welcome to the PowerShell GitHub Community! PowerShell Core is a cross-platform (Windows, Linux, and macOS) automation and configuration tool/framework that works well with your existing tools and is optimized for dealing with structured data (e.g. JSON, CSV, XML, etc.), REST APIs, and object models. It includes a command-line shell, an associated scripting language and a framework for processing cmdlets.

Windows PowerShell vs. PowerShell Core

Although this repository started as a fork of the Windows PowerShell code base, changes made in this repository do not make their way back to Windows PowerShell 5.1 automatically. This also means that issues tracked here are only for PowerShell Core 6 and higher. Windows PowerShell specific issues should be opened on UserVoice.

New to PowerShell?

If you are new to PowerShell and would like to learn more, we recommend reviewing the getting started documentation.

Get PowerShell

You can download and install a PowerShell package for any of the following platforms.

Supported Platform Download (LTS) Downloads (stable) Downloads (preview) How to Install
Windows (x64) .msi .msi .msi Instructions
Windows (x86) .msi .msi .msi Instructions
Ubuntu 20.04 .deb Instructions
Ubuntu 18.04 .deb .deb .deb Instructions
Ubuntu 16.04 .deb .deb .deb Instructions
Debian 9 .deb .deb .deb Instructions
Debian 10 .deb .deb .deb Instructions
Debian 11 .deb .deb
CentOS 7 .rpm .rpm .rpm Instructions
CentOS 8 .rpm .rpm .rpm
Red Hat Enterprise Linux 7 .rpm .rpm .rpm Instructions
openSUSE 42.3 .rpm .rpm .rpm Instructions
Fedora 30 .rpm .rpm .rpm Instructions
macOS 10.13+ .pkg .pkg .pkg Instructions
Docker Instructions

You can download and install a PowerShell package for any of the following platforms, which are supported by the community.

Platform Downloads (stable) Downloads (preview) How to Install
Arch Linux Instructions
Kali Linux .deb .deb Instructions
Many Linux distributions Snapcraft Snapcraft

You can also download the PowerShell binary archives for Windows, macOS and Linux.

Platform Downloads (stable) Downloads (preview) How to Install
Windows 32-bit/64-bit 32-bit/64-bit Instructions
macOS 64-bit 64-bit Instructions
Linux 64-bit 64-bit Instructions
Windows (Arm) 64-bit (preview) 32-bit/64-bit Instructions
Raspbian (Arm) 32-bit/64-bit 32-bit/64-bit Instructions

To install a specific version, visit releases.

Community Dashboard

Dashboard with visualizations for community contributions and project status using PowerShell, Azure, and PowerBI.

For more information on how and why we built this dashboard, check out this blog post.

Chat

Want to chat with other members of the PowerShell community?

We have a Gitter Room which you can join below.

Join the chat

There is also the community-driven PowerShell Virtual User Group, which you can join on:

Add-ons and libraries

Awesome PowerShell has a great curated list of add-ons and resources.

Building the Repository

Linux Windows macOS
Instructions Instructions Instructions

If you have any problems building, please consult the developer FAQ.

Build status of nightly builds

Azure CI (Windows) Azure CI (Linux) Azure CI (macOS) Code Coverage Status CodeFactor Grade
windows-nightly-image linux-nightly-image macOS-nightly-image cc-image cf-image

Downloading the Source Code

You can just clone the repository:

git clone https://github.com/PowerShell/PowerShell.git

See working with the PowerShell repository for more information.

Developing and Contributing

Please see the Contribution Guide for how to develop and contribute. If you are developing .NET Core C# applications targeting PowerShell Core, please check out our FAQ to learn more about the PowerShell SDK NuGet package.

Also, make sure to check out our PowerShell-RFC repository for request-for-comments (RFC) documents to submit and give comments on proposed and future designs.

Support

For support, please see the Support Section.

PowerShell is licensed under the MIT license.

Windows Docker Files and Images

License: By requesting and using the Container OS Image for Windows containers, you acknowledge, understand, and consent to the Supplemental License Terms available on Docker Hub:

Telemetry

By default, PowerShell collects the OS description and the version of PowerShell (equivalent to $PSVersionTable.OS and $PSVersionTable.GitCommitId) using Application Insights. To opt-out of sending telemetry, create an environment variable called POWERSHELL_TELEMETRY_OPTOUT set to a value of 1 before starting PowerShell from the installed location. The telemetry we collect falls under the Microsoft Privacy Statement.

Governance

The governance policy for the PowerShell project is described here.

Code of Conduct

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.