Commit Graph

65 Commits (d24a4f0bff9614d412c308d3e75adc792e032e33)

Author SHA1 Message Date
Jorge Bucaran d24a4f0bff Simplify fisher_help, update docs. 9 years ago
Jorge Bucaran 18e5103271 1.3.0 9 years ago
Jorge Bucaran 57964e6842 Close #149, #150. 9 years ago
Jorge Bucaran 1493292cd2 1.2.0 9 years ago
Jorge Bucaran c4c95779c3 Add ascii cast. 9 years ago
Jorge Bucaran 03baee2d24 1.1.0 9 years ago
Jorge Bucaran 6f6d874a3f Merge branch 'master' of https://github.com/fisherman/fisherman 9 years ago
Jorge Bucaran be65fdf3f0 Ahoy!! Fisherman 1.0.0
* Deprecate fisher --list in favor of a new command
  fisher list. The behavior is roughly the same. See
  fisher help list for usage. tl;dr: Use list to query
  the local system / cache and search to query the index.

* Teach fisher_plugin_walk about fish_postexec,
  fish_command_not_found and fish_preexec event emitters
  and erase them during uninstall if they were defined in
  a snippet.

* Fisherman now recognizes the following aliases by default:
  i for install, u for update, l for list, s for search and
  h for help.

* Rewrite documentation to be simpler and more consistent.

* Fisherman can install "functions" now. If you have created
  a function interactively, you can run fisher install name
  of the function and a directory will be created in
  $PWD/name of the function and installed as usual.

* Fisherman now detects if users have modified their fish
  prompt using fish_config and if so, uninstalls $fisher_prompt.

* Search results now truncate plugin descriptions based in
 the width of the terminal screen.

* Install/Update/Uninstall CLI was retouched.

Looking behind and Ahead
========================

On Jan, 1st, Fisherman 0.1.0 departed from the bay of
"my hard drive" and today 1.0.0 has finally shipped.

Things are still a little rough and knotty, what did
you think? But 1.0.0 means all the basic things are
here.

Internally, we may still push some large changes, more
robust tests; at ~300 there are still areas a bit dry.

On the outside, Fisherman will change little, I hope.
That's a feature. If you want a more colorful CLI,
concurrent updates, or another bit here and there,
we may work something out.

This release means more time to focus on the plugin
ecosystem, but the adventures are far from over.
9 years ago
Jorge Bucaran 9ac121b140 Fix wiki link. 9 years ago
Jorge Bucaran 6c10566bdf 0.9.0 9 years ago
Jorge Bucaran fbddca1106 Improve instrumentation, consistent logs. 9 years ago
Jorge Bucaran 0c8c3458a8 Remove strange _ next to logo link caused by GH markdown weirdness. 9 years ago
Jorge Bucaran 7543364e83 Fix logo head tag. 9 years ago
Jorge Bucaran 17caeb44d6 Thank you Denis, Ivan and Jethro ❤️. 9 years ago
Jorge Bucaran ebb2f4fccf Minimal readme. 9 years ago
Jorge Bucaran 77b551eccb Less emoji, I am a mental explorer. 9 years ago
Jorge Bucaran 6de1c342c6 More emoji 📦 tidy up. 9 years ago
Jorge Bucaran fe608a1fae Add emoji 🔎 and show installing Fisherman is simple. 9 years ago
Jorge Bucaran cf0d1f065c Simplify README, smaller benchmark img size. 9 years ago
Jorge Bucaran 2eace6ebe8 Remove fundle from benchmarks as meh. 9 years ago
Jorge Bucaran 25c26afbf8 Center align benchmark graph. 9 years ago
Jorge Bucaran 3059115b5a Make benchmarks run horizontally to save vertical space. 9 years ago
Jorge Bucaran 5b224e808f Fix GitHub markdown nonsense, move badges up. 9 years ago
Jorge Bucaran abd8d3bc68 Thin line under badges. 9 years ago
Jorge Bucaran b1d1530a73 Add link to plugin search. 9 years ago
Jorge Bucaran 4132d600a0 0.8.0 9 years ago
Jorge Bucaran 692bb22db6 Ahoy! We are getting close to 0.8.0
* Move AUTHORS -> THANKS and remove automatic generation.

THANKS is more sensible than AUTHORS. CREDITS was second best.
Also, after perusing similar files in other projects I noticed
some entries lacking a valid email address and decided fow now
this file should be curated manually to make sure each entry
contains a useful link. This allows users who have contributed
to the project ways other than committing code to be added to
the list as well.

* Rename wait -> spin.

* Remove extra padding in links. (Cosmetic)

