Go to file
Steve Lee abcdce4e3e Don't fail if SaferPolicy API is not available on Win10 IoT or NanoServer (#7075)
* don't fail if SaferApi is not available
* fix install-powershellremoting to work on Windows PowerShell 5.1
2018-06-19 17:53:32 -07:00
.github Add Andrew to the default reviewers of the build related files (#7019) 2018-06-07 12:55:14 -07:00
.vscode Add PowerShell VSCode style settings (#5529) 2017-11-28 09:09:32 -08:00
assets Disambiguate icon on Windows for preview builds/installers to use Powershell_av_colors and make daily build use Powershell_avatar instead (#7086) 2018-06-18 15:54:11 -07:00
demos Update links that contain 'en-us' culture (#7013) 2018-06-08 10:49:03 +05:00
docker Update links that contain 'en-us' culture (#7013) 2018-06-08 10:49:03 +05:00
docs Fix typos in DOCSMIGRATION.md (#7094) 2018-06-19 08:24:35 +05:00
src Don't fail if SaferPolicy API is not available on Win10 IoT or NanoServer (#7075) 2018-06-19 17:53:32 -07:00
test Fix conditions for transcription of Write-Information command. (#6917) 2018-06-16 21:11:21 +05:00
tools Disambiguate icon on Windows for preview builds/installers to use Powershell_av_colors and make daily build use Powershell_avatar instead (#7086) 2018-06-18 15:54:11 -07:00
.gitattributes Treat .rtf files as binary so EOL don't get changed (#5020) 2017-10-05 15:49:31 -07:00
.gitignore Remove support for file to opt-out of telemetry, only support env var (#6601) 2018-04-13 10:29:39 -07:00
.gitmodules build: unbundle pester (#5623) 2017-12-04 17:16:53 -08:00
.markdownlint.json Update CHANGELOG.md for 'v6.0.0-beta.1' release (#3736) 2017-05-08 17:58:12 -07:00
.spelling Update 'internals.md' with the latest build changes (#7058) 2018-06-14 23:06:16 +05:00
.travis.yml Skip dotnet-cli initialization and stop caching the 'dotnet' folder for Travis CI (#7007) 2018-06-05 15:51:13 -07:00
appveyor.yml AppVeyor build matrix: more efficient build job split to reduce total time by another 5 minutes (#7021) 2018-06-11 14:18:51 -07:00
build.psm1 Disambiguate icon on Windows for preview builds/installers to use Powershell_av_colors and make daily build use Powershell_avatar instead (#7086) 2018-06-18 15:54:11 -07:00
CHANGELOG.md Fix markdown and spelling errors in CHANGELOG.md (#7064) 2018-06-13 17:53:55 -07:00
CODE_OF_CONDUCT.md add CODE_OF_CONDUCT.md (#4109) 2017-06-28 10:34:09 -07:00
codecov.yml Make OpenCover merge and upload more reliable/usable (#3078) 2017-02-01 15:45:03 -08:00
global.json Add Windows Compatibility Pack 2.0.0 to PS Core and adopt the official .NET Core 2.1 (#6958) 2018-06-03 22:06:26 -07:00
LICENSE.txt Use consistent '(c)' for copyright symbol (#5210) 2017-10-26 14:12:19 -07:00
license_thirdparty_proprietary.txt Use consistent '(c)' for copyright symbol (#5210) 2017-10-26 14:12:19 -07:00
nuget.config Restore modules from the NuGet package cache by using dotnet restore (#6111) 2018-02-27 13:36:54 -08:00
PowerShell.Common.props Enable full symbols for windows (#6853) 2018-05-14 15:01:44 -07:00
PowerShell.sln rename solution to powershell 2018-04-03 09:50:09 -07:00
README.md Fedora 28 was released, Fedora 26 and 25 were EOL'ed. (#7079) 2018-06-18 15:27:57 -07:00
Settings.StyleCop Disable some StyleCop rules (#6986) 2018-06-05 16:32:06 +05:00
stylecop.json Add Settings.StyleCop file (#6930) 2018-06-04 10:41:10 +05:00
ThirdPartyNotices.txt Update third party notices (#7042) 2018-06-12 10:58:05 -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 repo started as a fork of the Windows PowerShell code base, changes made in this repo 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.0. 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 Downloads (stable) Downloads (preview) How to Install
Windows (x64) .msi .msi Instructions
Windows (x86) .msi .msi Instructions
Ubuntu 18.04 .deb Instructions
Ubuntu 17.10 .deb Instructions
Ubuntu 16.04 .deb .deb Instructions
Ubuntu 14.04 .deb .deb Instructions
Debian 8.7+ .deb .deb Instructions
Debian 9 .deb .deb Instructions
CentOS 7 .rpm .rpm Instructions
Red Hat Enterprise Linux 7 .rpm .rpm Instructions
OpenSUSE 42.2 .rpm .rpm Instructions
Fedora 27, Fedora 28 .rpm .rpm Instructions
macOS 10.12+ .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 .AppImage Instructions

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) Experimental 32-bit/64-bit 32-bit/64-bit Instructions
Raspbian (Stretch) Experimental .tgz .tgz 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 Room

Want to chat with other members of the PowerShell community?

We have a Gitter Room which you can join below.

Join the chat at https://gitter.im/PowerShell/PowerShell

There is also the community driven PowerShell Slack Team which you can sign up for at Slack Sign up.

Add-ons and libraries

Awesome PowerShell is 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 master branches

AppVeyor (Windows) Travis CI (Linux / macOS)
av-image tv-image

Build status of nightly builds

AppVeyor (Windows) Travis CI (Linux) Travis CI (macOS) Code Coverage Status Code Factor Status
av-nightly-image linux-nightly-image macOS-nightly-image cc-image cf-image

Downloading the Source Code

The PowerShell repository has a number of other repositories embedded as submodules.

To make things easy, you can just clone recursively:

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

If you already cloned but forgot to use --recursive, you can update submodules manually:

git submodule update --init

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 have any problems, please consult the known issues, developer FAQ, and GitHub issues. If you do not see your problem captured, please file a new issue and follow the provided template. 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.

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 fall under the Microsoft Privacy Statement.

Governance

Governance policy for 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.