578f9e5e8b
* Fix SSH process creation on Linux platforms * Fixed typos * Added UNIX managed code StartProcess * Fixed compile errors * Changed process create to return pid * Now resolve full SSH command file path for all platforms * Removed data reader error handling because it conflicts with SSH errors in the error stream * Clean up work * Fix for file line endings * More clean up * Change to Linux platform SSH process creation to create process in new session * Added third party license text for DotNet Core * Removed process creation in new session and added suppress SIGINT * Removed unneeded code for creating SSH process * Fixed Unix compile errors * Changes for code review * Response to more code review comments * Removed unneeded using statements |
||
---|---|---|
.github | ||
.vscode | ||
assets | ||
demos | ||
docker | ||
docs | ||
src | ||
test | ||
tools | ||
.gitattributes | ||
.gitignore | ||
.gitmodules | ||
.markdownlint.json | ||
.spelling | ||
.travis.yml | ||
appveyor.yml | ||
build.psm1 | ||
build.sh | ||
CHANGELOG.md | ||
codecov.yml | ||
license_thirdparty_proprietary.txt | ||
LICENSE.txt | ||
nuget.config | ||
README.md | ||
ThirdPartyNotices.txt |
PowerShell
Welcome to the PowerShell GitHub Community! PowerShell 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.
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.
Platform | Downloads | How to Install |
---|---|---|
Windows 10 / Server 2016 (x64) | .msi | Instructions |
Windows 8.1 / Server 2012 R2 (x64) | .msi | Instructions |
Windows 7 / Server 2008 R2 (x64) | .msi | Instructions |
Windows 7 (x86) | .msi | Instructions |
Ubuntu 16.04 | .deb | Instructions |
Ubuntu 14.04 | .deb | Instructions |
Debian 8 | .deb | Instructions |
CentOS 7 | .rpm | Instructions |
Red Hat Enterprise Linux 7 | .rpm | Instructions |
OpenSUSE 42.1 | .rpm | Instructions |
Arch Linux | Instructions | |
Many Linux distributions | .AppImage | Instructions |
macOS 10.12 | .pkg | Instructions |
Docker | Instructions | |
Kali Linux | .deb | 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.
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) |
---|---|
Build status of nightly builds
AppVeyor (Windows) | Travis CI (Linux / macOS) | Code Coverage Status |
---|---|---|
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
Note: To develop with VSCode on OSX and Linux, you need to install the
v1.11.0-beta4
C# extension by following these instructions.PowerShell is building against the .NET Core
2.0.0-preview2
packages using the .NET Core2.0.0-preview2
SDK.v1.13.0
VSCode +v1.10.0
C# extension works fine with the .NET Core2.0.0-preview2
SDK on Windows. However, on OSX and Linux you need to use thev1.11.0-beta4
C# extension due to omnisharp-vscode issue #1495.
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.
Legal and Licensing
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, delete the file DELETE_ME_TO_DISABLE_CONSOLEHOST_TELEMETRY
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.