From e29d02893167c8d46eed36571b91a5a278b7a2f4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20GRISOT?= Date: Mon, 19 Sep 2022 14:19:37 +0200 Subject: [PATCH 01/13] Adds function to "say hello" --- main.py | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/main.py b/main.py index e69de29..14b3939 100644 --- a/main.py +++ b/main.py @@ -0,0 +1,6 @@ +def say_hello(): + print("Hello") + + +if __name__ == '__main__': + say_hello() From 001ab4a029cc8e307a7d98b03efc2b3bdc4d46f4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20GRISOT?= Date: Mon, 19 Sep 2022 14:37:33 +0200 Subject: [PATCH 02/13] Creates a decimal to binary converter Function that convert a positive decimal int to binary, represented as list of 0s and 1s --- converter.py | 7 +++++++ main.py | 5 ++++- 2 files changed, 11 insertions(+), 1 deletion(-) create mode 100644 converter.py diff --git a/converter.py b/converter.py new file mode 100644 index 0000000..b1b37d1 --- /dev/null +++ b/converter.py @@ -0,0 +1,7 @@ +from typing import List + + +def dec_to_bin(n: int) -> List[int]: + bit = [0 if n % 2 == 0 else 1] + return bit if n <= 1 else dec_to_bin(n // 2) + bit + diff --git a/main.py b/main.py index 14b3939..70778de 100644 --- a/main.py +++ b/main.py @@ -1,6 +1,9 @@ +from converter import dec_to_bin + + def say_hello(): print("Hello") if __name__ == '__main__': - say_hello() + print(*dec_to_bin(256)) From cd3b00042872382ee620aea6733891cdfe6c7e01 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20GRISOT?= Date: Mon, 19 Sep 2022 14:50:13 +0200 Subject: [PATCH 03/13] Adds a binary to decimal converter Function that converts a array of 0s and 1s to an int --- converter.py | 5 +++++ main.py | 3 ++- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/converter.py b/converter.py index b1b37d1..387953d 100644 --- a/converter.py +++ b/converter.py @@ -5,3 +5,8 @@ def dec_to_bin(n: int) -> List[int]: bit = [0 if n % 2 == 0 else 1] return bit if n <= 1 else dec_to_bin(n // 2) + bit + +def bin_to_dec(bits_array: List[int]) -> int: + ba = bits_array.copy() + ba.reverse() + return sum([2 ** i * m for i, m in enumerate(ba)]) diff --git a/main.py b/main.py index 70778de..3c17562 100644 --- a/main.py +++ b/main.py @@ -1,4 +1,4 @@ -from converter import dec_to_bin +from converter import dec_to_bin, bin_to_dec def say_hello(): @@ -7,3 +7,4 @@ def say_hello(): if __name__ == '__main__': print(*dec_to_bin(256)) + print(bin_to_dec([1, 0, 1, 0, 0, 1])) From 96a3f84719bcfe37b35b00c54adc5cd9aac42824 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20GRISOT?= Date: Mon, 19 Sep 2022 15:05:25 +0200 Subject: [PATCH 04/13] Improves speed of conversion Uses bitshift that are faster to compute than powers / divisions --- converter.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/converter.py b/converter.py index 387953d..56e598c 100644 --- a/converter.py +++ b/converter.py @@ -3,10 +3,10 @@ def dec_to_bin(n: int) -> List[int]: bit = [0 if n % 2 == 0 else 1] - return bit if n <= 1 else dec_to_bin(n // 2) + bit + return bit if n <= 1 else dec_to_bin(n >> 2) + bit def bin_to_dec(bits_array: List[int]) -> int: ba = bits_array.copy() ba.reverse() - return sum([2 ** i * m for i, m in enumerate(ba)]) + return sum([1 << i * m for i, m in enumerate(ba)]) From ff5f0fa50c647707a2375b281fb9f5feff59b56b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20GRISOT?= Date: Mon, 19 Sep 2022 15:15:18 +0200 Subject: [PATCH 05/13] Adds some documentation to converters Adds documentation to the conversion functions --- converter.py | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/converter.py b/converter.py index 56e598c..ebc4e4a 100644 --- a/converter.py +++ b/converter.py @@ -2,11 +2,21 @@ def dec_to_bin(n: int) -> List[int]: + """ + Converts a positive integer to binary + :param n: int, decimal integer to convert to binary + :return: Binary translation of input number, as a list of 0s and 1 + """ bit = [0 if n % 2 == 0 else 1] return bit if n <= 1 else dec_to_bin(n >> 2) + bit def bin_to_dec(bits_array: List[int]) -> int: + """ + Converts a list of 0s and 1s to its corresponding decimal representation + :param bits_array: list of 0s and 1s to convert + :return: int + """ ba = bits_array.copy() ba.reverse() return sum([1 << i * m for i, m in enumerate(ba)]) From 4c1e33dde9cf5e5862b90d4612caa289fb0126d5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20GRISOT?= Date: Mon, 19 Sep 2022 15:18:09 +0200 Subject: [PATCH 06/13] Adds some input values check raise an Exception if the input is negative for decimal to bin conversion --- converter.py | 3 +++ 1 file changed, 3 insertions(+) diff --git a/converter.py b/converter.py index ebc4e4a..e3effb1 100644 --- a/converter.py +++ b/converter.py @@ -7,6 +7,9 @@ def dec_to_bin(n: int) -> List[int]: :param n: int, decimal integer to convert to binary :return: Binary translation of input number, as a list of 0s and 1 """ + if n < 0 : + raise ValueError("n should be positive") + bit = [0 if n % 2 == 0 else 1] return bit if n <= 1 else dec_to_bin(n >> 2) + bit From c098a3bb911c852456b5494241f49b6ff2948298 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20GRISOT?= Date: Mon, 19 Sep 2022 15:22:08 +0200 Subject: [PATCH 07/13] Checks that only bits are passed to conv Check bin to dec converter inputs. Raise error if some entries are not 0 or 1s --- converter.py | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/converter.py b/converter.py index e3effb1..c711ca1 100644 --- a/converter.py +++ b/converter.py @@ -7,9 +7,9 @@ def dec_to_bin(n: int) -> List[int]: :param n: int, decimal integer to convert to binary :return: Binary translation of input number, as a list of 0s and 1 """ - if n < 0 : + if n < 0: raise ValueError("n should be positive") - + bit = [0 if n % 2 == 0 else 1] return bit if n <= 1 else dec_to_bin(n >> 2) + bit @@ -20,6 +20,9 @@ def bin_to_dec(bits_array: List[int]) -> int: :param bits_array: list of 0s and 1s to convert :return: int """ + for b in bits_array: + if b not in [0, 1]: + raise ValueError("input should contain only bits (0 or 1)") ba = bits_array.copy() ba.reverse() return sum([1 << i * m for i, m in enumerate(ba)]) From 24356324765c7c1f2feaa9c67f68a7a7066d9c35 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20GRISOT?= Date: Mon, 19 Sep 2022 15:24:49 +0200 Subject: [PATCH 08/13] Refactors bits verification Check if inputs is made of bits only in a separate function --- converter.py | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/converter.py b/converter.py index c711ca1..f08f3e9 100644 --- a/converter.py +++ b/converter.py @@ -20,9 +20,15 @@ def bin_to_dec(bits_array: List[int]) -> int: :param bits_array: list of 0s and 1s to convert :return: int """ - for b in bits_array: - if b not in [0, 1]: - raise ValueError("input should contain only bits (0 or 1)") + if not inputs_is_bits(bits_array): + raise ValueError("input should contain only bits (0 or 1)") + ba = bits_array.copy() ba.reverse() return sum([1 << i * m for i, m in enumerate(ba)]) + + +def inputs_is_bits(bits_array): + for b in bits_array: + if b not in [0, 1]: + return False From cb3af7e9eafd587d0c547586dc8d09e0fdd72b75 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20GRISOT?= Date: Mon, 19 Sep 2022 15:33:37 +0200 Subject: [PATCH 09/13] Fixes bits check --- converter.py | 1 + 1 file changed, 1 insertion(+) diff --git a/converter.py b/converter.py index f08f3e9..5b9ef71 100644 --- a/converter.py +++ b/converter.py @@ -32,3 +32,4 @@ def inputs_is_bits(bits_array): for b in bits_array: if b not in [0, 1]: return False + return True From 7a6358adf655f62500bf4252d945541197582e4e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20GRISOT?= Date: Thu, 22 Sep 2022 10:30:34 +0200 Subject: [PATCH 10/13] Adds UT for converter --- test_converter.py | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) create mode 100644 test_converter.py diff --git a/test_converter.py b/test_converter.py new file mode 100644 index 0000000..ae6319a --- /dev/null +++ b/test_converter.py @@ -0,0 +1,29 @@ +from unittest import TestCase + +from converter import dec_to_bin, bin_to_dec + + +class TestConverter(TestCase): + def test_dec_to_bin_even(self): + n = 10 + expected = [1, 0, 1, 0] + self.assertListEqual(expected, dec_to_bin(n)) + + def test_dec_to_bin_odd(self): + n = 37 + expected = [1, 0, 0, 1, 0, 1] + self.assertListEqual(expected, dec_to_bin(n)) + + def test_bin_to_dec_odd(self): + bits = [1, 0, 0, 1, 0, 1] + expected = 37 + self.assertEqual(expected, bin_to_dec(bits)) + + def test_bin_to_dec_even(self): + bits = [1, 0, 1, 0] + expected = 10 + self.assertEqual(expected, bin_to_dec(bits)) + + def test_reverse(self): + n = 135 + self.assertEqual(n, bin_to_dec(dec_to_bin(n))) From 9d3866f60cea1bf58fb743cdcbd2701020f99a27 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20GRISOT?= Date: Thu, 22 Sep 2022 10:31:58 +0200 Subject: [PATCH 11/13] Fix converter bugs --- converter.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/converter.py b/converter.py index 5b9ef71..5735f4e 100644 --- a/converter.py +++ b/converter.py @@ -11,7 +11,7 @@ def dec_to_bin(n: int) -> List[int]: raise ValueError("n should be positive") bit = [0 if n % 2 == 0 else 1] - return bit if n <= 1 else dec_to_bin(n >> 2) + bit + return bit if n <= 1 else dec_to_bin(n >> 1) + bit def bin_to_dec(bits_array: List[int]) -> int: @@ -25,7 +25,7 @@ def bin_to_dec(bits_array: List[int]) -> int: ba = bits_array.copy() ba.reverse() - return sum([1 << i * m for i, m in enumerate(ba)]) + return sum([(1 << i) * m for i, m in enumerate(ba)]) def inputs_is_bits(bits_array): From b8f657f509b332e2453be1347cea98db04b062f7 Mon Sep 17 00:00:00 2001 From: Awwatts Date: Wed, 28 Sep 2022 09:47:45 +0200 Subject: [PATCH 12/13] activate py --- myvenv/bin/Activate.ps1 | 247 +++++++++++++++++++++++++++++++++++++++ myvenv/bin/activate | 69 +++++++++++ myvenv/bin/activate.csh | 26 +++++ myvenv/bin/activate.fish | 66 +++++++++++ myvenv/bin/pip | 8 ++ myvenv/bin/pip3 | 8 ++ myvenv/bin/pip3.10 | 8 ++ myvenv/bin/py.test | 8 ++ myvenv/bin/pytest | 8 ++ myvenv/bin/python | 1 + myvenv/bin/python3 | 1 + myvenv/bin/python3.10 | 1 + myvenv/pyvenv.cfg | 3 + 13 files changed, 454 insertions(+) create mode 100644 myvenv/bin/Activate.ps1 create mode 100644 myvenv/bin/activate create mode 100644 myvenv/bin/activate.csh create mode 100644 myvenv/bin/activate.fish create mode 100755 myvenv/bin/pip create mode 100755 myvenv/bin/pip3 create mode 100755 myvenv/bin/pip3.10 create mode 100755 myvenv/bin/py.test create mode 100755 myvenv/bin/pytest create mode 120000 myvenv/bin/python create mode 120000 myvenv/bin/python3 create mode 120000 myvenv/bin/python3.10 create mode 100644 myvenv/pyvenv.cfg diff --git a/myvenv/bin/Activate.ps1 b/myvenv/bin/Activate.ps1 new file mode 100644 index 0000000..eeea358 --- /dev/null +++ b/myvenv/bin/Activate.ps1 @@ -0,0 +1,247 @@ +<# +.Synopsis +Activate a Python virtual environment for the current PowerShell session. + +.Description +Pushes the python executable for a virtual environment to the front of the +$Env:PATH environment variable and sets the prompt to signify that you are +in a Python virtual environment. Makes use of the command line switches as +well as the `pyvenv.cfg` file values present in the virtual environment. + +.Parameter VenvDir +Path to the directory that contains the virtual environment to activate. The +default value for this is the parent of the directory that the Activate.ps1 +script is located within. + +.Parameter Prompt +The prompt prefix to display when this virtual environment is activated. By +default, this prompt is the name of the virtual environment folder (VenvDir) +surrounded by parentheses and followed by a single space (ie. '(.venv) '). + +.Example +Activate.ps1 +Activates the Python virtual environment that contains the Activate.ps1 script. + +.Example +Activate.ps1 -Verbose +Activates the Python virtual environment that contains the Activate.ps1 script, +and shows extra information about the activation as it executes. + +.Example +Activate.ps1 -VenvDir C:\Users\MyUser\Common\.venv +Activates the Python virtual environment located in the specified location. + +.Example +Activate.ps1 -Prompt "MyPython" +Activates the Python virtual environment that contains the Activate.ps1 script, +and prefixes the current prompt with the specified string (surrounded in +parentheses) while the virtual environment is active. + +.Notes +On Windows, it may be required to enable this Activate.ps1 script by setting the +execution policy for the user. You can do this by issuing the following PowerShell +command: + +PS C:\> Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser + +For more information on Execution Policies: +https://go.microsoft.com/fwlink/?LinkID=135170 + +#> +Param( + [Parameter(Mandatory = $false)] + [String] + $VenvDir, + [Parameter(Mandatory = $false)] + [String] + $Prompt +) + +<# Function declarations --------------------------------------------------- #> + +<# +.Synopsis +Remove all shell session elements added by the Activate script, including the +addition of the virtual environment's Python executable from the beginning of +the PATH variable. + +.Parameter NonDestructive +If present, do not remove this function from the global namespace for the +session. + +#> +function global:deactivate ([switch]$NonDestructive) { + # Revert to original values + + # The prior prompt: + if (Test-Path -Path Function:_OLD_VIRTUAL_PROMPT) { + Copy-Item -Path Function:_OLD_VIRTUAL_PROMPT -Destination Function:prompt + Remove-Item -Path Function:_OLD_VIRTUAL_PROMPT + } + + # The prior PYTHONHOME: + if (Test-Path -Path Env:_OLD_VIRTUAL_PYTHONHOME) { + Copy-Item -Path Env:_OLD_VIRTUAL_PYTHONHOME -Destination Env:PYTHONHOME + Remove-Item -Path Env:_OLD_VIRTUAL_PYTHONHOME + } + + # The prior PATH: + if (Test-Path -Path Env:_OLD_VIRTUAL_PATH) { + Copy-Item -Path Env:_OLD_VIRTUAL_PATH -Destination Env:PATH + Remove-Item -Path Env:_OLD_VIRTUAL_PATH + } + + # Just remove the VIRTUAL_ENV altogether: + if (Test-Path -Path Env:VIRTUAL_ENV) { + Remove-Item -Path env:VIRTUAL_ENV + } + + # Just remove VIRTUAL_ENV_PROMPT altogether. + if (Test-Path -Path Env:VIRTUAL_ENV_PROMPT) { + Remove-Item -Path env:VIRTUAL_ENV_PROMPT + } + + # Just remove the _PYTHON_VENV_PROMPT_PREFIX altogether: + if (Get-Variable -Name "_PYTHON_VENV_PROMPT_PREFIX" -ErrorAction SilentlyContinue) { + Remove-Variable -Name _PYTHON_VENV_PROMPT_PREFIX -Scope Global -Force + } + + # Leave deactivate function in the global namespace if requested: + if (-not $NonDestructive) { + Remove-Item -Path function:deactivate + } +} + +<# +.Description +Get-PyVenvConfig parses the values from the pyvenv.cfg file located in the +given folder, and returns them in a map. + +For each line in the pyvenv.cfg file, if that line can be parsed into exactly +two strings separated by `=` (with any amount of whitespace surrounding the =) +then it is considered a `key = value` line. The left hand string is the key, +the right hand is the value. + +If the value starts with a `'` or a `"` then the first and last character is +stripped from the value before being captured. + +.Parameter ConfigDir +Path to the directory that contains the `pyvenv.cfg` file. +#> +function Get-PyVenvConfig( + [String] + $ConfigDir +) { + Write-Verbose "Given ConfigDir=$ConfigDir, obtain values in pyvenv.cfg" + + # Ensure the file exists, and issue a warning if it doesn't (but still allow the function to continue). + $pyvenvConfigPath = Join-Path -Resolve -Path $ConfigDir -ChildPath 'pyvenv.cfg' -ErrorAction Continue + + # An empty map will be returned if no config file is found. + $pyvenvConfig = @{ } + + if ($pyvenvConfigPath) { + + Write-Verbose "File exists, parse `key = value` lines" + $pyvenvConfigContent = Get-Content -Path $pyvenvConfigPath + + $pyvenvConfigContent | ForEach-Object { + $keyval = $PSItem -split "\s*=\s*", 2 + if ($keyval[0] -and $keyval[1]) { + $val = $keyval[1] + + # Remove extraneous quotations around a string value. + if ("'""".Contains($val.Substring(0, 1))) { + $val = $val.Substring(1, $val.Length - 2) + } + + $pyvenvConfig[$keyval[0]] = $val + Write-Verbose "Adding Key: '$($keyval[0])'='$val'" + } + } + } + return $pyvenvConfig +} + + +<# Begin Activate script --------------------------------------------------- #> + +# Determine the containing directory of this script +$VenvExecPath = Split-Path -Parent $MyInvocation.MyCommand.Definition +$VenvExecDir = Get-Item -Path $VenvExecPath + +Write-Verbose "Activation script is located in path: '$VenvExecPath'" +Write-Verbose "VenvExecDir Fullname: '$($VenvExecDir.FullName)" +Write-Verbose "VenvExecDir Name: '$($VenvExecDir.Name)" + +# Set values required in priority: CmdLine, ConfigFile, Default +# First, get the location of the virtual environment, it might not be +# VenvExecDir if specified on the command line. +if ($VenvDir) { + Write-Verbose "VenvDir given as parameter, using '$VenvDir' to determine values" +} +else { + Write-Verbose "VenvDir not given as a parameter, using parent directory name as VenvDir." + $VenvDir = $VenvExecDir.Parent.FullName.TrimEnd("\\/") + Write-Verbose "VenvDir=$VenvDir" +} + +# Next, read the `pyvenv.cfg` file to determine any required value such +# as `prompt`. +$pyvenvCfg = Get-PyVenvConfig -ConfigDir $VenvDir + +# Next, set the prompt from the command line, or the config file, or +# just use the name of the virtual environment folder. +if ($Prompt) { + Write-Verbose "Prompt specified as argument, using '$Prompt'" +} +else { + Write-Verbose "Prompt not specified as argument to script, checking pyvenv.cfg value" + if ($pyvenvCfg -and $pyvenvCfg['prompt']) { + Write-Verbose " Setting based on value in pyvenv.cfg='$($pyvenvCfg['prompt'])'" + $Prompt = $pyvenvCfg['prompt']; + } + else { + Write-Verbose " Setting prompt based on parent's directory's name. (Is the directory name passed to venv module when creating the virtual environment)" + Write-Verbose " Got leaf-name of $VenvDir='$(Split-Path -Path $venvDir -Leaf)'" + $Prompt = Split-Path -Path $venvDir -Leaf + } +} + +Write-Verbose "Prompt = '$Prompt'" +Write-Verbose "VenvDir='$VenvDir'" + +# Deactivate any currently active virtual environment, but leave the +# deactivate function in place. +deactivate -nondestructive + +# Now set the environment variable VIRTUAL_ENV, used by many tools to determine +# that there is an activated venv. +$env:VIRTUAL_ENV = $VenvDir + +if (-not $Env:VIRTUAL_ENV_DISABLE_PROMPT) { + + Write-Verbose "Setting prompt to '$Prompt'" + + # Set the prompt to include the env name + # Make sure _OLD_VIRTUAL_PROMPT is global + function global:_OLD_VIRTUAL_PROMPT { "" } + Copy-Item -Path function:prompt -Destination function:_OLD_VIRTUAL_PROMPT + New-Variable -Name _PYTHON_VENV_PROMPT_PREFIX -Description "Python virtual environment prompt prefix" -Scope Global -Option ReadOnly -Visibility Public -Value $Prompt + + function global:prompt { + Write-Host -NoNewline -ForegroundColor Green "($_PYTHON_VENV_PROMPT_PREFIX) " + _OLD_VIRTUAL_PROMPT + } + $env:VIRTUAL_ENV_PROMPT = $Prompt +} + +# Clear PYTHONHOME +if (Test-Path -Path Env:PYTHONHOME) { + Copy-Item -Path Env:PYTHONHOME -Destination Env:_OLD_VIRTUAL_PYTHONHOME + Remove-Item -Path Env:PYTHONHOME +} + +# Add the venv to the PATH +Copy-Item -Path Env:PATH -Destination Env:_OLD_VIRTUAL_PATH +$Env:PATH = "$VenvExecDir$([System.IO.Path]::PathSeparator)$Env:PATH" diff --git a/myvenv/bin/activate b/myvenv/bin/activate new file mode 100644 index 0000000..a2e8865 --- /dev/null +++ b/myvenv/bin/activate @@ -0,0 +1,69 @@ +# This file must be used with "source bin/activate" *from bash* +# you cannot run it directly + +deactivate () { + # reset old environment variables + if [ -n "${_OLD_VIRTUAL_PATH:-}" ] ; then + PATH="${_OLD_VIRTUAL_PATH:-}" + export PATH + unset _OLD_VIRTUAL_PATH + fi + if [ -n "${_OLD_VIRTUAL_PYTHONHOME:-}" ] ; then + PYTHONHOME="${_OLD_VIRTUAL_PYTHONHOME:-}" + export PYTHONHOME + unset _OLD_VIRTUAL_PYTHONHOME + fi + + # This should detect bash and zsh, which have a hash command that must + # be called to get it to forget past commands. Without forgetting + # past commands the $PATH changes we made may not be respected + if [ -n "${BASH:-}" -o -n "${ZSH_VERSION:-}" ] ; then + hash -r 2> /dev/null + fi + + if [ -n "${_OLD_VIRTUAL_PS1:-}" ] ; then + PS1="${_OLD_VIRTUAL_PS1:-}" + export PS1 + unset _OLD_VIRTUAL_PS1 + fi + + unset VIRTUAL_ENV + unset VIRTUAL_ENV_PROMPT + if [ ! "${1:-}" = "nondestructive" ] ; then + # Self destruct! + unset -f deactivate + fi +} + +# unset irrelevant variables +deactivate nondestructive + +VIRTUAL_ENV="/Users/baptiste/Library/CloudStorage/OneDrive-yncréa/ISEN/ISEN-Cours/M1/Semestre1/Github/M1-2022-git-workflow/myvenv" +export VIRTUAL_ENV + +_OLD_VIRTUAL_PATH="$PATH" +PATH="$VIRTUAL_ENV/bin:$PATH" +export PATH + +# unset PYTHONHOME if set +# this will fail if PYTHONHOME is set to the empty string (which is bad anyway) +# could use `if (set -u; : $PYTHONHOME) ;` in bash +if [ -n "${PYTHONHOME:-}" ] ; then + _OLD_VIRTUAL_PYTHONHOME="${PYTHONHOME:-}" + unset PYTHONHOME +fi + +if [ -z "${VIRTUAL_ENV_DISABLE_PROMPT:-}" ] ; then + _OLD_VIRTUAL_PS1="${PS1:-}" + PS1="(myvenv) ${PS1:-}" + export PS1 + VIRTUAL_ENV_PROMPT="(myvenv) " + export VIRTUAL_ENV_PROMPT +fi + +# This should detect bash and zsh, which have a hash command that must +# be called to get it to forget past commands. Without forgetting +# past commands the $PATH changes we made may not be respected +if [ -n "${BASH:-}" -o -n "${ZSH_VERSION:-}" ] ; then + hash -r 2> /dev/null +fi diff --git a/myvenv/bin/activate.csh b/myvenv/bin/activate.csh new file mode 100644 index 0000000..ae3d384 --- /dev/null +++ b/myvenv/bin/activate.csh @@ -0,0 +1,26 @@ +# This file must be used with "source bin/activate.csh" *from csh*. +# You cannot run it directly. +# Created by Davide Di Blasi . +# Ported to Python 3.3 venv by Andrew Svetlov + +alias deactivate 'test $?_OLD_VIRTUAL_PATH != 0 && setenv PATH "$_OLD_VIRTUAL_PATH" && unset _OLD_VIRTUAL_PATH; rehash; test $?_OLD_VIRTUAL_PROMPT != 0 && set prompt="$_OLD_VIRTUAL_PROMPT" && unset _OLD_VIRTUAL_PROMPT; unsetenv VIRTUAL_ENV; unsetenv VIRTUAL_ENV_PROMPT; test "\!:*" != "nondestructive" && unalias deactivate' + +# Unset irrelevant variables. +deactivate nondestructive + +setenv VIRTUAL_ENV "/Users/baptiste/Library/CloudStorage/OneDrive-yncréa/ISEN/ISEN-Cours/M1/Semestre1/Github/M1-2022-git-workflow/myvenv" + +set _OLD_VIRTUAL_PATH="$PATH" +setenv PATH "$VIRTUAL_ENV/bin:$PATH" + + +set _OLD_VIRTUAL_PROMPT="$prompt" + +if (! "$?VIRTUAL_ENV_DISABLE_PROMPT") then + set prompt = "(myvenv) $prompt" + setenv VIRTUAL_ENV_PROMPT "(myvenv) " +endif + +alias pydoc python -m pydoc + +rehash diff --git a/myvenv/bin/activate.fish b/myvenv/bin/activate.fish new file mode 100644 index 0000000..008c386 --- /dev/null +++ b/myvenv/bin/activate.fish @@ -0,0 +1,66 @@ +# This file must be used with "source /bin/activate.fish" *from fish* +# (https://fishshell.com/); you cannot run it directly. + +function deactivate -d "Exit virtual environment and return to normal shell environment" + # reset old environment variables + if test -n "$_OLD_VIRTUAL_PATH" + set -gx PATH $_OLD_VIRTUAL_PATH + set -e _OLD_VIRTUAL_PATH + end + if test -n "$_OLD_VIRTUAL_PYTHONHOME" + set -gx PYTHONHOME $_OLD_VIRTUAL_PYTHONHOME + set -e _OLD_VIRTUAL_PYTHONHOME + end + + if test -n "$_OLD_FISH_PROMPT_OVERRIDE" + functions -e fish_prompt + set -e _OLD_FISH_PROMPT_OVERRIDE + functions -c _old_fish_prompt fish_prompt + functions -e _old_fish_prompt + end + + set -e VIRTUAL_ENV + set -e VIRTUAL_ENV_PROMPT + if test "$argv[1]" != "nondestructive" + # Self-destruct! + functions -e deactivate + end +end + +# Unset irrelevant variables. +deactivate nondestructive + +set -gx VIRTUAL_ENV "/Users/baptiste/Library/CloudStorage/OneDrive-yncréa/ISEN/ISEN-Cours/M1/Semestre1/Github/M1-2022-git-workflow/myvenv" + +set -gx _OLD_VIRTUAL_PATH $PATH +set -gx PATH "$VIRTUAL_ENV/bin" $PATH + +# Unset PYTHONHOME if set. +if set -q PYTHONHOME + set -gx _OLD_VIRTUAL_PYTHONHOME $PYTHONHOME + set -e PYTHONHOME +end + +if test -z "$VIRTUAL_ENV_DISABLE_PROMPT" + # fish uses a function instead of an env var to generate the prompt. + + # Save the current fish_prompt function as the function _old_fish_prompt. + functions -c fish_prompt _old_fish_prompt + + # With the original prompt function renamed, we can override with our own. + function fish_prompt + # Save the return status of the last command. + set -l old_status $status + + # Output the venv prompt; color taken from the blue of the Python logo. + printf "%s%s%s" (set_color 4B8BBE) "(myvenv) " (set_color normal) + + # Restore the return status of the previous command. + echo "exit $old_status" | . + # Output the original/"old" prompt. + _old_fish_prompt + end + + set -gx _OLD_FISH_PROMPT_OVERRIDE "$VIRTUAL_ENV" + set -gx VIRTUAL_ENV_PROMPT "(myvenv) " +end diff --git a/myvenv/bin/pip b/myvenv/bin/pip new file mode 100755 index 0000000..56d1384 --- /dev/null +++ b/myvenv/bin/pip @@ -0,0 +1,8 @@ +#!/Users/baptiste/Library/CloudStorage/OneDrive-yncréa/ISEN/ISEN-Cours/M1/Semestre1/Github/M1-2022-git-workflow/myvenv/bin/python3 +# -*- coding: utf-8 -*- +import re +import sys +from pip._internal.cli.main import main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/myvenv/bin/pip3 b/myvenv/bin/pip3 new file mode 100755 index 0000000..56d1384 --- /dev/null +++ b/myvenv/bin/pip3 @@ -0,0 +1,8 @@ +#!/Users/baptiste/Library/CloudStorage/OneDrive-yncréa/ISEN/ISEN-Cours/M1/Semestre1/Github/M1-2022-git-workflow/myvenv/bin/python3 +# -*- coding: utf-8 -*- +import re +import sys +from pip._internal.cli.main import main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/myvenv/bin/pip3.10 b/myvenv/bin/pip3.10 new file mode 100755 index 0000000..56d1384 --- /dev/null +++ b/myvenv/bin/pip3.10 @@ -0,0 +1,8 @@ +#!/Users/baptiste/Library/CloudStorage/OneDrive-yncréa/ISEN/ISEN-Cours/M1/Semestre1/Github/M1-2022-git-workflow/myvenv/bin/python3 +# -*- coding: utf-8 -*- +import re +import sys +from pip._internal.cli.main import main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/myvenv/bin/py.test b/myvenv/bin/py.test new file mode 100755 index 0000000..7e58042 --- /dev/null +++ b/myvenv/bin/py.test @@ -0,0 +1,8 @@ +#!/Users/baptiste/Library/CloudStorage/OneDrive-yncréa/ISEN/ISEN-Cours/M1/Semestre1/Github/M1-2022-git-workflow/myvenv/bin/python3 +# -*- coding: utf-8 -*- +import re +import sys +from pytest import console_main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(console_main()) diff --git a/myvenv/bin/pytest b/myvenv/bin/pytest new file mode 100755 index 0000000..7e58042 --- /dev/null +++ b/myvenv/bin/pytest @@ -0,0 +1,8 @@ +#!/Users/baptiste/Library/CloudStorage/OneDrive-yncréa/ISEN/ISEN-Cours/M1/Semestre1/Github/M1-2022-git-workflow/myvenv/bin/python3 +# -*- coding: utf-8 -*- +import re +import sys +from pytest import console_main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(console_main()) diff --git a/myvenv/bin/python b/myvenv/bin/python new file mode 120000 index 0000000..b8a0adb --- /dev/null +++ b/myvenv/bin/python @@ -0,0 +1 @@ +python3 \ No newline at end of file diff --git a/myvenv/bin/python3 b/myvenv/bin/python3 new file mode 120000 index 0000000..1ec499c --- /dev/null +++ b/myvenv/bin/python3 @@ -0,0 +1 @@ +/Library/Frameworks/Python.framework/Versions/3.10/bin/python3 \ No newline at end of file diff --git a/myvenv/bin/python3.10 b/myvenv/bin/python3.10 new file mode 120000 index 0000000..b8a0adb --- /dev/null +++ b/myvenv/bin/python3.10 @@ -0,0 +1 @@ +python3 \ No newline at end of file diff --git a/myvenv/pyvenv.cfg b/myvenv/pyvenv.cfg new file mode 100644 index 0000000..158aefd --- /dev/null +++ b/myvenv/pyvenv.cfg @@ -0,0 +1,3 @@ +home = /Library/Frameworks/Python.framework/Versions/3.10/bin +include-system-site-packages = false +version = 3.10.7 From 7230a6bf69116350e9d023433ccbc19126a4d176 Mon Sep 17 00:00:00 2001 From: Awwatts Date: Wed, 28 Sep 2022 09:56:15 +0200 Subject: [PATCH 13/13] Create python-publish.yml --- .github/workflows/python-publish.yml | 41 ++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 .github/workflows/python-publish.yml diff --git a/.github/workflows/python-publish.yml b/.github/workflows/python-publish.yml new file mode 100644 index 0000000..a21fd5e --- /dev/null +++ b/.github/workflows/python-publish.yml @@ -0,0 +1,41 @@ +# This workflow will upload a Python Package using Twine when a release is created +# For more information see: https://help.github.com/en/actions/language-and-framework-guides/using-python-with-github-actions#publishing-to-package-registries + +# This workflow uses actions that are not certified by GitHub. +# They are provided by a third-party and are governed by +# separate terms of service, privacy policy, and support +# documentation. + +name: Upload Python Package + +on: + release: + types: [published] + +permissions: + contents: read + +jobs: + deploy: + + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v3 + - name: Set up Python + uses: actions/setup-python@v3 + with: + python-version: '3.x' + - name: Install dependencies + run: | + python -m pip install --upgrade pip + pip install build + - name: Build package + run: python -m build + - name : test pacakge + run : test_converter.py + - name: Publish package + uses: pypa/gh-action-pypi-publish@27b31702a0e7fc50959f5ad993c78deac1bdfc29 + with: + user: __token__ + password: ${{ secrets.PYPI_API_TOKEN }}