mirror of
https://github.com/walles/moar.git
synced 2025-01-07 13:56:33 +03:00
Reboot in Go
This commit is contained in:
commit
f3097e7450
8
.whitesource
Normal file
8
.whitesource
Normal file
@ -0,0 +1,8 @@
|
||||
{
|
||||
"generalSettings": {
|
||||
"shouldScanRepo": true
|
||||
},
|
||||
"checkRunSettings": {
|
||||
"vulnerableCheckRunConclusionLevel": "failure"
|
||||
}
|
||||
}
|
26
LICENSE
Normal file
26
LICENSE
Normal file
@ -0,0 +1,26 @@
|
||||
Copyright (c) 2013, johan.walles@gmail.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:
|
||||
|
||||
1. Redistributions of source code must retain the above copyright notice, this
|
||||
list of conditions and the following disclaimer.
|
||||
2. 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 OWNER 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.
|
||||
|
||||
The views and conclusions contained in the software and documentation are those
|
||||
of the authors and should not be interpreted as representing official policies,
|
||||
either expressed or implied, of the FreeBSD Project.
|
340
README.md
Normal file
340
README.md
Normal file
@ -0,0 +1,340 @@
|
||||
Moar is a pager. It's designed to just do the right thing without any
|
||||
configuration:
|
||||
|
||||
![Moar displaying its own test suite](http://walles.github.io/moar/images/moar.png)
|
||||
|
||||
The intention is that Moar should work as a drop-in replacement for
|
||||
[Less](http://www.greenwoodsoftware.com/less/). If you find that Moar
|
||||
doesn't work that way,
|
||||
[please report it](https://github.com/walles/moar/issues)!
|
||||
|
||||
Doing the right thing includes:
|
||||
|
||||
* **Syntax highlight** source code by default if
|
||||
[GNU Source-highlight](http://www.gnu.org/software/src-highlite/)
|
||||
is installed.
|
||||
* **Search is incremental** / find-as-you-type just like in
|
||||
[Chrome](http://www.google.com/chrome) or
|
||||
[Emacs](http://www.gnu.org/software/emacs/)
|
||||
* Search becomes case sensitive if you add any UPPER CASE characters
|
||||
to your search terms, just like in Emacs
|
||||
* [Regexp](http://en.wikipedia.org/wiki/Regular_expression#Basic_concepts)
|
||||
search if your search string is a valid regexp
|
||||
* Supports displaying ANSI color coded texts (like the output from
|
||||
"git diff" for example)
|
||||
* Supports UTF-8 input and output
|
||||
* The position in the file is always shown
|
||||
|
||||
Installing
|
||||
----------
|
||||
|
||||
FIXME: Go install instructions
|
||||
|
||||
...
|
||||
|
||||
And now you can just invoke `moar` from the prompt!
|
||||
|
||||
Setting Moar as Your Default Pager
|
||||
----------------------------------
|
||||
|
||||
Set it as your default pager by adding...
|
||||
|
||||
```bash
|
||||
export PAGER=/usr/local/bin/moar
|
||||
```
|
||||
|
||||
... to your `.bashrc`.
|
||||
|
||||
Issues
|
||||
------
|
||||
|
||||
Issues are tracked [here](https://github.com/walles/moar/issues), or
|
||||
you can send questions to <johan.walles@gmail.com>.
|
||||
|
||||
Developing
|
||||
----------
|
||||
|
||||
FIXME: Go build instructions
|
||||
|
||||
FIXME: Go test instructions
|
||||
|
||||
Making a new Release
|
||||
--------------------
|
||||
|
||||
FIXME: Go release instructions
|
||||
|
||||
TODO
|
||||
----
|
||||
* Make search work cross color boundaries. Currently, if you have a syntax
|
||||
highlighted line and search for something across a color change you won't get
|
||||
any match.
|
||||
|
||||
* Handle search hits to the right of the right screen edge. Searching
|
||||
forwards should move first right, then to the left edge and
|
||||
down. Searching backwards should move first left, then up and to the
|
||||
right edge (if needed for showing search hits).
|
||||
|
||||
* Auto generate the in-program help text to correctly correspond to
|
||||
the actual key bindings.
|
||||
* If you try to bind the same key to multiple actions, that must be caught by
|
||||
the unit tests.
|
||||
* If you try to bind to an action that doesn't exist, that must be caught by
|
||||
the unit tests.
|
||||
|
||||
* Read `source-highlight` output as a stream for startup performance reasons.
|
||||
This must work when `source-highlight` fails as well, and when it succeeds on
|
||||
an empty input file.
|
||||
|
||||
* When skipping to the end, either while searching or when the user presses '>',
|
||||
try finding the end of the file for at most two seconds, then show wherever we
|
||||
are. Pressing '>' again or searching again should make another attempt until
|
||||
we're actually done.
|
||||
|
||||
* Redefine 'g' without any prefix to prompt for which line to go
|
||||
to. This definition makes more sense to me than having to prefix 'g'
|
||||
to jump.
|
||||
|
||||
* Start at a certain line if run as "moar.rb file.txt:42"
|
||||
|
||||
* Enable home / end using home / end keys.
|
||||
|
||||
* Always print the name of the file being shown in the status field.
|
||||
|
||||
* Support viewing multiple files by pushing them in reverse order on
|
||||
the view stack.
|
||||
|
||||
* Add search line editing
|
||||
|
||||
* Try to find a newer Ruby version if needed for color support and
|
||||
exec() with that instead if available.
|
||||
|
||||
* Write "/ to search" somewhere in the status field
|
||||
|
||||
* Incremental search using ^s and ^r like in Emacs
|
||||
|
||||
* Gunzip input files with .gz extension before displaying them
|
||||
|
||||
* Warn but don't hang if we get an incomplete UTF-8 sequence from
|
||||
getch() in wide_getch(). Hanging won't be that much of a problem
|
||||
assuming users will press more keys if nothing happens, thus
|
||||
resolving the hang.
|
||||
|
||||
* Enable up / down using the mouse wheel.
|
||||
|
||||
|
||||
DONE
|
||||
----
|
||||
* Enable exiting using q (restores screen)
|
||||
|
||||
* Handle the terminal window getting resized.
|
||||
|
||||
* Print info line in inverse video
|
||||
|
||||
* Enable up / down using arrow keys.
|
||||
|
||||
* Prevent pressing down past the last line of the file.
|
||||
|
||||
* Enable out-of-file visualization with ~ like less.
|
||||
|
||||
* Enable up / down using page-up and page-down keys.
|
||||
|
||||
* Enable home / end using < and >.
|
||||
|
||||
* Enable file input.
|
||||
|
||||
* Enable continuous position display with everything we know (lines
|
||||
visible, percentages, like less).
|
||||
|
||||
* Enable stdin input.
|
||||
|
||||
* Truncate lines that are longer than the screen width
|
||||
|
||||
* Make sure we can print all the way into the rightmost column of the
|
||||
screen when truncating too long lines. We should strip() lines
|
||||
before we print them and manually move the cursor to the next line
|
||||
after each.
|
||||
|
||||
* Handle all kinds of line endings.
|
||||
|
||||
* Handle files missing an ending newline.
|
||||
|
||||
* Handle hitting BACKSPACE in the search field
|
||||
|
||||
* Incremental search using /
|
||||
|
||||
* Typing backspace in the line editor when it's empty should make the
|
||||
line editor say "done".
|
||||
|
||||
* Change out-of-file visualization to writing --- after the end of the
|
||||
file and leaving the rest of the screen blank.
|
||||
|
||||
* Scroll down if we have no search hits on the current screen
|
||||
|
||||
* Wrap search if we have search hits above but not below
|
||||
|
||||
* Find next using n
|
||||
|
||||
* Highlight search hits using reverse video
|
||||
|
||||
* Make sure we can properly render all lines of /etc/php.ini.default
|
||||
without the bottom-of-the-screen prompt moving around.
|
||||
|
||||
* Find previous using N
|
||||
|
||||
* Indicate when we're wrapping the search while pressing n.
|
||||
|
||||
* Indicate when we're wrapping the search while pressing N.
|
||||
|
||||
* Highlight all matches while searching
|
||||
|
||||
* Scroll down one line on RETURN
|
||||
|
||||
* Print warnings to stderr after the run, for example if we aren't
|
||||
using color support because of a too-old version of Ruby.
|
||||
|
||||
* Make stdin input work even on newer (than 1.8) versions of
|
||||
Ruby. Apparently
|
||||
[this patch](http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/io.c?r1=7641&r2=7649&diff_format=h)
|
||||
is the reason it doesn't
|
||||
work. [Reported to the Ruby issue tracker](https://bugs.ruby-lang.org/issues/9067),
|
||||
let's see how that goes.
|
||||
|
||||
* Enable displaying colorized output from "git diff"
|
||||
* Arrow down through the whole file, then arrow up again
|
||||
* Page down through the whole file, then page up again
|
||||
* Search highlighting
|
||||
|
||||
* Use the same algorithm for highlighting as for determining which
|
||||
lines match.
|
||||
|
||||
* Make the search case sensitive only if it contains any capital
|
||||
letters.
|
||||
|
||||
* Do a regexp search if the search term is a valid regexp, otherwise
|
||||
just use it as a substring.
|
||||
|
||||
* Make the search case sensitive only if it contains any capital
|
||||
letters, for both regexps and non-regexps.
|
||||
|
||||
* If we print warnings at the end, also print an URL where they can be
|
||||
reported.
|
||||
|
||||
* If we crash with a stacktrace, print an URL where it can be reported
|
||||
|
||||
* Enable sideways scrolling using arrow keys.
|
||||
|
||||
* Warn about any unhandled keypresses during search.
|
||||
|
||||
* Enable displaying a man page
|
||||
* Arrow down through the whole file, then arrow up again
|
||||
* Page down through the whole file, then page up again
|
||||
* Search highlighting
|
||||
|
||||
* Make sure we get the line length right even with unicode characters
|
||||
present in the lines. Verify by looking at where the truncation
|
||||
markers end up.
|
||||
|
||||
* Make sure we can search for unicode characters
|
||||
* Work around
|
||||
[the issue with getch not returning unicode chars](https://bugs.ruby-lang.org/issues/9094)
|
||||
|
||||
* Work around
|
||||
[the issue with Regexp.quote() returning non-unicode strings](https://bugs.ruby-lang.org/issues/9096)
|
||||
|
||||
* Warn but don't crash if we get an invalid UTF-8 sequence from
|
||||
getch() in wide_getch().
|
||||
|
||||
* Make sure the LANG environment variable is printed if there are
|
||||
warnings.
|
||||
|
||||
* Make sure some kind of platform information is printed if there are
|
||||
warnings.
|
||||
|
||||
* Make sure the Ruby version is printed if there are warnings.
|
||||
|
||||
* Startup exceptions should be caught through the same reporting
|
||||
thingy as everything else.
|
||||
|
||||
* We must not crash on getting binary data. Testcase: "moar.rb /bin/ls"
|
||||
|
||||
* Fix handling of TAB characters in the input
|
||||
|
||||
* Run rubocop as part of test.rb if installed and have the exit code
|
||||
reflect any issues.
|
||||
|
||||
* Make sure version information is printed if there are warnings.
|
||||
|
||||
* Make it possible to install system-wide using "rake install". Don't
|
||||
forget to fix the version number when doing this.
|
||||
|
||||
* Enable --help for help
|
||||
|
||||
* Enable --version for version information.
|
||||
|
||||
* Report command line errors, think about different command line
|
||||
requirements depending on whether we're piping input into moar.rb or
|
||||
listing input files on the command line.
|
||||
|
||||
Command line formats we want to support:
|
||||
* moar.rb file.txt
|
||||
* moar.rb < file.txt
|
||||
|
||||
Command line formats we *don't* want to support:
|
||||
* moar.rb file1.txt file2.txt
|
||||
* moar.rb file1.txt < file2.txt
|
||||
|
||||
* Enable 'h', '?' or F1 for help
|
||||
|
||||
* Print something nice on file-not-found.
|
||||
|
||||
* Test on Ubuntu
|
||||
|
||||
* Test on Ruby 1.8.something. We did, and due to missing UTF-8 support
|
||||
in Ruby 1.8 we just dropped support for it. Now we print an error
|
||||
message if Ruby < 1.9 is detected.
|
||||
|
||||
* Add info to the end of the --help output on how to set Moar to be
|
||||
your default pager.
|
||||
|
||||
* Add licensing information (BSD)
|
||||
|
||||
* Enable source code highlighting by pre-filtering using GNU
|
||||
Source-highlight.
|
||||
|
||||
* Retain the search string when pressing / to search a second time.
|
||||
|
||||
* Exit search mode and cancel the search on ESC. Because that's what I
|
||||
feel like pressing.
|
||||
|
||||
* Exit search mode and cancel the search on ^G. For compatibility with
|
||||
Emacs.
|
||||
|
||||
* Make sure searching for an upper case unicode character turns on
|
||||
case sensitive search.
|
||||
|
||||
* Doing moar.rb on an arbitrary binary (like /bin/ls) should put all
|
||||
line-continuation markers at the rightmost column. This really
|
||||
means our truncation code must work even with things like tabs and
|
||||
various control characters.
|
||||
|
||||
* Enable exiting using ^c (without restoring the screen).
|
||||
|
||||
* Enable pass-through operation unless $stdout.isatty()
|
||||
|
||||
* Accept numeric prefixes just like less. Implement for 'g', 'G' and
|
||||
SPACE to begin with.
|
||||
|
||||
* Exit search on pressing up / down / pageup / pagedown keys and
|
||||
scroll. I attempted to do that spontaneously, so it's probably a
|
||||
good idea.
|
||||
|
||||
* Searching for something above us should wrap the search.
|
||||
|
||||
* When pressing '/' to edit the search terms, find a hit and
|
||||
re-highlight.
|
||||
|
||||
* Make sure "git grep" output gets highlighted properly.
|
||||
|
||||
* Lazy load big / slow streams
|
||||
|
||||
* Add making binaries to the Making a new Release section above.
|
75
sample-files/dos.txt
Normal file
75
sample-files/dos.txt
Normal file
@ -0,0 +1,75 @@
|
||||
1 #!/usr/bin/ruby
|
||||
2
|
||||
3 require "curses"
|
||||
4
|
||||
5 class Moar
|
||||
6 include Curses
|
||||
7
|
||||
8 def initialize(file)
|
||||
9 @first_line = 0
|
||||
10 @file = file
|
||||
11 @lines = IO.readlines(file)
|
||||
12 @last_key = 0
|
||||
13 end
|
||||
14
|
||||
15 def draw_screen()
|
||||
16 # @first_line must not be closer than lines-2 from the end
|
||||
17 max_first_line = @lines.size - (lines - 1)
|
||||
18 @first_line = [@first_line, max_first_line].min()
|
||||
19
|
||||
20 # @first_line cannot be negative
|
||||
21 @first_line = [0, @first_line].max()
|
||||
22
|
||||
23 clear()
|
||||
24 setpos(0, 0)
|
||||
25
|
||||
26 attrset(A_NORMAL)
|
||||
27 last_line = @first_line + lines - 2
|
||||
28 for line_number in @first_line..last_line do
|
||||
29 if line_number < @lines.size
|
||||
30 addstr(@lines[line_number])
|
||||
31 else
|
||||
32 addstr("~\n")
|
||||
33 end
|
||||
34 end
|
||||
35
|
||||
36 attrset(A_REVERSE)
|
||||
37 status = "Lines #{@first_line + 1}-"
|
||||
38 status += "#{[@lines.size, last_line].min()}"
|
||||
39 status += "/#{@lines.size}"
|
||||
40 addstr(status)
|
||||
41
|
||||
42 refresh()
|
||||
43 end
|
||||
44
|
||||
45 def run
|
||||
46 init_screen
|
||||
47 noecho
|
||||
48 stdscr.keypad(true)
|
||||
49
|
||||
50 begin
|
||||
51 crmode
|
||||
52 while true
|
||||
53 draw_screen()
|
||||
54
|
||||
55 key = getch()
|
||||
56 case key
|
||||
57 when ?q.ord
|
||||
58 break
|
||||
59 when Key::RESIZE
|
||||
60 draw_screen()
|
||||
61 when Key::DOWN
|
||||
62 @first_line += 1
|
||||
63 when Key::UP
|
||||
64 @first_line -= 1
|
||||
65 end
|
||||
66
|
||||
67 @last_key = key
|
||||
68 end
|
||||
69 ensure
|
||||
70 close_screen
|
||||
71 end
|
||||
72 end
|
||||
73 end
|
||||
74
|
||||
75 Moar.new(ARGV[0]).run()
|
100
sample-files/gitdiff-color.txt
Normal file
100
sample-files/gitdiff-color.txt
Normal file
@ -0,0 +1,100 @@
|
||||
[33mcommit 0ccc858f87d70c302117db9034186754a4091f23[m
|
||||
Author: Johan Walles <johan.walles@gmail.com>
|
||||
Date: Thu Oct 24 20:45:40 2013 +0200
|
||||
|
||||
Prioritize the TODO file
|
||||
|
||||
[1mdiff --git a/TODO.txt b/TODO.txt[m
|
||||
[1mindex 52551e7..663ffd7 100644[m
|
||||
[1m--- a/TODO.txt[m
|
||||
[1m+++ b/TODO.txt[m
|
||||
[36m@@ -1,36 +1,48 @@[m
|
||||
Moar is a pager. It's designed to be easy to use and just do the[m
|
||||
right thing without any configuration.[m
|
||||
[m
|
||||
[31m-TODO (in some order):[m
|
||||
[32m+[m[32mTODO (before using it myself)[m
|
||||
[32m+[m[32m-----------------------------[m
|
||||
[32m+[m[32m* Scroll down one line on RETURN[m
|
||||
[m
|
||||
[31m-* Write "/ to search" somewhere in the status field[m
|
||||
[32m+[m[32m* Enable displaying ANSI-colored input[m
|
||||
[32m+[m
|
||||
[32m+[m
|
||||
[32m+[m[32mTODO (before github)[m
|
||||
[32m+[m[32m--------------------[m
|
||||
[m
|
||||
[32m+[m[32mTODO (before trying to get others to use it)[m
|
||||
[32m+[m[32m--------------------------------------------[m
|
||||
* Do a regexp search if the search term is a valid regexp, otherwise[m
|
||||
just use it as a substring.[m
|
||||
[m
|
||||
[31m-* Make the search case sensitive only if it contains any capital[m
|
||||
[31m- letters. This goes for both regexps and non-regexps.[m
|
||||
[31m-[m
|
||||
* Make sure we can search for unicode characters[m
|
||||
[m
|
||||
[31m-* Make sure searching for an upper case unicode character turns on[m
|
||||
[31m- case sensitive search.[m
|
||||
[31m-[m
|
||||
* Make sure we get the line length right even with unicode characters[m
|
||||
present in the lines. Verify by looking at where the truncation[m
|
||||
markers end up.[m
|
||||
[m
|
||||
[31m-* Scroll down one line on RETURN[m
|
||||
[31m-[m
|
||||
* Enable sideways scrolling using arrow keys.[m
|
||||
[m
|
||||
* Handle search hits to the right of the right screen edge[m
|
||||
[m
|
||||
[31m-* Interactive search using ^s and ^r like in Emacs[m
|
||||
[32m+[m[32m* Enable 'h' or '?' for help[m
|
||||
[m
|
||||
[31m-* Highlight all matches while searching[m
|
||||
[32m+[m[32m* Report command line errors, think about when to use $stdin for input[m
|
||||
[32m+[m[32m vs what commands we accept[m
|
||||
[m
|
||||
[31m-* Enable displaying ANSI-colored input[m
|
||||
[32m+[m
|
||||
[32m+[m[32mTODO (bonus)[m
|
||||
[32m+[m[32m------------[m
|
||||
[32m+[m[32m* Make the search case sensitive only if it contains any capital[m
|
||||
[32m+[m[32m letters. This goes for both regexps and non-regexps.[m
|
||||
[32m+[m
|
||||
[32m+[m[32m* Make sure searching for an upper case unicode character turns on[m
|
||||
[32m+[m[32m case sensitive search.[m
|
||||
[32m+[m
|
||||
[32m+[m[32m* Write "/ to search" somewhere in the status field[m
|
||||
[32m+[m
|
||||
[32m+[m[32m* Interactive search using ^s and ^r like in Emacs[m
|
||||
[m
|
||||
* Enable filtered input, start with zcat as a filter[m
|
||||
[m
|
||||
[36m@@ -47,11 +59,6 @@[m [mTODO (in some order):[m
|
||||
[m
|
||||
* Enable up / down using the mouse wheel.[m
|
||||
[m
|
||||
[31m-* Enable 'h' or '?' for help[m
|
||||
[31m-[m
|
||||
[31m-* Report command line errors, think about when to use $stdin for input[m
|
||||
[31m- vs what commands we accept[m
|
||||
[31m-[m
|
||||
* Enable pass-through operation unless $stdout.isatty()[m
|
||||
[m
|
||||
* Doing moar.rb on an arbitrary binary (like /bin/ls) should put all[m
|
||||
[36m@@ -60,7 +67,8 @@[m [mTODO (in some order):[m
|
||||
various control characters.[m
|
||||
[m
|
||||
[m
|
||||
[31m-DONE:[m
|
||||
[32m+[m[32mDONE[m
|
||||
[32m+[m[32m----[m
|
||||
* Enable exiting using q (restores screen)[m
|
||||
[m
|
||||
* Handle the terminal window getting resized.[m
|
||||
[36m@@ -121,3 +129,5 @@[m [mDONE:[m
|
||||
* Indicate when we're wrapping the search while pressing n.[m
|
||||
[m
|
||||
* Indicate when we're wrapping the search while pressing N.[m
|
||||
[32m+[m
|
||||
[32m+[m[32m* Highlight all matches while searching[m
|
197
sample-files/hej.txt
Normal file
197
sample-files/hej.txt
Normal file
@ -0,0 +1,197 @@
|
||||
|
||||
PRINTF(1) BSD General Commands Manual PRINTF(1)
|
||||
|
||||
NNAAMMEE
|
||||
pprriinnttff -- formatted output
|
||||
|
||||
SSYYNNOOPPSSIISS
|
||||
pprriinnttff _f_o_r_m_a_t [_a_r_g_u_m_e_n_t_s _._._.]
|
||||
|
||||
DDEESSCCRRIIPPTTIIOONN
|
||||
The pprriinnttff utility formats and prints its arguments, after the first,
|
||||
under control of the _f_o_r_m_a_t. The _f_o_r_m_a_t is a character string which con-
|
||||
tains three types of objects: plain characters, which are simply copied
|
||||
to standard output, character escape sequences which are converted and
|
||||
copied to the standard output, and format specifications, each of which
|
||||
causes printing of the next successive _a_r_g_u_m_e_n_t.
|
||||
|
||||
The _a_r_g_u_m_e_n_t_s after the first are treated as strings if the corresponding
|
||||
format is either cc, bb or ss; otherwise it is evaluated as a C constant,
|
||||
with the following extensions:
|
||||
|
||||
++oo A leading plus or minus sign is allowed.
|
||||
++oo If the leading character is a single or double quote, the value
|
||||
is the ASCII code of the next character.
|
||||
|
||||
The format string is reused as often as necessary to satisfy the
|
||||
_a_r_g_u_m_e_n_t_s. Any extra format specifications are evaluated with zero or
|
||||
the null string.
|
||||
|
||||
Character escape sequences are in backslash notation as defined in the
|
||||
ANSI X3.159-1989 (``ANSI C89''), with extensions. The characters and
|
||||
their meanings are as follows:
|
||||
|
||||
\\aa Write a <bell> character.
|
||||
\\bb Write a <backspace> character.
|
||||
\\cc Ignore remaining characters in this string.
|
||||
\\ff Write a <form-feed> character.
|
||||
\\nn Write a <new-line> character.
|
||||
\\rr Write a <carriage return> character.
|
||||
\\tt Write a <tab> character.
|
||||
\\vv Write a <vertical tab> character.
|
||||
\\'' Write a <single quote> character.
|
||||
\\\\ Write a backslash character.
|
||||
\\_n_u_m
|
||||
\\00_n_u_m Write an 8-bit character whose ASCII value is the 1-, 2-,
|
||||
or 3-digit octal number _n_u_m.
|
||||
|
||||
Each format specification is introduced by the percent character (``%'').
|
||||
The remainder of the format specification includes, in the following
|
||||
order:
|
||||
|
||||
Zero or more of the following flags:
|
||||
|
||||
## A `#' character specifying that the value should be
|
||||
printed in an ``alternate form''. For cc, dd, and ss, for-
|
||||
mats, this option has no effect. For the oo formats the
|
||||
precision of the number is increased to force the first
|
||||
character of the output string to a zero. For the xx (XX)
|
||||
format, a non-zero result has the string 0x (0X)
|
||||
prepended to it. For ee, EE, ff, gg, and GG, formats, the
|
||||
result will always contain a decimal point, even if no
|
||||
digits follow the point (normally, a decimal point only
|
||||
appears in the results of those formats if a digit fol-
|
||||
lows the decimal point). For gg and GG formats, trailing
|
||||
zeros are not removed from the result as they would oth-
|
||||
erwise be;
|
||||
|
||||
-- A minus sign `-' which specifies _l_e_f_t _a_d_j_u_s_t_m_e_n_t of the
|
||||
output in the indicated field;
|
||||
|
||||
++ A `+' character specifying that there should always be a
|
||||
sign placed before the number when using signed formats.
|
||||
|
||||
` ' A space specifying that a blank should be left before a
|
||||
positive number for a signed format. A `+' overrides a
|
||||
space if both are used;
|
||||
|
||||
00 A zero `0' character indicating that zero-padding should
|
||||
be used rather than blank-padding. A `-' overrides a `0'
|
||||
if both are used;
|
||||
|
||||
Field Width:
|
||||
An optional digit string specifying a _f_i_e_l_d _w_i_d_t_h; if the output
|
||||
string has fewer characters than the field width it will be
|
||||
blank-padded on the left (or right, if the left-adjustment indi-
|
||||
cator has been given) to make up the field width (note that a
|
||||
leading zero is a flag, but an embedded zero is part of a field
|
||||
width);
|
||||
|
||||
Precision:
|
||||
An optional period, `..', followed by an optional digit string
|
||||
giving a _p_r_e_c_i_s_i_o_n which specifies the number of digits to appear
|
||||
after the decimal point, for ee and ff formats, or the maximum num-
|
||||
ber of characters to be printed from a string; if the digit
|
||||
string is missing, the precision is treated as zero;
|
||||
|
||||
Format:
|
||||
A character which indicates the type of format to use (one of
|
||||
ddiioouuxxXXffFFeeEEggGGaaAAccssbb). The uppercase formats differ from their low-
|
||||
ercase counterparts only in that the output of the former is
|
||||
entirely in uppercase. The floating-point format specifiers
|
||||
(ffFFeeEEggGGaaAA) may be prefixed by an LL to request that additional
|
||||
precision be used, if available.
|
||||
|
||||
A field width or precision may be `**' instead of a digit string. In this
|
||||
case an _a_r_g_u_m_e_n_t supplies the field width or precision.
|
||||
|
||||
The format characters and their meanings are:
|
||||
|
||||
ddiioouuXXxx The _a_r_g_u_m_e_n_t is printed as a signed decimal (d or i),
|
||||
unsigned octal, unsigned decimal, or unsigned hexadecimal (X
|
||||
or x), respectively.
|
||||
|
||||
ffFF The _a_r_g_u_m_e_n_t is printed in the style `[-]ddd.ddd' where the
|
||||
number of d's after the decimal point is equal to the preci-
|
||||
sion specification for the argument. If the precision is
|
||||
missing, 6 digits are given; if the precision is explicitly
|
||||
0, no digits and no decimal point are printed. The values
|
||||
infinity and _N_a_N are printed as `inf' and `nan', respec-
|
||||
tively.
|
||||
|
||||
eeEE The _a_r_g_u_m_e_n_t is printed in the style ee `[-_d_._d_d_d+-_d_d]' where
|
||||
there is one digit before the decimal point and the number
|
||||
after is equal to the precision specification for the argu-
|
||||
ment; when the precision is missing, 6 digits are produced.
|
||||
The values infinity and _N_a_N are printed as `inf' and `nan',
|
||||
respectively.
|
||||
|
||||
ggGG The _a_r_g_u_m_e_n_t is printed in style ff (FF) or in style ee (EE)
|
||||
whichever gives full precision in minimum space.
|
||||
|
||||
aaAA The _a_r_g_u_m_e_n_t is printed in style `[-_h_._h_h_h+-p_d]' where there
|
||||
is one digit before the hexadecimal point and the number
|
||||
after is equal to the precision specification for the argu-
|
||||
ment; when the precision is missing, enough digits are pro-
|
||||
duced to convey the argument's exact double-precision float-
|
||||
ing-point representation. The values infinity and _N_a_N are
|
||||
printed as `inf' and `nan', respectively.
|
||||
|
||||
cc The first character of _a_r_g_u_m_e_n_t is printed.
|
||||
|
||||
ss Characters from the string _a_r_g_u_m_e_n_t are printed until the end
|
||||
is reached or until the number of characters indicated by the
|
||||
precision specification is reached; however if the precision
|
||||
is 0 or missing, all characters in the string are printed.
|
||||
|
||||
bb As for ss, but interpret character escapes in backslash nota-
|
||||
tion in the string _a_r_g_u_m_e_n_t.
|
||||
|
||||
%% Print a `%'; no argument is used.
|
||||
|
||||
The decimal point character is defined in the program's locale (category
|
||||
LC_NUMERIC).
|
||||
|
||||
In no case does a non-existent or small field width cause truncation of a
|
||||
field; padding takes place only if the specified field width exceeds the
|
||||
actual width.
|
||||
|
||||
EEXXIITT SSTTAATTUUSS
|
||||
The pprriinnttff utility exits 0 on success, and >0 if an error occurs.
|
||||
|
||||
CCOOMMPPAATTIIBBIILLIITTYY
|
||||
The traditional BSD behavior of converting arguments of numeric formats
|
||||
not beginning with a digit to the ASCII code of the first character is
|
||||
not supported.
|
||||
|
||||
SSEEEE AALLSSOO
|
||||
echo(1), printf(3)
|
||||
|
||||
SSTTAANNDDAARRDDSS
|
||||
The pprriinnttff command is expected to be mostly compatible with the IEEE Std
|
||||
1003.2 (``POSIX.2'') specification.
|
||||
|
||||
HHIISSTTOORRYY
|
||||
The pprriinnttff command appeared in 4.3BSD-Reno. It is modeled after the
|
||||
standard library function, printf(3).
|
||||
|
||||
BBUUGGSS
|
||||
Since the floating point numbers are translated from ASCII to floating-
|
||||
point and then back again, floating-point precision may be lost. (By
|
||||
default, the number is translated to an IEEE-754 double-precision value
|
||||
before being printed. The LL modifier may produce additional precision,
|
||||
depending on the hardware platform.)
|
||||
|
||||
ANSI hexadecimal character constants were deliberately not provided.
|
||||
|
||||
The escape sequence \000 is the string terminator. When present in the
|
||||
argument for the bb format, the argument will be truncated at the \000
|
||||
character.
|
||||
|
||||
Multibyte characters are not recognized in format strings (this is only a
|
||||
problem if `%' can appear inside a multibyte character).
|
||||
|
||||
Parsing of - arguments is also somewhat different from printf(3), where
|
||||
unknown arguments are simply printed instead of being flagged as errors.
|
||||
|
||||
BSD April 14, 2005 BSD
|
289477
sample-files/large-git-log-patch.txt
Normal file
289477
sample-files/large-git-log-patch.txt
Normal file
File diff suppressed because it is too large
Load Diff
202
sample-files/long-and-wide.txt
Normal file
202
sample-files/long-and-wide.txt
Normal file
@ -0,0 +1,202 @@
|
||||
Search for monkeys in this file.
|
||||
monkeys
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
Search for monkeys in this file.
|
||||
monkeys
|
75
sample-files/long.txt
Normal file
75
sample-files/long.txt
Normal file
@ -0,0 +1,75 @@
|
||||
1 #!/usr/bin/ruby
|
||||
2
|
||||
3 require "curses"
|
||||
4
|
||||
5 class Moar
|
||||
6 include Curses
|
||||
7
|
||||
8 def initialize(file)
|
||||
9 @first_line = 0
|
||||
10 @file = file
|
||||
11 @lines = IO.readlines(file)
|
||||
12 @last_key = 0
|
||||
13 end
|
||||
14
|
||||
15 def draw_screen()
|
||||
16 # @first_line must not be closer than lines-2 from the end
|
||||
17 max_first_line = @lines.size - (lines - 1)
|
||||
18 @first_line = [@first_line, max_first_line].min()
|
||||
19
|
||||
20 # @first_line cannot be negative
|
||||
21 @first_line = [0, @first_line].max()
|
||||
22
|
||||
23 clear()
|
||||
24 setpos(0, 0)
|
||||
25
|
||||
26 attrset(A_NORMAL)
|
||||
27 last_line = @first_line + lines - 2
|
||||
28 for line_number in @first_line..last_line do
|
||||
29 if line_number < @lines.size
|
||||
30 addstr(@lines[line_number])
|
||||
31 else
|
||||
32 addstr("~\n")
|
||||
33 end
|
||||
34 end
|
||||
35
|
||||
36 attrset(A_REVERSE)
|
||||
37 status = "Lines #{@first_line + 1}-"
|
||||
38 status += "#{[@lines.size, last_line].min()}"
|
||||
39 status += "/#{@lines.size}"
|
||||
40 addstr(status)
|
||||
41
|
||||
42 refresh()
|
||||
43 end
|
||||
44
|
||||
45 def run
|
||||
46 init_screen
|
||||
47 noecho
|
||||
48 stdscr.keypad(true)
|
||||
49
|
||||
50 begin
|
||||
51 crmode
|
||||
52 while true
|
||||
53 draw_screen()
|
||||
54
|
||||
55 key = getch()
|
||||
56 case key
|
||||
57 when ?q.ord
|
||||
58 break
|
||||
59 when Key::RESIZE
|
||||
60 draw_screen()
|
||||
61 when Key::DOWN
|
||||
62 @first_line += 1
|
||||
63 when Key::UP
|
||||
64 @first_line -= 1
|
||||
65 end
|
||||
66
|
||||
67 @last_key = key
|
||||
68 end
|
||||
69 ensure
|
||||
70 close_screen
|
||||
71 end
|
||||
72 end
|
||||
73 end
|
||||
74
|
||||
75 Moar.new(ARGV[0]).run()
|
3
sample-files/man-page-overstrike.txt
Normal file
3
sample-files/man-page-overstrike.txt
Normal file
@ -0,0 +1,3 @@
|
||||
This works: bboolldd
|
||||
As does this: _u_n_d_e_r_l_i_n_e
|
||||
This breaks: _bb_oo_ll_dd _aa_nn_dd _uu_nn_dd_ee_rr_ll_ii_nn_ee
|
75
sample-files/no-ending-newline.txt
Normal file
75
sample-files/no-ending-newline.txt
Normal file
@ -0,0 +1,75 @@
|
||||
1 #!/usr/bin/ruby
|
||||
2
|
||||
3 require "curses"
|
||||
4
|
||||
5 class Moar
|
||||
6 include Curses
|
||||
7
|
||||
8 def initialize(file)
|
||||
9 @first_line = 0
|
||||
10 @file = file
|
||||
11 @lines = IO.readlines(file)
|
||||
12 @last_key = 0
|
||||
13 end
|
||||
14
|
||||
15 def draw_screen()
|
||||
16 # @first_line must not be closer than lines-2 from the end
|
||||
17 max_first_line = @lines.size - (lines - 1)
|
||||
18 @first_line = [@first_line, max_first_line].min()
|
||||
19
|
||||
20 # @first_line cannot be negative
|
||||
21 @first_line = [0, @first_line].max()
|
||||
22
|
||||
23 clear()
|
||||
24 setpos(0, 0)
|
||||
25
|
||||
26 attrset(A_NORMAL)
|
||||
27 last_line = @first_line + lines - 2
|
||||
28 for line_number in @first_line..last_line do
|
||||
29 if line_number < @lines.size
|
||||
30 addstr(@lines[line_number])
|
||||
31 else
|
||||
32 addstr("~\n")
|
||||
33 end
|
||||
34 end
|
||||
35
|
||||
36 attrset(A_REVERSE)
|
||||
37 status = "Lines #{@first_line + 1}-"
|
||||
38 status += "#{[@lines.size, last_line].min()}"
|
||||
39 status += "/#{@lines.size}"
|
||||
40 addstr(status)
|
||||
41
|
||||
42 refresh()
|
||||
43 end
|
||||
44
|
||||
45 def run
|
||||
46 init_screen
|
||||
47 noecho
|
||||
48 stdscr.keypad(true)
|
||||
49
|
||||
50 begin
|
||||
51 crmode
|
||||
52 while true
|
||||
53 draw_screen()
|
||||
54
|
||||
55 key = getch()
|
||||
56 case key
|
||||
57 when ?q.ord
|
||||
58 break
|
||||
59 when Key::RESIZE
|
||||
60 draw_screen()
|
||||
61 when Key::DOWN
|
||||
62 @first_line += 1
|
||||
63 when Key::UP
|
||||
64 @first_line -= 1
|
||||
65 end
|
||||
66
|
||||
67 @last_key = key
|
||||
68 end
|
||||
69 ensure
|
||||
70 close_screen
|
||||
71 end
|
||||
72 end
|
||||
73 end
|
||||
74
|
||||
75 Moar.new(ARGV[0]).run()
|
23
sample-files/short.txt
Normal file
23
sample-files/short.txt
Normal file
@ -0,0 +1,23 @@
|
||||
1 #
|
||||
2 # Default PF configuration file.
|
||||
3 #
|
||||
4 # This file contains the main ruleset, which gets automatically loaded
|
||||
5 # at startup. PF will not be automatically enabled, however. Instead,
|
||||
6 # each component which utilizes PF is responsible for enabling and disabling
|
||||
7 # PF via -E and -X as documented in pfctl(8). That will ensure that PF
|
||||
8 # is disabled only when the last enable reference is released.
|
||||
9 #
|
||||
10 # Care must be taken to ensure that the main ruleset does not get flushed,
|
||||
11 # as the nested anchors rely on the anchor point defined here.
|
||||
12 #
|
||||
13 # See pf.conf(5) for syntax.
|
||||
14 #
|
||||
15
|
||||
16 #
|
||||
17 # com.apple anchor point
|
||||
18 #
|
||||
19 scrub-anchor "com.apple/*"
|
||||
20 nat-anchor "com.apple/*"
|
||||
21 rdr-anchor "com.apple/*"
|
||||
22 anchor "com.apple/*"
|
||||
23 load anchor "com.apple" from "/etc/pf.anchors/com.apple"
|
11
sample-files/test.log
Normal file
11
sample-files/test.log
Normal file
@ -0,0 +1,11 @@
|
||||
Run options:
|
||||
|
||||
# Running tests:
|
||||
|
||||
...................[?1049h[1;24r(B[m[4l[?7h[39;49m[?1h=.
|
||||
|
||||
Finished tests in 0.006124s, 3265.8393 tests/s, 10940.5617 assertions/s.
|
||||
|
||||
20 tests, 67 assertions, 0 failures, 0 errors, 0 skips
|
||||
|
||||
ruby -v: ruby 2.0.0p247 (2013-06-27 revision 41674) [universal.x86_64-darwin13]
|
2
sample-files/two-lines.txt
Normal file
2
sample-files/two-lines.txt
Normal file
@ -0,0 +1,2 @@
|
||||
first line
|
||||
second line
|
11
sample-files/utf8.txt
Normal file
11
sample-files/utf8.txt
Normal file
@ -0,0 +1,11 @@
|
||||
Här är en fil som innehåller alla bokstäverna i ordet "räksmörgås" och den här raden är jättelång.
|
||||
|
||||
åäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖ
|
||||
|
||||
åäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖ
|
||||
|
||||
åäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖ
|
||||
|
||||
åäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖ
|
||||
|
||||
åäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖåäöÅÄÖ
|
3
sample-files/with-tabs.c
Normal file
3
sample-files/with-tabs.c
Normal file
@ -0,0 +1,3 @@
|
||||
int main(int argc, char *argv[]) {
|
||||
printf("Hej\n");
|
||||
}
|
Loading…
Reference in New Issue
Block a user