startify.txt 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935
  1. *startify.txt* The fancy start screen.
  2. *startify*
  3. __ __ ___
  4. /\ \__ /\ \__ __ /'___\
  5. ____\ \ ,_\ __ _ __\ \ ,_\/\_\/\ \__/ __ __
  6. /',__\\ \ \/ /'__`\ /\`'__\ \ \/\/\ \ \ ,__\/\ \/\ \
  7. /\__, `\\ \ \_/\ \L\.\_\ \ \/ \ \ \_\ \ \ \ \_/\ \ \_\ \
  8. \/\____/ \ \__\ \__/.\_\\ \_\ \ \__\\ \_\ \_\ \/`____ \
  9. \/___/ \/__/\/__/\/_/ \/_/ \/__/ \/_/\/_/ `/___/> \
  10. /\___/
  11. \/__/
  12. by Marco Hinz~
  13. >
  14. If you use any of my plugins, please star them on github. It's a great way
  15. of getting feedback and gives me the kick to put more time into their
  16. development.
  17. If you encounter any bugs or have feature requests, just open an issue
  18. report on Github.
  19. Thank you for flying mhi^ airlines. Get the Vim on!
  20. <
  21. ==============================================================================
  22. CONTENTS *startify-contents*
  23. INTRO .......................................... |startify-intro|
  24. USAGE .......................................... |startify-usage|
  25. OPTIONS ........................................ |startify-options|
  26. AUTOCMD ........................................ |startify-autocmd|
  27. COMMANDS ....................................... |startify-commands|
  28. MAPPINGS ....................................... |startify-mappings|
  29. COLORS ......................................... |startify-colors|
  30. FAQ ............................................ |startify-faq|
  31. EXAMPLE ........................................ |startify-example|
  32. ==============================================================================
  33. INTRO *startify-intro*
  34. Startify is a plugin that shows recently used files, bookmarks, commands and
  35. sessions that were saved to a certain directory.
  36. ==============================================================================
  37. USAGE *startify-usage*
  38. Startify basically provides two things:
  39. 1) If you start Vim without giving any filenames to it (or pipe stuff to it so
  40. it reads from STDIN), startify will show a small but pretty start screen
  41. that shows recently used files (using viminfo) and sessions by default.
  42. Additionally, you can define bookmarks (thus entries for files) and
  43. commands that always should be available on the start screen.
  44. You can either navigate to a certain menu entry and hit enter or you just
  45. key in whatever is written between the square brackets on that line. You
  46. can even double-click anywhere on the line now.
  47. In addition, 'e' creates an empty buffer, 'i' creates an empty buffer and
  48. jumps into insert mode, 'q' quits.
  49. Moreover, you can open several files at one go. Navigate to an entry and
  50. hit either 'b' (open in same window), 's' (open in split), 'v' (open in
  51. vertical split) or 't' (open in tab). You can do that for multiple entries.
  52. You can also mix them. The order of the selections will be remembered.
  53. Afterwards execute these actions via <cr>.
  54. When the selection is finished, Startify will close automatically. You can
  55. reopen the screen via :Startify.
  56. And you can define your own custom ascii art header now!
  57. 2) It eases handling of loading and saving sessions by only working with a
  58. certain directory. These commands are used for convenience:
  59. :SLoad load a session
  60. :SSave save a session
  61. :SDelete[!] delete a session
  62. :SClose close a session
  63. If ! is given, you won't get prompted.
  64. ==============================================================================
  65. OPTIONS *startify-options*
  66. Put these variables into your vimrc. The shown assignments are also the
  67. default values.
  68. Most used options:~
  69. |g:startify_bookmarks|
  70. |g:startify_change_to_dir|
  71. |g:startify_change_to_vcs_root|
  72. |g:startify_custom_header|
  73. |g:startify_enable_special|
  74. |g:startify_list_order|
  75. |g:startify_relative_path|
  76. |g:startify_skiplist|
  77. |g:startify_update_oldfiles|
  78. Misc options:~
  79. |g:startify_commands|
  80. |g:startify_custom_footer|
  81. |g:startify_custom_header_quotes|
  82. |g:startify_custom_indices|
  83. |g:startify_disable_at_vimenter|
  84. |g:startify_enable_unsafe|
  85. |g:startify_files_number|
  86. |g:startify_mapping_nowait|
  87. |g:startify_skiplist_server|
  88. |g:startify_use_env|
  89. Sessions:~
  90. |g:startify_session_autoload|
  91. |g:startify_session_delete_buffers|
  92. |g:startify_session_dir|
  93. |g:startify_session_persistence|
  94. |g:startify_session_remove_lines|
  95. |g:startify_session_savecmds|
  96. |g:startify_session_savevars|
  97. ------------------------------------------------------------------------------
  98. *g:startify_session_dir*
  99. >
  100. let g:startify_session_dir = '~/.vim/session'
  101. <
  102. The directory to save/load sessions to/from.
  103. The default for Windows systems is '$HOME\vimfiles\session'.
  104. ------------------------------------------------------------------------------
  105. *g:startify_list_order*
  106. >
  107. let g:startify_list_order = ['files', 'dir', 'bookmarks', 'sessions',
  108. \ 'commands']
  109. <
  110. At the moment startify supports these lists:~
  111. 1) "files"
  112. This lists the most recently used files using viminfo. The number of files
  113. is limited by |g:startify_files_number|.
  114. 2) "dir"
  115. This lists the files from the current directory sorted by modification
  116. time. The number of files is limited by |g:startify_files_number|.
  117. 3) "bookmarks"
  118. This lists bookmarks, thus hardcoded files or directories that will always
  119. be shown. Have a look at |g:startify_bookmarks|.
  120. 4) "sessions"
  121. This lists all the sessions saved in the directory |g:startify_session_dir|.
  122. 5) "commands"
  123. This lists commands defined in |g:startify_commands|.
  124. Section headers:~
  125. Additionally you can add lists of strings to that list. These will be shown
  126. above the following item in |g:startify_list_order|.
  127. NOTE: Section headers are context-senstive. This means that if the following
  128. item is a startify list ("dir", "bookmarks", ...) and empty (no files in the
  129. current directory, no bookmarks defined, ...), the section header won't be
  130. shown as well.
  131. NOTE: The section header use the StartifySection highlight group.
  132. Section headers example:~
  133. >
  134. let g:startify_list_order = [
  135. \ [' My most recently', ' used files'],
  136. \ 'files',
  137. \ [' My most recently used files in the current directory:'],
  138. \ 'dir',
  139. \ [' These are my sessions:'],
  140. \ 'sessions',
  141. \ [' These are my bookmarks:'],
  142. \ 'bookmarks',
  143. \ [' These are my commands:'],
  144. \ 'commands',
  145. \ ]
  146. <
  147. Feel free to add some cool ASCII action!
  148. ------------------------------------------------------------------------------
  149. *g:startify_bookmarks*
  150. >
  151. let g:startify_bookmarks = []
  152. <
  153. A list of files or directories to bookmark. The list can contain two kinds of
  154. types. Either a path or a dictionary whereas the key is the custom index and
  155. the value the path.
  156. Example:
  157. >
  158. let g:startify_bookmarks = [ {'c': '~/.vimrc'}, '~/.zshrc' ]
  159. <
  160. NOTE: Avoid using keys from |startify-mappings| if providing custom indices.
  161. ------------------------------------------------------------------------------
  162. *g:startify_commands*
  163. >
  164. let g:startify_commands = []
  165. <
  166. A list of commands to execute on selection. Leading colons are optional. It
  167. supports optional custom indices and/or command descriptions.
  168. Example:
  169. >
  170. let g:startify_commands = [
  171. \ ':help reference',
  172. \ ['Vim Reference', 'h ref'],
  173. \ {'h': 'h ref'},
  174. \ {'m': ['My magical function', 'call Magic()']},
  175. \ ]
  176. <
  177. NOTE: Avoid using keys from |startify-mappings| if providing custom indices.
  178. ------------------------------------------------------------------------------
  179. *g:startify_files_number*
  180. >
  181. let g:startify_files_number = 10
  182. <
  183. The number of files to list.
  184. ------------------------------------------------------------------------------
  185. *g:startify_update_oldfiles*
  186. >
  187. let g:startify_update_oldfiles = 0
  188. <
  189. Usually |v:oldfiles| only gets updated when Vim exits. Using this option updates
  190. it on-the-fly, so that :Startify is always up-to-date.
  191. ------------------------------------------------------------------------------
  192. *g:startify_session_autoload*
  193. >
  194. let g:startify_session_autoload = 0
  195. <
  196. If you fire up "vim" in a directory that contains a "Session.vim", that session
  197. will be loaded automatically. Otherwise it will be shown as the top entry in
  198. the Startify buffer.
  199. This also works if you open a bookmarked directory.
  200. Great way to create a portable project folder.
  201. ------------------------------------------------------------------------------
  202. *g:startify_session_persistence*
  203. >
  204. let g:startify_session_persistence = 0
  205. <
  206. Automatically update sessions in two cases:
  207. 1) Before leaving Vim
  208. 2) Before loading a new session via :SLoad
  209. This also works for sessions started with:
  210. >
  211. vim -S mysession.vim
  212. <
  213. ------------------------------------------------------------------------------
  214. *g:startify_session_delete_buffers*
  215. >
  216. let g:startify_session_delete_buffers = 0
  217. <
  218. Delete open buffers before loading a new session.
  219. ------------------------------------------------------------------------------
  220. *g:startify_change_to_dir*
  221. >
  222. let g:startify_change_to_dir = 1
  223. <
  224. When opening a file or bookmark, change to its directory.
  225. ------------------------------------------------------------------------------
  226. *g:startify_change_to_vcs_root*
  227. >
  228. let g:startify_change_to_vcs_root = 0
  229. <
  230. When opening a file or bookmark, seek and change to the root directory of the
  231. VCS (if there is one).
  232. At the moment only git, hg, bzr and svn are supported.
  233. ------------------------------------------------------------------------------
  234. *g:startify_skiplist*
  235. >
  236. let g:startify_skiplist = [
  237. \ 'COMMIT_EDITMSG',
  238. \ escape(fnamemodify(resolve($VIMRUNTIME), ':p'), '\') .'doc',
  239. \ 'bundle/.*/doc',
  240. \ ]
  241. <
  242. A list of Vim regular expressions that is used to filter recently used files.
  243. See |pattern.txt| for what patterns can be used.
  244. NOTE: Due to the nature of patterns, you can't just use "~/mysecret" but have
  245. to use "$HOME .'/mysecret.txt'". The former would do something entirely
  246. different: |/\~|. When using backslashes as path separators, escape them.
  247. Otherwise using "C:\this\vim\path\is\problematic" would not match what you
  248. expect, since |/\v| is a pattern, too.
  249. Example:
  250. >
  251. let g:startify_skiplist = [
  252. \ '\.vimgolf',
  253. \ '^/tmp',
  254. \ '/project/.*/documentation',
  255. \ escape(fnamemodify($HOME, ':p'), '\') .'mysecret.txt',
  256. \ ]
  257. <
  258. ------------------------------------------------------------------------------
  259. *g:startify_skiplist_server*
  260. >
  261. let g:startify_skiplist_server = []
  262. <
  263. Do not create the startify buffer, if this is a Vim server instance with a
  264. name contained in this list.
  265. Example:
  266. >
  267. let g:startify_skiplist_server = [ 'GVIM' ]
  268. <
  269. ------------------------------------------------------------------------------
  270. *g:startify_enable_special*
  271. >
  272. let g:startify_enable_special = 1
  273. <
  274. Show <empty buffer> and <quit>.
  275. ------------------------------------------------------------------------------
  276. *g:startify_enable_unsafe*
  277. >
  278. let g:startify_enable_unsafe = 0
  279. <
  280. Enable the option only in case you think Vim starts too slowly (because of
  281. :Startify) or if you often edit files on remote filesystems.
  282. It's called unsafe because it improves the time :Startify needs to execute by
  283. reducing the amount of syscalls to the underlying operating system, but
  284. sacrifices the precision of shown entries.
  285. This could lead to inconsistences in the shown :Startify entries (e.g. the
  286. same file could be shown twice, because one time file was opened via absolute
  287. path and another time via symlink).
  288. Currently this option does this:
  289. - don't resolves symlinks (readlink(2))
  290. - don't check every file if it's readable (stat(2))
  291. - don't filter through the bookmark list
  292. ------------------------------------------------------------------------------
  293. *g:startify_session_remove_lines*
  294. >
  295. let g:startify_session_remove_lines = []
  296. <
  297. Lines matching any of the patterns in this list, will be removed from the
  298. session file.
  299. Example:
  300. >
  301. let g:startify_session_remove_lines = ['setlocal', 'winheight']
  302. <
  303. Internally this simply does:
  304. >
  305. :global/setlocal/delete
  306. :global/winheight/delete
  307. <
  308. So you can use any |pattern|.
  309. NOTE: Take care not to mess up any expressions within the session file,
  310. otherwise you'll probably get problems when trying to load it.
  311. ------------------------------------------------------------------------------
  312. *g:startify_session_savevars*
  313. >
  314. let g:startify_session_savevars = []
  315. <
  316. Include a list of variables in here which you would like Startify to save into
  317. the session file in addition to what Vim normally saves into the session file.
  318. For example, Vim will not normally save all-lowercase global variables, which
  319. are common for plugin settings. It may be advisable to include
  320. |g:startify_session_savevars| and |g:startify_session_savecmds| into this list
  321. so they are saved every time the session saves.
  322. Example:
  323. >
  324. let g:startify_session_savevars = [
  325. \ 'g:startify_session_savevars',
  326. \ 'g:startify_session_savecmds',
  327. \ 'g:random_plugin_use_feature'
  328. \ ]
  329. <
  330. ------------------------------------------------------------------------------
  331. *g:startify_session_savecmds*
  332. >
  333. let g:startify_session_savecmds = []
  334. <
  335. Include a list of cmdline commands which Vim will run upon loading the
  336. session. This can be useful to set various things (other than variables,
  337. |g:startify_session_savevars| above) which Vim may not normally save into the
  338. session file, as well as run external commands upon loading a session.
  339. Example:
  340. >
  341. let g:startify_session_savecmds = [
  342. \ 'silent !pdfreader ~/latexproject/main.pdf &'
  343. \ ]
  344. <
  345. ------------------------------------------------------------------------------
  346. *g:startify_custom_indices*
  347. >
  348. let g:startify_custom_indices = []
  349. <
  350. Use any list of strings as indices instead of increasing numbers. If there are
  351. more startify entries than actual items in the custom list, the remaining
  352. entries will be filled using the default numbering scheme starting from 0.
  353. Thus you can create your own indexing scheme that fits your keyboard layout.
  354. You don't want to leave the home row, do you?!
  355. Example:
  356. >
  357. let g:startify_custom_indices = ['f', 'g', 'h']
  358. <
  359. This would result in:
  360. [f] /most/recently/used/file1
  361. [g] /most/recently/used/file2
  362. [h] /most/recently/used/file3
  363. [0] /most/recently/used/file4
  364. [1] /most/recently/used/file5
  365. [2] /most/recently/used/file6
  366. etc.
  367. If you want numbers to start at 1 instead of 0, you could use this:
  368. >
  369. let g:startify_custom_indices = map(range(1,100), 'string(v:val)')
  370. <
  371. NOTE: There is no sanitizing going on, so you should know what you're doing!
  372. Avoid using keys from |startify-mappings|.
  373. ------------------------------------------------------------------------------
  374. *g:startify_custom_header*
  375. >
  376. let g:startify_custom_header = startify#fortune#get_random_quote()
  377. <
  378. This is a list of strings to be shown before everything else. Every string
  379. will be written on its own line, hence you can use empty strings for blank
  380. lines.
  381. Static example:~
  382. >
  383. let g:startify_custom_header = ['line 1', '', 'line 3']
  384. <
  385. Static example #2:~
  386. >
  387. let g:startify_custom_header = [
  388. \ ' ________ __ __ ',
  389. \ ' __ /\_____ \/\ \\ \ ',
  390. \ ' __ __ /\_\ ___ ___ \/___//''/''\ \ \\ \ ',
  391. \ ' /\ \/\ \\/\ \ /'' __` __`\ /'' /'' \ \ \\ \_ ',
  392. \ ' \ \ \_/ |\ \ \/\ \/\ \/\ \ /'' /''__ \ \__ ,__\',
  393. \ ' \ \___/ \ \_\ \_\ \_\ \_\ /\_/ /\_\ \/_/\_\_/ ',
  394. \ ' \/__/ \/_/\/_/\/_/\/_/ \// \/_/ \/_/ ',
  395. \ ]
  396. <
  397. Dynamic example:~
  398. >
  399. let g:startify_custom_header =
  400. \ map(split(system('fortune | cowsay'), '\n'), '" ". v:val')
  401. <
  402. If you go for a dynamic header, you might find the following functions useful:
  403. startify#fortune#quote() raw random quote
  404. startify#fortune#boxed() formatted random quote in a box
  405. startify#fortune#cowsay() formatted random quote in a box + cow
  406. Try them like this:
  407. >
  408. :echo join(startify#fortune#cowsay(), "\n")
  409. <
  410. Let's assume you like the default boxed random quote, but not the ASCII art
  411. cow. You'd rather have another small ASCII art come before the quote. No
  412. problem!
  413. >
  414. let g:ascii = [
  415. \ ' __',
  416. \ '.--.--.|__|.--------.',
  417. \ '| | || || |',
  418. \ ' \___/ |__||__|__|__|',
  419. \ ''
  420. \]
  421. let g:startify_custom_header = g:ascii + startify#fortune#boxed()
  422. <
  423. Looks great! But it's not on the same column as the indices below which makes
  424. it look awkward. Let's indent the header by 3 spaces:
  425. >
  426. let g:startify_custom_header =
  427. \ map(g:ascii + startify#fortune#boxed(), '" ".v:val')
  428. <
  429. Ah, much better! There's only one issue left. If you set
  430. g:startify_custom_header this way, it will only be done once. Hence spamming
  431. :Startify will always show the same quote.
  432. If you provide a string to it instead, Startify will evaluate it every time
  433. :Startify is run:
  434. >
  435. let g:startify_custom_header =
  436. \ 'map(g:ascii + startify#fortune#boxed(), "\" \".v:val")'
  437. <
  438. Happy customizing!
  439. Also have a look at |startify-faq-08|.
  440. ------------------------------------------------------------------------------
  441. *g:startify_custom_header_quotes*
  442. If you don't set |g:startify_custom_header|, the internal cowsay implementation
  443. with shipped random quotes will be used.
  444. If you want to use your own quotes, add a list of lists, like this:
  445. >
  446. let g:startify_custom_header_quotes = [
  447. \ ['line 1', '', 'line 3'],
  448. \ ['quote #2']
  449. \ ]
  450. <
  451. ------------------------------------------------------------------------------
  452. *g:startify_custom_footer*
  453. >
  454. let g:startify_custom_footer = ''
  455. <
  456. Same as the custom header, but shown at the bottom of the startify buffer.
  457. ------------------------------------------------------------------------------
  458. *g:startify_disable_at_vimenter*
  459. >
  460. let g:startify_disable_at_vimenter = 0
  461. <
  462. Don't run Startify at Vim startup. You can still call it anytime via
  463. :Startify.
  464. -----------------------------------------------------------------------------
  465. *g:startify_relative_path*
  466. >
  467. let g:startify_relative_path = 0
  468. <
  469. Show filenames relative to the current working directory instead of as
  470. absolute paths. This only applies to the "files" list, since the "dir" list is
  471. relative by nature.
  472. -----------------------------------------------------------------------------
  473. *g:startify_use_env*
  474. >
  475. let g:startify_use_env = 0
  476. <
  477. Show environment variables in path, if their name is shorter than their value.
  478. See |startify-colors| for highlighting them.
  479. $PWD and $OLDPWD are ignored.
  480. -----------------------------------------------------------------------------
  481. *g:startify_mapping_nowait*
  482. >
  483. let g:startify_mapping_nowait = 0
  484. <
  485. Force the usage of |<nowait>| in all mappings.
  486. This helps guarding against global mappings that start with the same
  487. characters as a Startify index, but might break local mappings, e.g. when you
  488. have indexes "1" and "11", the "11" won't be accessable anymore, since "1"
  489. will be opened right way.
  490. Only use this when you know what you're doing.
  491. NOTE: This option needs at least Vim 7.3.1261. It gets ignored otherwise.
  492. ==============================================================================
  493. AUTOCMD *startify-autocmd*
  494. In case you want to alter the startify buffer to cause all kinds of mayhem, an
  495. user autocmd is issued. You can hook into it like this:
  496. >
  497. autocmd User Startified let &l:stl = ' This statusline rocks!'
  498. <
  499. ==============================================================================
  500. COMMANDS *startify-commands*
  501. *startify-:Startify*
  502. >
  503. :Startify
  504. <
  505. Open the startify buffer.
  506. *startify-:SSave*
  507. *startify-:SDelete*
  508. >
  509. :SSave [session]
  510. :SDelete [session]
  511. <
  512. Save or delete a session. If you don't specify a session name, it will prompt
  513. you for one.
  514. *startify-:SLoad*
  515. >
  516. :SLoad [session]
  517. <
  518. Load a session. If you don't specify a session name, it will either prompt you
  519. for one (Windows) or load the last used session (Unix).
  520. Providing only a part of the session name works too, if you complete the
  521. argument with either <c-d> or <tab> afterwards.
  522. *startify-:SClose*
  523. >
  524. :SClose
  525. <
  526. Save and close the current session, close all listed buffers, and open the
  527. Startify buffer.
  528. ==============================================================================
  529. MAPPINGS *startify-mappings*
  530. Some things are remapped in the startify buffer..
  531. >
  532. q
  533. <
  534. Close startify. Also quit Vim if it is the only buffer.
  535. >
  536. e
  537. <
  538. Close startify and create a blank buffer.
  539. >
  540. i
  541. <insert>
  542. <
  543. Close startify, create a blank buffer and jump into insert mode right away.
  544. >
  545. <2-LeftMouse>
  546. <
  547. Use a simple mouse click to open the targeted entry.
  548. >
  549. [any number that is shown between square brackets]
  550. <
  551. Open the entry with the given number.
  552. >
  553. b
  554. s
  555. v
  556. t
  557. <
  558. Mark current entry to be opened in either the same window, in a split window,
  559. in a vertical split window or in a new tab.
  560. >
  561. <cr>
  562. <
  563. Open all marked entries. If nothing was marked beforehand, just open the
  564. current entry.
  565. If you want to use another key instead of <cr>, put this in your vimrc:
  566. >
  567. autocmd User Startified nmap <buffer> o <plug>(startify-open-buffers)
  568. <
  569. ==============================================================================
  570. COLORS *startify-colors*
  571. You can overwrite the highlight groups used by startify. The plugin defines
  572. these groups:
  573. Highlight group | Description | Default
  574. ------------------------------------------------------------------
  575. | |
  576. StartifyBracket | [,] | linked to Delimiter
  577. StartifyFile | the actual file | <none>
  578. StartifyFooter | the custom footer | linked to Normal
  579. StartifyHeader | the custom header | linked to Normal
  580. StartifyNumber | the numbers between [] | linked to Number
  581. StartifyPath | the path to a file | <none>
  582. StartifySection | section headers | linked to Special
  583. StartifySelect | selected entries | linked to Title
  584. StartifySlash | slashes in paths | <none>
  585. StartifySpecial | <empty buffer>,<quit> | <none>
  586. StartifyVar | environment variables | linked to StartifyPath
  587. Example: (my terminal emulator supports 256 colors)
  588. >
  589. highlight StartifyBracket ctermfg=240
  590. highlight StartifyFooter ctermfg=240
  591. highlight StartifyHeader ctermfg=114
  592. highlight StartifyNumber ctermfg=215
  593. highlight StartifyPath ctermfg=245
  594. highlight StartifySlash ctermfg=240
  595. highlight StartifySpecial ctermfg=240
  596. <
  597. ==============================================================================
  598. FAQ *startify-faq*
  599. |startify-faq-01| I don't want the start screen to use cursorline!
  600. |startify-faq-02| Recent files aren't shown!
  601. |startify-faq-03| I have broken colors when using sessions!
  602. |startify-faq-04| How to disable common but unimportant files?
  603. |startify-faq-05| CtrlP or NERDTree open a split in Startify!
  604. |startify-faq-06| How do I get both NERDTree and Startify working at
  605. startup?
  606. |startify-faq-07| The session autoload feature is not working!
  607. |startify-faq-08| How do I center my header/footer?
  608. |startify-faq-09| tmux-resurrect?
  609. |startify-faq-10| Temporarily skip Startify at start?
  610. |startify-faq-11| How to use the output of a command as header?
  611. |startify-faq-12| There is an empty window with vim-plug!
  612. |startify-faq-13| How to disable random quotes header?
  613. ------------------------------------------------------------------------------
  614. *startify-faq-01*
  615. I want to use cursorline!~
  616. Startify issues a User event when it's finished. It can be used to set
  617. buffer-local options etc.
  618. >
  619. autocmd User Startified setlocal cursorline
  620. <
  621. ------------------------------------------------------------------------------
  622. *startify-faq-02*
  623. Recent files aren't shown!~
  624. Perhaps the problem is that the viminfo file..
  625. - doesn't exist
  626. - is invalid
  627. - is empty
  628. - can't be read (check permissions)
  629. I suggest the following steps:
  630. 1) Create a new directory:
  631. >
  632. $ mkdir -p ~/.vim/files/info
  633. <
  634. 2) Put this into your vimrc:
  635. >
  636. set viminfo='100,n$HOME/.vim/files/info/viminfo
  637. <
  638. See |'viminfo'| for information about the second step and what it does
  639. exactly.
  640. ------------------------------------------------------------------------------
  641. *startify-faq-03*
  642. I have broken colors when using sessions!~
  643. Nothing this plugin could do about. Try playing around with 'sessionoptions'.
  644. NOTE: Startify removes 'options' from the session options automatically,
  645. because it's the source of many problems.
  646. Some people swear it works for them with these settings:
  647. >
  648. set sessionoptions=blank,curdir,folds,help,tabpages,winpos
  649. <
  650. ------------------------------------------------------------------------------
  651. *startify-faq-04*
  652. How to disable common but unimportant files?~
  653. Use |g:startify_skiplist|.
  654. ------------------------------------------------------------------------------
  655. *startify-faq-05*
  656. CtrlP or NERDTree open a split in Startify!~
  657. Put this in your vimrc:
  658. >
  659. autocmd User Startified setlocal buftype=
  660. <
  661. If you're using CtrlP without NERDTree, there is an even more elegant
  662. solution:
  663. >
  664. let g:ctrlp_reuse_window = 'startify'
  665. <
  666. ------------------------------------------------------------------------------
  667. *startify-faq-06*
  668. How do I get both NERDTree and Startify working at startup?~
  669. Put this in your vimrc:
  670. >
  671. autocmd VimEnter *
  672. \ if !argc()
  673. \ | Startify
  674. \ | NERDTree
  675. \ | wincmd w
  676. \ | endif
  677. <
  678. ------------------------------------------------------------------------------
  679. *startify-faq-07*
  680. The session autoload feature is not working!~
  681. Do you have NERDTree installed by any chance? If so, try this:
  682. >
  683. let NERDTreeHijackNetrw = 0
  684. <
  685. ------------------------------------------------------------------------------
  686. *startify-faq-08*
  687. How do I center my header/footer?~
  688. Try something along these lines:
  689. >
  690. function! s:filter_header(lines) abort
  691. let longest_line = max(map(copy(a:lines), 'len(v:val)'))
  692. let centered_lines = map(copy(a:lines),
  693. \ 'repeat(" ", (&columns / 2) - (longest_line / 2)) . v:val')
  694. return centered_lines
  695. endfunction
  696. let g:startify_custom_header = s:filter_header(['a', 'bb', 'ccc'])
  697. <
  698. ------------------------------------------------------------------------------
  699. *startify-faq-09*
  700. tmux-resurrect?~
  701. If you use tmux-resurrect to restore your tmux environment, you can use :SLoad
  702. to load your last used session right away:
  703. >
  704. set -g @resurrect-processes '"vim->vim +SLoad"'
  705. <
  706. ------------------------------------------------------------------------------
  707. *startify-faq-10*
  708. Temporarily skip Startify at start?~
  709. In some cases you might need to skip Startify at start. E.g.
  710. >
  711. vim +VimwikiMakeDiaryNote
  712. <
  713. Startify would interfere in this case. A simple way to avoid that would be:
  714. >
  715. vim --cmd 'let g:startify_disable_at_vimenter = 1' +VimwikiMakeDiaryNote
  716. <
  717. ------------------------------------------------------------------------------
  718. *startify-faq-11*
  719. How to use the output of a command as header?~
  720. >
  721. redir => test
  722. silent echo 'one'
  723. silent echo 'two'
  724. silent echo 'three'
  725. redir END
  726. let g:startify_custom_header =
  727. \ map(split(test), 'repeat(" ", 10) . v:val')
  728. <
  729. |:redir| puts a string into 'test'. Then we turn it into a list of strings.
  730. Then we shift each string to the right by 10 spaces. Afterwards we add an
  731. empty string to the list, which results in an empty line in the header.
  732. ------------------------------------------------------------------------------
  733. *startify-faq-12*
  734. There is an empty window with vim-plug!~
  735. After start there might be only the Startify buffer which is marked as
  736. |unlisted-buffer|. The problem arises if you use :PlugUpdate followed by 'D'
  737. to see the changes. An empty window!
  738. The actual problem is that Vim won't close the last listed buffer. Try this:
  739. >
  740. $ vim -u NONE -N
  741. :set nobuflisted
  742. :new
  743. :bd
  744. <
  745. It won't close the buffer and therefore the window. This also happens in
  746. vim-plug. Note that this is no bug in neither plugin, it's a Vim weirdness.
  747. Workaround #1:~
  748. >
  749. autocmd User Startified setlocal buflisted
  750. <
  751. In some cases this could break other plugins at start (I look at you
  752. NERDTree), but works well most of the time.
  753. Workaround #2:~
  754. >
  755. let g:plug_window = 'enew' " or maybe 'tabnew'
  756. <
  757. This will open the plug buffer in the current window instead of creating a new
  758. window on the left side. Mind that this will also close the Startify buffer
  759. since it will be hidden.
  760. ------------------------------------------------------------------------------
  761. *startify-faq-13*
  762. How to disable random quotes header?~
  763. >
  764. let g:startify_custom_header = []
  765. <
  766. See |g:startify_custom_header|.
  767. ==============================================================================
  768. EXAMPLE *startify-example*
  769. This is my configuration..
  770. >
  771. autocmd User Startified setlocal cursorline
  772. let g:startify_enable_special = 0
  773. let g:startify_files_number = 8
  774. let g:startify_relative_path = 1
  775. let g:startify_change_to_dir = 1
  776. let g:startify_update_oldfiles = 1
  777. let g:startify_session_autoload = 1
  778. let g:startify_session_persistence = 1
  779. let g:startify_session_delete_buffers = 1
  780. let g:startify_skiplist = [
  781. \ 'COMMIT_EDITMSG',
  782. \ 'bundle/.*/doc',
  783. \ '/data/repo/neovim/runtime/doc',
  784. \ '/Users/mhi/local/vim/share/vim/vim74/doc',
  785. \ ]
  786. let g:startify_bookmarks = [
  787. \ { 'c': '~/.vim/vimrc' },
  788. \ '~/golfing',
  789. \ ]
  790. let g:startify_custom_footer =
  791. \ ['', " Vim is charityware. Please read ':help uganda'.", '']
  792. hi StartifyBracket ctermfg=240
  793. hi StartifyFile ctermfg=147
  794. hi StartifyFooter ctermfg=240
  795. hi StartifyHeader ctermfg=114
  796. hi StartifyNumber ctermfg=215
  797. hi StartifyPath ctermfg=245
  798. hi StartifySlash ctermfg=240
  799. hi StartifySpecial ctermfg=240
  800. <
  801. ==============================================================================
  802. vim: tw=78