Merge pull request #155 from basxto/v115_linux_changes
Export with Linux variables
This commit is contained in:
+87
-61
@@ -12,7 +12,6 @@ Public Class mgrPath
|
||||
Private Shared sLogFile As String = sSettingsRoot & Path.DirectorySeparatorChar & "gbm_log_" & Date.Now.ToString("dd-MM-yyyy-HH-mm-ss") & ".txt"
|
||||
Private Shared sRemoteDatabaseLocation As String
|
||||
Private Shared hshCustomVariables As Hashtable
|
||||
Private Shared hshUnixEnv As Hashtable
|
||||
Private Shared oReleaseType As ProcessorArchitecture = AssemblyName.GetAssemblyName(Application.ExecutablePath()).ProcessorArchitecture
|
||||
|
||||
Shared Sub New()
|
||||
@@ -331,61 +330,62 @@ Public Class mgrPath
|
||||
If Not mgrCommon.IsUnix Then
|
||||
Environment.SetEnvironmentVariable("USERDOCUMENTS", Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments))
|
||||
Environment.SetEnvironmentVariable("COMMONDOCUMENTS", Environment.GetFolderPath(Environment.SpecialFolder.CommonDocuments))
|
||||
Else
|
||||
GetUnixEnv()
|
||||
Environment.SetEnvironmentVariable("USERDOCUMENTS", Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments))
|
||||
Environment.SetEnvironmentVariable("APPDATA", Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData))
|
||||
Environment.SetEnvironmentVariable("LOCALAPPDATA", Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData))
|
||||
End If
|
||||
|
||||
End Sub
|
||||
|
||||
Private Shared Sub GetUnixEnv()
|
||||
Dim prEnv As Process
|
||||
Dim sEnv As String()
|
||||
|
||||
Try
|
||||
hshUnixEnv = New Hashtable
|
||||
prEnv = New Process
|
||||
prEnv.StartInfo.FileName = "/usr/bin/env"
|
||||
prEnv.StartInfo.UseShellExecute = False
|
||||
prEnv.StartInfo.RedirectStandardOutput = True
|
||||
prEnv.StartInfo.CreateNoWindow = True
|
||||
prEnv.Start()
|
||||
|
||||
Using swEnv As StreamReader = prEnv.StandardOutput
|
||||
While Not swEnv.EndOfStream
|
||||
sEnv = swEnv.ReadLine().Split("=")
|
||||
If Not hshUnixEnv.Contains(sEnv(0)) Then
|
||||
hshUnixEnv.Add(sEnv(0), sEnv(1))
|
||||
End If
|
||||
End While
|
||||
End Using
|
||||
Catch ex As Exception
|
||||
mgrCommon.ShowMessage(mgrPath_ErrorUnixEnv, ex.Message, MsgBoxStyle.Exclamation)
|
||||
End Try
|
||||
End Sub
|
||||
|
||||
Private Shared Function ProcessEnvironmentVariables(ByVal sValue As String) As String
|
||||
Dim sUnixShortHome As String = "~"
|
||||
Dim sEnvUnixHome As String = Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments)
|
||||
Dim sCurrentUnixVar As String
|
||||
Dim sXdgData As String = "${XDG_DATA_HOME:-~/.local/share}"
|
||||
Dim sEnvAppDataLocal As String = Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData)
|
||||
Dim sXdgConfig As String = "${XDG_CONFIG_HOME:-~/.config}"
|
||||
Dim sEnvAppDataRoaming As String = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData)
|
||||
Dim sHomeDir As String = "${HOME}"
|
||||
Dim sEnvCurrentUser As String = Environment.GetFolderPath(Environment.SpecialFolder.UserProfile)
|
||||
|
||||
If mgrCommon.IsUnix Then
|
||||
'Replace ~ for HOME
|
||||
If sValue.Contains(sUnixShortHome) Then
|
||||
Return sValue.Replace(sUnixShortHome, sEnvUnixHome)
|
||||
'$VAR_iable
|
||||
Dim oParse As new Regex("\$([a-zA-Z0-9_]+)")
|
||||
'${VAR_iable} but not advanced syntax like ${VAR:-iable}
|
||||
Dim oParseBracketed As new Regex("\$\{([a-zA-Z0-9_]+?)\}")
|
||||
'~ not inside ${...}
|
||||
Dim oParseTilde As new Regex("~(?![^\$\{]*\})")
|
||||
If sEnvCurrentUser = String.Empty Then
|
||||
'Fall back
|
||||
sEnvCurrentUser = Environment.GetFolderPath(Environment.SpecialFolder.Personal)
|
||||
End If
|
||||
If sEnvCurrentUser = String.Empty Then
|
||||
'Fall back
|
||||
sEnvCurrentUser = Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments)
|
||||
End If
|
||||
|
||||
'Replace any other environemnt variable
|
||||
For Each de As DictionaryEntry In hshUnixEnv
|
||||
sCurrentUnixVar = "$" & de.Key
|
||||
If sValue.Contains(sCurrentUnixVar) Then
|
||||
sValue = sValue.Replace(sCurrentUnixVar, de.Value)
|
||||
End If
|
||||
Next
|
||||
Else
|
||||
sValue = Environment.ExpandEnvironmentVariables(sValue)
|
||||
'$HOME to ${HOME}
|
||||
sValue = oParse.Replace(sValue, "${$1}")
|
||||
'Special notations for home directory
|
||||
sValue = oParseTilde.Replace(sValue,"${HOME}")
|
||||
'XDG Base Directory Specification has default values
|
||||
sValue = sValue.Replace("${XDG_DATA_HOME}", sXdgData)
|
||||
sValue = sValue.Replace("${XDG_CONFIG_HOME}", sXdgConfig)
|
||||
|
||||
'Replace with paths
|
||||
sValue = sValue.Replace(sXdgData, sEnvAppDataLocal)
|
||||
sValue = sValue.Replace(sXdgConfig, sEnvAppDataRoaming)
|
||||
sValue = sValue.Replace(sHomeDir, sEnvCurrentUser)
|
||||
|
||||
'Escape real Windows variables
|
||||
sValue = sValue.Replace("%", "\%")
|
||||
'Transform Linux variables to Windows variables
|
||||
sValue = oParseBracketed.Replace(sValue, "%$1%")
|
||||
End If
|
||||
|
||||
'On Linux real Linux environmental variables are used
|
||||
sValue = Environment.ExpandEnvironmentVariables(sValue)
|
||||
|
||||
If mgrCommon.IsUnix Then
|
||||
'Transform missing variables back
|
||||
Dim oParse As new Regex("%([a-zA-Z0-9_]+?)%")
|
||||
sValue = oParse.Replace(sValue, "${$1}")
|
||||
'Unscape real Windows variables
|
||||
sValue = sValue.Replace("\%", "%")
|
||||
End If
|
||||
|
||||
Return sValue
|
||||
@@ -397,36 +397,40 @@ Public Class mgrPath
|
||||
Dim sPublicDocs As String = "%COMMONDOCUMENTS%"
|
||||
Dim sEnvPublicDocs As String = Environment.GetFolderPath(Environment.SpecialFolder.CommonDocuments)
|
||||
Dim sAppDataLocal As String = "%LOCALAPPDATA%"
|
||||
Dim sXdgData As String = "${XDG_DATA_HOME:-~/.local/share}"
|
||||
Dim sEnvAppDataLocal As String = Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData)
|
||||
Dim sAppDataRoaming As String = "%APPDATA%"
|
||||
Dim sXdgConfig As String = "${XDG_CONFIG_HOME:-~/.config}"
|
||||
Dim sEnvAppDataRoaming As String = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData)
|
||||
Dim sCurrentUser As String = "%USERPROFILE%"
|
||||
Dim sHomeDir As String = "~"
|
||||
Dim sEnvCurrentUser As String = Environment.GetFolderPath(Environment.SpecialFolder.UserProfile)
|
||||
Dim oCustomVariable As clsPathVariable
|
||||
|
||||
sValue = ProcessEnvironmentVariables(sValue)
|
||||
|
||||
|
||||
For Each oCustomVariable In hshCustomVariables.Values
|
||||
If sValue.Contains(oCustomVariable.Path) Then
|
||||
Return sValue.Replace(oCustomVariable.Path, oCustomVariable.FormattedName)
|
||||
End If
|
||||
Next
|
||||
|
||||
If sValue.Contains(sEnvAppDataRoaming) Then
|
||||
Return sValue.Replace(sEnvAppDataRoaming, sAppDataRoaming)
|
||||
End If
|
||||
|
||||
If sValue.Contains(sEnvAppDataLocal) Then
|
||||
Return sValue.Replace(sEnvAppDataLocal, sAppDataLocal)
|
||||
End If
|
||||
|
||||
'This needs to be tested last for Unix compatability
|
||||
If sValue.Contains(sEnvMyDocs) Then
|
||||
Return sValue.Replace(sEnvMyDocs, sMyDocs)
|
||||
End If
|
||||
|
||||
'Mono doesn't set a path for these folders
|
||||
If Not mgrCommon.IsUnix Then
|
||||
If sValue.Contains(sEnvAppDataRoaming) Then
|
||||
Return sValue.Replace(sEnvAppDataRoaming, sAppDataRoaming)
|
||||
End If
|
||||
|
||||
If sValue.Contains(sEnvAppDataLocal) Then
|
||||
Return sValue.Replace(sEnvAppDataLocal, sAppDataLocal)
|
||||
End If
|
||||
|
||||
'This needs to be tested last for Unix compatability
|
||||
If sValue.Contains(sEnvMyDocs) Then
|
||||
Return sValue.Replace(sEnvMyDocs, sMyDocs)
|
||||
End If
|
||||
|
||||
'Mono doesn't set a path for these folders
|
||||
If sValue.Contains(sEnvPublicDocs) Then
|
||||
Return sValue.Replace(sEnvPublicDocs, sPublicDocs)
|
||||
End If
|
||||
@@ -434,6 +438,28 @@ Public Class mgrPath
|
||||
If sValue.Contains(sEnvCurrentUser) Then
|
||||
Return sValue.Replace(sEnvCurrentUser, sCurrentUser)
|
||||
End If
|
||||
Else
|
||||
'Use different paths on Linux
|
||||
If sValue.Contains(sEnvAppDataRoaming) Then
|
||||
Return sValue.Replace(sEnvAppDataRoaming, sXdgConfig)
|
||||
End If
|
||||
|
||||
If sValue.Contains(sEnvAppDataLocal) Then
|
||||
Return sValue.Replace(sEnvAppDataLocal, sXdgData)
|
||||
End If
|
||||
|
||||
'Must be last
|
||||
If sValue.Contains(sEnvCurrentUser) Then
|
||||
If sEnvCurrentUser = String.Empty Then
|
||||
'Fall back
|
||||
sEnvCurrentUser = Environment.GetFolderPath(Environment.SpecialFolder.Personal)
|
||||
End If
|
||||
If sEnvCurrentUser = String.Empty Then
|
||||
'Fall back
|
||||
sEnvCurrentUser = sMyDocs
|
||||
End If
|
||||
Return sValue.Replace(sEnvCurrentUser, sHomeDir)
|
||||
End If
|
||||
End If
|
||||
|
||||
Return sValue
|
||||
|
||||
Reference in New Issue
Block a user