* Update to reflect API refactorings.

* Fix bug causing brackets to show up in description.

* Implement using spin function.

* __fisher_gist_to_name uses curl to query the GitHub API which will
return a JSON stream even if the Gist could not be found. So, it's
not possible to determine whether we failed or not using our spin
function and actually need to check the returned string to see if
it contains a valid name or not.

* Let git pull write errors to stderr.

* Use new internal __fisher_spin.

* Extract spin to independent / external module and tweak Makefile
to better integrate with new install process.
9 years ago
Jorge Bucaran 46d99b6a15 Fix dead white space link next to the logo. 9 years ago
Jorge Bucaran babcc15337 Remove , but still think it's cool. 9 years ago
Jorge Bucaran b0a0821874 Make Slack logo blue. 9 years ago
Jorge Bucaran bf934b2181 0.7.0 9 years ago
Jorge Bucaran 4cfd037cc0 Ahoy! an early v0.7.0 is here!
+ Add  the ability  to install plugins  from Gists.  You can
distribute a very simple,  one-single function plugin in the
form  of a  Gist. Your  users  can install  it using  fisher
install  url and  Fisherman will  query the  Gist using  the
GitHub API to get a list of  the Gist files and use the name
of the  first identified *.fish  file to name the  plugin in
your system.  Since there is no  formal way to name  a Gist,
and you may  prefer to keep the "description"  field for the
actual description  and not a name,  Fisherman supports only
one fish file per Gist. Closes #75.

+ Use command(1) when calling non-builtins. Thanks @daenney.
Closes #79.

+  Add  __fisher_plugin_can_enable  to detect  installing  a
prompt that is not the current one. Closes #78.

+  Remove  the ability  to  install  a  plugin in  a  parent
directory using ..  or ../ or even worse, ../../  as well as
other combinations  that navigate  to a parent  directory. I
find  the use  case odd  at  best, and  more dangerous  that
useful.  If you  want  to  install a  local  plugin use  the
full  path  or a  relative  path,  always top  down.  fisher
install  . or  fisher  install my/plugin  or fisher  install
/Users/$USER/path/to/plugin. Closes #81.
9 years ago
Jorge Bucaran 7efb46bc10 0.6.0 9 years ago
Jorge Bucaran ff4968c01e Lowercase slack and 750->720 pixel logo. 9 years ago
Jorge Bucaran f421bb9186 Tidy up, more punch, more flavor, larger logo. 9 years ago
Jorge Bucaran e75d93a96f Add note in README about the nature of the benchmarks. 9 years ago
Jorge Bucaran aa8eba88cf Tidy up, add more spacing between sections. 9 years ago
Jorge Bucaran c7a906007f Tweak header, switch 'Get Started' emoji. 9 years ago
Jorge Bucaran c6984cdbb0 Remove code header from graphic. 9 years ago
Jorge Bucaran 6de5c60a56 Add horizontal spacing to legend. 9 years ago
Jorge Bucaran 1caa738226 Resize benchmark graphic. 9 years ago
Jorge Bucaran 8952b3cf34 Resize benchmark graphic. 9 years ago
Jorge Bucaran 17c0a0725f Polish benchmarks graphic. 9 years ago
Jorge Bucaran bc2215b50e 0.5.0 9 years ago
Jorge Bucaran 888a9a0cf3 Ahoy! Fisherman 0.5.0
=====================

Add user key bindings support.

Recall   $fisher_home/functions  are   always  before   user
functions in  $fish_function_path. This was an  early design
decision  in order  to  prevent users  from redefining  core
functions by  mistake or by  means other than  using plugins
(recommended).  In other  words, you  are free  to create  a
plugin  that modifies  a  Fisherman core  function, but  you
can't redefine  a Fisherman function privately  by saving it
to your user config fish. If  you found a bug in a Fisherman
function,  instead  of  creating  a private  patch  send  it
upstream.  If  you  created  a  function  that  overrides  a
Fisherman  core  feature,  create  a plugin.  This  way  the
community can benefit from your  code whenever you are ready
to publish it.

By  default, Fisherman  provides no  fish_user_key_bindings,
so   if   the   user   has   already   defined   their   own
fish_user_key_bindings that one will not be affected.

Now,  plugins can  define their  own key  bindings inside  a
fish_user_key_bindings.fish or key_bindings.fish at the root
of their repository or inside a functions directory. You can
put your key  bindings inside a function or not.  If you put
it inside a function, the function  name must be the same as
the file without the .fish extension.

