Skip to content

Latest commit

 

History

History
93 lines (71 loc) · 2.65 KB

README.md

File metadata and controls

93 lines (71 loc) · 2.65 KB

Build Status

LIBRARY

Directory structure:

$ BANK / $category / $sub-category / $filename .{cfg,sh}

#Example: 
$ BANK/PRINT/print_line.cfg 

script types

  • LONG LIFE-CYCLE ( source the file to update the Shell-Environment )

  • .cfg: export functions

export -f some_func 
  • .conf: export variables
export my_var='x'
alias my_alias='y'
  • SHORT LIFE-CYCLE ( run the file on demand )
  • .sh: regular scripts
./translate.sh ru dog #translate 'dog' to 'russian'

WORKFLOW

  • Install:
$ ./install.sh                          #creates symlink on path: /tmp
$ ls -l /tmp/library.cfg                #this is the anchor for the project (absolute path)
  • Activate:
$ source /tmp/library.cfg               #export function: use() , use_sh() , finder(), updatedb1()
  • Extending the Library:
$ cat /tmp/target                       #current list of library files
#Example: here we update the bank of files in our library:
$ touch BANK/my_file.cfg                #USER ACTION
$ touch BANK/my_file.sh                 #USER ACTION
#Example: here we index the new added files:
$ updatedb1                             #update the index:  after adding new files ( under BANK/ )
$ cat /tmp/target                       #current list of library files
$ finder my_file                        #will print the location of the new file: my_file.cfg
$ finder my_file sh                     #will print the location of the new file: my_file.sh
  • Use:
  • Example: for enabling the shell-command: $ print ok
$ cat /tmp/target | grep print          #if you want to make sure that file: print.cfg is indexed
$ use print                             #it source file: print.cfg (wherever located)
$ type print                            #the file print.cfg has command: export -f print
$ print ok                              #pass parameter: 'ok' to function: print()
  • Example: for enabling the shell-command: $ $translate_sh ru dog
$ cat /tmp/target | grep translate      #if you are curious where translate.sh is
$ finder translate sh                   #if you are curious where translate.sh is
$ use_sh translate                      #this will export variable: translate_sh (which point to the script)
$ $translate_sh ru dog                  #this will actualy run the file: translate.sh with params: ( ru , dog )
  • Update the library anchor: (for extending the core-functionality)
$ alias libraryE
$ libraryE