mirror of
https://github.com/cmderdev/cmder.git
synced 2025-07-17 04:59:09 +08:00
Compare commits
126 Commits
Author | SHA1 | Date | |
---|---|---|---|
ff595e62b1 | |||
a85a208b20 | |||
ecda3acfdf | |||
5477b7812d | |||
81951a4a14 | |||
0280593d4c | |||
f8e859f844 | |||
af4c1fddbb | |||
b58b3b4547 | |||
9184f8e2bf | |||
1e0e2193e0 | |||
38fd3468fe | |||
ebd977778b | |||
72dd8376cd | |||
b61752f89e | |||
8f59d529f4 | |||
711c436f04 | |||
ea531cdd44 | |||
73c21d1a59 | |||
a97ce1f950 | |||
4510abb3c8 | |||
6d132c2665 | |||
543c7ca6e9 | |||
efc978f6f8 | |||
5def1c584a | |||
865e443fcd | |||
893207453d | |||
5e5e0ece73 | |||
834f031442 | |||
0bd847e695 | |||
efe64ee6fd | |||
5f9f3560c8 | |||
9b9bb13f6a | |||
52eea5fe9f | |||
ab3f0b76fb | |||
528bbea7f5 | |||
f20eca01ac | |||
26d8d58e77 | |||
cf134604bb | |||
67b374ad37 | |||
d592f80364 | |||
3e40c80331 | |||
ac2082d56d | |||
a813e359c5 | |||
345562dbd0 | |||
13de4924ca | |||
f39b921121 | |||
43d5a7b833 | |||
b424012a08 | |||
192c2f4dd1 | |||
4622aa87e4 | |||
0b2c9bf005 | |||
081624d88e | |||
280bbfff1f | |||
a93fff6798 | |||
8abfa9d413 | |||
98a64b71b2 | |||
f2b26352b4 | |||
63128ed52f | |||
036efc2fb8 | |||
2582891307 | |||
ec42046297 | |||
522656845f | |||
6b22a5c583 | |||
e75958b881 | |||
8ec252276f | |||
16bf572cdf | |||
7bd25e95e1 | |||
cc12b848ac | |||
20d55c1469 | |||
06e6c63b7f | |||
89499f2a60 | |||
95e5169476 | |||
760f4e579e | |||
6d8f7a290a | |||
2a4e9d8301 | |||
961f38a399 | |||
5a48e568a8 | |||
524fce25ab | |||
46bde1af8b | |||
9a47bce6ac | |||
0a3be464be | |||
b2723d6f6a | |||
4f2ced57df | |||
88169b8721 | |||
f6db922732 | |||
e822d55aa5 | |||
ccb6cb80e5 | |||
e56ed810a0 | |||
7e8d67caa8 | |||
4e4f050374 | |||
51e75d4bb5 | |||
f4389fc552 | |||
8101923242 | |||
7e1bc4297a | |||
0f30329e38 | |||
25820ae4d4 | |||
528a69dab9 | |||
0c9e0e2f8c | |||
20eb7b8e81 | |||
ab02c4ce46 | |||
f9f06a5595 | |||
8ac540ebb6 | |||
fcab51da2b | |||
dc492c836f | |||
1eb03dd1b8 | |||
3163d6d1c3 | |||
5c7f4943ad | |||
378ebff566 | |||
572a94ca3a | |||
22aa59bd83 | |||
eb6a332da2 | |||
dd614642b2 | |||
036cf09360 | |||
7203671fc9 | |||
787ac3773c | |||
b16aa7a29e | |||
d8e8fc8adb | |||
0efeaa91fa | |||
8c0817941e | |||
e17b04cbb9 | |||
e904ebce72 | |||
a226019d5a | |||
d04cc1f04e | |||
d8444dae97 | |||
0a5d1ac156 |
93
.github/issue_template.md
vendored
93
.github/issue_template.md
vendored
@ -2,63 +2,88 @@
|
|||||||
|
|
||||||
Thank you for reporting a bug for the Cmder project!
|
Thank you for reporting a bug for the Cmder project!
|
||||||
------------------------------------------------------------------
|
------------------------------------------------------------------
|
||||||
|
|
||||||
Please make sure you read and follow the following instructions
|
Please make sure you read and follow the following instructions
|
||||||
carefully before reporting bugs, and/or requesting new features.
|
carefully before reporting bugs, and/or requesting new features.
|
||||||
|
|
||||||
Make sure that you have:
|
Make sure that you have:
|
||||||
|
|
||||||
• Searched for existing issues (including the **closed** ones)
|
• Searched for existing issues (including the **closed** ones)
|
||||||
for the similar problems here:
|
for the similar problems here:
|
||||||
|
|
||||||
https://github.com/cmderdev/cmder/issues?q=is:issue
|
https://github.com/cmderdev/cmder/issues?q=is:issue
|
||||||
|
|
||||||
• Read the README.md and the Wiki:
|
• Read both the README.md and the Wiki:
|
||||||
|
|
||||||
- https://github.com/cmderdev/cmder/blob/master/README.md
|
- https://github.com/cmderdev/cmder/blob/master/README.md
|
||||||
- https://github.com/cmderdev/cmder/wiki
|
- https://github.com/cmderdev/cmder/wiki
|
||||||
|
|
||||||
(What you may be asking here could already be explained there!)
|
(What you may be asking here could already be explained there!)
|
||||||
|
|
||||||
• Please understand that Cmder by default uses ConEmu as the
|
• Please understand that Cmder uses ConEmu as the default
|
||||||
underlying Terminal Emulator. If your issue is regarding
|
underlying Terminal Emulator. If your issue is regarding
|
||||||
the **Terminal Emulator**, please visit the ConEmu issues page:
|
the **Terminal Emulator**, please visit the ConEmu issues page:
|
||||||
|
|
||||||
https://github.com/Maximus5/ConEmu/issues?q=is:issue
|
https://github.com/Maximus5/ConEmu/issues?q=is:issue
|
||||||
|
|
||||||
If there isn't an existing issue, you may open a new one there.
|
If there isn't an existing issue, you may open a new one there.
|
||||||
|
|
||||||
(We don't resolve issues regarding ConEmu here, so please
|
(We don't resolve issues regarding ConEmu here, so please
|
||||||
make sure you open the issue in the correct place.)
|
make sure you open the issue in the correct place.)
|
||||||
|
|
||||||
more info: https://conemu.github.io/en/ThirdPartyProblems.html
|
more info: https://conemu.github.io/en/ThirdPartyProblems.html
|
||||||
|
|
||||||
• If you are asking for guides on how to integrate Cmder into
|
• If you would like to ask for guides on how to integrate Cmder with
|
||||||
your favorite IDE of choice, or how to perform an specific
|
your favorite IDE of choice, or how to perform a specific task
|
||||||
task with Cmder, make sure you visit our label section first!
|
with Cmder, make sure you visit our label section first.
|
||||||
|
|
||||||
You may already have an answer under the Guides or Questions section.
|
You may already have an answer under the Guides or Questions section.
|
||||||
|
|
||||||
For a list of labels, visit:
|
For a list of labels, visit:
|
||||||
- https://github.com/cmderdev/cmder/labels
|
- https://github.com/cmderdev/cmder/labels
|
||||||
|
|
||||||
(Be sure to also check “Closed” issues in the labels section!)
|
(Be sure to also check “Closed” issues in the labels section!)
|
||||||
|
|
||||||
• If the issue is regarding the other upstream technologies that
|
• If you have a request to provide auto-complete support for a new tool,
|
||||||
Cmder uses (e.g. Clink, Git, etc), please make sure that the
|
please post your request here:
|
||||||
bug you are reporting only applies when they are used in
|
|
||||||
combination with Cmder. If the bug applies when the mentioned
|
https://github.com/vladimir-kotikov/clink-completions/issues
|
||||||
tools are NOT used within Cmder, there's a good chance that
|
|
||||||
you should open the bug at the corresponding repo instead.
|
• If you are having an issue with any of the **upstream technologies**
|
||||||
|
that are used by Cmder, please make sure that the issue is reproducible
|
||||||
|
_only_ when used in combination with Cmder.
|
||||||
|
|
||||||
|
We may not directly address the issues related to the following tools:
|
||||||
|
- Clink, the default shell in Cmder
|
||||||
|
- ConEmu, the terminal emulator
|
||||||
|
- Git/MinGW, which also provide *NIX tools
|
||||||
|
- clink-completions, which provide autocompletion
|
||||||
|
|
||||||
|
The issues related to upstream technologies are labeled as 👆 [name].
|
||||||
|
|
||||||
|
We'll try our best to help you -- but we recommend creating an issue
|
||||||
|
specifically at each of the corresponding repositories for the best
|
||||||
|
result.
|
||||||
|
|
||||||
|
► Try to reproduce the bug you're reporting, on a stand-alone edition
|
||||||
|
of each tool, without using Cmder. If the bug applies when the
|
||||||
|
mentioned tools are NOT used within Cmder, there's a good chance that
|
||||||
|
you should open the bug at the corresponding repo instead.
|
||||||
|
|
||||||
|
• Lastly, have a look at official documentation for Cmder over
|
||||||
|
our website, and our wiki.
|
||||||
|
|
||||||
Read more on about Cmder on ConEmu docs:
|
Read more on about Cmder on ConEmu docs:
|
||||||
https://conemu.github.io/en/cmder.html
|
https://conemu.github.io/en/cmder.html
|
||||||
|
|
||||||
|
|
||||||
Thank you for making sure you are opening a new valid issue!
|
Thank you for making sure you are opening a new valid issue! ♥
|
||||||
|
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
Some tips on how to write a better report:
|
Some tips on how to write a better report:
|
||||||
- Put an `x` into all the boxes [ ] relevant to your issue (example: [x]).
|
- Put an `x` into all the boxes [ ] relevant to your issue (correct example: [x] -- not like this: [ x] or [x ]).
|
||||||
- Use the *Preview* tab to see how your issue will actually look like, before sending it.
|
- Use the *Preview* tab to see how your issue will actually look like, before sending it.
|
||||||
- Make sure the description is worded well enough to be understood, and with as much context and examples as possible.
|
- Make sure the description is worded well enough to be understood, and with as much context and examples as possible.
|
||||||
- Post a screenshot or the command the triggered the problem, if applicable.
|
- Post a screenshot or the command the triggered the problem, if applicable.
|
||||||
@ -66,6 +91,7 @@
|
|||||||
Help us reproduce the issue by explaining what went wrong, and what did you expect to happen.
|
Help us reproduce the issue by explaining what went wrong, and what did you expect to happen.
|
||||||
- Please keep the ticket language to English only here.
|
- Please keep the ticket language to English only here.
|
||||||
We can't process your issue if it's written in Russian or Chinese as we can't understand them.
|
We can't process your issue if it's written in Russian or Chinese as we can't understand them.
|
||||||
|
- You can find the version of Cmder.exe and ConEmu.exe binaries using Right Click → Properties → Details menu.
|
||||||
- ⚠ Read the following page to avoid posting a bad issue: https://conemu.github.io/en/BadIssue.html
|
- ⚠ Read the following page to avoid posting a bad issue: https://conemu.github.io/en/BadIssue.html
|
||||||
-->
|
-->
|
||||||
|
|
||||||
@ -74,5 +100,10 @@
|
|||||||
- [ ] Feature request (request for new functionality)
|
- [ ] Feature request (request for new functionality)
|
||||||
- [ ] Question
|
- [ ] Question
|
||||||
|
|
||||||
### Description of the issue
|
### Version Information
|
||||||
|
<!-- Please write your Cmder and ConEmu version here -->
|
||||||
|
|
||||||
|
<!-- If applicable, write down your Windows edition too (e.g. Windows 10 Pro 1809) -->
|
||||||
|
|
||||||
|
### Description of the issue
|
||||||
<!-- Provide a clear, simple description of your issue here -->
|
<!-- Provide a clear, simple description of your issue here -->
|
||||||
|
19
.github/stale.yml
vendored
Normal file
19
.github/stale.yml
vendored
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
# Number of days of inactivity before an issue becomes stale
|
||||||
|
daysUntilStale: 30
|
||||||
|
# Number of days of inactivity before a stale issue is closed
|
||||||
|
daysUntilClose: 7
|
||||||
|
# Issues with these labels will never be considered stale
|
||||||
|
exemptLabels:
|
||||||
|
- "📌 Pinned"
|
||||||
|
# Label to use when marking an issue as stale
|
||||||
|
staleLabel: "👀 Awaiting Response"
|
||||||
|
# Comment to post when marking an issue as stale. Set to `false` to disable
|
||||||
|
markComment: >
|
||||||
|
This issue has been automatically marked as stale because it has not had
|
||||||
|
any recent activity. It will be closed in a week if no further activity occurs.
|
||||||
|
Thank you for your contribution(s).
|
||||||
|
# Comment to post when closing a stale issue. Set to `false` to disable
|
||||||
|
closeComment: >
|
||||||
|
This issue has been automatically closed due to it not having any
|
||||||
|
activity since it was marked as stale.
|
||||||
|
Thank you for your contribution(s).
|
2
.gitignore
vendored
2
.gitignore
vendored
@ -13,6 +13,8 @@ vendor/*/*
|
|||||||
config/*
|
config/*
|
||||||
!config/Readme.md
|
!config/Readme.md
|
||||||
|
|
||||||
|
config_user/*
|
||||||
|
|
||||||
Thumbs.db
|
Thumbs.db
|
||||||
*.exe
|
*.exe
|
||||||
*.dll
|
*.dll
|
||||||
|
201
CHANGELOG.md
201
CHANGELOG.md
@ -1,5 +1,206 @@
|
|||||||
# Change Log
|
# Change Log
|
||||||
|
|
||||||
|
## [1.3.12](https://github.com/cmderdev/cmder/tree/v1.3.12) (2019-08-18)
|
||||||
|
|
||||||
|
### Fixes
|
||||||
|
|
||||||
|
* Pull Request: [#2113](https://github.com/cmderdev/cmder/pull/2113)
|
||||||
|
* Add `vendor\bin\vscode_init.cmd` for use with Visual Studio Code
|
||||||
|
* Fixes [#2118](https://github.com/cmderdev/cmder/issues/2118)
|
||||||
|
* Fixes [#1985](https://github.com/cmderdev/cmder/issues/1985)
|
||||||
|
* Pull Request: [#2106](https://github.com/cmderdev/cmder/pull/2106)
|
||||||
|
* Portable Git requires running `post-install.bat` which deletes itself when done. This was not happening.
|
||||||
|
* Resolves [#2105](https://github.com/cmderdev/cmder/issues/2105)
|
||||||
|
* Pull Request: [#2002](https://github.com/cmderdev/cmder/pull/2002)
|
||||||
|
* Updated the HG prompt code to use the '-ib' option to 'hg id' so the branch name is always available, regardless of the state of the working copy
|
||||||
|
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
* Pull Request: [#2055](https://github.com/cmderdev/cmder/pull/2055)
|
||||||
|
* Upgrade git to 2.21.0
|
||||||
|
* Provide default settings for Clink that updates the history file in real time
|
||||||
|
* Turn this on in existing Cmder using `clink set history_io 1`
|
||||||
|
* Allow clink disable by setting CMDER_CLINK=0 before starting task
|
||||||
|
* Pull Request: [#2068](https://github.com/cmderdev/cmder/pull/2068)
|
||||||
|
* Print Index in History Command Output.
|
||||||
|
* Sets default `history_expand_mode = 3` in initial Clink Settings.
|
||||||
|
|
||||||
|
### Adds
|
||||||
|
|
||||||
|
* Pull Request : [#2096](https://github.com/cmderdev/cmder/pull/2096)
|
||||||
|
* Question issue: [#2094](https://github.com/cmderdev/cmder/issues/2094)
|
||||||
|
* New argument created to ConEmu forwarding arguments.
|
||||||
|
* Syntax: `/x [ConEmu extras arguments]`
|
||||||
|
* e.g.: `Cmder.exe /x "-min -tsa"`
|
||||||
|
|
||||||
|
## [1.3.11](https://github.com/cmderdev/cmder/tree/v1.3.11) (2018-12-22)
|
||||||
|
|
||||||
|
### Fixes
|
||||||
|
|
||||||
|
* Fix uncommenting `call ssh-agent` in `user_profile.cmd` breaks Cmder prompt. [#1990](https://github.com/cmderdev/cmder/issues/1990), [#1807](https://github.com/cmderdev/cmder/issues/1807), [#1785](https://github.com/cmderdev/cmder/issues/1785), [#1885](https://github.com/cmderdev/cmder/issues/1885)
|
||||||
|
* Pull Request: [#1999](https://github.com/cmderdev/cmder/issues/1999) fix ssh-agent call in user_profile.cmd.default
|
||||||
|
* Unable to use '%' character in git branch names [#1779](https://github.com/cmderdev/cmder/issues/1779)
|
||||||
|
* Pull Request: [#1991](https://github.com/cmderdev/cmder/issues/1991) add percent escaping for string.gsub
|
||||||
|
* sort command, unix vs windows (/usr/bin/sort vs sort.exe) [#1931](https://github.com/cmderdev/cmder/issues/1931)
|
||||||
|
* Pull Request: [#1988](https://github.com/cmderdev/cmder/issues/1988) Prefer /nix_tools option
|
||||||
|
|
||||||
|
### Adds
|
||||||
|
|
||||||
|
* [#1988](https://github.com/cmderdev/cmder/issues/1988) Prefer /nix_tools option
|
||||||
|
* [#1982](https://github.com/cmderdev/cmder/issues/1982) make /register work with /single
|
||||||
|
* [#1975](https://github.com/cmderdev/cmder/issues/1975) Add `/nix_tools 0` option to init.bat to prevent adding !GIT_INSTALL_ROOT!\usr\bin to PATH
|
||||||
|
|
||||||
|
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
* [#1987](https://github.com/cmderdev/cmder/issues/1987) Use default files for default user profiles
|
||||||
|
|
||||||
|
## [1.3.10](https://github.com/cmderdev/cmder/tree/v1.3.10) (2018-11-30)
|
||||||
|
|
||||||
|
### Fixes
|
||||||
|
|
||||||
|
* Replaces Cmder Release v1.3.9 which has been removed.
|
||||||
|
* /c now completely separates user config including Conemu configuration. This enables true multi-user Cmder with no configuration collisions. See PR #1949.
|
||||||
|
* Fix #1959 Start cmder "find" errors. See PR #1961.
|
||||||
|
* Fix #1956 Git detection should use env from git install root. See PR #1969
|
||||||
|
|
||||||
|
### Adds
|
||||||
|
|
||||||
|
* /m initially creates %cmder_root%/config/conemu-%computername%.xml for users that want per computer Conemu configuration with shared init scripts. See PR #1949.
|
||||||
|
* /register now recognizes /c [path] and creates an appropriate Cmder Here shell context menu. See PR #1949.
|
||||||
|
|
||||||
|
## [1.3.8](https://github.com/cmderdev/cmder/tree/v1.3.8) (2018-11-10)
|
||||||
|
|
||||||
|
### Fixes
|
||||||
|
|
||||||
|
* Fix \vendor\bin\timer.cmd was unexpected at this time. on session start.
|
||||||
|
|
||||||
|
## [1.3.7](https://github.com/cmderdev/cmder/tree/v1.3.7) (2018-11-10)
|
||||||
|
## Updated components
|
||||||
|
|
||||||
|
* ConEmu to 180626
|
||||||
|
* Update Git to 2.19.0
|
||||||
|
|
||||||
|
## Fixes:
|
||||||
|
|
||||||
|
* Cmder now opens in the in the current working dir
|
||||||
|
|
||||||
|
## Commits
|
||||||
|
### Aaron Arney (1):
|
||||||
|
|
||||||
|
* Update README
|
||||||
|
|
||||||
|
### Arion Roberto Krause (1):
|
||||||
|
|
||||||
|
* Fixed typo
|
||||||
|
|
||||||
|
### Benjamin Staneck (8):
|
||||||
|
|
||||||
|
* Revert "replace user-aliases with user_aliases"
|
||||||
|
* replace user-aliases with user_aliases
|
||||||
|
* better fix for #1265
|
||||||
|
* Revert "sanitize dir before assigning to prompt"
|
||||||
|
* sanitize dir before assigning to prompt
|
||||||
|
* Update CHANGELOG.md
|
||||||
|
|
||||||
|
### Bob Hood (1):
|
||||||
|
|
||||||
|
* Refactored the Mercurial prompt code to be more efficient.
|
||||||
|
|
||||||
|
### David Refoua (1):
|
||||||
|
|
||||||
|
* fix some spelling issues
|
||||||
|
|
||||||
|
### Dax T Games (30):
|
||||||
|
|
||||||
|
* Revert "Ignore %cmder_root%\config (#1945)"
|
||||||
|
* Ignore %cmder_root%\config (#1945)
|
||||||
|
* Add /f for fast init. (#1942)
|
||||||
|
* add diag helper scripts and adds to the path (#1918)
|
||||||
|
* Fix #1806 #1675 (#1870)
|
||||||
|
* Profile.ps1 (#1796)
|
||||||
|
* Fix lib base (#1794)
|
||||||
|
* Little Changes
|
||||||
|
* Fixed move of default conemu.xml to the vendor folder
|
||||||
|
* ignore all of config folder
|
||||||
|
* move default comemu.xml to vendor folder
|
||||||
|
* fixes
|
||||||
|
* more headers
|
||||||
|
* init.bat update for cexec
|
||||||
|
* git prompt yellow
|
||||||
|
* fix user lua and git detection
|
||||||
|
* allow conditionally setting environment variables
|
||||||
|
* added exit codes
|
||||||
|
* flag_exists.cmd to flag_exec.cmd, also to lib as an option
|
||||||
|
* fixed
|
||||||
|
* handle start dir args with trailing "
|
||||||
|
* cleanup
|
||||||
|
* '.gitignore'
|
||||||
|
* verbose output
|
||||||
|
* cmder_shell settings
|
||||||
|
* add cmder_shell method
|
||||||
|
* replace - with \_ in debug-output and verbose-output
|
||||||
|
* Trying to get tcc working
|
||||||
|
* move user-aliases.cmd to user_aliases.cmd
|
||||||
|
* move bin\alias.bat to vendor\bin\alias.cmd
|
||||||
|
* fix /unregister
|
||||||
|
|
||||||
|
### Dmitri S. Guskov (2):
|
||||||
|
|
||||||
|
* Powershell 5.1 compatibility
|
||||||
|
* Update profile.ps1
|
||||||
|
|
||||||
|
### Gregory Lucas (1):
|
||||||
|
|
||||||
|
* Initialize time_init to fix init error message
|
||||||
|
|
||||||
|
### Josef Pihrt (2):
|
||||||
|
|
||||||
|
* Fix typos, remove escaping inside inline code, replace single quote with backtick
|
||||||
|
* Fix typo and broken link
|
||||||
|
|
||||||
|
### Merlin (1):
|
||||||
|
|
||||||
|
* Remove duplicate Install-Module detection
|
||||||
|
|
||||||
|
### Nicolas Arnaud-Cormos (1):
|
||||||
|
|
||||||
|
* Ensure the right git path is found in case of shim.
|
||||||
|
|
||||||
|
### Thorsten Sommer (1):
|
||||||
|
|
||||||
|
* Fixed spelling
|
||||||
|
|
||||||
|
### gaoslin (1):
|
||||||
|
|
||||||
|
* Update init.bat
|
||||||
|
|
||||||
|
### leochien0102 (1):
|
||||||
|
|
||||||
|
* fix the 'was unexpected at this time.'
|
||||||
|
|
||||||
|
### xiazeyu (4):
|
||||||
|
|
||||||
|
* chore: unite slash
|
||||||
|
* docs: update to latest useage
|
||||||
|
* refactor: reduce global varible useage, fixed quote issue, added parameters support
|
||||||
|
* doc: fix typo
|
||||||
|
|
||||||
|
### xiazeyu_2011 (8):
|
||||||
|
|
||||||
|
* docs: migrated instructions to the wiki pages
|
||||||
|
* rename /bin/have.bat to /vendor/lib/flag_exists.cmd
|
||||||
|
* fix: bug when no argument is passed in
|
||||||
|
* docs: update doc for have.bat
|
||||||
|
* feat: add have.bat as a wrapper
|
||||||
|
* Optimize comments of using arguments in user-profile.cmd
|
||||||
|
* fix conflict with init.bat build-in command parser, update user-profile.cmd
|
||||||
|
* Pass arguments to user-profile.cmd
|
||||||
|
|
||||||
|
刘祺 (1):
|
||||||
|
|
||||||
|
* add LANG support
|
||||||
|
|
||||||
## [1.3.6](https://github.com/cmderdev/cmder/tree/v1.3.6) (2018-05-30)
|
## [1.3.6](https://github.com/cmderdev/cmder/tree/v1.3.6) (2018-05-30)
|
||||||
**Updated components:**
|
**Updated components:**
|
||||||
|
|
||||||
|
28
README.md
28
README.md
@ -41,12 +41,16 @@ The Cmder's user interface is also designed to be more eye pleasing, and you can
|
|||||||
## Cmder.exe Command Line Arguments
|
## Cmder.exe Command Line Arguments
|
||||||
|
|
||||||
|
|
||||||
| Argument | Description |
|
| Argument | Description |
|
||||||
| ------------------- | ----------------------------------------------------------------------- |
|
| ------------------- | ----------------------------------------------------------------------- |
|
||||||
| `/C [user_root_path]` | Individual user Cmder root folder. Example: `%userprofile%\cmder_config` |
|
| `/C [user_root_path]` | Individual user Cmder root folder. Example: `%userprofile%\cmder_config` |
|
||||||
| `/SINGLE` | Start Cmder in single mode. |
|
| `/M` | Use `conemu-%computername%.xml` for ConEmu settings storage instead of `user_conemu.xml` |
|
||||||
| `/START [start_path]` | Folder path to start in. |
|
| `/REGISTER [ALL, USER]` | Register a Windows Shell Menu shortcut. |
|
||||||
| `/TASK [task_name]` | Task to start after launch. |
|
| `/UNREGISTER [ALL, USER]` | Un-register a Windows Shell Menu shortcut. |
|
||||||
|
| `/SINGLE` | Start Cmder in single mode. |
|
||||||
|
| `/START [start_path]` | Folder path to start in. |
|
||||||
|
| `/TASK [task_name]` | Task to start after launch. |
|
||||||
|
| `/X [ConEmu extras pars]` | Forwads parameters to ConEmu |
|
||||||
|
|
||||||
## Context Menu Integration
|
## Context Menu Integration
|
||||||
|
|
||||||
@ -143,9 +147,11 @@ You may find some Monokai color schemes for mintty to match Cmder [here](https:/
|
|||||||
| `/c [user cmder root]` | Enables user bin and config folders for 'Cmder as admin' sessions due to non-shared environment. | not set |
|
| `/c [user cmder root]` | Enables user bin and config folders for 'Cmder as admin' sessions due to non-shared environment. | not set |
|
||||||
| `/d` | Enables debug output. | not set |
|
| `/d` | Enables debug output. | not set |
|
||||||
| `/f` | Enables Cmder Fast Init Mode. This disables some features, see pull request [#1492](https://github.com/cmderdev/cmder/pull/1942) for more details. | not set |
|
| `/f` | Enables Cmder Fast Init Mode. This disables some features, see pull request [#1492](https://github.com/cmderdev/cmder/pull/1942) for more details. | not set |
|
||||||
|
| `/t` | Enables Cmder Timed Init Mode. This displays the time taken run init scripts | not set |
|
||||||
| `/git_install_root [file path]` | User specified Git installation root path. | `%CMDER_ROOT%\vendor\Git-for-Windows` |
|
| `/git_install_root [file path]` | User specified Git installation root path. | `%CMDER_ROOT%\vendor\Git-for-Windows` |
|
||||||
| `/home [home folder]` | User specified folder path to set `%HOME%` environment variable. | `%userprofile%` |
|
| `/home [home folder]` | User specified folder path to set `%HOME%` environment variable. | `%userprofile%` |
|
||||||
| `/max_depth [1-5]` | Define max recurse depth when adding to the path for `%cmder_root%\bin` and `%cmder_user_bin%` | 1 |
|
| `/max_depth [1-5]` | Define max recurse depth when adding to the path for `%cmder_root%\bin` and `%cmder_user_bin%` | 1 |
|
||||||
|
| `/nix_tools [0-2]` | Define how `*nix` tools are added to the path. Prefer Windows Tools: 1, Prefer *nix Tools: 2, No `/usr/bin` in `%PATH%`: 0 | 1 |
|
||||||
| `/svn_ssh [path to ssh.exe]` | Define `%SVN_SSH%` so we can use git svn with ssh svn repositories. | `%GIT_INSTALL_ROOT%\bin\ssh.exe` |
|
| `/svn_ssh [path to ssh.exe]` | Define `%SVN_SSH%` so we can use git svn with ssh svn repositories. | `%GIT_INSTALL_ROOT%\bin\ssh.exe` |
|
||||||
| `/user_aliases [file path]` | File path pointing to user aliases. | `%CMDER_ROOT%\config\user-aliases.cmd` |
|
| `/user_aliases [file path]` | File path pointing to user aliases. | `%CMDER_ROOT%\config\user-aliases.cmd` |
|
||||||
| `/v` | Enables verbose output. | not set |
|
| `/v` | Enables verbose output. | not set |
|
||||||
@ -308,11 +314,11 @@ For instructions on how to integrate Cmder with your IDE, please read our [Wiki
|
|||||||
|
|
||||||
The process of upgrading Cmder depends on the version/build you are currently running.
|
The process of upgrading Cmder depends on the version/build you are currently running.
|
||||||
|
|
||||||
If you have a `[cmder_root]/config/user-conemu.xml`, you are running a newer version of Cmder, follow the below process:
|
If you have a `[cmder_root]/config/user[-|_]conemu.xml`, you are running a newer version of Cmder, follow the below process:
|
||||||
|
|
||||||
1. Exit all Cmder sessions and relaunch `[cmder_root]/cmder.exe`, this backs up your existing `[cmder_root]/vendor/conemu-maximus5/conemu.xml` to `[cmder_root]/config/user-conemu.xml`.
|
1. Exit all Cmder sessions and relaunch `[cmder_root]/cmder.exe`, this backs up your existing `[cmder_root]/vendor/conemu-maximus5/conemu.xml` to `[cmder_root]/config/user[-|_]conemu.xml`.
|
||||||
|
|
||||||
* The `[cmder_root]/config/user-conemu.xml` contains any custom settings you have made using the 'Setup Tasks' settings dialog.
|
* The `[cmder_root]/config/user[-|_]conemu.xml` contains any custom settings you have made using the 'Setup Tasks' settings dialog.
|
||||||
|
|
||||||
2. Exit all Cmder sessions and backup any files you have manually edited under `[cmder_root]/vendor`.
|
2. Exit all Cmder sessions and backup any files you have manually edited under `[cmder_root]/vendor`.
|
||||||
|
|
||||||
@ -321,9 +327,9 @@ If you have a `[cmder_root]/config/user-conemu.xml`, you are running a newer ver
|
|||||||
3. Delete the `[cmder_root]/vendor` folder.
|
3. Delete the `[cmder_root]/vendor` folder.
|
||||||
4. Extract the new `cmder.zip` or `cmder_mini.zip` into `[cmder_root]/` overwriting all files when prompted.
|
4. Extract the new `cmder.zip` or `cmder_mini.zip` into `[cmder_root]/` overwriting all files when prompted.
|
||||||
|
|
||||||
If you do not have a `[cmder_root]/config/user-conemu.xml`, you are running an older version of cmder, follow the below process:
|
If you do not have a `[cmder_root]/config/user[-|_]conemu.xml`, you are running an older version of cmder, follow the below process:
|
||||||
|
|
||||||
1. Exit all Cmder sessions and backup `[cmder_root]/vendor/conemu-maximus5/conemu.xml` to `[cmder_root]/config/user-conemu.xml`.
|
1. Exit all Cmder sessions and backup `[cmder_root]/vendor/conemu-maximus5/conemu.xml` to `[cmder_root]/config/user[-|_]conemu.xml`.
|
||||||
|
|
||||||
2. Backup any files you have manually edited under `[cmder_root]/vendor`.
|
2. Backup any files you have manually edited under `[cmder_root]/vendor`.
|
||||||
|
|
||||||
|
@ -4,11 +4,12 @@ All config files must be in this folder. If there is no option to set this folde
|
|||||||
directly, it has to be hardlinked.
|
directly, it has to be hardlinked.
|
||||||
|
|
||||||
* `user-aliases.cmd`: aliases in cmd; called from vendor\init.bat; autocreated from
|
* `user-aliases.cmd`: aliases in cmd; called from vendor\init.bat; autocreated from
|
||||||
`vendor\user-aliases.cmd.example`.
|
`vendor\user-aliases.cmd.default`.
|
||||||
* `*.lua`: clink completions and prompt filters; autoloaded after all
|
* `*.lua`: clink completions and prompt filters; autoloaded after all
|
||||||
prompt filter and clink completions are initialized; add your own.
|
prompt filter and clink completions are initialized; add your own.
|
||||||
* `user-profile.{sh|cmd|ps1}`: startup files for bash|cmd|powershell tasks; called from their
|
* `user-profile.{sh|cmd|ps1}`: startup files for bash|cmd|powershell tasks; called from their
|
||||||
respective startup scripts in `vendor\`; autocreated on first start of such a task.
|
respective startup scripts in `vendor\`; autocreated from
|
||||||
|
`vendor\user-profile.{sh|cmd|ps1}.default` on first start of such a task.
|
||||||
* `.history`: the current commandline history; autoupdated on close.
|
* `.history`: the current commandline history; autoupdated on close.
|
||||||
* `settings`: settings for readline; overwritten on update.
|
* `settings`: settings for readline; overwritten on update.
|
||||||
* `ConEmu.xml`: settings from ConEmu (=the UI of cmder -> Preferences); overwritten on update.
|
* `ConEmu.xml`: settings from ConEmu (=the UI of cmder -> Preferences); overwritten on update.
|
||||||
|
@ -20,6 +20,8 @@
|
|||||||
#define MB_TITLE L"Cmder Launcher"
|
#define MB_TITLE L"Cmder Launcher"
|
||||||
#define SHELL_MENU_REGISTRY_PATH_BACKGROUND L"Directory\\Background\\shell\\Cmder"
|
#define SHELL_MENU_REGISTRY_PATH_BACKGROUND L"Directory\\Background\\shell\\Cmder"
|
||||||
#define SHELL_MENU_REGISTRY_PATH_LISTITEM L"Directory\\shell\\Cmder"
|
#define SHELL_MENU_REGISTRY_PATH_LISTITEM L"Directory\\shell\\Cmder"
|
||||||
|
#define SHELL_MENU_REGISTRY_DRIVE_PATH_BACKGROUND L"Drive\\Background\\shell\\Cmder"
|
||||||
|
#define SHELL_MENU_REGISTRY_DRIVE_PATH_LISTITEM L"Drive\\shell\\Cmder"
|
||||||
|
|
||||||
#define streqi(a, b) (_wcsicmp((a), (b)) == 0)
|
#define streqi(a, b) (_wcsicmp((a), (b)) == 0)
|
||||||
|
|
||||||
@ -69,7 +71,7 @@ bool FileExists(const wchar_t * filePath)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void StartCmder(std::wstring path = L"", bool is_single_mode = false, std::wstring taskName = L"", std::wstring cfgRoot = L"")
|
void StartCmder(std::wstring path = L"", bool is_single_mode = false, std::wstring taskName = L"", std::wstring cfgRoot = L"", bool use_user_cfg = true, std::wstring conemu_args = L"")
|
||||||
{
|
{
|
||||||
#if USE_TASKBAR_API
|
#if USE_TASKBAR_API
|
||||||
wchar_t appId[MAX_PATH] = { 0 };
|
wchar_t appId[MAX_PATH] = { 0 };
|
||||||
@ -91,9 +93,12 @@ void StartCmder(std::wstring path = L"", bool is_single_mode = false, std::wstr
|
|||||||
wchar_t userAliasesPath[MAX_PATH] = { 0 };
|
wchar_t userAliasesPath[MAX_PATH] = { 0 };
|
||||||
wchar_t legacyUserAliasesPath[MAX_PATH] = { 0 };
|
wchar_t legacyUserAliasesPath[MAX_PATH] = { 0 };
|
||||||
wchar_t args[MAX_PATH * 2 + 256] = { 0 };
|
wchar_t args[MAX_PATH * 2 + 256] = { 0 };
|
||||||
|
wchar_t userConEmuCfgPath[MAX_PATH] = { 0 };
|
||||||
|
|
||||||
|
|
||||||
std::wstring cmderStart = path;
|
std::wstring cmderStart = path;
|
||||||
std::wstring cmderTask = taskName;
|
std::wstring cmderTask = taskName;
|
||||||
|
std::wstring cmderConEmuArgs = conemu_args;
|
||||||
|
|
||||||
std::copy(cfgRoot.begin(), cfgRoot.end(), userConfigDirPath);
|
std::copy(cfgRoot.begin(), cfgRoot.end(), userConfigDirPath);
|
||||||
userConfigDirPath[cfgRoot.length()] = 0;
|
userConfigDirPath[cfgRoot.length()] = 0;
|
||||||
@ -147,7 +152,7 @@ void StartCmder(std::wstring path = L"", bool is_single_mode = false, std::wstr
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Was -c [path] specified?
|
Was /c [path] specified?
|
||||||
*/
|
*/
|
||||||
if (wcscmp(userConfigDirPath, L"") == 0)
|
if (wcscmp(userConfigDirPath, L"") == 0)
|
||||||
{
|
{
|
||||||
@ -216,34 +221,86 @@ void StartCmder(std::wstring path = L"", bool is_single_mode = false, std::wstr
|
|||||||
// Set path to Cmder user ConEmu config file
|
// Set path to Cmder user ConEmu config file
|
||||||
PathCombine(userCfgPath, userConfigDirPath, L"user-ConEmu.xml");
|
PathCombine(userCfgPath, userConfigDirPath, L"user-ConEmu.xml");
|
||||||
|
|
||||||
if (PathFileExists(cpuCfgPath)) // config/ConEmu-%COMPUTERNAME%.xml file exists, use it.
|
if ( PathFileExists(cpuCfgPath) || use_user_cfg == false ) // config/ConEmu-%COMPUTERNAME%.xml file exists or /m was specified on command line, use machine specific config.
|
||||||
{
|
{
|
||||||
if (PathFileExists(cfgPath)) // vendor/conemu-maximus5/ConEmu.xml file exists, copy vendor/conemu-maximus5/ConEmu.xml to config/ConEmu-%COMPUTERNAME%.xml.
|
if (cfgRoot.length() == 0) // '/c [path]' was NOT specified
|
||||||
{
|
{
|
||||||
if (!CopyFile(cfgPath, cpuCfgPath, FALSE))
|
if (PathFileExists(cfgPath)) // vendor/conemu-maximus5/ConEmu.xml file exists, copy vendor/conemu-maximus5/ConEmu.xml to config/ConEmu-%COMPUTERNAME%.xml.
|
||||||
{
|
{
|
||||||
MessageBox(NULL,
|
if (!CopyFile(cfgPath, cpuCfgPath, FALSE))
|
||||||
(GetLastError() == ERROR_ACCESS_DENIED)
|
{
|
||||||
? L"Failed to copy vendor/conemu-maximus5/ConEmu.xml file to config/ConEmu-%COMPUTERNAME%.xml! Access Denied."
|
MessageBox(NULL,
|
||||||
: L"Failed to copy vendor/conemu-maximus5/ConEmu.xml file to config/ConEmu-%COMPUTERNAME%.xml!", MB_TITLE, MB_ICONSTOP);
|
(GetLastError() == ERROR_ACCESS_DENIED)
|
||||||
exit(1);
|
? L"Failed to copy vendor/conemu-maximus5/ConEmu.xml file to config/ConEmu-%COMPUTERNAME%.xml! Access Denied."
|
||||||
|
: L"Failed to copy vendor/conemu-maximus5/ConEmu.xml file to config/ConEmu-%COMPUTERNAME%.xml!", MB_TITLE, MB_ICONSTOP);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else // vendor/conemu-maximus5/ConEmu.xml config file does not exist, copy config/ConEmu-%COMPUTERNAME%.xml to vendor/conemu-maximus5/ConEmu.xml file
|
||||||
|
{
|
||||||
|
if (!CopyFile(cpuCfgPath, cfgPath, FALSE))
|
||||||
|
{
|
||||||
|
MessageBox(NULL,
|
||||||
|
(GetLastError() == ERROR_ACCESS_DENIED)
|
||||||
|
? L"Failed to copy conig/ConEmu-%COMPUTERNAME%.xml file to vendor/conemu-maximus5/ConEmu.xml! Access Denied."
|
||||||
|
: L"Failed to copy config/ConEmu-%COMPUTERNAME%.xml file to vendor/conemu-maximus5/ConEmu.xml!", MB_TITLE, MB_ICONSTOP);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else // vendor/conemu-maximus5/ConEmu.xml config file does not exist, copy config/ConEmu-%COMPUTERNAME%.xml to vendor/conemu-maximus5/ConEmu.xml file
|
else // '/c [path]' was specified, don't copy anything and use existing conemu-%COMPUTERNAME%.xml to start comemu.
|
||||||
{
|
{
|
||||||
if (!CopyFile(cpuCfgPath, cfgPath, FALSE))
|
if (use_user_cfg == false && PathFileExists(cfgPath) && !PathFileExists(cpuCfgPath)) // vendor/conemu-maximus5/ConEmu.xml file exists, copy vendor/conemu-maximus5/ConEmu.xml to config/ConEmu-%COMPUTERNAME%.xml.
|
||||||
{
|
{
|
||||||
MessageBox(NULL,
|
if (!CopyFile(cfgPath, cpuCfgPath, FALSE))
|
||||||
(GetLastError() == ERROR_ACCESS_DENIED)
|
{
|
||||||
? L"Failed to copy conig/ConEmu-%COMPUTERNAME%.xml file to vendor/conemu-maximus5/ConEmu.xml! Access Denied."
|
MessageBox(NULL,
|
||||||
: L"Failed to copy config/ConEmu-%COMPUTERNAME%.xml file to vendor/conemu-maximus5/ConEmu.xml!", MB_TITLE, MB_ICONSTOP);
|
(GetLastError() == ERROR_ACCESS_DENIED)
|
||||||
exit(1);
|
? L"Failed to copy vendor/conemu-maximus5/ConEmu.xml file to config/ConEmu-%COMPUTERNAME%.xml! Access Denied."
|
||||||
|
: L"Failed to copy vendor/conemu-maximus5/ConEmu.xml file to config/ConEmu-%COMPUTERNAME%.xml!", MB_TITLE, MB_ICONSTOP);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PathCombine(userConEmuCfgPath, userConfigDirPath, L"ConEmu-%COMPUTERNAME%.xml");
|
||||||
|
ExpandEnvironmentStrings(userConEmuCfgPath, userConEmuCfgPath, sizeof(userConEmuCfgPath) / sizeof(userConEmuCfgPath[0]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (PathFileExists(userCfgPath)) // config/user_conemu.xml exists, use it.
|
else if (PathFileExists(userCfgPath)) // config/user_conemu.xml exists, use it.
|
||||||
{
|
{
|
||||||
if (PathFileExists(cfgPath)) // vendor/conemu-maximus5/ConEmu.xml exists, copy vendor/conemu-maximus5/ConEmu.xml to config/user_conemu.xml.
|
if (cfgRoot.length() == 0) // '/c [path]' was NOT specified
|
||||||
|
{
|
||||||
|
if (PathFileExists(cfgPath)) // vendor/conemu-maximus5/ConEmu.xml exists, copy vendor/conemu-maximus5/ConEmu.xml to config/user_conemu.xml.
|
||||||
|
{
|
||||||
|
if (!CopyFile(cfgPath, userCfgPath, FALSE))
|
||||||
|
{
|
||||||
|
MessageBox(NULL,
|
||||||
|
(GetLastError() == ERROR_ACCESS_DENIED)
|
||||||
|
? L"Failed to copy vendor/conemu-maximus5/ConEmu.xml file to config/user-conemu.xml! Access Denied."
|
||||||
|
: L"Failed to copy vendor/conemu-maximus5/ConEmu.xml file to config/user-conemu.xml!", MB_TITLE, MB_ICONSTOP);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else // vendor/conemu-maximus5/ConEmu.xml does not exist, copy config/user-conemu.xml to vendor/conemu-maximus5/ConEmu.xml
|
||||||
|
{
|
||||||
|
if (!CopyFile(userCfgPath, cfgPath, FALSE))
|
||||||
|
{
|
||||||
|
MessageBox(NULL,
|
||||||
|
(GetLastError() == ERROR_ACCESS_DENIED)
|
||||||
|
? L"Failed to copy config/user-conemu.xml file to vendor/conemu-maximus5/ConEmu.xml! Access Denied."
|
||||||
|
: L"Failed to copy config/user-conemu.xml file to vendor/conemu-maximus5/ConEmu.xml!", MB_TITLE, MB_ICONSTOP);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else // '/c [path]' was specified, don't copy anything and use existing user_conemu.xml to start comemu.
|
||||||
|
{
|
||||||
|
PathCombine(userConEmuCfgPath, userConfigDirPath, L"user-ConEmu.xml");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (cfgRoot.length() == 0) // '/c [path]' was NOT specified
|
||||||
|
{
|
||||||
|
if (PathFileExists(cfgPath)) // vendor/conemu-maximus5/ConEmu.xml exists, copy vendor/conemu-maximus5/ConEmu.xml to config/user_conemu.xml
|
||||||
{
|
{
|
||||||
if (!CopyFile(cfgPath, userCfgPath, FALSE))
|
if (!CopyFile(cfgPath, userCfgPath, FALSE))
|
||||||
{
|
{
|
||||||
@ -253,15 +310,25 @@ void StartCmder(std::wstring path = L"", bool is_single_mode = false, std::wstr
|
|||||||
: L"Failed to copy vendor/conemu-maximus5/ConEmu.xml file to config/user-conemu.xml!", MB_TITLE, MB_ICONSTOP);
|
: L"Failed to copy vendor/conemu-maximus5/ConEmu.xml file to config/user-conemu.xml!", MB_TITLE, MB_ICONSTOP);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
else // vendor/ConEmu.xml.default config exists, copy Cmder vendor/ConEmu.xml.default file to vendor/conemu-maximus5/ConEmu.xml.
|
||||||
|
{
|
||||||
|
if (!CopyFile(defaultCfgPath, cfgPath, FALSE))
|
||||||
|
{
|
||||||
|
MessageBox(NULL,
|
||||||
|
(GetLastError() == ERROR_ACCESS_DENIED)
|
||||||
|
? L"Failed to copy vendor/ConEmu.xml.default file to vendor/conemu-maximus5/ConEmu.xml! Access Denied."
|
||||||
|
: L"Failed to copy vendor/ConEmu.xml.default file to vendor/conemu-maximus5/ConEmu.xml!", MB_TITLE, MB_ICONSTOP);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else // vendor/conemu-maximus5/ConEmu.xml does not exist, copy config/user-conemu.xml to vendor/conemu-maximus5/ConEmu.xml
|
else {
|
||||||
{
|
if (!CopyFile(defaultCfgPath, cfgPath, FALSE))
|
||||||
if (!CopyFile(userCfgPath, cfgPath, FALSE))
|
|
||||||
{
|
{
|
||||||
MessageBox(NULL,
|
MessageBox(NULL,
|
||||||
(GetLastError() == ERROR_ACCESS_DENIED)
|
(GetLastError() == ERROR_ACCESS_DENIED)
|
||||||
? L"Failed to copy config/user-conemu.xml file to vendor/conemu-maximus5/ConEmu.xml! Access Denied."
|
? L"Failed to copy vendor/ConEmu.xml.default file to vendor/conemu-maximus5/ConEmu.xml! Access Denied."
|
||||||
: L"Failed to copy config/user-conemu.xml file to vendor/conemu-maximus5/ConEmu.xml!", MB_TITLE, MB_ICONSTOP);
|
: L"Failed to copy vendor/ConEmu.xml.default file to vendor/conemu-maximus5/ConEmu.xml!", MB_TITLE, MB_ICONSTOP);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -276,18 +343,20 @@ void StartCmder(std::wstring path = L"", bool is_single_mode = false, std::wstr
|
|||||||
: L"Failed to copy vendor/conemu-maximus5/ConEmu.xml file to config/user-conemu.xml!", MB_TITLE, MB_ICONSTOP);
|
: L"Failed to copy vendor/conemu-maximus5/ConEmu.xml file to config/user-conemu.xml!", MB_TITLE, MB_ICONSTOP);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PathCombine(userConEmuCfgPath, userConfigDirPath, L"user-ConEmu.xml");
|
||||||
}
|
}
|
||||||
else // vendor/ConEmu.xml config exists, copy Cmder vendor/ConEmu.xml file to vendor/conemu-maximus5/ConEmu.xml.
|
else // '/c [path]' was specified and 'vendor/ConEmu.xml.default' config exists, copy Cmder 'vendor/ConEmu.xml.default' file to '[user specified path]/config/user_ConEmu.xml'.
|
||||||
{
|
{
|
||||||
if ( ! CopyFile(defaultCfgPath, cfgPath, FALSE))
|
if ( ! CopyFile(defaultCfgPath, userCfgPath, FALSE))
|
||||||
{
|
{
|
||||||
ShowErrorAndExit(GetLastError(), __WFUNCTION__, __LINE__);
|
|
||||||
MessageBox(NULL,
|
MessageBox(NULL,
|
||||||
(GetLastError() == ERROR_ACCESS_DENIED)
|
(GetLastError() == ERROR_ACCESS_DENIED)
|
||||||
? L"Failed to copy vendor/ConEmu.xml.default file to vendor/conemu-maximus5/ConEmu.xml! Access Denied."
|
? L"Failed to copy vendor/ConEmu.xml.default file to [user specified path]/config/user_ConEmu.xml! Access Denied."
|
||||||
: L"Failed to copy vendor/ConEmu.xml.default file to vendor/conemu-maximus5/ConEmu.xml!", MB_TITLE, MB_ICONSTOP);
|
: L"Failed to copy vendor/ConEmu.xml.default file to [user specified path]/config/user_ConEmu.xml!", MB_TITLE, MB_ICONSTOP);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
PathCombine(userConEmuCfgPath, userConfigDirPath, L"user-ConEmu.xml");
|
||||||
}
|
}
|
||||||
|
|
||||||
SYSTEM_INFO sysInfo;
|
SYSTEM_INFO sysInfo;
|
||||||
@ -301,27 +370,31 @@ void StartCmder(std::wstring path = L"", bool is_single_mode = false, std::wstr
|
|||||||
PathCombine(conEmuPath, exeDir, L"vendor\\conemu-maximus5\\ConEmu.exe");
|
PathCombine(conEmuPath, exeDir, L"vendor\\conemu-maximus5\\ConEmu.exe");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
swprintf_s(args, L"%s /Icon \"%s\" /Title Cmder", args, icoPath);
|
||||||
|
|
||||||
|
if (!streqi(cmderStart.c_str(), L""))
|
||||||
|
{
|
||||||
|
swprintf_s(args, L"%s /dir \"%s\"", args, cmderStart.c_str());
|
||||||
|
}
|
||||||
|
|
||||||
if (is_single_mode)
|
if (is_single_mode)
|
||||||
{
|
{
|
||||||
if (!streqi(cmderTask.c_str(), L""))
|
swprintf_s(args, L"%s /single", args);
|
||||||
{
|
|
||||||
swprintf_s(args, L"%s /single /Icon \"%s\" /Title Cmder /dir \"%s\" /run {%s}", args, icoPath, cmderStart.c_str(), cmderTask.c_str());
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
swprintf_s(args, L"%s /single /Icon \"%s\" /Title Cmder /dir \"%s\"", args, icoPath, cmderStart.c_str());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
|
||||||
|
if (!streqi(cmderTask.c_str(), L""))
|
||||||
{
|
{
|
||||||
if (!streqi(cmderTask.c_str(), L""))
|
swprintf_s(args, L"%s /run {%s}", args, cmderTask.c_str());
|
||||||
{
|
}
|
||||||
swprintf_s(args, L"/Icon \"%s\" /Title Cmder /dir \"%s\" /run {%s}", icoPath, cmderStart.c_str(), cmderTask.c_str());
|
|
||||||
}
|
if (cfgRoot.length() != 0)
|
||||||
else
|
{
|
||||||
{
|
swprintf_s(args, L"%s -loadcfgfile \"%s\"", args, userConEmuCfgPath);
|
||||||
swprintf_s(args, L"%s /Icon \"%s\" /Title Cmder /dir \"%s\"", args, icoPath, cmderStart.c_str());
|
}
|
||||||
}
|
|
||||||
|
if (!streqi(cmderConEmuArgs.c_str(), L""))
|
||||||
|
{
|
||||||
|
swprintf_s(args, L"%s %s", args, cmderConEmuArgs.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
SetEnvironmentVariable(L"CMDER_ROOT", exeDir);
|
SetEnvironmentVariable(L"CMDER_ROOT", exeDir);
|
||||||
@ -387,8 +460,10 @@ HKEY GetRootKey(std::wstring opt)
|
|||||||
return root;
|
return root;
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegisterShellMenu(std::wstring opt, wchar_t* keyBaseName)
|
void RegisterShellMenu(std::wstring opt, wchar_t* keyBaseName, std::wstring cfgRoot, bool single)
|
||||||
{
|
{
|
||||||
|
wchar_t userConfigDirPath[MAX_PATH] = { 0 };
|
||||||
|
|
||||||
// First, get the paths we will use
|
// First, get the paths we will use
|
||||||
|
|
||||||
wchar_t exePath[MAX_PATH] = { 0 };
|
wchar_t exePath[MAX_PATH] = { 0 };
|
||||||
@ -397,7 +472,23 @@ void RegisterShellMenu(std::wstring opt, wchar_t* keyBaseName)
|
|||||||
GetModuleFileName(NULL, exePath, sizeof(exePath));
|
GetModuleFileName(NULL, exePath, sizeof(exePath));
|
||||||
|
|
||||||
wchar_t commandStr[MAX_PATH + 20] = { 0 };
|
wchar_t commandStr[MAX_PATH + 20] = { 0 };
|
||||||
swprintf_s(commandStr, L"\"%s\" \"%%V\"", exePath);
|
wchar_t baseCommandStr[MAX_PATH + 20] = { 0 };
|
||||||
|
if (!single) {
|
||||||
|
swprintf_s(baseCommandStr, L"\"%s\"", exePath);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
swprintf_s(baseCommandStr, L"\"%s\" /single", exePath);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cfgRoot.length() == 0) // '/c [path]' was NOT specified
|
||||||
|
{
|
||||||
|
swprintf_s(commandStr, L"%s \"%%V\"", baseCommandStr);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
std::copy(cfgRoot.begin(), cfgRoot.end(), userConfigDirPath);
|
||||||
|
userConfigDirPath[cfgRoot.length()] = 0;
|
||||||
|
swprintf_s(commandStr, L"%s /c \"%s\" \"%%V\"", baseCommandStr, userConfigDirPath);
|
||||||
|
}
|
||||||
|
|
||||||
// Now that we have `commandStr`, it's OK to change `exePath`...
|
// Now that we have `commandStr`, it's OK to change `exePath`...
|
||||||
PathRemoveFileSpec(exePath);
|
PathRemoveFileSpec(exePath);
|
||||||
@ -442,7 +533,9 @@ struct cmderOptions
|
|||||||
std::wstring cmderStart = L"";
|
std::wstring cmderStart = L"";
|
||||||
std::wstring cmderTask = L"";
|
std::wstring cmderTask = L"";
|
||||||
std::wstring cmderRegScope = L"USER";
|
std::wstring cmderRegScope = L"USER";
|
||||||
|
std::wstring cmderConEmuArgs = L"";
|
||||||
bool cmderSingle = false;
|
bool cmderSingle = false;
|
||||||
|
bool cmderUserCfg = true;
|
||||||
bool registerApp = false;
|
bool registerApp = false;
|
||||||
bool unRegisterApp = false;
|
bool unRegisterApp = false;
|
||||||
bool error = false;
|
bool error = false;
|
||||||
@ -460,98 +553,111 @@ cmderOptions GetOption()
|
|||||||
{
|
{
|
||||||
|
|
||||||
// MessageBox(NULL, szArgList[i], L"Arglist contents", MB_OK);
|
// MessageBox(NULL, szArgList[i], L"Arglist contents", MB_OK);
|
||||||
if (_wcsicmp(L"/c", szArgList[i]) == 0)
|
if (cmderOptions.error == false) {
|
||||||
{
|
if (_wcsicmp(L"/c", szArgList[i]) == 0)
|
||||||
TCHAR userProfile[MAX_PATH];
|
{
|
||||||
const DWORD ret = GetEnvironmentVariable(L"USERPROFILE", userProfile, MAX_PATH);
|
TCHAR userProfile[MAX_PATH];
|
||||||
|
const DWORD ret = GetEnvironmentVariable(L"USERPROFILE", userProfile, MAX_PATH);
|
||||||
|
|
||||||
wchar_t cmderCfgRoot[MAX_PATH] = { 0 };
|
wchar_t cmderCfgRoot[MAX_PATH] = { 0 };
|
||||||
PathCombine(cmderCfgRoot, userProfile, L"cmder_cfg");
|
PathCombine(cmderCfgRoot, userProfile, L"cmder_cfg");
|
||||||
|
|
||||||
cmderOptions.cmderCfgRoot = cmderCfgRoot;
|
cmderOptions.cmderCfgRoot = cmderCfgRoot;
|
||||||
|
|
||||||
if (szArgList[i + 1] != NULL && szArgList[i + 1][0] != '/')
|
if (szArgList[i + 1] != NULL && szArgList[i + 1][0] != '/')
|
||||||
{
|
|
||||||
cmderOptions.cmderCfgRoot = szArgList[i + 1];
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (_wcsicmp(L"/start", szArgList[i]) == 0)
|
|
||||||
{
|
|
||||||
int len = wcslen(szArgList[i + 1]);
|
|
||||||
if (wcscmp(&szArgList[i + 1][len - 1], L"\"") == 0)
|
|
||||||
{
|
|
||||||
szArgList[i + 1][len - 1] = '\0';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (PathFileExists(szArgList[i + 1]))
|
|
||||||
{
|
|
||||||
cmderOptions.cmderStart = szArgList[i + 1];
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
MessageBox(NULL, szArgList[i + 1], L"/START - Folder does not exist!", MB_OK);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (_wcsicmp(L"/task", szArgList[i]) == 0)
|
|
||||||
{
|
|
||||||
cmderOptions.cmderTask = szArgList[i + 1];
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
else if (_wcsicmp(L"/single", szArgList[i]) == 0)
|
|
||||||
{
|
|
||||||
cmderOptions.cmderSingle = true;
|
|
||||||
}
|
|
||||||
else if (_wcsicmp(L"/register", szArgList[i]) == 0)
|
|
||||||
{
|
|
||||||
cmderOptions.registerApp = true;
|
|
||||||
cmderOptions.unRegisterApp = false;
|
|
||||||
if (szArgList[i + 1] != NULL)
|
|
||||||
{
|
|
||||||
if (_wcsicmp(L"all", szArgList[i + 1]) == 0 || _wcsicmp(L"user", szArgList[i + 1]) == 0)
|
|
||||||
{
|
{
|
||||||
cmderOptions.cmderRegScope = szArgList[i + 1];
|
cmderOptions.cmderCfgRoot = szArgList[i + 1];
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
else if (_wcsicmp(L"/start", szArgList[i]) == 0)
|
||||||
else if (_wcsicmp(L"/unregister", szArgList[i]) == 0)
|
|
||||||
{
|
|
||||||
cmderOptions.unRegisterApp = true;
|
|
||||||
cmderOptions.registerApp = false;
|
|
||||||
if (szArgList[i + 1] != NULL)
|
|
||||||
{
|
{
|
||||||
if (_wcsicmp(L"all", szArgList[i + 1]) == 0 || _wcsicmp(L"user", szArgList[i + 1]) == 0)
|
int len = wcslen(szArgList[i + 1]);
|
||||||
|
if (wcscmp(&szArgList[i + 1][len - 1], L"\"") == 0)
|
||||||
{
|
{
|
||||||
cmderOptions.cmderRegScope = szArgList[i + 1];
|
szArgList[i + 1][len - 1] = '\0';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (PathFileExists(szArgList[i + 1]))
|
||||||
|
{
|
||||||
|
cmderOptions.cmderStart = szArgList[i + 1];
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
MessageBox(NULL, szArgList[i + 1], L"/START - Folder does not exist!", MB_OK);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
else if (_wcsicmp(L"/task", szArgList[i]) == 0)
|
||||||
else if (cmderOptions.cmderStart == L"")
|
|
||||||
{
|
|
||||||
int len = wcslen(szArgList[i]);
|
|
||||||
if (wcscmp(&szArgList[i][len - 1], L"\"") == 0)
|
|
||||||
{
|
{
|
||||||
szArgList[i][len - 1] = '\0';
|
cmderOptions.cmderTask = szArgList[i + 1];
|
||||||
}
|
|
||||||
|
|
||||||
if (PathFileExists(szArgList[i]))
|
|
||||||
{
|
|
||||||
cmderOptions.cmderStart = szArgList[i];
|
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
else if (_wcsicmp(L"/single", szArgList[i]) == 0)
|
||||||
|
{
|
||||||
|
cmderOptions.cmderSingle = true;
|
||||||
|
}
|
||||||
|
else if (_wcsicmp(L"/m", szArgList[i]) == 0)
|
||||||
|
{
|
||||||
|
cmderOptions.cmderUserCfg = false;
|
||||||
|
}
|
||||||
|
else if (_wcsicmp(L"/register", szArgList[i]) == 0)
|
||||||
|
{
|
||||||
|
cmderOptions.registerApp = true;
|
||||||
|
cmderOptions.unRegisterApp = false;
|
||||||
|
if (szArgList[i + 1] != NULL)
|
||||||
|
{
|
||||||
|
if (_wcsicmp(L"all", szArgList[i + 1]) == 0 || _wcsicmp(L"user", szArgList[i + 1]) == 0)
|
||||||
|
{
|
||||||
|
cmderOptions.cmderRegScope = szArgList[i + 1];
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (_wcsicmp(L"/unregister", szArgList[i]) == 0)
|
||||||
|
{
|
||||||
|
cmderOptions.unRegisterApp = true;
|
||||||
|
cmderOptions.registerApp = false;
|
||||||
|
if (szArgList[i + 1] != NULL)
|
||||||
|
{
|
||||||
|
if (_wcsicmp(L"all", szArgList[i + 1]) == 0 || _wcsicmp(L"user", szArgList[i + 1]) == 0)
|
||||||
|
{
|
||||||
|
cmderOptions.cmderRegScope = szArgList[i + 1];
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* Used for passing arguments to conemu prog */
|
||||||
|
else if (_wcsicmp(L"/x", szArgList[i]) == 0)
|
||||||
|
{
|
||||||
|
cmderOptions.cmderConEmuArgs = szArgList[i + 1];
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
else if (cmderOptions.cmderStart == L"")
|
||||||
|
{
|
||||||
|
int len = wcslen(szArgList[i]);
|
||||||
|
if (wcscmp(&szArgList[i][len - 1], L"\"") == 0)
|
||||||
|
{
|
||||||
|
szArgList[i][len - 1] = '\0';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (PathFileExists(szArgList[i]))
|
||||||
|
{
|
||||||
|
cmderOptions.cmderStart = szArgList[i];
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
MessageBox(NULL, L"Unrecognized parameter.\n\nValid options:\n\n /c [CMDER User Root Path]\n\n /task [ConEmu Task Name]\n\n [/start [Start in Path] | [Start in Path]]\n\n /single\n\n /m\n\n /x [ConEmu extra arguments]\n\nor\n\n /register [USER | ALL]\n\nor\n\n /unregister [USER | ALL]\n", MB_TITLE, MB_OK);
|
||||||
|
cmderOptions.error = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
MessageBox(NULL, szArgList[i], L"Folder does not exist!", MB_OK);
|
MessageBox(NULL, L"Unrecognized parameter.\n\nValid options:\n\n /c [CMDER User Root Path]\n\n /task [ConEmu Task Name]\n\n [/start [Start in Path] | [Start in Path]]\n\n /single\n\n /m\n\n /x [ConEmu extra arguments]\n\nor\n\n /register [USER | ALL]\n\nor\n\n /unregister [USER | ALL]\n", MB_TITLE, MB_OK);
|
||||||
|
cmderOptions.error = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
MessageBox(NULL, L"Unrecognized parameter.\n\nValid options:\n\n /c [CMDER User Root Path]\n\n /task [ConEmu Task Name]\n\n [/start [Start in Path] | [Start in Path]]\n\n /single\n\nor\n\n /register [USER | ALL]\n\nor\n\n /unregister [USER | ALL]\n", MB_TITLE, MB_OK);
|
|
||||||
cmderOptions.error = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
LocalFree(szArgList);
|
LocalFree(szArgList);
|
||||||
@ -572,13 +678,17 @@ int APIENTRY _tWinMain(_In_ HINSTANCE hInstance,
|
|||||||
|
|
||||||
if (cmderOptions.registerApp == true)
|
if (cmderOptions.registerApp == true)
|
||||||
{
|
{
|
||||||
RegisterShellMenu(cmderOptions.cmderRegScope, SHELL_MENU_REGISTRY_PATH_BACKGROUND);
|
RegisterShellMenu(cmderOptions.cmderRegScope, SHELL_MENU_REGISTRY_PATH_BACKGROUND, cmderOptions.cmderCfgRoot, cmderOptions.cmderSingle);
|
||||||
RegisterShellMenu(cmderOptions.cmderRegScope, SHELL_MENU_REGISTRY_PATH_LISTITEM);
|
RegisterShellMenu(cmderOptions.cmderRegScope, SHELL_MENU_REGISTRY_PATH_LISTITEM, cmderOptions.cmderCfgRoot, cmderOptions.cmderSingle);
|
||||||
|
RegisterShellMenu(cmderOptions.cmderRegScope, SHELL_MENU_REGISTRY_DRIVE_PATH_BACKGROUND, cmderOptions.cmderCfgRoot, cmderOptions.cmderSingle);
|
||||||
|
RegisterShellMenu(cmderOptions.cmderRegScope, SHELL_MENU_REGISTRY_DRIVE_PATH_LISTITEM, cmderOptions.cmderCfgRoot, cmderOptions.cmderSingle);
|
||||||
}
|
}
|
||||||
else if (cmderOptions.unRegisterApp == true)
|
else if (cmderOptions.unRegisterApp == true)
|
||||||
{
|
{
|
||||||
UnregisterShellMenu(cmderOptions.cmderRegScope, SHELL_MENU_REGISTRY_PATH_BACKGROUND);
|
UnregisterShellMenu(cmderOptions.cmderRegScope, SHELL_MENU_REGISTRY_PATH_BACKGROUND);
|
||||||
UnregisterShellMenu(cmderOptions.cmderRegScope, SHELL_MENU_REGISTRY_PATH_LISTITEM);
|
UnregisterShellMenu(cmderOptions.cmderRegScope, SHELL_MENU_REGISTRY_PATH_LISTITEM);
|
||||||
|
UnregisterShellMenu(cmderOptions.cmderRegScope, SHELL_MENU_REGISTRY_DRIVE_PATH_BACKGROUND);
|
||||||
|
UnregisterShellMenu(cmderOptions.cmderRegScope, SHELL_MENU_REGISTRY_DRIVE_PATH_LISTITEM);
|
||||||
}
|
}
|
||||||
else if (cmderOptions.error == true)
|
else if (cmderOptions.error == true)
|
||||||
{
|
{
|
||||||
@ -586,7 +696,7 @@ int APIENTRY _tWinMain(_In_ HINSTANCE hInstance,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
StartCmder(cmderOptions.cmderStart, cmderOptions.cmderSingle, cmderOptions.cmderTask, cmderOptions.cmderCfgRoot);
|
StartCmder(cmderOptions.cmderStart, cmderOptions.cmderSingle, cmderOptions.cmderTask, cmderOptions.cmderCfgRoot, cmderOptions.cmderUserCfg, cmderOptions.cmderConEmuArgs);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
61
vendor/bin/alias.cmd
vendored
61
vendor/bin/alias.cmd
vendored
@ -22,10 +22,15 @@ goto parseargument
|
|||||||
|
|
||||||
if /i "%currentarg%" equ "/f" (
|
if /i "%currentarg%" equ "/f" (
|
||||||
set ALIASES=%~2
|
set ALIASES=%~2
|
||||||
|
set _f=%~2
|
||||||
shift
|
shift
|
||||||
goto :do_shift
|
goto :do_shift
|
||||||
) else if /i "%currentarg%" == "/reload" (
|
) else if /i "%currentarg%" == "/reload" (
|
||||||
goto :p_reload
|
goto :p_reload
|
||||||
|
) else if "%currentarg%" equ "/H" (
|
||||||
|
goto :p_help
|
||||||
|
) else if "%currentarg%" equ "/h" (
|
||||||
|
goto :p_help
|
||||||
) else if "%currentarg%" equ "/?" (
|
) else if "%currentarg%" equ "/?" (
|
||||||
goto :p_help
|
goto :p_help
|
||||||
) else if /i "%currentarg%" equ "/d" (
|
) else if /i "%currentarg%" equ "/d" (
|
||||||
@ -40,7 +45,7 @@ goto parseargument
|
|||||||
) else if "%currentarg%" neq "" (
|
) else if "%currentarg%" neq "" (
|
||||||
if "%~2" equ "" (
|
if "%~2" equ "" (
|
||||||
:: Show the specified alias
|
:: Show the specified alias
|
||||||
doskey /macros | findstr /b %currentarg%= && exit /b
|
doskey /macros | %WINDIR%\System32\findstr /b %currentarg%= && exit /b
|
||||||
echo insufficient parameters.
|
echo insufficient parameters.
|
||||||
goto :p_help
|
goto :p_help
|
||||||
) else (
|
) else (
|
||||||
@ -48,6 +53,7 @@ goto parseargument
|
|||||||
set _x=%*
|
set _x=%*
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
rem #endregion parseargument
|
rem #endregion parseargument
|
||||||
|
|
||||||
if "%ALIASES%" neq "%CMDER_ROOT%\config\user_aliases.cmd" (
|
if "%ALIASES%" neq "%CMDER_ROOT%\config\user_aliases.cmd" (
|
||||||
@ -64,28 +70,28 @@ if "%ALIASES%" neq "%CMDER_ROOT%\config\user_aliases.cmd" (
|
|||||||
)
|
)
|
||||||
|
|
||||||
:: validate alias
|
:: validate alias
|
||||||
for /f "delims== tokens=1,* usebackq" %%G in (`echo "%_x%"`) do (
|
for /f "delims== tokens=1,* usebackq" %%G in (`echo "!_x!"`) do (
|
||||||
set alias_name=%%G
|
set alias_name=%%G
|
||||||
set alias_value=%%H
|
set alias_value=%%H
|
||||||
)
|
)
|
||||||
|
|
||||||
:: leading quotes added while validating
|
:: leading quotes added while validating
|
||||||
set alias_name=%alias_name:~1%
|
set alias_name=!alias_name:~1!
|
||||||
|
|
||||||
:: trailing quotes added while validating
|
:: trailing quotes added while validating
|
||||||
set alias_value=%alias_value:~0,-1%
|
set alias_value=!alias_value:~0,-1!
|
||||||
|
|
||||||
::remove spaces
|
::remove spaces
|
||||||
set _temp=%alias_name: =%
|
set _temp=%alias_name: =%
|
||||||
|
|
||||||
if not ["%_temp%"] == ["%alias_name%"] (
|
if not ["%_temp%"] == ["%alias_name%"] (
|
||||||
echo Your alias name can not contain a space
|
echo Your alias name can not contain a space
|
||||||
endlocal
|
endlocal
|
||||||
exit /b
|
exit /b
|
||||||
)
|
)
|
||||||
|
|
||||||
:: replace already defined alias
|
:: replace already defined alias
|
||||||
findstr /b /v /i "%alias_name%=" "%ALIASES%" >> "%ALIASES%.tmp"
|
%WINDIR%\System32\findstr /b /v /i "%alias_name%=" "%ALIASES%" >> "%ALIASES%.tmp"
|
||||||
echo %alias_name%=%alias_value% >> "%ALIASES%.tmp" && type "%ALIASES%.tmp" > "%ALIASES%" & @del /f /q "%ALIASES%.tmp"
|
echo %alias_name%=%alias_value% >> "%ALIASES%.tmp" && type "%ALIASES%.tmp" > "%ALIASES%" & @del /f /q "%ALIASES%.tmp"
|
||||||
doskey /macrofile="%ALIASES%"
|
doskey /macrofile="%ALIASES%"
|
||||||
endlocal
|
endlocal
|
||||||
@ -93,7 +99,7 @@ exit /b
|
|||||||
|
|
||||||
:p_del
|
:p_del
|
||||||
set del_alias=%~1
|
set del_alias=%~1
|
||||||
findstr /b /v /i "%del_alias%=" "%ALIASES%" >> "%ALIASES%.tmp"
|
%WINDIR%\System32\findstr /b /v /i "%del_alias%=" "%ALIASES%" >> "%ALIASES%.tmp"
|
||||||
type "%ALIASES%".tmp > "%ALIASES%" & @del /f /q "%ALIASES%.tmp"
|
type "%ALIASES%".tmp > "%ALIASES%" & @del /f /q "%ALIASES%.tmp"
|
||||||
doskey %del_alias%=
|
doskey %del_alias%=
|
||||||
doskey /macrofile="%ALIASES%"
|
doskey /macrofile="%ALIASES%"
|
||||||
@ -105,27 +111,38 @@ echo Aliases reloaded
|
|||||||
exit /b
|
exit /b
|
||||||
|
|
||||||
:p_show
|
:p_show
|
||||||
doskey /macros|findstr /v /r "^;=" | sort
|
doskey /macros|%WINDIR%\System32\findstr /v /r "^;=" | sort
|
||||||
exit /b
|
exit /b
|
||||||
|
|
||||||
:p_help
|
:p_help
|
||||||
echo.Usage:
|
echo.Usage:
|
||||||
echo.
|
echo.
|
||||||
echo. alias [options] [alias=full command]
|
echo. alias [options] [alias=alias command]
|
||||||
echo.
|
echo.
|
||||||
echo.Options:
|
echo.Options:
|
||||||
echo.
|
echo.
|
||||||
echo. /d [alias] Delete an [alias].
|
echo. Note: Options MUST precede the alias definition.
|
||||||
echo. /f [macrofile] Path to the [macrofile] you want to store the new alias in.
|
|
||||||
echo. Default: %cmder_root%\config\user_aliases.cmd
|
|
||||||
echo. /reload Reload the aliases file. Can be used with /f argument.
|
|
||||||
echo. Default: %cmder_root%\config\user_aliases.cmd
|
|
||||||
echo.
|
echo.
|
||||||
echo. If alias is called with no parameters, it will display the list of existing aliases.
|
echo. /d [alias] Delete an [alias].
|
||||||
|
echo. /f [macrofile] Path to the [macrofile] you want to store the new alias in.
|
||||||
|
echo. Default: %cmder_root%\config\user_aliases.cmd
|
||||||
|
echo. /reload Reload the aliases file. Can be used with /f argument.
|
||||||
|
echo. Default: %cmder_root%\config\user_aliases.cmd
|
||||||
echo.
|
echo.
|
||||||
echo. In the command, you can use the following notations:
|
echo. If alias is called with no parameters, it will display the list of existing
|
||||||
echo. $* allows the alias to assume all the parameters of the supplied command.
|
echo. aliases.
|
||||||
echo. $1-$9 Allows you to seperate parameter by number, much like %%1 in batch.
|
echo.
|
||||||
echo. $T is the command seperator, allowing you to string several commands together into one alias.
|
echo. In the alias command, you can use the following notations:
|
||||||
echo. For more information, read DOSKEY/?
|
echo.
|
||||||
|
echo. ^^^^^^^^%% - %% signs in env vars must be escaped if preserving the variable
|
||||||
|
echo. in he alias is desired. Variables in aliases surrounded by double
|
||||||
|
echo. quotes only require '^^%%' vs '^^^^^^^^%%'
|
||||||
|
echo. $* - allows the alias to assume all the parameters of the supplied
|
||||||
|
echo. command.
|
||||||
|
echo. $1-$9 - Allows you to seperate parameter by number, much like %%1 in
|
||||||
|
echo. batch.
|
||||||
|
echo. $T - Command seperator, allowing you to string several commands
|
||||||
|
echo. together into one alias.
|
||||||
|
echo.
|
||||||
|
echo. For more information, read DOSKEY /?
|
||||||
exit /b
|
exit /b
|
||||||
|
2
vendor/bin/cexec.cmd
vendored
2
vendor/bin/cexec.cmd
vendored
@ -52,7 +52,7 @@ set "feFlagName=%feFlagName% "
|
|||||||
:: echo %feCommand%
|
:: echo %feCommand%
|
||||||
:: echo %feParam%
|
:: echo %feParam%
|
||||||
:: echo.
|
:: echo.
|
||||||
echo %CMDER_USER_FLAGS% | find /i "%feFlagName%">nul
|
echo %CMDER_USER_FLAGS% | %WINDIR%\System32\find /i "%feFlagName%">nul
|
||||||
if "%ERRORLEVEL%" == "0" (
|
if "%ERRORLEVEL%" == "0" (
|
||||||
if "%feNOT%" == "false" (
|
if "%feNOT%" == "false" (
|
||||||
endlocal && call %feCommand% %feParam%
|
endlocal && call %feCommand% %feParam%
|
||||||
|
9
vendor/bin/vscode_init.cmd
vendored
Normal file
9
vendor/bin/vscode_init.cmd
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
@echo off
|
||||||
|
IF [%1] == [] (
|
||||||
|
REM -- manually opened console (Ctrl + Shift + `) --
|
||||||
|
CALL "%~dp0..\init.bat"
|
||||||
|
) ELSE (
|
||||||
|
REM -- task --
|
||||||
|
CALL cmd %*
|
||||||
|
exit
|
||||||
|
)
|
61
vendor/clink.lua
vendored
61
vendor/clink.lua
vendored
@ -13,6 +13,14 @@ dofile(clink_lua_file)
|
|||||||
|
|
||||||
-- now add our own things...
|
-- now add our own things...
|
||||||
|
|
||||||
|
---
|
||||||
|
-- Makes a string safe to use as the replacement in string.gsub
|
||||||
|
---
|
||||||
|
local function verbatim(s)
|
||||||
|
s = string.gsub(s, "%%", "%%%%")
|
||||||
|
return s
|
||||||
|
end
|
||||||
|
|
||||||
---
|
---
|
||||||
-- Setting the prompt in clink means that commands which rewrite the prompt do
|
-- Setting the prompt in clink means that commands which rewrite the prompt do
|
||||||
-- not destroy our own prompt. It also means that started cmds (or batch files
|
-- not destroy our own prompt. It also means that started cmds (or batch files
|
||||||
@ -41,13 +49,12 @@ local function set_prompt_filter()
|
|||||||
-- color codes: "\x1b[1;37;40m"
|
-- color codes: "\x1b[1;37;40m"
|
||||||
local cmder_prompt = "\x1b[1;32;40m{cwd} {git}{hg}{svn} \n\x1b[1;39;40m{lamb} \x1b[0m"
|
local cmder_prompt = "\x1b[1;32;40m{cwd} {git}{hg}{svn} \n\x1b[1;39;40m{lamb} \x1b[0m"
|
||||||
local lambda = "λ"
|
local lambda = "λ"
|
||||||
cwd = string.gsub(cwd, "%%", "{percent}")
|
cmder_prompt = string.gsub(cmder_prompt, "{cwd}", verbatim(cwd))
|
||||||
cmder_prompt = string.gsub(cmder_prompt, "{cwd}", cwd)
|
|
||||||
|
|
||||||
if env ~= nil then
|
if env ~= nil then
|
||||||
lambda = "("..env..") "..lambda
|
lambda = "("..env..") "..lambda
|
||||||
end
|
end
|
||||||
clink.prompt.value = string.gsub(cmder_prompt, "{lamb}", lambda)
|
clink.prompt.value = string.gsub(cmder_prompt, "{lamb}", verbatim(lambda))
|
||||||
end
|
end
|
||||||
|
|
||||||
local function percent_prompt_filter()
|
local function percent_prompt_filter()
|
||||||
@ -182,12 +189,15 @@ end
|
|||||||
-- @return {false|mercurial branch name}
|
-- @return {false|mercurial branch name}
|
||||||
---
|
---
|
||||||
local function get_hg_branch()
|
local function get_hg_branch()
|
||||||
for line in io.popen("hg branch 2>nul"):lines() do
|
local file = io.popen("hg branch 2>nul")
|
||||||
|
for line in file:lines() do
|
||||||
local m = line:match("(.+)$")
|
local m = line:match("(.+)$")
|
||||||
if m then
|
if m then
|
||||||
|
file:close()
|
||||||
return m
|
return m
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
file:close()
|
||||||
|
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
@ -197,12 +207,15 @@ end
|
|||||||
-- @return {false|svn branch name}
|
-- @return {false|svn branch name}
|
||||||
---
|
---
|
||||||
local function get_svn_branch(svn_dir)
|
local function get_svn_branch(svn_dir)
|
||||||
for line in io.popen("svn info 2>nul"):lines() do
|
local file = io.popen("svn info 2>nul")
|
||||||
|
for line in file:lines() do
|
||||||
local m = line:match("^Relative URL:")
|
local m = line:match("^Relative URL:")
|
||||||
if m then
|
if m then
|
||||||
|
file:close()
|
||||||
return line:sub(line:find("/")+1,line:len())
|
return line:sub(line:find("/")+1,line:len())
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
file:close()
|
||||||
|
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
@ -295,7 +308,7 @@ local function git_prompt_filter()
|
|||||||
color = colors.conflict
|
color = colors.conflict
|
||||||
end
|
end
|
||||||
|
|
||||||
clink.prompt.value = string.gsub(clink.prompt.value, "{git}", color.."("..branch..")")
|
clink.prompt.value = string.gsub(clink.prompt.value, "{git}", color.."("..verbatim(branch)..")")
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -317,30 +330,30 @@ local function hg_prompt_filter()
|
|||||||
dirty = "\x1b[31;1m",
|
dirty = "\x1b[31;1m",
|
||||||
}
|
}
|
||||||
|
|
||||||
-- 'hg id' gives us BOTH the branch name AND an indicator that there
|
local pipe = io.popen("hg branch 2>&1")
|
||||||
-- are uncommitted changes, in one fast(er) call
|
|
||||||
local pipe = io.popen("hg id 2>&1")
|
|
||||||
local output = pipe:read('*all')
|
local output = pipe:read('*all')
|
||||||
local rc = { pipe:close() }
|
local rc = { pipe:close() }
|
||||||
|
|
||||||
if output ~= nil and
|
-- strip the trailing newline from the branch name
|
||||||
string.sub(output,1,7) ~= "abort: " and -- not an HG working copy
|
local n = #output
|
||||||
string.sub(output,1,12) ~= "000000000000" and -- empty wc (needs update)
|
while n > 0 and output:find("^%s", n) do n = n - 1 end
|
||||||
(not string.find(output, "is not recognized")) then -- 'hg' not in path
|
local branch = output:sub(1, n)
|
||||||
|
|
||||||
|
if branch ~= nil and
|
||||||
|
string.sub(branch,1,7) ~= "abort: " and -- not an HG working copy
|
||||||
|
(not string.find(branch, "is not recognized")) then -- 'hg' not in path
|
||||||
local color = colors.clean
|
local color = colors.clean
|
||||||
-- split elements on space delimiter
|
|
||||||
local items = {}
|
local pipe = io.popen("hg status -amrd 2>&1")
|
||||||
for i in string.gmatch(output, "%S+") do
|
local output = pipe:read('*all')
|
||||||
table.insert(items, i)
|
local rc = { pipe:close() }
|
||||||
end
|
|
||||||
-- if the repo hash ends with '+', the wc has uncommitted changes
|
if output ~= nil and output ~= "" then color = colors.dirty end
|
||||||
if string.sub(items[1], -1, -1) == "+" then color = colors.dirty end
|
result = color .. "(" .. branch .. ")"
|
||||||
-- substitute the branch in directly -- already WITH parentheses. :)
|
|
||||||
result = color .. items[2] -- string.sub(items[2], 1, string.len(items[2]) - 1)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
clink.prompt.value = string.gsub(clink.prompt.value, "{hg}", result)
|
clink.prompt.value = string.gsub(clink.prompt.value, "{hg}", verbatim(result))
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -362,7 +375,7 @@ local function svn_prompt_filter()
|
|||||||
color = colors.dirty
|
color = colors.dirty
|
||||||
end
|
end
|
||||||
|
|
||||||
clink.prompt.value = string.gsub(clink.prompt.value, "{svn}", color.."("..branch..")")
|
clink.prompt.value = string.gsub(clink.prompt.value, "{svn}", color.."("..verbatim(branch)..")")
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
116
vendor/clink_settings.default
vendored
Normal file
116
vendor/clink_settings.default
vendored
Normal file
@ -0,0 +1,116 @@
|
|||||||
|
# name: Pressing Ctrl-D exits session
|
||||||
|
# type: bool
|
||||||
|
# Ctrl-D exits cmd.exe when it is pressed on an empty line.
|
||||||
|
ctrld_exits = 1
|
||||||
|
|
||||||
|
# name: Toggle if pressing Esc clears line
|
||||||
|
# type: bool
|
||||||
|
# Clink clears the current line when Esc is pressed (unless Readline's Vi mode
|
||||||
|
# is enabled).
|
||||||
|
esc_clears_line = 1
|
||||||
|
|
||||||
|
# name: Match display colour
|
||||||
|
# type: int
|
||||||
|
# Colour to use when displaying matches. A value less than 0 will be the
|
||||||
|
# opposite brightness of the default colour.
|
||||||
|
match_colour = -1
|
||||||
|
|
||||||
|
# name: Executable match style
|
||||||
|
# type: enum
|
||||||
|
# 0 = PATH only
|
||||||
|
# 1 = PATH and CWD
|
||||||
|
# 2 = PATH, CWD, and directories
|
||||||
|
# Changes how Clink will match executables when there is no path separator on
|
||||||
|
# the line. 0 = PATH only, 1 = PATH and CWD, 2 = PATH, CWD, and directories. In
|
||||||
|
# all cases both executables and directories are matched when there is a path
|
||||||
|
# separator present. A value of -1 will disable executable matching completely.
|
||||||
|
exec_match_style = 2
|
||||||
|
|
||||||
|
# name: Whitespace prefix matches files
|
||||||
|
# type: bool
|
||||||
|
# If the line begins with whitespace then Clink bypasses executable matching and
|
||||||
|
# will match all files and directories instead.
|
||||||
|
space_prefix_match_files = 1
|
||||||
|
|
||||||
|
# name: Colour of the prompt
|
||||||
|
# type: int
|
||||||
|
# Surrounds the prompt in ANSI escape codes to set the prompt's colour. Disabled
|
||||||
|
# when the value is less than 0.
|
||||||
|
prompt_colour = -1
|
||||||
|
|
||||||
|
# name: Auto-answer terminate prompt
|
||||||
|
# type: enum
|
||||||
|
# 0 = Disabled
|
||||||
|
# 1 = Answer 'Y'
|
||||||
|
# 2 = Answer 'N'
|
||||||
|
# Automatically answers cmd.exe's 'Terminate batch job (Y/N)?' prompts. 0 =
|
||||||
|
# disabled, 1 = answer 'Y', 2 = answer 'N'.
|
||||||
|
terminate_autoanswer = 0
|
||||||
|
|
||||||
|
# name: Lines of history saved to disk
|
||||||
|
# type: int
|
||||||
|
# When set to a positive integer this is the number of lines of history that
|
||||||
|
# will persist when Clink saves the command history to disk. Use 0 for infinite
|
||||||
|
# lines and <0 to disable history persistence.
|
||||||
|
history_file_lines = 10000
|
||||||
|
|
||||||
|
# name: Skip adding lines prefixed with whitespace
|
||||||
|
# type: bool
|
||||||
|
# Ignore lines that begin with whitespace when adding lines in to the history.
|
||||||
|
history_ignore_space = 0
|
||||||
|
|
||||||
|
# name: Controls how duplicate entries are handled
|
||||||
|
# type: enum
|
||||||
|
# 0 = Always add
|
||||||
|
# 1 = Ignore
|
||||||
|
# 2 = Erase previous
|
||||||
|
# If a line is a duplicate of an existing history entry Clink will erase the
|
||||||
|
# duplicate when this is set 2. A value of 1 will not add duplicates to the
|
||||||
|
# history and a value of 0 will always add lines. Note that history is not
|
||||||
|
# deduplicated when reading/writing to disk.
|
||||||
|
history_dupe_mode = 2
|
||||||
|
|
||||||
|
# name: Read/write history file each line edited
|
||||||
|
# type: bool
|
||||||
|
# When non-zero the history will be read from disk before editing a new line and
|
||||||
|
# written to disk afterwards.
|
||||||
|
history_io = 1
|
||||||
|
|
||||||
|
# name: Sets how command history expansion is applied
|
||||||
|
# type: enum
|
||||||
|
# 0 = Off
|
||||||
|
# 1 = On
|
||||||
|
# 2 = Not in single quotes
|
||||||
|
# 3 = Not in double quote
|
||||||
|
# 4 = Not in any quotes
|
||||||
|
# The '!' character in an entered line can be interpreted to introduce words
|
||||||
|
# from the history. This can be enabled and disable by setting this value to 1
|
||||||
|
# or 0. Values or 2, 3 or 4 will skip any ! character quoted in single, double,
|
||||||
|
# or both quotes respectively.
|
||||||
|
history_expand_mode = 3
|
||||||
|
|
||||||
|
# name: Support Windows' Ctrl-Alt substitute for AltGr
|
||||||
|
# type: bool
|
||||||
|
# Windows provides Ctrl-Alt as a substitute for AltGr, historically to support
|
||||||
|
# keyboards with no AltGr key. This may collide with some of Readline's
|
||||||
|
# bindings.
|
||||||
|
use_altgr_substitute = 1
|
||||||
|
|
||||||
|
# name: Strips CR and LF chars on paste
|
||||||
|
# type: enum
|
||||||
|
# 0 = Paste unchanged
|
||||||
|
# 1 = Strip
|
||||||
|
# 2 = As space
|
||||||
|
# Setting this to a value >0 will make Clink strip CR and LF characters from
|
||||||
|
# text pasted into the current line. Set this to 1 to strip all newline
|
||||||
|
# characters and 2 to replace them with a space.
|
||||||
|
strip_crlf_on_paste = 2
|
||||||
|
|
||||||
|
# name: Enables basic ANSI escape code support
|
||||||
|
# type: bool
|
||||||
|
# When printing the prompt, Clink has basic built-in support for SGR ANSI escape
|
||||||
|
# codes to control the text colours. This is automatically disabled if a third
|
||||||
|
# party tool is detected that also provides this facility. It can also be
|
||||||
|
# disabled by setting this to 0.
|
||||||
|
ansi_code_support = 1
|
||||||
|
|
7
vendor/cmder.sh
vendored
7
vendor/cmder.sh
vendored
@ -90,12 +90,7 @@ fi
|
|||||||
|
|
||||||
if [ ! -f "${CmderUserProfilePath}" ] ; then
|
if [ ! -f "${CmderUserProfilePath}" ] ; then
|
||||||
echo Creating user startup file: "${CmderUserProfilePath}"
|
echo Creating user startup file: "${CmderUserProfilePath}"
|
||||||
cat <<-eof >"${CmderUserProfilePath}"
|
cp "${CMDER_ROOT}/vendor/user_profile.sh.default" "${CmderUserProfilePath}"
|
||||||
# use this file to run your own startup commands for msys2 bash'
|
|
||||||
|
|
||||||
# To add a new vendor to the path, do something like:
|
|
||||||
# export PATH=\${CMDER_ROOT}/vendor/whatever:\${PATH}
|
|
||||||
eof
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Source the users .bashrc file if it exists
|
# Source the users .bashrc file if it exists
|
||||||
|
7
vendor/cmder_exinit
vendored
7
vendor/cmder_exinit
vendored
@ -108,11 +108,6 @@ if [ ! "$CMDER_ROOT" = "" ] ; then
|
|||||||
|
|
||||||
if [ ! -f "${CmderUserProfilePath}" ] ; then
|
if [ ! -f "${CmderUserProfilePath}" ] ; then
|
||||||
echo Creating user startup file: "${CmderUserProfilePath}"
|
echo Creating user startup file: "${CmderUserProfilePath}"
|
||||||
cat <<-eof >"${CmderUserProfilePath}"
|
cp "${CMDER_ROOT}/vendor/user_profile.sh.default" "${CmderUserProfilePath}"
|
||||||
# use this file to run your own startup commands for msys2 bash'
|
|
||||||
|
|
||||||
# To add a new vendor to the path, do something like:
|
|
||||||
# export PATH=\${CMDER_ROOT}/vendor/whatever:\${PATH}
|
|
||||||
eof
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
102
vendor/init.bat
vendored
102
vendor/init.bat
vendored
@ -1,6 +1,6 @@
|
|||||||
@echo off
|
@echo off
|
||||||
|
|
||||||
set cmder_init_start=%time%
|
set CMDER_INIT_START=%time%
|
||||||
|
|
||||||
:: Init Script for cmd.exe
|
:: Init Script for cmd.exe
|
||||||
:: Created as part of cmder project
|
:: Created as part of cmder project
|
||||||
@ -14,6 +14,8 @@ set debug_output=0
|
|||||||
set time_init=0
|
set time_init=0
|
||||||
set fast_init=0
|
set fast_init=0
|
||||||
set max_depth=1
|
set max_depth=1
|
||||||
|
:: Add *nix tools to end of path. 0 turns off *nix tools.
|
||||||
|
set nix_tools=1
|
||||||
set "CMDER_USER_FLAGS= "
|
set "CMDER_USER_FLAGS= "
|
||||||
|
|
||||||
:: Find root dir
|
:: Find root dir
|
||||||
@ -79,6 +81,20 @@ call "%cmder_root%\vendor\lib\lib_profile"
|
|||||||
%lib_console% show_error "The Git install root folder "%~2", you specified does not exist!"
|
%lib_console% show_error "The Git install root folder "%~2", you specified does not exist!"
|
||||||
exit /b
|
exit /b
|
||||||
)
|
)
|
||||||
|
) else if /i "%1"=="/nix_tools" (
|
||||||
|
if "%2" equ "0" (
|
||||||
|
REM Do not add *nix tools to path
|
||||||
|
set nix_tools=0
|
||||||
|
shift
|
||||||
|
) else if "%2" equ "1" (
|
||||||
|
REM Add *nix tools to end of path
|
||||||
|
set nix_tools=1
|
||||||
|
shift
|
||||||
|
) else if "%2" equ "2" (
|
||||||
|
REM Add *nix tools to front of path
|
||||||
|
set nix_tools=2
|
||||||
|
shift
|
||||||
|
)
|
||||||
) else if /i "%1" == "/home" (
|
) else if /i "%1" == "/home" (
|
||||||
if exist "%~2" (
|
if exist "%~2" (
|
||||||
set "HOME=%~2"
|
set "HOME=%~2"
|
||||||
@ -122,12 +138,14 @@ if "%CMDER_CLINK%" == "1" (
|
|||||||
if defined CMDER_USER_CONFIG (
|
if defined CMDER_USER_CONFIG (
|
||||||
if not exist "%CMDER_USER_CONFIG%\settings" (
|
if not exist "%CMDER_USER_CONFIG%\settings" (
|
||||||
echo Generating clink initial settings in "%CMDER_USER_CONFIG%\settings"
|
echo Generating clink initial settings in "%CMDER_USER_CONFIG%\settings"
|
||||||
|
copy "%CMDER_ROOT%\vendor\clink_settings.default" "%CMDER_USER_CONFIG%\settings"
|
||||||
echo Additional *.lua files in "%CMDER_USER_CONFIG%" are loaded on startup.\
|
echo Additional *.lua files in "%CMDER_USER_CONFIG%" are loaded on startup.\
|
||||||
)
|
)
|
||||||
"%CMDER_ROOT%\vendor\clink\clink_x%architecture%.exe" inject --quiet --profile "%CMDER_USER_CONFIG%" --scripts "%CMDER_ROOT%\vendor"
|
"%CMDER_ROOT%\vendor\clink\clink_x%architecture%.exe" inject --quiet --profile "%CMDER_USER_CONFIG%" --scripts "%CMDER_ROOT%\vendor"
|
||||||
) else (
|
) else (
|
||||||
if not exist "%CMDER_ROOT%\config\settings" (
|
if not exist "%CMDER_ROOT%\config\settings" (
|
||||||
echo Generating clink initial settings in "%CMDER_ROOT%\config\settings"
|
echo Generating clink initial settings in "%CMDER_ROOT%\config\settings"
|
||||||
|
copy "%CMDER_ROOT%\vendor\clink_settings.default" "%CMDER_ROOT%\config\settings"
|
||||||
echo Additional *.lua files in "%CMDER_ROOT%\config" are loaded on startup.
|
echo Additional *.lua files in "%CMDER_ROOT%\config" are loaded on startup.
|
||||||
)
|
)
|
||||||
"%CMDER_ROOT%\vendor\clink\clink_x%architecture%.exe" inject --quiet --profile "%CMDER_ROOT%\config" --scripts "%CMDER_ROOT%\vendor"
|
"%CMDER_ROOT%\vendor\clink\clink_x%architecture%.exe" inject --quiet --profile "%CMDER_ROOT%\config" --scripts "%CMDER_ROOT%\vendor"
|
||||||
@ -215,7 +233,7 @@ for /F "delims=" %%F in ('where git.exe 2^>nul') do (
|
|||||||
:VENDORED_GIT
|
:VENDORED_GIT
|
||||||
if exist "%CMDER_ROOT%\vendor\git-for-windows" (
|
if exist "%CMDER_ROOT%\vendor\git-for-windows" (
|
||||||
set "GIT_INSTALL_ROOT=%CMDER_ROOT%\vendor\git-for-windows"
|
set "GIT_INSTALL_ROOT=%CMDER_ROOT%\vendor\git-for-windows"
|
||||||
%lib_console% debug_output "Using vendored Git from '!GIT_INSTALL_ROOT!..."
|
%lib_console% debug_output "Using vendored Git '!GIT_VERSION_VENDORED!' from '!GIT_INSTALL_ROOT!..."
|
||||||
goto :CONFIGURE_GIT
|
goto :CONFIGURE_GIT
|
||||||
) else (
|
) else (
|
||||||
goto :NO_GIT
|
goto :NO_GIT
|
||||||
@ -226,26 +244,44 @@ if exist "%CMDER_ROOT%\vendor\git-for-windows" (
|
|||||||
goto :CONFIGURE_GIT
|
goto :CONFIGURE_GIT
|
||||||
|
|
||||||
:FOUND_GIT
|
:FOUND_GIT
|
||||||
%lib_console% debug_output "Using found Git from '%GIT_INSTALL_ROOT%..."
|
%lib_console% debug_output "Using found Git '!GIT_VERSION_USER!' from '%GIT_INSTALL_ROOT%..."
|
||||||
goto :CONFIGURE_GIT
|
goto :CONFIGURE_GIT
|
||||||
|
|
||||||
:CONFIGURE_GIT
|
:CONFIGURE_GIT
|
||||||
:: Add git to the path
|
:: Add git to the path
|
||||||
if defined GIT_INSTALL_ROOT (
|
if defined GIT_INSTALL_ROOT (
|
||||||
rem add the unix commands at the end to not shadow windows commands like more
|
rem add the unix commands at the end to not shadow windows commands like more
|
||||||
if exist "!GIT_INSTALL_ROOT!\cmd\git.exe" %lib_path% enhance_path "!GIT_INSTALL_ROOT!\cmd" append
|
if %nix_tools% equ 1 (
|
||||||
if exist "!GIT_INSTALL_ROOT!\mingw32" (
|
%lib_console% debug_output init.bat "Preferring Windows commands"
|
||||||
%lib_path% enhance_path "!GIT_INSTALL_ROOT!\mingw32\bin" append
|
set "path_position=append"
|
||||||
) else if exist "!GIT_INSTALL_ROOT!\mingw64" (
|
) else (
|
||||||
%lib_path% enhance_path "!GIT_INSTALL_ROOT!\mingw64\bin" append
|
%lib_console% debug_output init.bat "Preferring *nix commands"
|
||||||
|
set "path_position="
|
||||||
|
)
|
||||||
|
|
||||||
|
if exist "!GIT_INSTALL_ROOT!\cmd\git.exe" %lib_path% enhance_path "!GIT_INSTALL_ROOT!\cmd" !path_position!
|
||||||
|
if exist "!GIT_INSTALL_ROOT!\mingw32" (
|
||||||
|
%lib_path% enhance_path "!GIT_INSTALL_ROOT!\mingw32\bin" !path_position!
|
||||||
|
) else if exist "!GIT_INSTALL_ROOT!\mingw64" (
|
||||||
|
%lib_path% enhance_path "!GIT_INSTALL_ROOT!\mingw64\bin" !path_position!
|
||||||
|
)
|
||||||
|
|
||||||
|
if %nix_tools% geq 1 (
|
||||||
|
%lib_path% enhance_path "!GIT_INSTALL_ROOT!\usr\bin" !path_position!
|
||||||
)
|
)
|
||||||
%lib_path% enhance_path "!GIT_INSTALL_ROOT!\usr\bin" append
|
|
||||||
|
|
||||||
:: define SVN_SSH so we can use git svn with ssh svn repositories
|
:: define SVN_SSH so we can use git svn with ssh svn repositories
|
||||||
if not defined SVN_SSH set "SVN_SSH=%GIT_INSTALL_ROOT:\=\\%\\bin\\ssh.exe"
|
if not defined SVN_SSH set "SVN_SSH=%GIT_INSTALL_ROOT:\=\\%\\bin\\ssh.exe"
|
||||||
|
|
||||||
for /F "delims=" %%F in ('env /usr/bin/locale -uU 2') do (
|
if not defined LANG (
|
||||||
set "LANG=%%F"
|
:: Find locale.exe: From the git install root, from the path, using the git installed env, or fallback using the env from the path.
|
||||||
|
if not defined git_locale if exist "!GIT_INSTALL_ROOT!\usr\bin\locale.exe" set git_locale="!GIT_INSTALL_ROOT!\usr\bin\locale.exe"
|
||||||
|
if not defined git_locale for /F "delims=" %%F in ('where locale.exe 2^>nul') do (if not defined git_locale set git_locale="%%F")
|
||||||
|
if not defined git_locale if exist "!GIT_INSTALL_ROOT!\usr\bin\env.exe" set git_locale="!GIT_INSTALL_ROOT!\usr\bin\env.exe" /usr/bin/locale
|
||||||
|
if not defined git_locale set git_locale=env /usr/bin/locale
|
||||||
|
for /F "delims=" %%F in ('!git_locale! -uU 2') do (
|
||||||
|
set "LANG=%%F"
|
||||||
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -277,7 +313,7 @@ if defined CMDER_USER_CONFIG (
|
|||||||
:: scripts run above by setting the 'aliases' env variable.
|
:: scripts run above by setting the 'aliases' env variable.
|
||||||
::
|
::
|
||||||
:: Note: If overriding default aliases store file the aliases
|
:: Note: If overriding default aliases store file the aliases
|
||||||
:: must also be self executing, see '.\user_aliases.cmd.example',
|
:: must also be self executing, see '.\user_aliases.cmd.default',
|
||||||
:: and be in profile.d folder.
|
:: and be in profile.d folder.
|
||||||
if not defined user_aliases (
|
if not defined user_aliases (
|
||||||
if defined CMDER_USER_CONFIG (
|
if defined CMDER_USER_CONFIG (
|
||||||
@ -298,17 +334,17 @@ if "%CMDER_ALIASES%" == "1" (
|
|||||||
setlocal enabledelayedexpansion
|
setlocal enabledelayedexpansion
|
||||||
if not exist "%user_aliases%" (
|
if not exist "%user_aliases%" (
|
||||||
echo Creating initial user_aliases store in "%user_aliases%"...
|
echo Creating initial user_aliases store in "%user_aliases%"...
|
||||||
copy "%CMDER_ROOT%\vendor\user_aliases.cmd.example" "%user_aliases%"
|
copy "%CMDER_ROOT%\vendor\user_aliases.cmd.default" "%user_aliases%"
|
||||||
) else (
|
) else (
|
||||||
type "%user_aliases%" | findstr /i ";= Add aliases below here" >nul
|
type "%user_aliases%" | %WINDIR%\System32\findstr /i ";= Add aliases below here" >nul
|
||||||
if "!errorlevel!" == "1" (
|
if "!errorlevel!" == "1" (
|
||||||
echo Creating initial user_aliases store in "%user_aliases%"...
|
echo Creating initial user_aliases store in "%user_aliases%"...
|
||||||
if defined CMDER_USER_CONFIG (
|
if defined CMDER_USER_CONFIG (
|
||||||
copy "%user_aliases%" "%user_aliases%.old_format"
|
copy "%user_aliases%" "%user_aliases%.old_format"
|
||||||
copy "%CMDER_ROOT%\vendor\user_aliases.cmd.example" "%user_aliases%"
|
copy "%CMDER_ROOT%\vendor\user_aliases.cmd.default" "%user_aliases%"
|
||||||
) else (
|
) else (
|
||||||
copy "%user_aliases%" "%user_aliases%.old_format"
|
copy "%user_aliases%" "%user_aliases%.old_format"
|
||||||
copy "%CMDER_ROOT%\vendor\user_aliases.cmd.example" "%user_aliases%"
|
copy "%CMDER_ROOT%\vendor\user_aliases.cmd.default" "%user_aliases%"
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
@ -333,9 +369,9 @@ call "%user_aliases%"
|
|||||||
:: Basically we need to execute this post-install.bat because we are
|
:: Basically we need to execute this post-install.bat because we are
|
||||||
:: manually extracting the archive rather than executing the 7z sfx
|
:: manually extracting the archive rather than executing the 7z sfx
|
||||||
if exist "%GIT_INSTALL_ROOT%\post-install.bat" (
|
if exist "%GIT_INSTALL_ROOT%\post-install.bat" (
|
||||||
%lib_console% verbose_output "Running Git for Windows one time Post Install...."
|
echo Running Git for Windows one time Post Install....
|
||||||
pushd "%GIT_INSTALL_ROOT%\"
|
pushd "%GIT_INSTALL_ROOT%\"
|
||||||
"%GIT_INSTALL_ROOT%\git-bash.exe" --no-needs-console --hide --no-cd --command=post-install.bat
|
"%GIT_INSTALL_ROOT%\git-cmd.exe" --no-needs-console --no-cd --command=post-install.bat
|
||||||
popd
|
popd
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -346,6 +382,7 @@ if not defined HOME set "HOME=%USERPROFILE%"
|
|||||||
set "initialConfig=%CMDER_ROOT%\config\user_profile.cmd"
|
set "initialConfig=%CMDER_ROOT%\config\user_profile.cmd"
|
||||||
if exist "%CMDER_ROOT%\config\user_profile.cmd" (
|
if exist "%CMDER_ROOT%\config\user_profile.cmd" (
|
||||||
REM Create this file and place your own command in there
|
REM Create this file and place your own command in there
|
||||||
|
%lib_console% debug_output init.bat "Calling - %CMDER_ROOT%\config\user_profile.cmd"
|
||||||
call "%CMDER_ROOT%\config\user_profile.cmd"
|
call "%CMDER_ROOT%\config\user_profile.cmd"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -353,33 +390,14 @@ if defined CMDER_USER_CONFIG (
|
|||||||
set "initialConfig=%CMDER_USER_CONFIG%\user_profile.cmd"
|
set "initialConfig=%CMDER_USER_CONFIG%\user_profile.cmd"
|
||||||
if exist "%CMDER_USER_CONFIG%\user_profile.cmd" (
|
if exist "%CMDER_USER_CONFIG%\user_profile.cmd" (
|
||||||
REM Create this file and place your own command in there
|
REM Create this file and place your own command in there
|
||||||
|
%lib_console% debug_output init.bat "Calling - %CMDER_USER_CONFIG%\user_profile.cmd
|
||||||
call "%CMDER_USER_CONFIG%\user_profile.cmd"
|
call "%CMDER_USER_CONFIG%\user_profile.cmd"
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
if not exist "%initialConfig%" (
|
if not exist "%initialConfig%" (
|
||||||
echo Creating user startup file: "%initialConfig%"
|
echo Creating user startup file: "%initialConfig%"
|
||||||
(
|
copy "%CMDER_ROOT%\vendor\user_profile.cmd.default" "%initialConfig%"
|
||||||
echo :: use this file to run your own startup commands
|
|
||||||
echo :: use in front of the command to prevent printing the command
|
|
||||||
echo.
|
|
||||||
echo :: uncomment this to have the ssh agent load when cmder starts
|
|
||||||
echo :: call "%%GIT_INSTALL_ROOT%%/cmd/start-ssh-agent.cmd"
|
|
||||||
echo.
|
|
||||||
echo :: uncomment the next two lines to use pageant as the ssh authentication agent
|
|
||||||
echo :: SET SSH_AUTH_SOCK=/tmp/.ssh-pageant-auth-sock
|
|
||||||
echo :: call "%%GIT_INSTALL_ROOT%%/cmd/start-ssh-pageant.cmd"
|
|
||||||
echo.
|
|
||||||
echo :: you can add your plugins to the cmder path like so
|
|
||||||
echo :: set "PATH=%%CMDER_ROOT%%\vendor\whatever;%%PATH%%"
|
|
||||||
echo.
|
|
||||||
echo :: arguments in this batch are passed from init.bat, you can quickly parse them like so:
|
|
||||||
echo :: more useage can be seen by typing "cexec /?"
|
|
||||||
echo.
|
|
||||||
echo :: %%ccall%% "/customOption" "command/program"
|
|
||||||
echo.
|
|
||||||
echo @echo off
|
|
||||||
) >"%initialConfig%"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
if "%CMDER_ALIASES%" == "1" if exist "%CMDER_ROOT%\bin\alias.bat" if exist "%CMDER_ROOT%\vendor\bin\alias.cmd" (
|
if "%CMDER_ALIASES%" == "1" if exist "%CMDER_ROOT%\bin\alias.bat" if exist "%CMDER_ROOT%\vendor\bin\alias.cmd" (
|
||||||
@ -398,9 +416,9 @@ if "%CMDER_ALIASES%" == "1" if exist "%CMDER_ROOT%\bin\alias.bat" if exist "%CMD
|
|||||||
set initialConfig=
|
set initialConfig=
|
||||||
set CMDER_CONFIGURED=1
|
set CMDER_CONFIGURED=1
|
||||||
|
|
||||||
set cmder_init_end=%time%
|
set CMDER_INIT_END=%time%
|
||||||
|
|
||||||
if %time_init% gtr 0 (
|
if %time_init% gtr 0 (
|
||||||
%cmder_root%\vendor\bin\timer.cmd %cmder_init_start% %cmder_init_end%
|
"%cmder_root%\vendor\bin\timer.cmd" %CMDER_INIT_START% %CMDER_INIT_END%
|
||||||
)
|
)
|
||||||
exit /b
|
exit /b
|
||||||
|
25
vendor/lib/lib_base.cmd
vendored
25
vendor/lib/lib_base.cmd
vendored
@ -27,7 +27,7 @@ exit /b
|
|||||||
::: file <in> full path to file containing lib_routines to display
|
::: file <in> full path to file containing lib_routines to display
|
||||||
:::.
|
:::.
|
||||||
:::-------------------------------------------------------------------------------
|
:::-------------------------------------------------------------------------------
|
||||||
for /f "tokens=* delims=:" %%a in ('type "%~1" ^| findstr /i /r "^:::"') do (
|
for /f "tokens=* delims=:" %%a in ('type "%~1" ^| %WINDIR%\System32\findstr /i /r "^:::"') do (
|
||||||
rem echo a="%%a"
|
rem echo a="%%a"
|
||||||
|
|
||||||
if "%%a"=="." (
|
if "%%a"=="." (
|
||||||
@ -61,16 +61,21 @@ exit /b
|
|||||||
::: file <in> full path to file containing lib_routines to display
|
::: file <in> full path to file containing lib_routines to display
|
||||||
:::.
|
:::.
|
||||||
:::-------------------------------------------------------------------------------
|
:::-------------------------------------------------------------------------------
|
||||||
echo %comspec% | find /i "\cmd.exe" > nul && set "CMDER_SHELL=cmd"
|
echo %comspec% | %WINDIR%\System32\find /i "\cmd.exe" > nul && set "CMDER_SHELL=cmd"
|
||||||
echo %comspec% | find /i "\tcc.exe" > nul && set "CMDER_SHELL=tcc"
|
echo %comspec% | %WINDIR%\System32\find /i "\tcc.exe" > nul && set "CMDER_SHELL=tcc"
|
||||||
echo %comspec% | find /i "\tccle" > nul && set "CMDER_SHELL=tccle"
|
echo %comspec% | %WINDIR%\System32\find /i "\tccle" > nul && set "CMDER_SHELL=tccle"
|
||||||
|
|
||||||
set CMDER_CLINK=1
|
if not defined CMDER_CLINK (
|
||||||
if "%CMDER_SHELL%" equ "tcc" set CMDER_CLINK=0
|
set CMDER_CLINK=1
|
||||||
if "%CMDER_SHELL%" equ "tccle" set CMDER_CLINK=0
|
if "%CMDER_SHELL%" equ "tcc" set CMDER_CLINK=0
|
||||||
|
if "%CMDER_SHELL%" equ "tccle" set CMDER_CLINK=0
|
||||||
|
)
|
||||||
|
|
||||||
set CMDER_ALIASES=1
|
|
||||||
if "%CMDER_SHELL%" equ "tcc" set CMDER_ALIASES=0
|
if not defined CMDER_ALIASES (
|
||||||
if "%CMDER_SHELL%" equ "tccle" set CMDER_ALIASES=0
|
set CMDER_ALIASES=1
|
||||||
|
if "%CMDER_SHELL%" equ "tcc" set CMDER_ALIASES=0
|
||||||
|
if "%CMDER_SHELL%" equ "tccle" set CMDER_ALIASES=0
|
||||||
|
)
|
||||||
|
|
||||||
exit /b
|
exit /b
|
||||||
|
6
vendor/lib/lib_git.cmd
vendored
6
vendor/lib/lib_git.cmd
vendored
@ -88,8 +88,11 @@ exit /b
|
|||||||
::: [SCOPE]_BUILD <out> Scoped Build version.
|
::: [SCOPE]_BUILD <out> Scoped Build version.
|
||||||
:::-------------------------------------------------------------------------------
|
:::-------------------------------------------------------------------------------
|
||||||
|
|
||||||
setlocal enabledelayedexpansion
|
|
||||||
:: process a `x.x.x.xxxx.x` formatted string
|
:: process a `x.x.x.xxxx.x` formatted string
|
||||||
|
set "%~1_MAJOR="
|
||||||
|
set "%~1_MINOR="
|
||||||
|
set "%~1_PATCH="
|
||||||
|
set "%~1_BUILD="
|
||||||
%lib_console% debug_output :parse_version "ARGV[1]=%~1, ARGV[2]=%~2"
|
%lib_console% debug_output :parse_version "ARGV[1]=%~1, ARGV[2]=%~2"
|
||||||
for /F "tokens=1-3* delims=.,-" %%A in ("%2") do (
|
for /F "tokens=1-3* delims=.,-" %%A in ("%2") do (
|
||||||
set "%~1_MAJOR=%%A"
|
set "%~1_MAJOR=%%A"
|
||||||
@ -98,7 +101,6 @@ exit /b
|
|||||||
set "%~1_BUILD=%%D"
|
set "%~1_BUILD=%%D"
|
||||||
)
|
)
|
||||||
|
|
||||||
endlocal & set "%~1_MAJOR=!%~1_MAJOR!" & set "%~1_MINOR=!%~1_MINOR!" & set "%~1_PATCH=!%~1_PATCH!" & set "%~1_BUILD=!%~1_BUILD!"
|
|
||||||
exit /b
|
exit /b
|
||||||
|
|
||||||
:validate_version
|
:validate_version
|
||||||
|
4
vendor/lib/lib_path.cmd
vendored
4
vendor/lib/lib_path.cmd
vendored
@ -68,14 +68,14 @@ exit /b
|
|||||||
|
|
||||||
if "%CMDER_CONFIGURED%" == "1" (
|
if "%CMDER_CONFIGURED%" == "1" (
|
||||||
%lib_console% debug_output :enhance_path "Env Var - find_query=%find_query%"
|
%lib_console% debug_output :enhance_path "Env Var - find_query=%find_query%"
|
||||||
echo "%path%"|findstr >nul /I /R ";%find_query%\"$"
|
echo "%path%"|%WINDIR%\System32\findstr >nul /I /R ";%find_query%\"$"
|
||||||
if "!ERRORLEVEL!" == "0" set found=1
|
if "!ERRORLEVEL!" == "0" set found=1
|
||||||
)
|
)
|
||||||
%lib_console% debug_output :enhance_path "Env Var 1 - found=!found!"
|
%lib_console% debug_output :enhance_path "Env Var 1 - found=!found!"
|
||||||
|
|
||||||
if "!found!" == "0" (
|
if "!found!" == "0" (
|
||||||
if "%CMDER_CONFIGURED%" == "1" (
|
if "%CMDER_CONFIGURED%" == "1" (
|
||||||
echo "%path%"|findstr >nul /i /r ";%find_query%;"
|
echo "%path%"|%WINDIR%\System32\findstr >nul /i /r ";%find_query%;"
|
||||||
if "!ERRORLEVEL!" == "0" set found=1
|
if "!ERRORLEVEL!" == "0" set found=1
|
||||||
)
|
)
|
||||||
%lib_console% debug_output :enhance_path "Env Var 2 - found=!found!"
|
%lib_console% debug_output :enhance_path "Env Var 2 - found=!found!"
|
||||||
|
22
vendor/lib/start-ssh-agent.sh
vendored
Normal file
22
vendor/lib/start-ssh-agent.sh
vendored
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
# Copied from https://help.github.com/articles/working-with-ssh-key-passphrases
|
||||||
|
env=~/.ssh/agent.env
|
||||||
|
|
||||||
|
agent_load_env () { test -f "$env" && . "$env" >| /dev/null ; }
|
||||||
|
|
||||||
|
agent_start () {
|
||||||
|
(umask 077; ssh-agent >| "$env")
|
||||||
|
. "$env" >| /dev/null ; }
|
||||||
|
|
||||||
|
agent_load_env
|
||||||
|
|
||||||
|
# agent_run_state: 0=agent running w/ key; 1=agent w/o key; 2= agent not running
|
||||||
|
agent_run_state=$(ssh-add -l >| /dev/null 2>&1; echo $?)
|
||||||
|
|
||||||
|
if [ ! "$SSH_AUTH_SOCK" ] || [ $agent_run_state = 2 ]; then
|
||||||
|
agent_start
|
||||||
|
ssh-add
|
||||||
|
elif [ "$SSH_AUTH_SOCK" ] && [ $agent_run_state = 1 ]; then
|
||||||
|
ssh-add
|
||||||
|
fi
|
||||||
|
|
||||||
|
unset env
|
190
vendor/profile.ps1
vendored
190
vendor/profile.ps1
vendored
@ -25,9 +25,9 @@ if (! $ENV:CMDER_ROOT ) {
|
|||||||
# Remove trailing '\'
|
# Remove trailing '\'
|
||||||
$ENV:CMDER_ROOT = (($ENV:CMDER_ROOT).trimend("\"))
|
$ENV:CMDER_ROOT = (($ENV:CMDER_ROOT).trimend("\"))
|
||||||
|
|
||||||
# do not load bundled psget if a module installer is already available
|
# Do not load bundled psget if a module installer is already available
|
||||||
# -> recent PowerShell versions include PowerShellGet out of the box
|
# -> recent PowerShell versions include PowerShellGet out of the box
|
||||||
$moduleInstallerAvailable = [bool](Get-Command -Name 'Install-Module' -ErrorAction SilentlyContinue | Out-Null)
|
$moduleInstallerAvailable = [bool](Get-Command -Name 'Install-Module' -ErrorAction SilentlyContinue)
|
||||||
|
|
||||||
# Add Cmder modules directory to the autoload path.
|
# Add Cmder modules directory to the autoload path.
|
||||||
$CmderModulePath = Join-path $PSScriptRoot "psmodules/"
|
$CmderModulePath = Join-path $PSScriptRoot "psmodules/"
|
||||||
@ -36,26 +36,21 @@ if(-not $moduleInstallerAvailable -and -not $env:PSModulePath.Contains($CmderMod
|
|||||||
$env:PSModulePath = $env:PSModulePath.Insert(0, "$CmderModulePath;")
|
$env:PSModulePath = $env:PSModulePath.Insert(0, "$CmderModulePath;")
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
function Configure-Git($GIT_INSTALL_ROOT){
|
||||||
Get-command -Name "vim" -ErrorAction Stop >$null
|
$env:Path += $(";" + $GIT_INSTALL_ROOT + "\cmd")
|
||||||
} catch {
|
|
||||||
# # You could do this but it may be a little drastic and introduce a lot of
|
|
||||||
# # unix tool overlap with powershel unix like aliases
|
|
||||||
# $env:Path += $(";" + $env:CMDER_ROOT + "\vendor\git-for-windows\usr\bin")
|
|
||||||
# set-alias -name "vi" -value "vim"
|
|
||||||
# # I think the below is safer.
|
|
||||||
|
|
||||||
new-alias -name "vim" -value $($ENV:CMDER_ROOT + "\vendor\git-for-windows\usr\bin\vim.exe")
|
# Add "$GIT_INSTALL_ROOT\usr\bin" to the path if exists and not done already
|
||||||
new-alias -name "vi" -value vim
|
$GIT_INSTALL_ROOT_ESC=$GIT_INSTALL_ROOT.replace('\','\\')
|
||||||
}
|
if ((test-path "$GIT_INSTALL_ROOT\usr\bin") -and -not ($env:path -match "$GIT_INSTALL_ROOT_ESC\\usr\\bin")) {
|
||||||
|
$env:path = "$env:path;$GIT_INSTALL_ROOT\usr\bin"
|
||||||
try {
|
}
|
||||||
# Check if git is on PATH, i.e. Git already installed on system
|
|
||||||
Get-command -Name "git" -ErrorAction Stop >$null
|
# Add "$GIT_INSTALL_ROOT\mingw[32|64]\bin" to the path if exists and not done already
|
||||||
} catch {
|
if ((test-path "$GIT_INSTALL_ROOT\mingw32\bin") -and -not ($env:path -match "$GIT_INSTALL_ROOT_ESC\\mingw32\\bin")) {
|
||||||
$env:Path += $(";" + $env:CMDER_ROOT + "\vendor\git-for-windows\cmd")
|
$env:path = "$env:path;$GIT_INSTALL_ROOT\mingw32\bin"
|
||||||
# for bash.exe, which in the cmd version is found as <GIT>\usr\bin\bash.exe
|
} elseif ((test-path "$GIT_INSTALL_ROOT\mingw64\bin") -and -not ($env:path -match "$GIT_INSTALL_ROOT_ESC\\mingw64\\bin")) {
|
||||||
$env:Path += $(";" + $env:CMDER_ROOT + "\vendor\git-for-windows\bin")
|
$env:path = "$env:path;$GIT_INSTALL_ROOT\mingw64\bin"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$gitLoaded = $false
|
$gitLoaded = $false
|
||||||
@ -84,6 +79,19 @@ function checkGit($Path) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
# Check if git is on PATH, i.e. Git already installed on system
|
||||||
|
Get-command -Name "git" -ErrorAction Stop >$null
|
||||||
|
} catch {
|
||||||
|
if (test-path "$env:CMDER_ROOT\vendor\git-for-windows") {
|
||||||
|
Configure-Git "$env:CMDER_ROOT\vendor\git-for-windows"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( Get-command -Name "vim" -ErrorAction silentlycontinue) {
|
||||||
|
new-alias -name "vi" -value vim
|
||||||
|
}
|
||||||
|
|
||||||
if (Get-Module PSReadline -ErrorAction "SilentlyContinue") {
|
if (Get-Module PSReadline -ErrorAction "SilentlyContinue") {
|
||||||
Set-PSReadlineOption -ExtraPromptLineCount 1
|
Set-PSReadlineOption -ExtraPromptLineCount 1
|
||||||
}
|
}
|
||||||
@ -91,36 +99,6 @@ if (Get-Module PSReadline -ErrorAction "SilentlyContinue") {
|
|||||||
# Enhance Path
|
# Enhance Path
|
||||||
$env:Path = "$Env:CMDER_ROOT\bin;$Env:CMDER_ROOT\vendor\bin;$env:Path;$Env:CMDER_ROOT"
|
$env:Path = "$Env:CMDER_ROOT\bin;$Env:CMDER_ROOT\vendor\bin;$env:Path;$Env:CMDER_ROOT"
|
||||||
|
|
||||||
#
|
|
||||||
# Prompt Section
|
|
||||||
# Users should modify their user_profile.ps1 as it will be safe from updates.
|
|
||||||
#
|
|
||||||
|
|
||||||
# Pre assign the hooks so the first run of cmder gets a working prompt.
|
|
||||||
[ScriptBlock]$PrePrompt = {}
|
|
||||||
[ScriptBlock]$PostPrompt = {}
|
|
||||||
[ScriptBlock]$CmderPrompt = {
|
|
||||||
$Host.UI.RawUI.ForegroundColor = "White"
|
|
||||||
Microsoft.PowerShell.Utility\Write-Host $pwd.ProviderPath -NoNewLine -ForegroundColor Green
|
|
||||||
checkGit($pwd.ProviderPath)
|
|
||||||
}
|
|
||||||
|
|
||||||
<#
|
|
||||||
This scriptblock runs every time the prompt is returned.
|
|
||||||
Explicitly use functions from MS namespace to protect from being overridden in the user session.
|
|
||||||
Custom prompt functions are loaded in as constants to get the same behaviour
|
|
||||||
#>
|
|
||||||
[ScriptBlock]$Prompt = {
|
|
||||||
$realLASTEXITCODE = $LASTEXITCODE
|
|
||||||
$host.UI.RawUI.WindowTitle = Microsoft.PowerShell.Management\Split-Path $pwd.ProviderPath -Leaf
|
|
||||||
PrePrompt | Microsoft.PowerShell.Utility\Write-Host -NoNewline
|
|
||||||
CmderPrompt
|
|
||||||
Microsoft.PowerShell.Utility\Write-Host "`nλ " -NoNewLine -ForegroundColor "DarkGray"
|
|
||||||
PostPrompt | Microsoft.PowerShell.Utility\Write-Host -NoNewline
|
|
||||||
$global:LASTEXITCODE = $realLASTEXITCODE
|
|
||||||
return " "
|
|
||||||
}
|
|
||||||
|
|
||||||
# Drop *.ps1 files into "$ENV:CMDER_ROOT\config\profile.d"
|
# Drop *.ps1 files into "$ENV:CMDER_ROOT\config\profile.d"
|
||||||
# to source them at startup.
|
# to source them at startup.
|
||||||
if (-not (test-path "$ENV:CMDER_ROOT\config\profile.d")) {
|
if (-not (test-path "$ENV:CMDER_ROOT\config\profile.d")) {
|
||||||
@ -128,23 +106,33 @@ if (-not (test-path "$ENV:CMDER_ROOT\config\profile.d")) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pushd $ENV:CMDER_ROOT\config\profile.d
|
pushd $ENV:CMDER_ROOT\config\profile.d
|
||||||
foreach ($x in Get-ChildItem *.ps1) {
|
foreach ($x in Get-ChildItem *.psm1) {
|
||||||
# write-host write-host Sourcing $x
|
# write-host write-host Sourcing $x
|
||||||
Import-Module $x
|
Import-Module $x
|
||||||
}
|
}
|
||||||
|
|
||||||
|
foreach ($x in Get-ChildItem *.ps1) {
|
||||||
|
# write-host write-host Sourcing $x
|
||||||
|
. $x
|
||||||
|
}
|
||||||
popd
|
popd
|
||||||
|
|
||||||
# Drop *.ps1 files into "$ENV:CMDER_USER_CONFIG\config\profile.d"
|
# Drop *.ps1 files into "$ENV:CMDER_USER_CONFIG\config\profile.d"
|
||||||
# to source them at startup. Requires using cmder.exe /C [cmder_user_root_path] argument
|
# to source them at startup. Requires using cmder.exe /C [cmder_user_root_path] argument
|
||||||
if ($ENV:CMDER_USER_CONFIG -ne "" -and (test-path "$ENV:CMDER_USER_CONFIG\profile.d")) {
|
if ($ENV:CMDER_USER_CONFIG -ne "" -and (test-path "$ENV:CMDER_USER_CONFIG\profile.d")) {
|
||||||
pushd $ENV:CMDER_USER_CONFIG\profile.d
|
pushd $ENV:CMDER_USER_CONFIG\profile.d
|
||||||
foreach ($x in Get-ChildItem *.ps1) {
|
foreach ($x in Get-ChildItem *.psm1) {
|
||||||
# write-host write-host Sourcing $x
|
# write-host write-host Sourcing $x
|
||||||
Import-Module $x
|
Import-Module $x
|
||||||
}
|
}
|
||||||
|
|
||||||
|
foreach ($x in Get-ChildItem *.ps1) {
|
||||||
|
# write-host write-host Sourcing $x
|
||||||
|
. $x
|
||||||
|
}
|
||||||
popd
|
popd
|
||||||
}
|
}
|
||||||
|
|
||||||
# Renaming to "config\user_profile.ps1" to "user_profile.ps1" for consistency.
|
# Renaming to "config\user_profile.ps1" to "user_profile.ps1" for consistency.
|
||||||
if (test-path "$env:CMDER_ROOT\config\user-profile.ps1") {
|
if (test-path "$env:CMDER_ROOT\config\user-profile.ps1") {
|
||||||
rename-item "$env:CMDER_ROOT\config\user-profile.ps1" user_profile.ps1
|
rename-item "$env:CMDER_ROOT\config\user-profile.ps1" user_profile.ps1
|
||||||
@ -153,7 +141,7 @@ if (test-path "$env:CMDER_ROOT\config\user-profile.ps1") {
|
|||||||
$CmderUserProfilePath = Join-Path $env:CMDER_ROOT "config\user_profile.ps1"
|
$CmderUserProfilePath = Join-Path $env:CMDER_ROOT "config\user_profile.ps1"
|
||||||
if (Test-Path $CmderUserProfilePath) {
|
if (Test-Path $CmderUserProfilePath) {
|
||||||
# Create this file and place your own command in there.
|
# Create this file and place your own command in there.
|
||||||
Import-Module "$CmderUserProfilePath"
|
. "$CmderUserProfilePath" # user_profile.ps1 is not a module DO NOT USE import-module
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($ENV:CMDER_USER_CONFIG) {
|
if ($ENV:CMDER_USER_CONFIG) {
|
||||||
@ -166,53 +154,63 @@ if ($ENV:CMDER_USER_CONFIG) {
|
|||||||
|
|
||||||
$CmderUserProfilePath = Join-Path $ENV:CMDER_USER_CONFIG "user_profile.ps1"
|
$CmderUserProfilePath = Join-Path $ENV:CMDER_USER_CONFIG "user_profile.ps1"
|
||||||
if (Test-Path $CmderUserProfilePath) {
|
if (Test-Path $CmderUserProfilePath) {
|
||||||
Import-Module "$CmderUserProfilePath"
|
. "$CmderUserProfilePath" # user_profile.ps1 is not a module DO NOT USE import-module
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! (Test-Path $CmderUserProfilePath) ) {
|
if (! (Test-Path $CmderUserProfilePath) ) {
|
||||||
# This multiline string cannot be indented, for this reason I've not indented the whole block
|
Write-Host -BackgroundColor Darkgreen -ForegroundColor White "First Run: Creating user startup file: $CmderUserProfilePath"
|
||||||
|
Copy-Item "$env:CMDER_ROOT\vendor\user_profile.ps1.default" -Destination $CmderUserProfilePath
|
||||||
Write-Host -BackgroundColor Darkgreen -ForegroundColor White "First Run: Creating user startup file: $CmderUserProfilePath"
|
|
||||||
|
|
||||||
$UserProfileTemplate = @'
|
|
||||||
# Use this file to run your own startup commands
|
|
||||||
|
|
||||||
## Prompt Customization
|
|
||||||
<#
|
|
||||||
.SYNTAX
|
|
||||||
<PrePrompt><CMDER DEFAULT>
|
|
||||||
λ <PostPrompt> <repl input>
|
|
||||||
.EXAMPLE
|
|
||||||
<PrePrompt>N:\Documents\src\cmder [master]
|
|
||||||
λ <PostPrompt> |
|
|
||||||
#>
|
|
||||||
|
|
||||||
[ScriptBlock]$PrePrompt = {
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# Replace the cmder prompt entirely with this.
|
#
|
||||||
# [ScriptBlock]$CmderPrompt = {}
|
# Prompt Section
|
||||||
|
# Users should modify their user_profile.ps1 as it will be safe from updates.
|
||||||
|
#
|
||||||
|
|
||||||
[ScriptBlock]$PostPrompt = {
|
# Only set the prompt if it is currently set to the default
|
||||||
|
# This allows users to configure the prompt in their user_profile.ps1 or config\profile.d\*.ps1
|
||||||
|
if ( $(get-command prompt).Definition -match 'PS \$\(\$executionContext.SessionState.Path.CurrentLocation\)\$\(' -and `
|
||||||
|
$(get-command prompt).Definition -match '\(\$nestedPromptLevel \+ 1\)\) ";') {
|
||||||
|
# Pre assign the hooks so the first run of cmder gets a working prompt.
|
||||||
|
[ScriptBlock]$PrePrompt = {}
|
||||||
|
[ScriptBlock]$PostPrompt = {}
|
||||||
|
[ScriptBlock]$CmderPrompt = {
|
||||||
|
$Host.UI.RawUI.ForegroundColor = "White"
|
||||||
|
Microsoft.PowerShell.Utility\Write-Host $pwd.ProviderPath -NoNewLine -ForegroundColor Green
|
||||||
|
if (get-command git -erroraction silentlycontinue) {
|
||||||
|
checkGit($pwd.ProviderPath)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
<#
|
||||||
|
This scriptblock runs every time the prompt is returned.
|
||||||
|
Explicitly use functions from MS namespace to protect from being overridden in the user session.
|
||||||
|
Custom prompt functions are loaded in as constants to get the same behaviour
|
||||||
|
#>
|
||||||
|
[ScriptBlock]$Prompt = {
|
||||||
|
$realLASTEXITCODE = $LASTEXITCODE
|
||||||
|
$host.UI.RawUI.WindowTitle = Microsoft.PowerShell.Management\Split-Path $pwd.ProviderPath -Leaf
|
||||||
|
PrePrompt | Microsoft.PowerShell.Utility\Write-Host -NoNewline
|
||||||
|
CmderPrompt
|
||||||
|
Microsoft.PowerShell.Utility\Write-Host "`nλ " -NoNewLine -ForegroundColor "DarkGray"
|
||||||
|
PostPrompt | Microsoft.PowerShell.Utility\Write-Host -NoNewline
|
||||||
|
$global:LASTEXITCODE = $realLASTEXITCODE
|
||||||
|
return " "
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# Once Created these code blocks cannot be overwritten
|
||||||
|
# if (-not $(get-command PrePrompt).Options -match 'Constant') {Set-Item -Path function:\PrePrompt -Value $PrePrompt -Options Constant}
|
||||||
|
# if (-not $(get-command CmderPrompt).Options -match 'Constant') {Set-Item -Path function:\CmderPrompt -Value $CmderPrompt -Options Constant}
|
||||||
|
# if (-not $(get-command PostPrompt).Options -match 'Constant') {Set-Item -Path function:\PostPrompt -Value $PostPrompt -Options Constant}
|
||||||
|
|
||||||
|
Set-Item -Path function:\PrePrompt -Value $PrePrompt -Options Constant
|
||||||
|
Set-Item -Path function:\CmderPrompt -Value $CmderPrompt -Options Constant
|
||||||
|
Set-Item -Path function:\PostPrompt -Value $PostPrompt -Options Constant
|
||||||
|
|
||||||
|
# Functions can be made constant only at creation time
|
||||||
|
# ReadOnly at least requires `-force` to be overwritten
|
||||||
|
# if (!$(get-command Prompt).Options -match 'ReadOnly') {Set-Item -Path function:\prompt -Value $Prompt -Options ReadOnly}
|
||||||
|
Set-Item -Path function:\prompt -Value $Prompt -Options ReadOnly
|
||||||
}
|
}
|
||||||
|
|
||||||
## <Continue to add your own>
|
|
||||||
|
|
||||||
|
|
||||||
'@
|
|
||||||
|
|
||||||
New-Item -ItemType File -Path $CmderUserProfilePath -Value $UserProfileTemplate > $null
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
# Once Created these code blocks cannot be overwritten
|
|
||||||
Set-Item -Path function:\PrePrompt -Value $PrePrompt -Options Constant
|
|
||||||
Set-Item -Path function:\CmderPrompt -Value $CmderPrompt -Options Constant
|
|
||||||
Set-Item -Path function:\PostPrompt -Value $PostPrompt -Options Constant
|
|
||||||
|
|
||||||
# Functions can be made constant only at creation time
|
|
||||||
# ReadOnly at least requires `-force` to be overwritten
|
|
||||||
Set-Item -Path function:\prompt -Value $Prompt -Options ReadOnly
|
|
||||||
|
4
vendor/sources.json
vendored
4
vendor/sources.json
vendored
@ -1,8 +1,8 @@
|
|||||||
[
|
[
|
||||||
{
|
{
|
||||||
"name": "git-for-windows",
|
"name": "git-for-windows",
|
||||||
"version": "v2.19.0.windows.1",
|
"version": "v2.21.0.windows.1",
|
||||||
"url": "https://github.com/git-for-windows/git/releases/download/v2.19.0.windows.1/PortableGit-2.19.0-64-bit.7z.exe"
|
"url": "https://github.com/git-for-windows/git/releases/download/v2.21.0.windows.1/PortableGit-2.21.0-64-bit.7z.exe"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "clink",
|
"name": "clink",
|
||||||
|
@ -9,7 +9,7 @@ gl=git log --oneline --all --graph --decorate $*
|
|||||||
ls=ls --show-control-chars -F --color $*
|
ls=ls --show-control-chars -F --color $*
|
||||||
pwd=cd
|
pwd=cd
|
||||||
clear=cls
|
clear=cls
|
||||||
history=cat "%CMDER_ROOT%\config\.history"
|
history=cat -n "%CMDER_ROOT%\config\.history"
|
||||||
unalias=alias /d $1
|
unalias=alias /d $1
|
||||||
vi=vim $*
|
vi=vim $*
|
||||||
cmderr=cd /d "%CMDER_ROOT%"
|
cmderr=cd /d "%CMDER_ROOT%"
|
19
vendor/user_profile.cmd.default
vendored
Normal file
19
vendor/user_profile.cmd.default
vendored
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
:: use this file to run your own startup commands
|
||||||
|
:: use in front of the command to prevent printing the command
|
||||||
|
|
||||||
|
:: uncomment this to have the ssh agent load when cmder starts
|
||||||
|
:: call "%GIT_INSTALL_ROOT%/cmd/start-ssh-agent.cmd" /k exit
|
||||||
|
|
||||||
|
:: uncomment the next two lines to use pageant as the ssh authentication agent
|
||||||
|
:: SET SSH_AUTH_SOCK=/tmp/.ssh-pageant-auth-sock
|
||||||
|
:: call "%GIT_INSTALL_ROOT%/cmd/start-ssh-pageant.cmd"
|
||||||
|
|
||||||
|
:: you can add your plugins to the cmder path like so
|
||||||
|
:: set "PATH=%CMDER_ROOT%\vendor\whatever;%PATH%"
|
||||||
|
|
||||||
|
:: arguments in this batch are passed from init.bat, you can quickly parse them like so:
|
||||||
|
:: more useage can be seen by typing "cexec /?"
|
||||||
|
|
||||||
|
:: %ccall% "/customOption" "command/program"
|
||||||
|
|
||||||
|
@echo off
|
41
vendor/user_profile.ps1.default
vendored
Normal file
41
vendor/user_profile.ps1.default
vendored
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
# Use this file to run your own startup commands
|
||||||
|
|
||||||
|
## Prompt Customization
|
||||||
|
<#
|
||||||
|
.SYNTAX
|
||||||
|
<PrePrompt><CMDER DEFAULT>
|
||||||
|
λ <PostPrompt> <repl input>
|
||||||
|
.EXAMPLE
|
||||||
|
<PrePrompt>N:\Documents\src\cmder [master]
|
||||||
|
λ <PostPrompt> |
|
||||||
|
#>
|
||||||
|
|
||||||
|
[ScriptBlock]$PrePrompt = {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
# Replace the cmder prompt entirely with this.
|
||||||
|
# [ScriptBlock]$CmderPrompt = {}
|
||||||
|
|
||||||
|
[ScriptBlock]$PostPrompt = {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
## <Continue to add your own>
|
||||||
|
|
||||||
|
# # Delete default powershell aliases that conflict with bash commands
|
||||||
|
# if (get-command git) {
|
||||||
|
# del -force alias:cat
|
||||||
|
# del -force alias:clear
|
||||||
|
# del -force alias:cp
|
||||||
|
# del -force alias:diff
|
||||||
|
# del -force alias:echo
|
||||||
|
# del -force alias:kill
|
||||||
|
# del -force alias:ls
|
||||||
|
# del -force alias:mv
|
||||||
|
# del -force alias:ps
|
||||||
|
# del -force alias:pwd
|
||||||
|
# del -force alias:rm
|
||||||
|
# del -force alias:sleep
|
||||||
|
# del -force alias:tee
|
||||||
|
# }
|
7
vendor/user_profile.sh.default
vendored
Normal file
7
vendor/user_profile.sh.default
vendored
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
# use this file to run your own startup commands for msys2 bash'
|
||||||
|
|
||||||
|
# To add a new vendor to the path, do something like:
|
||||||
|
# export PATH=${CMDER_ROOT}/vendor/whatever:${PATH}
|
||||||
|
|
||||||
|
# Uncomment this to have the ssh agent load with the first bash terminal
|
||||||
|
# . "${CMDER_ROOT}/vendor/lib/start-ssh-agent.sh"
|
Reference in New Issue
Block a user