mirror of
https://github.com/smxi/inxi.git
synced 2024-11-16 16:21:39 +00:00
New version, tarball, man page. Shows as default OpenGL core profile version number.
-xx option will show OpenGL compatibility version number as well, though that's largely useless information for most users, thus the -xx. Note that this reverses the default, which previously showed OpenGL version, which is actually the compatibility version. This should resolve #105 pull request, though it does it differently, by switching the default output to what is more relevant, and offering the compatibility version as an optional output item. Note that much of the glx information will probably change to more neutral terms once wayland support starts growing, and systems without xwayland etc libraries appear. Further note that non free drivers showed the OpenGL core profile version numbers all along, so really this simply corrects misleading output for free drivers.
This commit is contained in:
parent
51f547c5bb
commit
5b384610a0
56
inxi
56
inxi
|
@ -1,8 +1,8 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
########################################################################
|
########################################################################
|
||||||
#### Script Name: inxi
|
#### Script Name: inxi
|
||||||
#### Version: 2.3.12
|
#### Version: 2.3.13
|
||||||
#### Date: 2017-06-06
|
#### Date: 2017-06-08
|
||||||
#### Patch Number: 00
|
#### Patch Number: 00
|
||||||
########################################################################
|
########################################################################
|
||||||
#### SPECIAL THANKS
|
#### SPECIAL THANKS
|
||||||
|
@ -3100,7 +3100,7 @@ show_options()
|
||||||
print_lines_basic "1" "-D" "Full hard Disk info, not only model, ie: /dev/sda ST380817AS 80.0GB. See also -x and -xx. Disk total used percentage includes swap partition size(s)."
|
print_lines_basic "1" "-D" "Full hard Disk info, not only model, ie: /dev/sda ST380817AS 80.0GB. See also -x and -xx. Disk total used percentage includes swap partition size(s)."
|
||||||
print_lines_basic "1" "-f" "All cpu flags, triggers -C. Not shown with -F to avoid spamming. ARM cpus show 'features'."
|
print_lines_basic "1" "-f" "All cpu flags, triggers -C. Not shown with -F to avoid spamming. ARM cpus show 'features'."
|
||||||
print_lines_basic "1" "-F" "Full output for $SCRIPT_NAME. Includes all Upper Case line letters, plus -s and -n. Does not show extra verbose options like -d -f -l -m -o -p -r -t -u -x"
|
print_lines_basic "1" "-F" "Full output for $SCRIPT_NAME. Includes all Upper Case line letters, plus -s and -n. Does not show extra verbose options like -d -f -l -m -o -p -r -t -u -x"
|
||||||
print_lines_basic "1" "-G" "Graphic card information (card, display server type/version, resolution, glx renderer, version)."
|
print_lines_basic "1" "-G" "Graphic card information (card, display server type/version, resolution, glx renderer, GL core profile version)."
|
||||||
print_lines_basic "1" "-i" "Wan IP address, and shows local interfaces (requires ifconfig
|
print_lines_basic "1" "-i" "Wan IP address, and shows local interfaces (requires ifconfig
|
||||||
network tool). Same as -Nni. Not shown with -F for user security reasons, you shouldn't paste your local/wan IP."
|
network tool). Same as -Nni. Not shown with -F for user security reasons, you shouldn't paste your local/wan IP."
|
||||||
print_lines_basic "1" "-I" "Information: processes, uptime, memory, irc client (or shell type), $SCRIPT_NAME version."
|
print_lines_basic "1" "-I" "Information: processes, uptime, memory, irc client (or shell type), $SCRIPT_NAME version."
|
||||||
|
@ -3158,7 +3158,7 @@ show_options()
|
||||||
print_lines_basic "2" "-B" "serial number, voltage (if available)."
|
print_lines_basic "2" "-B" "serial number, voltage (if available)."
|
||||||
print_lines_basic "2" "-C" "Minimum CPU speed, if available."
|
print_lines_basic "2" "-C" "Minimum CPU speed, if available."
|
||||||
print_lines_basic "2" "-D" "Disk serial number."
|
print_lines_basic "2" "-D" "Disk serial number."
|
||||||
print_lines_basic "2" "-G" "Chip vendor:product ID for each video card; (mir/wayland only) compositor (alpha test)."
|
print_lines_basic "2" "-G" "Chip vendor:product ID for each video card; (mir/wayland only) compositor (alpha test); OpenGL compatibility version, if free drivers and available."
|
||||||
print_lines_basic "2" "-I" "Other detected installed gcc versions (if present). System default runlevel. Adds parent program (or tty) for shell info if not in IRC (like Konsole or Gterm). Adds Init/RC (if found) version number."
|
print_lines_basic "2" "-I" "Other detected installed gcc versions (if present). System default runlevel. Adds parent program (or tty) for shell info if not in IRC (like Konsole or Gterm). Adds Init/RC (if found) version number."
|
||||||
print_lines_basic "2" "-m" "Manufacturer, Serial Number, single/double bank (if found)."
|
print_lines_basic "2" "-m" "Manufacturer, Serial Number, single/double bank (if found)."
|
||||||
print_lines_basic "2" "-M" "Chassis information, bios rom size (dmidecode only), if data for either is available."
|
print_lines_basic "2" "-M" "Chassis information, bios rom size (dmidecode only), if data for either is available."
|
||||||
|
@ -6396,7 +6396,6 @@ get_graphics_glx_data()
|
||||||
if [[ $B_SHOW_DISPLAY_DATA == 'true' && $B_ROOT != 'true' ]];then
|
if [[ $B_SHOW_DISPLAY_DATA == 'true' && $B_ROOT != 'true' ]];then
|
||||||
IFS=$'\n'
|
IFS=$'\n'
|
||||||
A_GLX_DATA=( $( glxinfo | gawk -F ': ' '
|
A_GLX_DATA=( $( glxinfo | gawk -F ': ' '
|
||||||
# note: function declarations go before BEGIN? It appears so, confirm.
|
|
||||||
# the real question here though is why this function is even here, seems
|
# the real question here though is why this function is even here, seems
|
||||||
# just to be a complicated way to pack/print a variable, but maybe the
|
# just to be a complicated way to pack/print a variable, but maybe the
|
||||||
# original idea was to handle > 1 cases of detections I guess
|
# original idea was to handle > 1 cases of detections I guess
|
||||||
|
@ -6414,6 +6413,7 @@ get_graphics_glx_data()
|
||||||
|
|
||||||
BEGIN {
|
BEGIN {
|
||||||
IGNORECASE=1
|
IGNORECASE=1
|
||||||
|
compatVersion=""
|
||||||
}
|
}
|
||||||
/opengl renderer/ {
|
/opengl renderer/ {
|
||||||
gsub(/'"$BAN_LIST_NORMAL"'/, "", $2)
|
gsub(/'"$BAN_LIST_NORMAL"'/, "", $2)
|
||||||
|
@ -6436,16 +6436,32 @@ get_graphics_glx_data()
|
||||||
# /opengl version/ && ( f || $2 !~ /mesa/ ) {
|
# /opengl version/ && ( f || $2 !~ /mesa/ ) {
|
||||||
/opengl version/ {
|
/opengl version/ {
|
||||||
# fglrx started appearing with this extra string, does not appear to communicate anything of value
|
# fglrx started appearing with this extra string, does not appear to communicate anything of value
|
||||||
sub(/Compatibility Profile Context/, "- CPC", $2 )
|
sub(/(Compatibility Profile Context|\(Compatibility Profile\))/, "", $2 )
|
||||||
gsub(/ [ \t]+/, " ", $2) # get rid of the created white spaces
|
gsub(/ [ \t]+/, " ", $2) # get rid of the created white spaces
|
||||||
gsub(/^ +| +$/, "", $2)
|
gsub(/^ +| +$/, "", $2)
|
||||||
$2 && b[$2]
|
$2 && b[$2]
|
||||||
|
# note: this is going to be off if ever multi opengl versions appear, never seen one
|
||||||
|
compatVersion=gensub(/^([^ \t]+)[ \t].*/,"\\1","g",$2)
|
||||||
|
}
|
||||||
|
|
||||||
|
/opengl core profile version/ {
|
||||||
|
gsub(/'"$BAN_LIST_NORMAL"'/, "", $2)
|
||||||
|
# fglrx started appearing with this extra string, does not appear to communicate anything of value
|
||||||
|
sub(/(Core Profile Context|\(Core Profile\))/, "", $2 )
|
||||||
|
gsub(/ [ \t]+/, " ", $2) # get rid of the created white spaces
|
||||||
|
gsub(/^ +| +$/, "", $2)
|
||||||
|
$2 && d[$2]
|
||||||
}
|
}
|
||||||
/direct rendering/ {
|
/direct rendering/ {
|
||||||
$2 && c[$2]
|
$2 && c[$2]
|
||||||
}
|
}
|
||||||
END {
|
END {
|
||||||
printf( "%s\n%s\n%s\n", join( a, ", " ), join( b, ", " ), join( c, ", " ) )
|
dr = join( c, ", " )
|
||||||
|
oglr = join( a, ", " )
|
||||||
|
oglv = join( b, ", " )
|
||||||
|
oglcpv = join( d, ", " )
|
||||||
|
# output processing done in print functions
|
||||||
|
printf( "%s\n%s\n%s\n%s\n%s\n", oglr, oglv, dr, oglcpv, compatVersion )
|
||||||
}' ) )
|
}' ) )
|
||||||
IFS="$ORIGINAL_IFS"
|
IFS="$ORIGINAL_IFS"
|
||||||
|
|
||||||
|
@ -12783,11 +12799,13 @@ print_graphics_data()
|
||||||
|
|
||||||
# set A_GLX_DATA
|
# set A_GLX_DATA
|
||||||
get_graphics_glx_data
|
get_graphics_glx_data
|
||||||
local glx_renderer="${A_GLX_DATA[0]}"
|
local opengl_renderer="${A_GLX_DATA[0]}"
|
||||||
local glx_version="${A_GLX_DATA[1]}"
|
local glx_version="${A_GLX_DATA[1]}"
|
||||||
# this can contain a long No case debugging message, so it's being sliced off
|
# this can contain a long No case debugging message, so it's being sliced off
|
||||||
# note: using grep -ioE '(No|Yes)' <<< ${A_GLX_DATA[2]} did not work in Arch, no idea why
|
# note: using grep -ioE '(No|Yes)' <<< ${A_GLX_DATA[2]} did not work in Arch, no idea why
|
||||||
local glx_direct_render=$( gawk '{print $1}' <<< "${A_GLX_DATA[2]}" )
|
local direct_rendering=$( gawk '{print $1}' <<< "${A_GLX_DATA[2]}" )
|
||||||
|
local glx_core_version="${A_GLX_DATA[3]}"
|
||||||
|
local glx_core_version_nu="${A_GLX_DATA[4]}"
|
||||||
|
|
||||||
# set A_GRAPHICS_CARD_DATA
|
# set A_GRAPHICS_CARD_DATA
|
||||||
if [[ $BSD_TYPE == 'bsd' ]];then
|
if [[ $BSD_TYPE == 'bsd' ]];then
|
||||||
|
@ -12968,26 +12986,32 @@ print_graphics_data()
|
||||||
print_screen_output "$graphics_data"
|
print_screen_output "$graphics_data"
|
||||||
line_starter=' '
|
line_starter=' '
|
||||||
fi
|
fi
|
||||||
# if [[ -z $glx_renderer || -z $glx_version ]];then
|
# if [[ -z $opengl_renderer || -z $glx_version ]];then
|
||||||
# b_is_mesa='true'
|
# b_is_mesa='true'
|
||||||
# fi
|
# fi
|
||||||
|
|
||||||
## note: if glx render or display_version have no content, then mesa is true
|
## note: if glx render or display_version have no content, then mesa is true
|
||||||
# if [[ $B_SHOW_DISPLAY_DATA == 'true' ]] && [[ $b_is_mesa != 'true' ]];then
|
# if [[ $B_SHOW_DISPLAY_DATA == 'true' ]] && [[ $b_is_mesa != 'true' ]];then
|
||||||
if [[ $B_SHOW_DISPLAY_DATA == 'true' && $B_ROOT != 'true' ]];then
|
if [[ $B_SHOW_DISPLAY_DATA == 'true' && $B_ROOT != 'true' ]];then
|
||||||
if [[ -z $glx_renderer ]];then
|
if [[ -z $opengl_renderer ]];then
|
||||||
glx_renderer='N/A'
|
opengl_renderer='N/A'
|
||||||
fi
|
fi
|
||||||
if [[ -z $glx_version ]];then
|
if [[ -z $glx_version ]];then
|
||||||
glx_version='N/A'
|
glx_version='N/A'
|
||||||
|
else
|
||||||
|
if [[ $B_EXTRA_EXTRA_DATA == 'true' ]];then
|
||||||
|
if [[ $glx_core_version_nu != '' && $glx_core_version != '' && $glx_core_version != $glx_version ]];then
|
||||||
|
glx_version=" $glx_version (oglcv$SEP3 $glx_core_version_nu)"
|
||||||
fi
|
fi
|
||||||
if [[ -z $glx_direct_render ]];then
|
fi
|
||||||
glx_direct_render='N/A'
|
fi
|
||||||
|
if [[ -z $direct_rendering ]];then
|
||||||
|
direct_rendering='N/A'
|
||||||
fi
|
fi
|
||||||
if [[ $B_HANDLE_CORRUPT_DATA == 'true' || $B_EXTRA_DATA == 'true' ]];then
|
if [[ $B_HANDLE_CORRUPT_DATA == 'true' || $B_EXTRA_DATA == 'true' ]];then
|
||||||
direct_render_string=" ${C1}Direct Rendering$SEP3${C2} $glx_direct_render"
|
direct_render_string=" ${C1}Direct Rendering$SEP3${C2} $direct_rendering"
|
||||||
fi
|
fi
|
||||||
part_1_data="${C1}GLX Renderer$SEP3${C2} $glx_renderer "
|
part_1_data="${C1}GLX Renderer$SEP3${C2} $opengl_renderer "
|
||||||
part_2_data="${C1}GLX Version$SEP3${C2} $glx_version$direct_render_string"
|
part_2_data="${C1}GLX Version$SEP3${C2} $glx_version$direct_render_string"
|
||||||
# echo $line_starter
|
# echo $line_starter
|
||||||
if [[ $( calculate_line_length "$part_1_data$part_2_data" ) -gt $COLS_INNER ]];then
|
if [[ $( calculate_line_length "$part_1_data$part_2_data" ) -gt $COLS_INNER ]];then
|
||||||
|
|
6
inxi.1
6
inxi.1
|
@ -1,4 +1,4 @@
|
||||||
.TH INXI 1 "2017\-06\-06" inxi "inxi manual"
|
.TH INXI 1 "2017\-06\-08" inxi "inxi manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
inxi \- Command line system information script for console and IRC
|
inxi \- Command line system information script for console and IRC
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
|
@ -126,7 +126,7 @@ those arguments in the command, like: \fBinxi \-Frmxx\fR
|
||||||
.B \-G
|
.B \-G
|
||||||
Show Graphic card information. Card(s), Display Server (vendor and version number), for example:
|
Show Graphic card information. Card(s), Display Server (vendor and version number), for example:
|
||||||
\fBDisplay Server: Xorg 1.15.1 \fR
|
\fBDisplay Server: Xorg 1.15.1 \fR
|
||||||
,screen resolution(s), glx renderer, version). If detected (currently only available if on a desktop: will
|
,screen resolution(s), glx renderer, OpenGL core profile version). If detected (currently only available if on a desktop: will
|
||||||
attempt to show the server type, ie, x11, wayland, mir. When xorg is present, its version information will show
|
attempt to show the server type, ie, x11, wayland, mir. When xorg is present, its version information will show
|
||||||
after the server type in parentheses. Future versions will show compositor information as well.
|
after the server type in parentheses. Future versions will show compositor information as well.
|
||||||
.TP
|
.TP
|
||||||
|
@ -454,6 +454,8 @@ Note that \fBvolts\fR shows the data (if available) as: Voltage Now / Minimum De
|
||||||
.TP
|
.TP
|
||||||
.B \-xx \-G
|
.B \-xx \-G
|
||||||
\- Adds vendor:product ID of each Graphics card. Wayland/Mir only: if found, attempts to show compositor (experimental).
|
\- Adds vendor:product ID of each Graphics card. Wayland/Mir only: if found, attempts to show compositor (experimental).
|
||||||
|
For free drivers, adds OpenGL compatibility version number if it's available, like this:
|
||||||
|
\fB3.3 Mesa 11.2.0 (oglcv: 3.0)\fR
|
||||||
.TP
|
.TP
|
||||||
.B \-xx \-I
|
.B \-xx \-I
|
||||||
\- Show init type version number (and rc if present).
|
\- Show init type version number (and rc if present).
|
||||||
|
|
|
@ -1,3 +1,27 @@
|
||||||
|
=====================================================================================
|
||||||
|
Version: 2.3.13
|
||||||
|
Patch Version: 00
|
||||||
|
Script Date: 2017-06-08
|
||||||
|
-----------------------------------
|
||||||
|
Changes:
|
||||||
|
-----------------------------------
|
||||||
|
New version, tarball, man page. Shows as default OpenGL core profile version number.
|
||||||
|
-xx option will show OpenGL compatibility version number as well, though that's largely useless
|
||||||
|
information for most users, thus the -xx. Note that this reverses the default, which previously
|
||||||
|
showed OpenGL version, which is actually the compatibility version.
|
||||||
|
|
||||||
|
This should resolve #105 pull request, though it does it differently, by switching the default
|
||||||
|
output to what is more relevant, and offering the compatibility version as an optional output item.
|
||||||
|
|
||||||
|
Note that much of the glx information will probably change to more neutral terms once wayland support
|
||||||
|
starts growing, and systems without xwayland etc libraries appear.
|
||||||
|
|
||||||
|
Further note that non free drivers showed the OpenGL core profile version numbers all along, so really
|
||||||
|
this simply corrects misleading output for free drivers.
|
||||||
|
|
||||||
|
-----------------------------------
|
||||||
|
-- Harald Hope - Thu, 08 Jun 2017 15:54:04 -0700
|
||||||
|
|
||||||
=====================================================================================
|
=====================================================================================
|
||||||
Version: 2.3.12
|
Version: 2.3.12
|
||||||
Patch Version: 00
|
Patch Version: 00
|
||||||
|
|
Loading…
Reference in a new issue