Bitness/Bitness.ps1

#region Copyright & License

# Copyright © 2020 - 2020 François Chabot
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

#endregion

Set-StrictMode -Version Latest

<#
.SYNOPSIS
    Ensures the current process is 32 bit.
.DESCRIPTION
    This command will throw if the current process is not a 32 bit process and will silently complete otherwise.
.EXAMPLE
    PS> Assert-32bitProcess
.EXAMPLE
    PS> Assert-32bitProcess -Verbose
    With the -Verbose switch, this command will confirm this process is 32 bit.
.NOTES
    © 2020 be.stateless.
#>

function Assert-32bitProcess {
    [CmdletBinding()]
    [OutputType([void])]
    param()

    Resolve-ActionPreference -Cmdlet $PSCmdlet -SessionState $ExecutionContext.SessionState
    if (-not(Test-32bitProcess)) {
        throw "A 32 bit process is required to run this function!"
    }
    Write-Verbose -Message "Process is 32 bit."
}

<#
.SYNOPSIS
    Ensures the current process is 64 bit.
.DESCRIPTION
    This command will throw if the current process is not a 64 bit process and will silently complete otherwise.
.EXAMPLE
    PS> Assert-64bitProcess
.EXAMPLE
    PS> Assert-64bitProcess -Verbose
    With the -Verbose switch, this command will confirm this process is 64 bit.
.NOTES
    © 2020 be.stateless.
#>

function Assert-64bitProcess {
    [CmdletBinding()]
    [OutputType([void])]
    param()

    Resolve-ActionPreference -Cmdlet $PSCmdlet -SessionState $ExecutionContext.SessionState
    if (-not(Test-64bitProcess)) {
        throw "A 64 bit process is required to run this function!"
    }
    Write-Verbose -Message "Process is 64 bit."
}

<#
.SYNOPSIS
    Returns whether the current operating system is 32 bit.
.DESCRIPTION
    This command will return $true if the current operating system is 32 bit, or $false otherwise.
.EXAMPLE
    PS> Test-32bitArchitecture
.NOTES
    © 2020 be.stateless.
#>

function Test-32bitArchitecture {
    [CmdletBinding()]
    [OutputType([bool])]
    param()

    Resolve-ActionPreference -Cmdlet $PSCmdlet -SessionState $ExecutionContext.SessionState
    # https://docs.microsoft.com/en-us/windows/win32/cimwin32prov/cim-processor
    [bool](Get-CimInstance -ClassName CIM_Processor | Where-Object AddressWidth -eq 32)
}

<#
.SYNOPSIS
    Returns whether the current process is 32 bit.
.DESCRIPTION
    This command will return $true if the current process is 32 bit, or $false otherwise.
.EXAMPLE
    PS> Test-32bitProcess
.NOTES
    © 2020 be.stateless.
#>

function Test-32bitProcess {
    [CmdletBinding()]
    [OutputType([bool])]
    param()

    # https://docs.microsoft.com/en-us/dotnet/api/system.intptr.size
    [System.IntPtr]::Size -eq 4
}

<#
.SYNOPSIS
    Returns whether the current operating system is 64 bit.
.DESCRIPTION
    This command will return $true if the current operating system is 64 bit, or $false otherwise.
.EXAMPLE
    PS> Test-64bitArchitecture
.NOTES
    © 2020 be.stateless.
#>

function Test-64bitArchitecture {
    [CmdletBinding()]
    [OutputType([bool])]
    param()

    Resolve-ActionPreference -Cmdlet $PSCmdlet -SessionState $ExecutionContext.SessionState
    # https://docs.microsoft.com/en-us/windows/win32/cimwin32prov/cim-processor
    [bool](Get-CimInstance -ClassName CIM_Processor | Where-Object AddressWidth -eq 64)
}

<#
.SYNOPSIS
    Returns whether the current process is 64 bit.
.DESCRIPTION
    This command will return $true if the current process is 64 bit, or $false otherwise.
.EXAMPLE
    PS> Test-64bitProcess
.NOTES
    © 2020 be.stateless.
