all repos — min @ 135ba8c32b3f64602a322f42c2bb5dc22e03cb23

A small but practical concatenative programming language.

linenoise.nim

 1
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
 100
 101
 102
 103
 104
 105
 106
 107
 108
 109
 110
 111
 112
 113
 114
 115
 116
 117
 118
 119
 120
 121
 122
 123
 124
 125
 126
 127
# linenoise.h -- guerrilla line editing library against the idea that a
#  line editing lib needs to be 20,000 lines of C code.
# 
#  See linenoise.c for more information.
# 
#  ------------------------------------------------------------------------
# 
#  Copyright (c) 2010, Salvatore Sanfilippo <antirez at gmail dot com>
#  Copyright (c) 2010, Pieter Noordhuis <pcnoordhuis at gmail dot com>
# 
#  All rights reserved.
# 
#  Redistribution and use in source and binary forms, with or without
#  modification, are permitted provided that the following conditions are
#  met:
# 
#   *  Redistributions of source code must retain the above copyright
#      notice, this list of conditions and the following disclaimer.
# 
#   *  Redistributions in binary form must reproduce the above copyright
#      notice, this list of conditions and the following disclaimer in the
#      documentation and/or other materials provided with the distribution.
# 
#  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
#  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
#  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
#  A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
#  HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
#  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
#  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
#  DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
#  THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
#  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
#  OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
# 

{.compile: "linenoise/liblinenoise.c".}
{.push importc.}
when not(defined(LINENOISE_H)): 
  const 
    LINENOISE_H* = true
  when not(defined(NO_COMPLETION)): 
    type 
      linenoiseCompletions* = object 
        len*: csize
        cvec*: cstringArray
      linenoiseCompletionCallback* = proc (a: cstring, b: ptr linenoiseCompletions)

    #
    #  The callback type for tab completion handlers.
    # 
    #typedef void(linenoiseCompletionCallback)(const char *, linenoiseCompletions *);
    #
    #  Sets the current tab completion handler and returns the previous one, or NULL
    #  if no prior one has been set.
    # 
    proc linenoiseSetCompletionCallback*(a: linenoiseCompletionCallback): linenoiseCompletions;
    #
    #  Adds a copy of the given string to the given completion list. The copy is owned
    #  by the linenoiseCompletions object.
    # 
    proc linenoiseAddCompletion*(a2: ptr linenoiseCompletions; a3: cstring)
  #
  #  Prompts for input using the given string as the input
  #  prompt. Returns when the user has tapped ENTER or (on an empty
  #  line) EOF (Ctrl-D on Unix, Ctrl-Z on Windows). Returns either
  #  a copy of the entered string (for ENTER) or NULL (on EOF).  The
  #  caller owns the returned string and must eventually free() it.
  # 
  proc linenoise*(prompt: cstring): cstring
  #
  #  Activates password entry in future calls of linenoise(), i.e. user
  #  input will not be echoed back to the terminal during entry.
  # 
  const 
    LN_HIDDEN_NO* = (0)       # Fully visible entry.           
    LN_HIDDEN_ALL* = (1)      # Fully hidden, no echo at all   
    LN_HIDDEN_STAR* = (2)     # Hidden entry, echoing *'s back 
  proc linenoiseSetHidden*(enable: cint)
  #
  #  Activates normal entry in future calls of linenoise(), i.e. user
  #  input will again be echoed back to the terminal during entry.
  # 
  proc linenoiseGetHidden*(): cint
  #
  #  Adds a copy of the given line of the command history.
  # 
  proc linenoiseHistoryAdd*(line: cstring): cint
  #
  #  Sets the maximum length of the command history, in lines.
  #  If the history is currently longer, it will be trimmed,
  #  retaining only the most recent entries. If len is 0 or less
  #  then this function does nothing.
  # 
  proc linenoiseHistorySetMaxLen*(len: cint): cint
  #
  #  Returns the current maximum length of the history, in lines.
  # 
  proc linenoiseHistoryGetMaxLen*(): cint
  #
  #  Saves the current contents of the history to the given file.
  #  Returns 0 on success.
  # 
  proc linenoiseHistorySave*(filename: cstring): cint
  #
  #  Replaces the current history with the contents
  #  of the given file.  Returns 0 on success.
  # 
  proc linenoiseHistoryLoad*(filename: cstring): cint
  #
  #  Frees all history entries, clearing the history.
  # 
  proc linenoiseHistoryFree*()
  #
  #  Returns a pointer to the list of history entries, writing its
  #  length to *len if len is not NULL. The memory is owned by linenoise
  #  and must not be freed.
  # 
  proc linenoiseHistory*(len: ptr cint): cstringArray
  #
  #  Returns the number of display columns in the current terminal.
  # 
  proc linenoiseColumns*(): cint
  #
  #  Returns the number of display rows|lines in the current terminal.
  # 
  proc linenoiseLines*(): cint