summarylogtreecommitdiffstats
path: root/github-desktop.patch
blob: ae28d847d9a3b004e4fa4f97035fe4b62bc0a863 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
diff -ura orig/app/src/lib/shells/linux.ts new/app/src/lib/shells/linux.ts
--- orig/app/src/lib/shells/linux.ts	2017-11-16 13:55:35.000000000 -0800
+++ new/app/src/lib/shells/linux.ts	2017-11-17 05:27:59.832386000 -0800
@@ -6,11 +6,13 @@
 export enum Shell {
   Gnome = 'GNOME Terminal',
   Tilix = 'Tilix',
+  Urxvt = 'URxvt',
 }

-export const Default = Shell.Gnome
+export const Default = Shell.Urxvt

 export function parse(label: string): Shell {
+
   if (label === Shell.Gnome) {
     return Shell.Gnome
   }
@@ -19,6 +21,10 @@
     return Shell.Tilix
   }

+  if (label === Shell.Urxvt) {
+    return Shell.Urxvt
+  }
+
   return Default
 }

@@ -32,6 +38,8 @@
       return getPathIfAvailable('/usr/bin/gnome-terminal')
     case Shell.Tilix:
       return getPathIfAvailable('/usr/bin/tilix')
+    case Shell.Urxvt:
+      return getPathIfAvailable('/usr/bin/urxvt')
     default:
       return assertNever(shell, `Unknown shell: ${shell}`)
   }
@@ -40,9 +48,10 @@
 export async function getAvailableShells(): Promise<
   ReadonlyArray<IFoundShell<Shell>>
 > {
-  const [gnomeTerminalPath, tilixPath] = await Promise.all([
+  const [gnomeTerminalPath, tilixPath, urxvtPath] = await Promise.all([
     getShellPath(Shell.Gnome),
     getShellPath(Shell.Tilix),
+    getShellPath(Shell.Urxvt),
   ])

   const shells: Array<IFoundShell<Shell>> = []
@@ -54,6 +63,10 @@
     shells.push({ shell: Shell.Tilix, path: tilixPath })
   }

+  if (urxvtPath) {
+    shells.push({ shell: Shell.Urxvt, path: urxvtPath })
+  }
+
   return shells
 }

@@ -61,6 +74,11 @@
   shell: IFoundShell<Shell>,
   path: string
 ): Promise<void> {
+  if (shell.shell === Shell.Urxvt) {
+    const commandArgs = ['-cd', path]
+    await spawn(shell.path, commandArgs)
+  }
+
   const commandArgs = ['--working-directory', path]
   await spawn(shell.path, commandArgs)
 }