forked from okbob/pspg
-
Notifications
You must be signed in to change notification settings - Fork 0
/
pspg.1
781 lines (762 loc) · 31.9 KB
/
pspg.1
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
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
.\" generated with Ronn-NG/v0.10.1
.\" http://github.com/apjanke/ronn-ng/tree/0.10.1
.TH "PSPG" "1" "March 2024" "" "pspg manual"
.SH "NAME"
\fBpspg\fR \- Postgres Pager
.P
Everybody who uses \fBpsql\fR also uses the \fBless\fR pager\. Which, while it works well, has no special support for tabular data\. I found a few projects, but none was good enough for this purpose\. Thus I decided to write a small specialized pager to use as a \fBpsql\fR pager\.
.P
This pager can be used from the following command line clients, too:
.IP "\(bu" 4
\fBmysql\fR
.IP "\(bu" 4
\fBsqlite\fR
.IP "\(bu" 4
\fBpgcli\fR \fIhttps://github\.com/dbcli/pgcli/\fR
.IP "\(bu" 4
\fBmonetdb\fR
.IP "\(bu" 4
\fBTrino (formerly Presto SQL)\fR \fIhttps://trino\.io/\fR
.IP "\(bu" 4
\fBusql\fR \fIhttps://github\.com/xo/usql/\fR
.IP "\(bu" 4
\fBsqlcl\fR \fIhttps://github\.com/okbob/pspg/#sqlcl\fR (for oracle)
.IP "\(bu" 4
\fBnushell\fR \fIhttps://www\.nushell\.sh/\fR
.IP "" 0
.SH "Main target"
.IP "\(bu" 4
ability to freeze the first few rows, or first few columns
.IP "\(bu" 4
ability to sort data by the specified numeric column
.IP "\(bu" 4
ability to use fancy themes \- like \fBmcview\fR or \fBFoxPro\fR \- http://okbob\.blogspot\.com/2019/12/pspg\-themes\-what\-you\-use\-it\.html
.IP "\(bu" 4
mouse is supported and used
.IP "\(bu" 4
ability to copy a selected range to the clipboard
.IP "" 0
.SH "Installation and basic configuration"
The \fBpspg\fR can be simply installed from Debian (Ubuntu) repositories\. RedHat (Fedora) repositories contains \fBpspg\fR too:
.IP "" 4
.nf
# Debian (Ubuntu)
sudo apt\-get install pspg
# RedHat (Fedora)
sudo dnf install pspg
.fi
.IP "" 0
.P
Basic configuration is very simple \- just set system environment variable \fBPSQL_PAGER\fR:
.IP "" 4
.nf
export PSQL_PAGER='pspg \-X \-b'
.fi
.IP "" 0
.P
Native installation on MS Windows is not supported, but \fBpspg\fR works well inside \fBwsl2\fR\. Inside wsl2 environment, the installation is same like on used Linux system\.
.P
Installation on macOS/homebrew is simple by \fBbrew install pspg\fR\.
.SH "Video presentation"
\fIhttps://www\.youtube\.com/watch?v=JyxuEkoYDQk\fR
.SH "Screenshots"
.SH "Options"
.nf
[pavel@localhost ~]$ pspg \-\-help
pspg is a Unix pager designed for table browsing\.
Usage:
pspg [OPTION] [file]
General options:
\-\-about about authors
\-\-help show this help
\-V, \-\-version show version
\-\-info show info about libraries and system
\-\-direct\-color force direct\-color terminal mode
\-f, \-\-file=FILE open file
\-F, \-\-quit\-if\-one\-screen
quit if content is one screen
\-\-clipboard\-app=NUM specify app used by copy to clipboard (1, 2, 3)
\-\-esc\-delay=NUM specify escape delay in ms (\-1 inf, 0 not used, )
\-\-interactive force interactive mode
\-\-ignore_file_suffix don't try to deduce format from file suffix
\-\-ni not interactive mode (only for csv and query)
\-\-no\-watch\-file don't watch inotify event of file
\-\-no\-mouse don't use own mouse handling
\-\-no\-progressive\-load don't use progressive data load
\-\-no\-sigint\-search\-reset
without reset searching on sigint (CTRL C)
\-\-no\-sleep without waits against flickering
\-\-no_xterm_mouse_mode don't use optional xterm mouse mode
\-\-only\-for\-tables use std pager when content is not table
\-\-on\-sigint\-exit exit on sigint(CTRL C or Escape)
\-\-pgcli\-fix try to fix some pgcli related issues
\-\-querystream read queries from stream forever
\-\-quit\-on\-f3 exit on F3 like mc viewers
\-\-rr=ROWNUM rows reserved for specific purposes
\-\-stream read input forever
\-X, \-\-reprint\-on\-exit preserve content after exit
Output format options:
\-a, \-\-ascii force ascii
\-b, \-\-blackwhite black\-white style
\-s, \-\-style=N set color style number (0\.\.22)
\-\-bold\-labels row, column labels use bold font
\-\-bold\-cursor cursor use bold font
\-\-border type of borders (0\.\.2)
\-\-double\-header header separator uses double lines
\-\-force\-uniborder replace ascii borders by unicode borders
\-\-highlight\-odd\-rec highlights odd records (when it is supported by style)
\-\-hide\-header\-line hides header line (between column names and data)
\-\-ignore\-short\-rows rows with wrong column numbers are ignored
\-\-null=STRING STRING used instead NULL
Searching options
\-g \-\-hlite\-search, \-G \-\-HILITE\-SEARCH
don't highlight lines for searches
\-i \-\-ignore\-case ignore case in searches that do not contain uppercase
\-I \-\-IGNORE\-CASE ignore case in all searches
Interface options:
\-c, \-\-freezecols=N freeze N columns (0\.\.9)
\-\-less\-status\-bar status bar like less pager
\-\-line\-numbers show line number column
\-\-menu\-always show top bar menu every time
\-\-no\-bars, \-\-no\-commandbar, \-\-no\-topbar
don't show bottom, top bar or both
\-\-no\-cursor row cursor will be hidden
\-\-no\-last\-row\-search don't use the last pattern when starting a new search
\-\-no\-scrollbar don't show scrollbar
\-\-no\-sound don't use beep when scroll is not possible
\-\-tabular\-cursor cursor is visible only when data has table format
\-\-vertical\-cursor show vertical column cursor
Input format options:
\-\-csv input stream has csv format
\-\-csv\-separator char used as field separator
\-\-csv\-header [on/off] specify header line usage
\-\-skip\-columns\-like="SPACE SEPARATED STRING LIST"
columns with substr in name are ignored
\-\-csv\-trim\-width=NUM trim value after NUM chars
\-\-csv\-trim\-rows=NUM trim value after NUM rows
\-\-tsv input stream has tsv format
On exit options:
\-\-on\-exit\-reset sends reset terminal sequence "\e33c"
\-\-on\-exit\-clean sends clean terminal sequence "\e033[2J"
\-\-on\-exit\-erase\-line sends erase line terminal sequence "\e33[2K\er"
\-\-on\-exit\-sgr0 sends sgr0 terminal sequence "\e033[0;10m"
Watch mode options:
\-q, \-\-query=QUERY execute query
\-w, \-\-watch time the query (or read file) is repeated every time (sec)
Connection options:
\-d, \-\-dbname=DBNAME database name
\-h, \-\-host=HOSTNAME database server host (default: "local socket")
\-p, \-\-port=PORT database server port (default: "5432")
\-U, \-\-username=USERNAME database user name
\-W, \-\-password force password prompt
Debug options:
\-\-log=FILE log debug info to file
\-\-wait=NUM wait NUM seconds to allow attach from a debugger
.fi
.P
pspg shares a lot of key commands with the less pager or the vi editor\.
.P
Options can be passed within the environment variable \fBPSPG\fR, too\.
.SH "Environment variables"
.TS
allbox;
l l.
Name Usage
\fBPSPG\fR can hold same options like command line
\fBPSPG_CONF\fR path to configuration file
\fBPSPG_HISTORY\fR path to file pspg's readline history file
.TE
.SH "Example of config file"
The fields names can be different than from related command line options:
.IP "" 4
.nf
ascii_menu = false
bold_labels = false
bold_cursor = false
ignore_case = false
ignore_lower_case = false
no_cursor = false
no_sound = false
no_mouse = false
less_status_bar = false
no_highlight_search = false
no_highlight_lines = false
force_uniborder = false
show_rownum = false
without_commandbar = false
without_topbar = false
vertical_cursor = false
on_sigint_exit = false
no_sigint_search_reset = false
double_header = false
quit_on_f3 = false
pgcli_fix = false
xterm_mouse_mode = true
show_scrollbar = true
menu_always = false
empty_string_is_null = true
last_row_search = true
progressive_load_mode = true
highlight_odd_rec = false
hide_header_line = false
on_exit_reset = false
on_exit_clean = false
on_exit_erase_line = false
on_exit_sgr0 = false
direct_color = false
theme = 16
border_type = 2
default_clipboard_format = 0
clipboard_app = 0
hist_size = 500
esc_delay = \-1
.fi
.IP "" 0
.SH "Themes"
.TS
allbox;
l l.
Code Name
0 black & white
1 Midnight Commander like
2 FoxPro like
3 Pdmenu like
4 White theme
5 Mutt like
6 PCFand like
7 Green theme
8 Blue theme
9 Word Perfect like
10 Low contrast blue theme
11 Dark cyan/black mode
12 Paradox like
13 dBase IV retro style
14 dBase IV retro style (Magenta labels)
15 Red white theme
16 Simple theme
17 Solarized dark theme
18 Solarized light theme
19 Gruvbox light theme
20 Tao Light theme
21 FlatWhite theme
22 Relational pipes theme
23 Paper Color theme
.TE
.P
see http://okbob\.blogspot\.cz/2017/07/i\-hope\-so\-every\-who\-uses\-psql\-uses\-less\.html
.SS "Custom themes"
The theme can be customized over base and menu templates referencing the built\-in themes\. The custom theme file should be saved in directory with \fBpspg\fR configuration\. The name of this file should be \.pspg_theme_xxx\. The custom theme can be selected by command line option \fB\-\-custom\-style=name\fR or by command \fB\ectheme name\fR\.
.P
.P
Example of a custom theme file (named \fB\.pspg_theme_mc2\fR (it can be activated by command \fB\ectheme mc2\fR)):
.IP "" 4
.nf
template = 1
template_menu = 3
background = black, white
data = black, white
label = black, white, italic, bold
border = #000000, white
footer = lightgray, white
cursor_data = blue, white, italic, bold, dim, reverse
cursor_border = blue, blue , italic, bold, dim, reverse
cursor_label = blue, white, italic, bold, dim, reverse
cursor_footer = blue, white, italic, bold, dim, reverse
cursor_bookmark = red, white, italic, bold, dim, reverse
cross_cursor = white, blue, italic, bold
cross_cursor_border = brightblue, blue
status_bar = black, lightgray
title = black, lightgray
scrollbar_arrows = black, white
scrollbar_background = lightgray, white
scrollbar_slider = white, gray
.fi
.IP "" 0
.P
Some keys can be marked by symbol \fB*\fR\. Marked keys are used for odd records\.
.IP "" 4
.nf
data* = black, lightgray
label* = black, lightgray, italic, bold
border* = #000000, lightgray
.fi
.IP "" 0
.P
\fBtemplate\fR and \fBtemplate_menu\fR set fallback values for any keys not specified in the custom theme\. \fBtemplate_menu\fR in particular is currently the only way to customize the F9 menu appearance\.
.TS
allbox;
l l.
key customizes
\fBbackground\fR Background color
\fBdata\fR Data (non\-header or frozen column) text
\fBborder\fR Border color
\fBlabel\fR Label (header or frozen column) text
\fBrow_number\fR Line numbers
\fBrecord_number\fR \~
\fBselected_area\fR \~
\fBfooter\fR Results footer (non\-tabular e\.g\. rowcount)
\fBcursor_data\fR Highlighted data (non\-header or frozen column) text
\fBcursor_border\fR Highlighted border color
\fBcursor_label\fR Highlighted label (header or frozen column) text
\fBcursor_row_number\fR Highlighted line numbers
\fBcursor_record_number\fR \~
\fBcursor_selected_area\fR \~
\fBcursor_footer\fR Highlighted results footer (non\-tabular e\.g\. rowcount)
\fBscrollbar_arrows\fR Scrollbar up and down arrows
\fBscrollbar_background\fR Scrollbar "empty" background
\fBscrollbar_slider\fR Scrollbar slider over the background
\fBscrollbar_active_slider\fR Scrollbar slider grabbed by mouse
\fBtitle\fR Results headline (in psql describe commands)
\fBstatus_bar\fR Top query and cursor location information
\fBprompt_bar\fR \~
\fBinfo_bar\fR Info text (e\.g\. "Not found" when searching)
\fBinput_bar\fR Input prompt and text (e\.g\. search)
\fBerror_bar\fR \~
\fBbookmark\fR \~
\fBbookmark_border\fR \~
\fBcursor_bookmark\fR \~
\fBcross_cursor\fR Highlighted cell at intersection of horizontal and vertical cursors
\fBcross_cursor_border\fR Borders at intersection of horizontal and vertical cursors
\fBmatched_pattern\fR Search result match text
\fBmatched_pattern_nohl\fR \~
\fBmatched_line\fR Line containing search result
\fBmatched_line_border\fR Borders in search result line
\fBmatched_pattern_cursor\fR Highlighted search result match text
\fBmatched_line_vertical_cursor\fR Vertically highlighted search result match text
\fBmatched_line_vertical_cursor_border\fR Borders of vertically highlighted cell with search result match
\fBerror\fR \~
.TE
.P
ANSI colors \fBBlack\fR, \fBRed\fR, \fBGreen\fR, \fBBrown\fR, \fBBlue\fR, \fBMagenta\fR, \fBCyan\fR, \fBLightGray\fR, \fBGray\fR, \fBBrightRed\fR, \fBBrightGreen\fR, \fBYellow\fR, \fBBrightBlue\fR, \fBBrightMagenta\fR, \fBBrightCyan\fR, \fBWhite\fR, and \fBDefault\fR will display as your terminal emulator configures them\. Alternatively, you can specify hex RGB values \fB#FF00FF\fR\.
.P
Styles are any combination of: \fBbold\fR, \fBitalic\fR, \fBunderline\fR, \fBreverse\fR, \fBstandout\fR, \fBdim\fR\.
.P
If the format of some key is not correct, then this row is ignored\. For debugging of custom theme is good to start \fBpspg\fR with option \fB\-\-log\fR\. An information about broken definitions are stored in log file\.
.SH "Keyboard commands"
.TS
allbox;
l l.
Key(s) Command
\fB0\fR, \fB1\fR, \fB2\fR, \fB3\fR, \.\., \fB9\fR freeze first N columns
\fBKEY_UP\fR, \fBk\fR navigate backward by one line
\fBKEY_DOWN\fR, \fBj\fR navigate forward by one line
\fBKEY_LEFT\fR, \fBh\fR scroll to left
\fBKEY_RIGHT\fR, \fBl\fR scroll to right
\fBCtrl\fR+\fBKEY_LEFT\fR scroll one char left
\fBCtrl\fR+\fBKEY_RIGHT\fR scroll one char right
\fBShift\fR+\fBKEY_LEFT\fR scroll one column left
\fBShift\fR+\fBKEY_RIGHT\fR scroll one column right
\fBCtrl\fR+\fBHome\fR, \fBg\fR go to the start of file
\fBCtrl\fR+\fBEnd\fR, \fBG\fR go to the end of file
\fBAlt\fR+\fBl\fR go to line number
\fBH\fR go to first line of current window
\fBM\fR go to half of current window
\fBL\fR go to end of current window
\fBPPAGE\fR, \fBCtrl\fR+\fBb\fR backward one window
\fBNPAGE\fR, \fBCtrl\fR+\fBf\fR, \fBspace\fR forward one window
\fBHOME\fR, \fB^\fR go to begin of line, first column
\fBEND\fR, \fB$\fR go to end of line, last column
\fBCtrl\fR+\fBe\fR scroll a window down
\fBCtrl\fR+\fBy\fR scroll a window up
\fBCtrl\fR+\fBd\fR forward a half window
\fBCtrl\fR+\fBu\fR backward a half window
\fBs\fR save content to file
\fB/\fR search for a pattern which will take you to the next occurrence
\fB?\fR search for a pattern which will take you to the previous occurrence
\fBn\fR for next match
\fBN\fR for next match in reverse direction
\fBc\fR column search
\fBAlt\fR+\fB/\fR search for a pattern inside selected area
\fBAlt\fR+\fB?\fR backward search for a pattern inside selected area
\fBAlt\fR+\fBc\fR switch (on, off) drawing line cursor
\fBAlt\fR+\fBm\fR switch (on, off) own mouse handler
\fBAlt\fR+\fBn\fR switch (on, off) drawing line numbers
\fBAlt\fR+\fBv\fR, \fBdouble click\fR on column header switch (on, off) drawing column cursor
\fBMouse button wheel\fR scroll vertical
\fBAlt\fR+\fBMouse button wheel\fR scroll horizontal
\fBF9\fR show menu
\fBq\fR, \fBF10\fR, \fBEsc\fR \fB0\fR quit
\fBAlt\fR+\fBq\fR quit and print raw (unformatted) content
\fBAlt\fR+\fBk\fR, \fBAlt\fR+\fBdouble click\fR switch bookmark
\fBAlt\fR+\fBj\fR go to next bookmark
\fBAlt\fR+\fBi\fR go to previous bookmark
\fBAlt\fR+\fBo\fR flush bookmarks
\fBa\fR sort ascendent
\fBd\fR sort descendent
\fBu\fR unsorted (sorted in origin order)
\fBSpace\fR stop/continue in watch mode
\fBR\fR Repaint screen and refresh input file
\fBIns\fR export row, column or cell to default target
\fBshift\fR+\fBcursor\|\.\|\.\|\.\fR define range
\fBF3\fR start/finish of selection rows
\fBShift\fR+\fBF3\fR start/finish of selection block
\fBCtrl\fR+\fBdrag mouse\fR defines rows selection, on column header defines column selection
\fBCtrl\fR+\fBo\fR show primary screen, press any key to return to pager again
\fB%\fR, \fBCtrl\fR+\fBa\fR select all
.TE
.SH "Backslash commands"
.TS
allbox;
l l.
Command Description
\fB\eN\fR go to line number
\fB\e+N\fR go to N lines forward
\fB\e\-N\fR go to N lines backward
\fB\eN+\fR go to line number
\fB\eN\-\fR go to line number from end
\fB\etheme N\fR set theme number
\fB\ecopy [all\e|selected] [nullstr "str"] [csv\e|tsv\e|insert\e|text\e|pipesep\e|sqlvalues]\fR copy data to clipboard
\fB\esave [all\e|selected] [nullstr "str"] [csv\e|tsv\e|insert\e|text\e|pipesep\e|sqlvalues]\fR copy data to clipboard
\fB\eorder [N\e|column name]\fR sort by column
\fB\eorderd [N\e|column name]\fR desc sort by column
\fB\esort [N\e|column name]\fR sort by column
\fB\esortd [N\e|column name]\fR desc sort by column
\fB\edsort [N\e|column name]\fR desc sort by column (alias)
\fB\ersort [N\e|column name]\fR desc sort by column (alias)
\fB\easc [N\e|column name]\fR sort by column (alias)
\fB\edesc [N\e|column name]\fR desc sort by column (alias)
\fB\esearch [back] [selected] [column name] [string\e|"string"]\fR search string in data
.TE
.P
The output can be redirected to any command when the name starts with pipe symbol:
.IP "" 4
.nf
\ecopy csv | less
.fi
.IP "" 0
.SH "Ending"
The pager can be ended by pressing keys \fBq\fR or \fBF10\fR or \fBEsc\fR \fB0\fR\. With option \fB\-\-on\-sigint\-exit\fR then the pager is closed by pressing keys \fBCtrl\fR+\fBc\fR or \fBEsc\fR \fBEsc\fR\.
.SH "Use <kbd>Escape</kbd>, key instead <key>Alt</key> + <key>key</key>"
pspg supports a possibility to use a sequence of keys \fBEsc\fR, \fBkey\fR instead an combination of \fBAlt\fR+\fBkey\fR\. The interval between pressing \fBEsc\fR and \fBkey\fR is limited by interval specified by option \fBesc\-delay\fR or by configuration's option \fBesc_delay\fR\. This is max delay time in ms\. After this interval, the single pressing \fBEsc\fR is interpreted as \fBEscape\fR\. \-1 meas unlimited, 0 disables this feature\.
.SH "Column search"
Column search is case insensitive every time\. Searched column is marked by vertical cursor\. Last non empty string searching pattern is used when current searching pattern is empty string\. Searching is starting after visible vertical column or on first visible not freezed columns (after some horizontal scrolling) or on first column\. After last column searching starts from first again\.
.SH "Export & Clipboard"
For clipboard support the clipboard application should be installed: 1\. wl\-clipboard (Wayland),
.IP "1." 4
xclip (xwindows) or 3\. pbcopy (MacOS)\.
.IP "" 0
.P
\fBpspg\fR try to translate unicode symbol '∅' to NULL every time\. If you don't use special setting by \fB\epset null \|\.\|\.\|\.\fR, then \fBpsql\fR displays empty string instead NULL\. \fBpspg\fR hasn't any special detection (in export routines) for this case\. You should to check and enable or disable menu item \fBEmpty string is NULL\fR\.
.P
\fBpspg\fR has automatic detection of clipboard application\. Unfortunately, this detection should not to work for same cases\. You can specify the application by specify number (1,2,3) to \fB\-\-clipboard\-app\fR option\.
.SH "Status line description"
.IP "\(bu" 4
\fBV: [d/d d\.\.d]\fR \- vertical cursor: (column number)/(columns) (char positions from) \.\. (char positions to)
.IP "\(bu" 4
\fBFC: d\fR \- freezed columns length in chars
.IP "\(bu" 4
\fBC: d\.\.d/d\fR \- unfreezed visible data in chars (from \.\. to)/(total)
.IP "\(bu" 4
\fBL:[d + d d/d]\fR \- lines (number of first visible line) + (number of line of display), (current line)/(lines)
.IP "\(bu" 4
\fBd%\fR \- percent of already displayed data
.IP "" 0
.SH "Usage as csv viewer"
It works well with miller http://johnkerl\.org/miller/doc/index\.html
.IP "" 4
.nf
mlr \-\-icsv \-\-opprint \-\-barred put '' obce\.csv | pspg \-\-force\-uniborder
.fi
.IP "" 0
.P
New version has integrated csv support \- just use \fB\-\-csv\fR option\.
.P
It can be integrated into \fBmc\fR
.IP "\(bu" 4
copy file from \fB/etc/mc/mc\.ext\fR to your \fB~/\.config/mc directory\fR
.IP "\(bu" 4
insert there
.IP "" 0
.IP "" 4
.nf
##csv
regex/\e\.csv
View=pspg \-f %f \-\-csv
.fi
.IP "" 0
.IP "\(bu" 4
restart \fBmc\fR
.IP "" 0
.SH "Known issues"
.IP "\(bu" 4
When you use \fBpspg\fR on Cygwin, then some temporary freezing of scrolling was reported In this case, please, use an option \fB\-\-no\-sleep\fR\. I see slow scrolling (via scrollbar) inside konsole (KDE terminal)\. The option \fB\-\-no\-sleep\fR helps too\.
.IP "" 0
.SH "Usage in watch mode"
The result of query can be refreshed every n seconds\. \fBpspg\fR remembers cursor row, possible vertical cursor, possible ordering\. The refreshing should be paused by pressing \fBspace\fR key\. Repeated pressing of this key enables refreshing again\.
.P
\fBpspg\fR uses inotify API when it is available, and when input file is changed, then \fBpspg\fR reread file immediately\. This behave can be disabled by option \fB\-\-no\-watch\-file\fR or by specification watch time by option \fB\-\-watch\fR\.
.SH "Streaming modes"
\fBpspg\fR can read a continuous stream of tabular data from pipe, named pipe or from file (with an option \fB\-\-stream\fR or it can read a stream of queries from pipe or from file (with an option \fB\-\-querystream\fR)\. In stream mode, only data in table format can be processed, because \fBpspg\fR uses empty line as separator between tables\.
.P
The query stream mode is an sequence of SQL statements separated by char GS (Group separator \- 0x1D on separated line\.
.IP "" 4
.nf
pavel@localhost ~]$ cat < /dev/pts/3 > ~/pipe
select 10
^]
select 20
^]
select *
from
pg_class
^]
.fi
.IP "" 0
.SH "Recommended psql configuration"
you should to add to your profile:
.IP "" 4
.nf
#for Postgres 10 and older
export PAGER="pspg"
#for postgres 11 and newer
export PSQL_PAGER="pspg"
#or "\esetenv PAGER pspg" to \.psqlrc
.fi
.IP "" 0
.P
and \fB\.psqlrc\fR
.IP "" 4
.nf
\eset QUIET 1
\epset linestyle unicode
\epset border 2
\epset null ∅
\eunset QUIET
.fi
.IP "" 0
.P
some possible configuration:
.IP "" 4
.nf
\-\- Switch pagers with :x and :xx commands
\eset x '\e\esetenv PAGER less'
\eset xx '\e\esetenv PAGER \e'pspg \-bX \-\-no\-mouse\e''
:xx
.fi
.IP "" 0
.P
\fBLC_CTYPE\fR should be correct\. Mainly when you use unicode borders\. ncurses doesn't display unicode borders (produced by \fBpsql\fR) without correct setting of this variable\. Is possible to check a value 'C\.UTF8'\.
.SH "Attention"
When you use a option \fB\-\-only\-for\-tables\fR, then
.IP "\(bu" 4
set \fBPAGER\fR to \fBpspg\fR and \fBPSQL_PAGER\fR to \fBless\fR or
.IP "\(bu" 4
set \fBPAGER\fR to \fBless\fR and \fBPSQL_PAGER\fR to \fBpspg\fR
.IP "" 0
.SH "MySQL usage"
.nf
MariaDB [sakila]> pager pspg \-s 14 \-X \-\-force\-uniborder \-\-quit\-if\-one\-screen
PAGER set to 'pspg \-s 14 \-X \-\-force\-uniborder \-\-quit\-if\-one\-screen'
MariaDB [sakila]> select now();
MariaDB [sakila]> select * from nicer_but_slower_film_list limit 100;
.fi
.SH "SQLite"
SQLite native client doesn't produce well formatted output, but can be forced to generate CSV format \- and this format is well readable for \fBpspg\fR
.IP "" 4
.nf
sqlite3 \-csv \-header testdb\.db 'select * from foo2' | pspg \-\-csv \-\-csv\-header=on \-\-double\-header
.fi
.IP "" 0
.SH "pgcli"
pgcli \fIhttps://github\.com/dbcli/pgcli/\fR needs the following configuration options (\fB~/\.config/pgcli/config\fR):
.IP "" 4
.nf
pager = /usr/bin/pspg \-\-csv \-\-rr=2 \-\-quit\-if\-one\-screen \-\-ignore\-case \-\-csv\-header on \-\-pgcli\-fix
table_format = csv
.fi
.IP "" 0
.P
Older version of pgcli had very slow output in tabular format\. An workaround was using csv format\. This should not be necessary on current versions when the performance issue was fixed\. An option \fB\-\-pgcli\-fix\fR fixed import of partially broken csv format generated by \fBpgcli\fR\. Modern version of \fBpgcli\fR doesn't need csv format, and doesn't need \fB\-\-pgcli\-fix\fR option\.
.IP "" 4
.nf
pager = /usr/bin/pspg \-\-rr=2 \-\-quit\-if\-one\-screen \-\-ignore\-case
.fi
.IP "" 0
.SH "sqlcl"
As \fBsqlcl\fR doesn't currently support a pager option directly, you can either use a tool like qsh \fIhttps://github\.com/muhmud/qsh\fR to work around this issue, or use the pspg\.sql \fIhttps://github\.com/okbob/pspg/blob/master/scripts/sqlcl/pspg\.sql\fR script from this repo\.
.P
To use the script, start \fBsqlcl\fR as shown below (it's important to pass in the details of your current tty):
.IP "" 4
.nf
$ TTY=$(tty) sqlcl system/system @/path/to/pspg\.sql
.fi
.IP "" 0
.P
You can now have the results of a query sent to \fBpspg\fR like this:
.IP "" 4
.nf
SQL> pspg select * from user_tables;
.fi
.IP "" 0
.SH "nushell"
The \fBpspg\fR supports default \fBtable_mode\fR: \fBrounded\fR and \fBtable_mode\fR: \fBheavy\fR\.
.P
The conversion to csv can be used too\.
.IP "" 4
.nf
sys | get cpu | to csv | pspg \-\-csv
.fi
.IP "" 0
.P
Note: \fBfooter_mode\fR should be disabled
.SH "Note \- mouse"
pspg try to use xterm mouse mode 1002, when terminal and ncurses are not too antique\. If there are problems with usage \- unwanted visual artefacts when you move with mouse when some mouse button is pressed, then 1\. please, report issue (please, attach log file), 2\. use an option \fB\-\-no\-xterm\-mouse\-mode\fR and \fBpspg\fR will not try to activate this mode\.
.SH "Note \- true color themes on KDE konsole terminal"
On my Fedora this terminal doesn't correctly display true color themes\. The basic problem is in default \fBTERM\fR setting, that is \fBxterm\-256color\fR\. Unfortunately, the \fBkonsole\fR terminal is not fully compatible with \fBxterm\fR, and doesn't allow color changing\. You can force direct colors by using the option \fB\-\-direct\-color\fR or by setting \fBTERM=xterm\-direct\fR\. Second option is more correct setting of \fBTERM\fR variable to \fBkonsole\-256color\fR\. In this case the \fBpspg\fR will map the true rgb colors to supported 256 colors\.
.SH "Note \- compilation issue"
Some linker issues can be fixed by:
.IP "" 4
.nf
I changed
gcc \-lncursesw pager\.c \-o pspg \-ggdb
to
gcc pager\.c \-o pspg \-ggdb \-lncursesw
.fi
.IP "" 0
.P
If you want to use \fBpspg\fR as Postgres client, then you need run \fBconfigure \-\-with\-postgresql=yes\fR\. On Fedora with own Postgres build I had to install \fBopenssl\-devel\fR package and I had to set \fBexport PKG_CONFIG_PATH="/usr/local/pgsql/master/lib/pkgconfig/"\fR\.
.P
On FreeBsd you should to use \fBgmake\fR instead \fBmake\fR\.
.SH "Note \- Installation details"
When you compile code from source, run \./configure first\. Sometimes \./autogen\.sh first
.P
If you would to display UTF\-8 characters, then \fBpspg\fR should be linked with \fBncursesw\fR library\. UTF\-8 characters are displayed badly when library \fBncursesw\fR is used\. You can see broken characters with incorrect locale setting too\.
.P
You can check wide chars support by \fBpspg \-\-version\fR\. Row \fBncurses with wide char support\fR is expected\. Re\-run \fBconfigure\fR with \fB\-\-with\-ncursesw\fR option\. When this command fails check if development package for ncursesw library is installed\.
.SS "Homebrew (for Linux & MacOS)"
.nf
# brew install pspg
.fi
.P
You can compile easily \fBpspg\fR without \fBbrew\fR, but you need \fBgnu readline\fR library\. MacOS uses by default readline emulated over libedit, but \fBpspg\fR requires full gnu readline library\.
.IP "" 4
.nf
LDFLAGS="\-L/usr/local/opt/readline/lib" CPPFLAGS="\-I/usr/local/opt/readline/include" \./configure
LDFLAGS="\-L/usr/local/opt/readline/lib" CPPFLAGS="\-I/usr/local/opt/readline/include" make
.fi
.IP "" 0
.SS "Debian"
.nf
# apt\-cache search pspg
# apt\-get install pspg
.fi
.SS "Fedora (28 and later)"
.nf
# dnf install pspg
.fi
.SS "RPM (CentOS/openSUSE/…)"
The pspg is available from community repository https://yum\.postgresql\.org/packages\.php
.SS "Alpine Linux"
.nf
# apk add pspg
.fi
.SS "Gentoo"
.nf
# emerge \-av dev\-db/pspg
.fi
.SS "Arch Linux"
The Arch User Repository contains two versions:
.IP "\(bu" 4
pspg \fIhttps://aur\.archlinux\.org/packages/pspg/\fR is a fixed release\.
.IP "\(bu" 4
pspg\-git \fIhttps://aur\.archlinux\.org/packages/pspg\-git/\fR tracks the \fBmaster\fR branch\.
.IP "" 0
.P
Use the AUR helper of your choice or git and \fBmakepkg\fR to install pspg\.
.SS "FreeBSD"
.nf
# pkg install pspg
.fi
.SS "OpenBSD"
.nf
# pkg_add pspg
.fi
.P
More about it \fIhttps://fluca1978\.github\.io/2021/10/28/pspgOpenBSD\.html\fR
.SS "Using MacPorts (MacOS only)"
.nf
# port install pspg
.fi
.SS "MS Windows"
\fBpspg\fR can be simply used on MS Windows by using wsl2\. I tested it, and it is working without problems\.
.IP "\(bu" 4
In terminal execute \fBwsl \-\-install \-d Ubuntu\-22\.04\fR
.IP "\(bu" 4
In terminal open Ubuntu session
.IP "" 0
.IP "" 4
.nf
sudo apt\-get update
sudo apt\-get install pspg
sudo apt\-get install postgresql postgresql\-contrib
# set password for user postgres
sudo passwd postgres
su \- postgres
psql postgres
>> create role pavel login;
\eq
exit
touch ~/\.psqlrc
mcedit \.psqlrc
\epset linestyle unicode
\epset border 2
\esetenv PSQL_PAGER 'pspg \-b \-X'
# press F2 and F10
psql postgres
.fi
.IP "" 0
.P
there is not any difference from installation and work on Ubuntu (Debian)
.P
\fBpspg\fR is not ported to MS Windows yet\. There is the dependency on ncurses and correctly (fully) implemented function \fBnewterm\fR (\fBpdcurses\fR does this only on Unix platforms)\. It can work with WSL2 maybe (I didn't test it)\. An alternative can be using \fBless\fR pager, that is ported to some MS Win enviroments\. \fBless\fR depends on \fBtermcap\fR, and it is little bit more portable than \fBpspg\fR (\fBtermcal\fR is low layer of ncurses)\. \fBless\fR supports fixed rows and with \fB\-\-chop\-long\-lines\fR option or just \fB\-S\fR can be used as pager for \fBpspg\fR\.
.IP "" 4
.nf
export PSQL_PAGER="less \-\-chop\-long\-lines \-\-header 1"
.fi
.IP "" 0
.SS "Solaris"
There are few issues requires manual code changes for successful compilation \- we successfully tested \fBpspg\fR, but although \fBpspg\fR was linked with ncursesw libraries, the utf8 encoding support didn't work fully correctly \- probably due some issues in \fBlibc\fR library\. There are problems with chars encoded to 3bytes \- unicode borders, \.\. Two bytes unicode chars should be displayed well\.
.P
You can use \fBpspg\fR with usual accented chars, but unicode borders should not be used\. Replacement ascii borders by special borders chars (by ncurses technology) works well \- looks on \fBOptions|Force unicode borders\fR option\.
.IP "\(bu" 4
Solaris \fBmake\fR doesn't support conditional statements \- should be removed So, remove unsupported functionality from \fBMakefile\fR (\fBifdef\fR,\fBendif\fR), replace \fB\-include\fR by \fBinclude\fR first\.
.IP "\(bu" 4
After running \fBconfigure\fR remove link on \fBtermcap\fR library from \fBconfig\.make\fR\. It is garbage produced by \fBreadline\fR automake script\. Combination with \fBncurses\fR libraries makes some linking issues\.
.IP "" 0
.SS "builtin libraries"
.IP "" 4
.nf
export CURSES_CFLAGS="\-I/usr/include/ncurses/"
export PANEL_LIBS="\-lpanelw"
\&\./configure
.fi
.IP "" 0
.SS "OpenCSW development"
.IP "" 4
.nf
export CFLAGS="\-m64 \-I/opt/csw/include"
export LDFLAGS="\-L/opt/csw/lib/64 \-R/opt/csw/lib/64"
export PKG_CONFIG_PATH="/opt/csw/lib/64/pkgconfig"
\&\./configure
.fi
.IP "" 0
.SH "Possible ToDo"
.IP "\(bu" 4
Store data in some column format (now data are stored like array of rows)\. With this change can be possible to operate over columns \- hide columns, change width, cyclic iteration over columns, change order of columns, mark columns and export only selected columns (selected rows)\.
.IP "\(bu" 4
Replace printing document directly to ncurses window by some smarter structure\. Internally there are lot of checks and fixes to support complex dynamic layout\. The possibly views should to remember first row, last row, current row\. Now, these data are in global variables or in DataDesc and ScrDesc structures\.
.IP "" 0
.SH "st_menu"
This project uses st_menu library \- implementation of CUA menubar and pulldown menu for ncurses https://github\.com/okbob/ncurses\-st\-menu
.SH "Note"
If you like it, send a postcard from your home country to my address, please:
.IP "" 4
.nf
Pavel Stehule
Skalice 12
256 01 Benesov u Prahy
Czech Republic
.fi
.IP "" 0
.P
I invite any questions, comments, bug reports, patches on mail address pavel\.stehule@gmail\.com