$fisher_config/bindings.fish   When   a  plugin   with   key
bindings  is  installed  for  the first  time  or  the  only
one  with bindings  is  uninstalled,  Fisherman will  modify
~/.config/functions/fish_user_key_bindings.fish  (or  create
it for  the first  time) and  add a single  line at  the top
of  the fish_user_key_bindings  function to  source the  new
$fisher_config/bindings.fish. All  the key  bindings defined
by the enabled/installed plugins  are concatenated and saved
to this file.

This mechanism has the following advantages:

Does not slow  down shell start. Does  not require Fisherman
to  provide  his   own  fish_user_key_bindings  by  default.
Honors  any previously  existing user  key bindings.  Allows
plugin  to  define  their   own  key  bindings  and  coexist
with  the  user's key  bindings.  If  the user  updates  his
fish_user_key_bindings, re-running the  function does update
the key bindings. Mega Refactoring

The   entire   source   code   of   Fisherman   received   a
major   revision  and   refactoring.   The  validation   and
install/uninstall mechanisms were thoroughly revised and and
broken down into smaller functions easier to test as well as
several other sub parts of the system.

Rewrite fisher  search and  remove features that  are mostly
already covered by  fisher --list and remove  the ability to
generate information  about plugins  of unknown  origin. The
decision  to remove  this feature  was based  in performance
concerns  and the  result  of thinking  about the  usability
and  whether it  was really  worth the  speed tradeoff.  The
conclusion is I would rather  have better performance and if
I need  to query a  plugins origin  I can always  use fisher
--list or fisher --list=url or fisher --list=author.

Add $fisher_update_interval to determine if the index should
update  or not  when a  search  query is  taking place.  The
default value is  10 seconds. This means the  index will not
be updated  if less than  10 seconds have elapsed  since the
last action that triggered an update in the first place. See

Improve Install/Uninstall/Update status  output. If a plugin
fails  to install  decrease the  total. If  any plugins  are
skipped because  they are already  installed in the  case of
fisher install  or available in  the cache, but  disabled in
the  case of  fisher uninstall  they are  collected into  an
array and displayed in a  new section n plugin/s skipped (a,
b, c) at the bottom of the report.

Improve test coverage.

Tightly coupled  functions were making  testing increasingly
difficult.  Most of  the test  effort was  basically testing
whether git  clone or git  pull. New separation  of concerns
makes tests  run faster and the  difficult install/uninstall
algorithms has better coverage now. Other

Now  __fisher_list  can  list  plugins  from  the  cache,  a
fishfile/bundle  and plugins  that are  installed/enabled or
disabled. This  removes __fisher_file  and combines  it with
__fisher_list. This  also removes fisher -f  and replaces it
with fisher -l <file> or fisher --list=<file>.

Rename __fisher_parse_help to __fisher_complete and have the
function create  the completions automatically.  This allows
you  to complete  your  commands with  parseable usage  help
faster.  The  original  design  was fine,  but  this  change
improves auto-complete performance so it was preferred.

Use __fisher_index_update when building file with Make. This
helps prevent  an error when  using a fish version  < 2.2.0.
See #55 #50 #48.

Add  __fisher_index_update to  update the  index and  remove
previously   undocumented   fisher  update   --index.   This
function  is  designed  to bypass  GitHub's  server  network
cache  passing  an  arbitrary  query  string  to  curl  like
$fisher_index?RANDOM_NUMBER.  This means  index updates  are
immediately available now.

Add fisher --list=url option to  display local plugin url or
path.

Add fisher  --list=bare option  to display local  plugins in
the cache without the * enabled symbol.

Prepend > to  the currently enabled theme  when using fisher
--list[=cache]. Related #49.

Prepend *  to plugin  names to  indicate they  are currently
enabled when using fisher --list[=cache]. See #49.
9 years ago
Jorge Bucaran a6a6e506e4 Tweak introduction 💪 9 years ago
Jorge Bucaran 4688885fa4 Align badges to the left. 9 years ago
Jorge Bucaran a329d498d8 Simplify more, point to the wiki 9 years ago
Jorge Bucaran cb53572084 Revamp 💪 README. 9 years ago
Jorge Bucaran d9c06f33de Add quick install instructions and remove manual method.
Ahoy dear captain and distinguished members of the crew aboard. 

Now you can install Fisherman using, not one, but two methods!

The traditional, or "manual" method to install Fisherman. Still the one
favored by beefy old Fisherman with 💪 and heart.

    git clone https://github.com/fisherman/fisherman
    cd fisherman
    make

Or you can use the new hot, quick install method like a Fisherman
that communicates to sea creatures and can breathe under water.
He also carries a GE XM214 Machine Gun in one arm.
9 years ago