mirror of
https://github.com/JanDeDobbeleer/oh-my-posh.git
synced 2025-01-03 07:17:26 -08:00
parent
8b93da005e
commit
b9dd5c18a8
|
@ -23,6 +23,7 @@ type Path struct {
|
||||||
StackCount int
|
StackCount int
|
||||||
Location string
|
Location string
|
||||||
Writable bool
|
Writable bool
|
||||||
|
RootDir bool
|
||||||
}
|
}
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
@ -427,6 +428,9 @@ func (pt *Path) replaceMappedLocations() (string, string) {
|
||||||
sort.Sort(sort.Reverse(sort.StringSlice(keys)))
|
sort.Sort(sort.Reverse(sort.StringSlice(keys)))
|
||||||
|
|
||||||
root, relative := pt.parsePath(pt.pwd)
|
root, relative := pt.parsePath(pt.pwd)
|
||||||
|
if len(relative) == 0 {
|
||||||
|
pt.RootDir = true
|
||||||
|
}
|
||||||
rootN := pt.normalize(root)
|
rootN := pt.normalize(root)
|
||||||
relativeN := pt.normalize(relative)
|
relativeN := pt.normalize(relative)
|
||||||
pathSeparator := pt.env.PathSeparator()
|
pathSeparator := pt.env.PathSeparator()
|
||||||
|
|
|
@ -64,13 +64,13 @@ For example, to swap out `C:\Users\Leet\GitHub` with a GitHub icon, you can do t
|
||||||
### Notes
|
### Notes
|
||||||
|
|
||||||
- To make mapped locations work cross-platform, use `/` as the path separator, Oh My Posh will
|
- To make mapped locations work cross-platform, use `/` as the path separator, Oh My Posh will
|
||||||
automatically match effective separators based on the running operating system.
|
automatically match effective separators based on the running operating system.
|
||||||
- If you want to match all child directories, you can use `*` as a wildcard, for example:
|
- If you want to match all child directories, you can use `*` as a wildcard, for example:
|
||||||
`"C:/Users/Bill/*": "$"` will turn `C:/Users/Bill/Downloads` into `$/Downloads`.
|
`"C:/Users/Bill/*": "$"` will turn `C:/Users/Bill/Downloads` into `$/Downloads`.
|
||||||
- The character `~` at the start of a mapped location will match the user's home directory.
|
- The character `~` at the start of a mapped location will match the user's home directory.
|
||||||
- The match is case-insensitive on Windows and macOS, but case-sensitive on other operating systems. This means that for
|
- The match is case-insensitive on Windows and macOS, but case-sensitive on other operating systems. This means that for
|
||||||
user Bill, who has a user account `Bill` on Windows and `bill` on Linux, `~/Foo` might match
|
user Bill, who has a user account `Bill` on Windows and `bill` on Linux, `~/Foo` might match
|
||||||
`C:\Users\Bill\Foo` or `C:\Users\Bill\foo` on Windows but only `/home/bill/Foo` on Linux.
|
`C:\Users\Bill\Foo` or `C:\Users\Bill\foo` on Windows but only `/home/bill/Foo` on Linux.
|
||||||
|
|
||||||
## Style
|
## Style
|
||||||
|
|
||||||
|
@ -151,9 +151,10 @@ folders at the same level, so if `C:\projectA\dev` and `C:\projectB\dev` exist,
|
||||||
### Properties
|
### Properties
|
||||||
|
|
||||||
| Name | Type | Description |
|
| Name | Type | Description |
|
||||||
| ------------- | --------- | ---------------------------------------------------------------------------- |
|
| ------------- | --------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `.Path` | `string` | the current directory (based on the `style` property) |
|
| `.Path` | `string` | the current directory (based on the `style` property) |
|
||||||
| `.Parent` | `string` | the current directory's parent folder which ends with a path separator (designed for use with style `folder`, it is empty if `.Path` contains only one single element) |
|
| `.Parent` | `string` | the current directory's parent folder which ends with a path separator (designed for use with style `folder`, it is empty if `.Path` contains only one single element) |
|
||||||
|
| `.RootDir` | `boolean` | true if we're at the root directory (no parent) |
|
||||||
| `.Location` | `string` | the current directory (raw value) |
|
| `.Location` | `string` | the current directory (raw value) |
|
||||||
| `.StackCount` | `int` | the stack count |
|
| `.StackCount` | `int` | the stack count |
|
||||||
| `.Writable` | `boolean` | is the current directory writable by the user or not |
|
| `.Writable` | `boolean` | is the current directory writable by the user or not |
|
||||||
|
|
Loading…
Reference in a new issue