Merge pull request #1583 from nikita-bykov/win-docs

Improve documentation for Android on Windows
This commit is contained in:
Maxim Lobanov
2020-09-21 18:56:31 +03:00
committed by GitHub
2 changed files with 123 additions and 106 deletions

View File

@@ -1,4 +1,11 @@
function Get-AndroidComponentLocation { function Split-TableRowByColumns {
param(
[string] $Row
)
return $Row.Split("|") | ForEach-Object { $_.trim() }
}
function Get-AndroidSDKRoot {
param( param(
[string] $ComponentName [string] $ComponentName
) )
@@ -6,24 +13,6 @@ function Get-AndroidComponentLocation {
return "Location $path" return "Location $path"
} }
function Split-AndroidSDKOutputRow {
param(
[string] $Row
)
return $Row.Split("|").Trim()
}
function Create-AndroidTableObject {
param(
[string] $PackageName,
[string] $Description
)
return [PSCustomObject] @{
"Package Name" = $PackageName
"Description" = $Description
}
}
function Get-AndroidSDKManagerPath { function Get-AndroidSDKManagerPath {
return Join-Path $env:ANDROID_HOME "tools\bin\sdkmanager.bat" return Join-Path $env:ANDROID_HOME "tools\bin\sdkmanager.bat"
} }
@@ -42,68 +31,120 @@ function Get-AndroidInstalledPackages {
return $androidInstalledPackages return $androidInstalledPackages
} }
function Build-AndroidSDKToolsTable {
param (
[Parameter(Mandatory)]
[object] $packageInfo
)
return $packageInfo | ForEach-Object { function Build-AndroidTable {
$packageInfoParts = Split-AndroidSDKOutputRow $_ $packageInfo = Get-AndroidInstalledPackages
$packageName = $packageInfoParts[0] return @(
$packageDescription = $packageInfoParts[2] + ", Revision " + $packageInfoParts[1] @{
Create-AndroidTableObject -PackageName $packageName -Description $packageDescription "Package" = "Android SDK Platform-Tools"
} "Version" = Get-AndroidPackageVersions -PackageInfo $packageInfo -MatchedString "Android SDK Platform-Tools"
} },
@{
function Build-AndroidSDKPlatformTable { "Package" = "Android SDK Tools"
param ( "Version" = Get-AndroidPackageVersions -PackageInfo $packageInfo -MatchedString "Android SDK Tools"
[Parameter(Mandatory)] },
[object] $packageInfo @{
) "Package" = "Android SDK Platforms"
"Version" = Get-AndroidPlatformVersions -PackageInfo $packageInfo
return $packageInfo | ForEach-Object { },
$packageInfoParts = Split-AndroidSDKOutputRow $_ @{
$packageName = $packageInfoParts[0].split(";")[1] "Package" = "Android SDK Build-tools"
$packageDescription = $packageInfoParts[2] + ", Revision " + $packageInfoParts[1] "Version" = Get-AndroidBuildToolVersions -PackageInfo $packageInfo
return Create-AndroidTableObject -PackageName $packageName -Description $packageDescription },
} @{
} "Package" = "NDK"
"Version" = Get-AndroidPackageVersions -PackageInfo $packageInfo -MatchedString "ndk-bundle"
function Build-AndroidSDKBuildToolsTable { },
param ( @{
[Parameter(Mandatory)] "Package" = "Android Support Repository"
[object] $packageInfo "Version" = Get-AndroidPackageVersions -PackageInfo $packageInfo -MatchedString "Android Support Repository"
) },
@{
return $packageInfo | ForEach-Object { "Package" = "Google APIs"
$packageInfoParts = Split-AndroidSDKOutputRow $_ "Version" = Get-AndroidGoogleAPIsVersions -PackageInfo $packageInfo
$packageName = $packageInfoParts[0].replace(";", "-") },
$packageDescription = "Android SDK Build-Tools, Revision " + $packageInfoParts[1] @{
return Create-AndroidTableObject -PackageName $packageName -Description $packageDescription "Package" = "Google Play services"
} "Version" = Get-AndroidPackageVersions -PackageInfo $packageInfo -MatchedString "Google Play services"
} },
@{
function Build-AndroidExtraPackagesTable { "Package" = "Google Repository"
param ( "Version" = Get-AndroidPackageVersions -PackageInfo $packageInfo -MatchedString "Google Repository"
[Parameter(Mandatory)][AllowEmptyString()] },
[string[]] $installedPackages @{
) "Package" = "SDK Patch Applier v4"
"Version" = Get-AndroidPackageVersions -PackageInfo $packageInfo -MatchedString "SDK Patch Applier v4"
$extraPackages = @( },
"Android Support Repository", @{
"Google Play services", "Package" = "CMake"
"Google Repository", "Version" = Get-AndroidPackageVersions -PackageInfo $packageInfo -MatchedString "cmake"
"ndk-bundle" }
) ) | Where-Object { $_.Version } | ForEach-Object {
[PSCustomObject] @{
return $extraPackages | ForEach-Object { "Package Name" = $_.Package
$packageId = $_ "Version" = $_.Version
$packageInfo = $installedPackages | Where-Object { $_ -Like "*${packageId}*" } | Select-Object -First 1
$packageInfoParts = Split-AndroidSDKOutputRow $packageInfo
return [PSCustomObject] @{
"Package Name" = $packageInfoParts[2]
"Version" = $packageInfoParts[1]
} }
} }
}
function Get-AndroidPackageVersions {
param (
[Parameter(Mandatory)]
[object] $PackageInfo,
[Parameter(Mandatory)]
[object] $MatchedString
)
$versions = $packageInfo | Where-Object { $_ -Match $MatchedString } | ForEach-Object {
$packageInfoParts = Split-TableRowByColumns $_
return $packageInfoParts[1]
}
return ($versions -Join "<br>")
}
function Get-AndroidPlatformVersions {
param (
[Parameter(Mandatory)]
[object] $PackageInfo
)
$versions = $packageInfo | Where-Object { $_ -Match "Android SDK Platform " } | ForEach-Object {
$packageInfoParts = Split-TableRowByColumns $_
$revision = $packageInfoParts[1]
$version = $packageInfoParts[0].split(";")[1]
return "$version (rev $revision)"
}
[array]::Reverse($versions)
return ($versions -Join "<br>")
}
function Get-AndroidBuildToolVersions {
param (
[Parameter(Mandatory)]
[object] $PackageInfo
)
$versions = $packageInfo | Where-Object { $_ -Match "Android SDK Build-Tools" } | ForEach-Object {
$packageInfoParts = Split-TableRowByColumns $_
return $packageInfoParts[1]
}
$groupVersions = @()
$versions | ForEach-Object {
$majorVersion = $_.Split(".")[0]
$groupVersions += $versions | Where-Object { $_.StartsWith($majorVersion) } | Join-String -Separator " "
}
return ($groupVersions | Sort-Object -Descending -Unique | Join-String -Separator "<br>")
}
function Get-AndroidGoogleAPIsVersions {
param (
[Parameter(Mandatory)]
[object] $PackageInfo
)
$versions = $packageInfo | Where-Object { $_ -Match "Google APIs" } | ForEach-Object {
$packageInfoParts = Split-TableRowByColumns $_
return $packageInfoParts[0].split(";")[1]
}
return ($versions -Join "<br>")
} }

