Communities

Writing
Writing
Codidact Meta
Codidact Meta
The Great Outdoors
The Great Outdoors
Photography & Video
Photography & Video
Scientific Speculation
Scientific Speculation
Cooking
Cooking
Electrical Engineering
Electrical Engineering
Judaism
Judaism
Languages & Linguistics
Languages & Linguistics
Software Development
Software Development
Mathematics
Mathematics
Christianity
Christianity
Code Golf
Code Golf
Music
Music
Physics
Physics
Linux Systems
Linux Systems
Power Users
Power Users
Tabletop RPGs
Tabletop RPGs
Community Proposals
Community Proposals
tag:snake search within a tag
answers:0 unanswered questions
user:xxxx search by author id
score:0.5 posts with 0.5+ score
"snake oil" exact phrase
votes:4 posts with 4+ votes
created:<1w created < 1 week ago
post_type:xxxx type of post
Search help
Notifications
Mark all as read See all your notifications »
Q&A

Comments on Make Less use a normal view instead of hexdump view

Parent

Make Less use a normal view instead of hexdump view

+4
−0

Less does not display data files normally, but if it were some sort of Xxd.

$ bash --norc
$ export LESS=
$ file -i /var/log/lastlog
/var/log/lastlog: application/octet-stream; charset=binary
$ less -EX /var/log/lastlog
00000000  a3 4c d2 60 74 74 79 32  00 00 00 00 00 00 00 00  |.L.`tty2........|
00000010  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
*
000474a0  ee c7 66 61 74 74 79 31  00 00 00 00 00 00 00 00  |..fatty1........|
000474b0  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
*
000475c0  00 00 00 00                                       |....|
000475c4

Usually that is a good choice, but some data files are better read as normal text. How can I switch to the normal, plain text view in Less?

I have searched for "binary", "hex" and "xxd" in Less' manual but there does not seem to be a mention of it.


An update just to situate Canina's correct answer.

$ env | grep LESS
LESS=-iRj4
LESSOPEN=|lesspipe %s

lesspipe is a shell script with # Copyright 1999-2020 Gentoo Authors, so it is no surprise that many could not reproduce what I described.

History
Why does this post require attention from curators or moderators?
You might want to add some details to your flag.
Why should this post be closed?

2 comment threads

norepro (2 comments)
What is in your ~/.bashrc? (2 comments)
Post
+7
−0

As I noted in a comment thread, I don't get the same behavior as you do (nor do I recall ever seeing it on any system), which points toward something about your setup. Apparently in response to the question about your ~/.bashrc, you showed that you run this from a freshly started shell (bash --norc); however, there is a methodological error here, as that bash instance is going to inherit its environment from the shell from which it is started, just like any other application that is started from the shell.

All this, to me, suggests that something in the environment that less is running within causes it to behave differently.

The easiest thing to check is that there is no alias for less that includes extraneous parameters that could influence its behavior. which less will tell you where less is on disk, and type less will tell you what bash does with a bare less, in case for example it is an alias. Invoking an executable using a path will bypass an alias; for example, if you had an alias less that added some parameters, using the path from which less would invoke less without those parameters being passed to it. Apparently, you had no such alias or similar that would interfere.

Next, you showed that you reset $LESS, but less uses a number of environment variables to control its behavior. Those are listed in the man page under the "environment variables" heading, or you can take the crude, somewhat brute-force way of finding out which the likely candidates are by doing something like:

$ man less | tr ' ' $'\n' | grep ^LESS | sort --unique

and comparing the output of that to the output of

$ env | grep ^LESS

In your case, it appears that this revealed that the value of $LESSOPEN was problematic. This is significant because $LESSOPEN controls input preprocessing. The script it points to is also likely to be provided by either your OS distribution (possibly from upstream), or locally; this might help explain why the behavior you are seeing differs from that on my system.

(Also note its sibling, $LESSCLOSE, which controls the opposite half of the invoke/exit cycle. See the less(1) and lesspipe(1) man pages for more details.)

$LESSOPEN can be ignored by passing either -L or its long form --no-lessopen when invoking less.

History
Why does this post require attention from curators or moderators?
You might want to add some details to your flag.

1 comment thread

More places to look at (2 comments)
More places to look at
celtschk‭ wrote over 3 years ago

Another thing to note is that the script called through $LESSOPEN may have further customisation points. For example, I just figured out that the version installed on my system (Linux Mint) first looks for an executable script named .lessfilter in the home directory and if that exists and executes successfully, its output is instead used. Thus on my system, the following commands will cause less to output “Hello world” for any file:

echo "echo Hello world" > ~/.lessfilter
chmod +x ~/.lessfilter

I have no idea how common this is for other systems, but it means another place to look for the reason of unexpected behaviour.

Quasímodo‭ wrote over 3 years ago

celtschk‭ Yes, Gentoo's lesspipe also looks for ~/.lessfilter. Very bad taste if you ask me...