#>

function Test-64bitProcess {
    [CmdletBinding()]
    [OutputType([bool])]
    param()

    # https://docs.microsoft.com/en-us/dotnet/api/system.intptr.size
    [System.IntPtr]::Size -eq 8
}

# SIG # Begin signature block
# MIIJEgYJKoZIhvcNAQcCoIIJAzCCCP8CAQExCzAJBgUrDgMCGgUAMGkGCisGAQQB
# gjcCAQSgWzBZMDQGCisGAQQBgjcCAR4wJgIDAQAABBAfzDtgWUsITrck0sYpfvNR
# AgEAAgEAAgEAAgEAAgEAMCEwCQYFKw4DAhoFAAQUtXQwJf14/KjTLotDDuY12NsO
# ysOgggWhMIIFnTCCA1GgAwIBAgIQKBOAjgMDO55A7UJ/k/g5nTBBBgkqhkiG9w0B
# AQowNKAPMA0GCWCGSAFlAwQCAQUAoRwwGgYJKoZIhvcNAQEIMA0GCWCGSAFlAwQC
# AQUAogMCASAwJjEkMCIGA1UEAwwbaWNyYWZ0c29mdHdhcmVAc3RhdGVsZXNzLmJl
# MB4XDTIwMDYyMzExNDM1NloXDTIxMDYyMzEyMDM1NlowJjEkMCIGA1UEAwwbaWNy
# YWZ0c29mdHdhcmVAc3RhdGVsZXNzLmJlMIICIjANBgkqhkiG9w0BAQEFAAOCAg8A
# MIICCgKCAgEAmQcb0GwlBHBHBJZ9vNM8EewN7T+nhsWVU0WBoWnIw6UAT99Rw9x5
# RcfOQU2hxqKmR1k+iI6B+qddpTC3VLSChA/mh1P4pCDDsZeyR/0nn/r/DezhDe8x
# 5jckjR88KSRcgDoh0kLjgfrToDpx9EvBcwXmNJKDwBIWu5SBvk04beU4XO7OHjBo
# g0kMaHxCZc9HcWfdzBefP+fbVzu6f1j1WgEqZn9sr1ML2ulHRdu26+56xGq9RZGJ
# vXyY1mY+K5mqBcET+1bV2pZnBrM3Gc/hlmvTkwrC0ZGBALLZWZqqpLVrDCY5eoHP
# w2C0kA4JzK4Q1o218s+wXbuDcjYRIZqBSwI8fizR/4DS+6dEjfa3kzs2z/MrkJOk
# hJ06tiMSRr55tX1DR8NwVLdiNqZYvs4zP2ZNRMMI8uFCjkP/Wn1hfBr+GSPlgdLq
# 2TFishY2pj5O1WlE/tCz+B0YLhPWdfbVEp8kB3fGBsVf7uw4STK/wDA1MYRIHikt
# w+K9gtdf0eIR9dYX9CMwoDN2TNLK6vnCWMrzWFe5EOU3/oljUBkyQT838a5A6wMu
# cGeu7Cwjdigylt7ULaTglL7ORIyaRbzkltxd+1oaQ21kjl4ef0ZD2gWLj7bwrZR+
# KWCfmaHFoZlVRKNPtScuyOnilPGGZ6T7SNuwVxSXFRtbp+cQea4UxxUCAwEAAaNf
# MF0wDgYDVR0PAQH/BAQDAgeAMBMGA1UdJQQMMAoGCCsGAQUFBwMDMBcGA1UdEQQQ
# MA6CDHN0YXRlbGVzcy5iZTAdBgNVHQ4EFgQUq4sCoE2IqN4K4uwNuibjqd5yNNQw
# QQYJKoZIhvcNAQEKMDSgDzANBglghkgBZQMEAgEFAKEcMBoGCSqGSIb3DQEBCDAN
# BglghkgBZQMEAgEFAKIDAgEgA4ICAQBR98amLpANKFlc7mPlkaV4ZtS2uTmbJ6dO
# qzyWKJ2yTmv7U9yq8PdEH9mPJlxYvGyNgxqHoocKv1SdjgYh27SM8pDnsfU2NpER
# 6K/3sICy6Orh9vhC+U18Bp93WoLEezolaBcF0co3/o+HazOvs/2zBFONFHMkef9/
# 3Bipm0sd95teHo53vLKViHbjSmoGxYsvJJiYITB4Zeo6xgUAmwcUpL1To62Lb3RP
# CDLKZQ5h8Ir07nncV4HLq+0qF3+G9Y0IXHJv6Qcr/XTTLo0J877HRqS37WJcgF8+
# 2nbZbqO9NVvp14A4nTqpeDFmzewDU33hiZvzuLHBj//OgLgGZ9lJPxCu0tVxfFWZ
# INHg1YHp3lMaAw00Q3tb/vhc5kE6Kl7FnXnUTsu4j+vUoaFMWhYezoyn9m4rD+xN
# RITrbLPZdWAZvVOJ8ehmswRhfiMZ1npwbrk7KU1UTsmMS7PHREWSyUM28WlMFf2i
# ut8TlY/MV/adUGr2GpqBWhxp5DRgfl1uamKm2wFlCra3/kReVlQgC/Bbod2JOgJW
# t8zCbO4nJx+fJYwM9RG70h/TmuqzP8uChsHtKcgs2YtXmSm12JZakXY4IflInI7p
# ddDEs9UOfsWXDsqpvmFQZbwgGeNeEsPk3Fdm1MzDtS9PBXMk4jGGXNzEsVUgwf42
# 2HuDWeX/4jGCAtswggLXAgEBMDowJjEkMCIGA1UEAwwbaWNyYWZ0c29mdHdhcmVA
# c3RhdGVsZXNzLmJlAhAoE4COAwM7nkDtQn+T+DmdMAkGBSsOAwIaBQCgeDAYBgor
# BgEEAYI3AgEMMQowCKACgAChAoAAMBkGCSqGSIb3DQEJAzEMBgorBgEEAYI3AgEE
# MBwGCisGAQQBgjcCAQsxDjAMBgorBgEEAYI3AgEVMCMGCSqGSIb3DQEJBDEWBBTI
# 7J7IlWU3ni9ggEB416gsH4K/XjANBgkqhkiG9w0BAQEFAASCAgAsSx1iIL1DgL0U
# b+ukKTqtTIGFmHAIetFcJ+JsYexMhtiGkQrKC8mruzBR2Wf2lhVYq7iM+DsFIA+N
# R8IhpaR8Em7PtN84yXYcx9Diwm5dfr/REqbmUulv6RZOB0KDRhi5BGPir/j5II80
# Lq6XyHGYPSmSPoP2T1ZKD8gAvtO9YtO1Nhrg0+kcZGcmBgo4aonD4uLgMNY7RETJ
# 01eMZTOemOTxCJohIctZIjFm6D/iEWYDk4+b+joXM/Z1xE/AuptErqK7x5tI3sxB
# X179kYhvTo87H8WqddwsS8mmFkjpaArWTj1g0AjA0SGWMibM3rjWkL7W4E4D8u0r
# QYgMHL35X7QNdlr+GJ2mCSM33LF1f2DjJa76t64v1Z4y+X+8FVXyfXgmTYruqf30
# DnrrK/GbgG0nyPK4Q0ZvM8c4S/RpeFgVgjthCohzZWB/8zHPnd0E12DpYODrbQFG
# A8R6p75NXmIxwU48kD3/ZK9MUpUqx+Bebj3llCew0/oYgrnFJZQwnCKCX+C/9bGM
# MeZIYTgaovMQLq6rdgsMKd9mAW9unhQzYB4HGu6ltAQqQIz9JPXBSozKPnjPzkOq
# 8E5FSXJlOV+eDR/jZYsZFIkN8ZB7hJJELoke1v4j/WlmlMyLQGTq0wWKvBfV2Db1
# JpYA1N8DCY6wVfalnBGFmVzL9+RhYg==
# SIG # End signature block