View File

@@ -222,32 +222,8 @@ $markdown += Get-PowerShellModules | New-MDTable
$markdown += New-MDNewLine $markdown += New-MDNewLine
# Android section # Android section
$androidInstalledPackages = Get-AndroidInstalledPackages $markdown += New-MDHeader "Android" -Level 3
$markdown += Build-AndroidTable | New-MDTable
$markdown += New-MDHeader "Android SDK Tools" -Level 3
$androidSDKTools = $androidInstalledPackages | Where-Object { $_ -Match "Android SDK Tools" -or $_ -Match "Android SDK Platform-Tools" }
$markdown += Build-AndroidSDKToolsTable $androidSDKTools | New-MDTable
$markdown += New-MDNewLine $markdown += New-MDNewLine
$markdown += New-MDHeader "Android SDK Platforms" -Level 3
$androidSDKPlatforms = $androidInstalledPackages | Where-Object { $_ -Match "Android SDK Platform " }
$markdown += New-MDInlineCode -Text (Get-AndroidComponentLocation -ComponentName "platforms")
$markdown += New-MDNewLine
$markdown += Build-AndroidSDKPlatformTable $androidSDKPlatforms | New-MDTable
$markdown += New-MDNewLine
$markdown += New-MDHeader "Android SDK Build-Tools" -Level 3
$androidSDKBuildTools = $androidInstalledPackages | Where-Object { $_ -Match "Android SDK Build-Tools" }
$markdown += New-MDInlineCode -Text (Get-AndroidComponentLocation -ComponentName "build-tools")
$markdown += New-MDNewLine
$markdown += Build-AndroidSDKBuildtoolsTable $androidSDKBuildTools | New-MDTable
$markdown += New-MDNewLine
$markdown += New-MDHeader "Android Extra Packages" -Level 3
$markdown += Build-AndroidExtraPackagesTable $androidInstalledPackages | New-MDTable
$markdown += New-MDNewLine
$markdown += New-MDHeader "Cached Docker images" -Level 3
$markdown += New-MDList -Style Unordered -Lines @(Get-CachedDockerImages)
$markdown | Out-File -FilePath "C:\InstalledSoftware.md" $markdown | Out-File -FilePath "C:\InstalledSoftware.md"