commit inxi for openSUSE:Factory
![](https://seccdn.libravatar.org/avatar/e2145bc5cf53dda95c308a3c75e8fef3.jpg?s=120&d=mm&r=g)
Hello community, here is the log from the commit of package inxi for openSUSE:Factory checked in at 2018-10-26 11:10:26 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Comparing /work/SRC/openSUSE:Factory/inxi (Old) and /work/SRC/openSUSE:Factory/.inxi.new (New) ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Package is "inxi" Fri Oct 26 11:10:26 2018 rev:9 rq:644650 version:3.0.27 Changes: -------- --- /work/SRC/openSUSE:Factory/inxi/inxi.changes 2018-10-08 17:50:04.290128511 +0200 +++ /work/SRC/openSUSE:Factory/.inxi.new/inxi.changes 2018-10-26 11:10:27.269704403 +0200 @@ -1,0 +2,6 @@ +Thu Oct 25 12:16:46 UTC 2018 - sor.alexei@meowr.ru + +- Update to version 3.0.27: + * See /usr/share/doc/packages/inxi/inxi.changelog + +------------------------------------------------------------------- Old: ---- inxi-3.0.26-1.tar.gz New: ---- inxi-3.0.27-1.tar.gz ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Other differences: ------------------ ++++++ inxi.spec ++++++ --- /var/tmp/diff_new_pack.Cz1M5C/_old 2018-10-26 11:10:29.165701865 +0200 +++ /var/tmp/diff_new_pack.Cz1M5C/_new 2018-10-26 11:10:29.165701865 +0200 @@ -17,9 +17,9 @@ # -%define _version 3.0.26-1 +%define _version 3.0.27-1 Name: inxi -Version: 3.0.26 +Version: 3.0.27 Release: 0 Summary: A system information script License: GPL-3.0-or-later ++++++ inxi-3.0.26-1.tar.gz -> inxi-3.0.27-1.tar.gz ++++++ diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' old/inxi-3.0.26-1/README.txt new/inxi-3.0.27-1/README.txt --- old/inxi-3.0.26-1/README.txt 2018-09-29 03:38:30.000000000 +0200 +++ new/inxi-3.0.27-1/README.txt 2018-10-15 04:13:25.000000000 +0200 @@ -11,7 +11,14 @@ internally. =============================================================================== -Help inxi development! Submit a user debugger dataset. +DEVELOPMENT AND ISSUES +------------------------------------------------------------------------------- + +Make inxi better! Expand supported hardware and OS data, fix broken items! + +------------------------------------------------------------------------------- +HELP PROJECT DEVELOPMENT! SUBMIT A DEBUGGER DATASET +------------------------------------------------------------------------------- This is easy to do, and only takes a few seconds. These datasets really help the project add and debug features. You will generally also be asked to provide @@ -32,11 +39,12 @@ data, like from dmidecode, and other tools that need superuser permissions to run. -ARM and BSD datasets are particularly appreciated because we simply do not -have enough of those. +ARM (plus MIPS, SPARC, PowerPC) and BSD datasets are particularly appreciated +because we simply do not have enough of those. -=============================================================================== -Make inxi better! Expand supported hardware and OS data, fix broken items! +------------------------------------------------------------------------------- +FILE AN ISSUE IF YOU FIND SOMETHING MISSING, BROKEN, OR FOR AN ENHANCEMENT +------------------------------------------------------------------------------- inxi strives to support the widest range of operating systems and hardware, from the most simple consumer desktops, to the most advanced professional @@ -46,12 +54,43 @@ appreciated since user data and feedback is what keeps inxi working and supporting the latest (or not so latest) hardware and operating systems. -See the BSD section below for qualifications re BSDs, and OSX in particular. +See INXI VERSION/SUPPORT/ISSUES/BUGS INFORMATION for more about issues/support. + +See BSD/UNIX below for qualifications re BSDs, and OSX in particular. =============================================================================== -BRANCHES +SOURCE VERSION CONTROL +------------------------------------------------------------------------------- + +https://github.com/smxi/inxi +MAIN BRANCH: master +DEVELOPMENT BRANCHES: inxi-perl, one, two +inxi-perl is the dev branch, the others are rarely if ever used. inxi itself +has the built in feature to be able to update itself from anywhere, including +these branches, which is very useful for development and debugging on various +user systems. + +PULL REQUESTS: Please talk to me before starting to work on patches of any +reasonable complexity. inxi is hard to work on, and you have to understand how +it works before submitting patches, unless it's a trivial bug fix. Please: +NEVER even think about looking at or using previous inxi commits, previous to +the current master version, as a base for a patch. If you do, your patch / pull +request will probably be rejected. Developers, get your version from the +inxi-perl branch, pinxi, otherwise you may not be current to actual development +versions. inxi-perl pinxi is always equal to or ahead of master branch inxi. + +Man page updates, doc page updates, etc, of course, are easy and will probably +be accepted, as long as they are properly formatted and logically coherent. + +When under active development, inxi releases early, and releases often. + +PACKAGERS: inxi has one and only one 'release', and that is the current +commit/version in the master branch (plus pinxi inxi-perl branch, of course, +but those should never be packaged). + +------------------------------------------------------------------------------- +MASTER BRANCH ------------------------------------------------------------------------------- -MASTER BRANCH: This is the only supported branch, and the current latest commit/version is the only supported 'release'. There are no 'releases' of inxi beyond the @@ -70,8 +109,14 @@ are releases! I can't change the words on the tag page. They are tagged commmits, period. A tag is a pointer to a commit, and has no further meaning. +If your distribution has blocked -U self updater and you want a newer version: + +Open /etc/inxi.conf and change false to true: B_ALLOW_UPDATE=true + +------------------------------------------------------------------------------- +DEVELOPMENT BRANCH ------------------------------------------------------------------------------- -DEVELOPMENT BRANCH: + All active development is now done on the inxi-perl branch (pinxi): git clone https://github.com/smxi/inxi --branch inxi-perl --single-branch @@ -90,7 +135,9 @@ not been corrected, since pinxi is always equal to or ahead of inxi. ------------------------------------------------------------------------------- -LEGACY BRANCH: +LEGACY BRANCH +------------------------------------------------------------------------------- + If you'd like to look at or check out the Gawk/Bash version of inxi, you can find it here, at the inxi-legacy branch (binxi): @@ -107,14 +154,19 @@ anyone. =============================================================================== -SUPPORT INFO: +SUPPORT INFO +------------------------------------------------------------------------------- Do not ask for basic help that reading the inxi -h / --help menus, or man page would show you, and do not ask for features to be added that inxi already has. Also do not ask for support if your distro won't update its inxi version, some are bad about that. -DOCUMENTATION: https://smxi.org/docs/inxi.htm +------------------------------------------------------------------------------- +DOCUMENTATION +------------------------------------------------------------------------------- + +https://smxi.org/docs/inxi.htm (smxi.org/docs/ is easier to remember, and is one click away from inxi.htm). The one page wiki on github is only a pointer to the real resources. @@ -125,52 +177,54 @@ _should_ be included in a distribution's core modules, but which are unfortunately sometimes removed. +INXI CONFIGURATION: https://smxi.org/docs/inxi-configuration.htm HTML MAN PAGE: https://smxi.org/docs/inxi-man.htm INXI OPTIONS PAGE: http://smxi.org/docs/inxi-options.htm -NOTE: These may not always be up to date, but generally track the most recent -inxi commits. -ISSUES: https://github.com/smxi/inxi/issues +NOTE: Check the inxi version number on each doc page to see which version +will support the options listed. The man and options page also link to a +legacy version, pre 2.9. + +------------------------------------------------------------------------------- +IRC +------------------------------------------------------------------------------- + +You can go to: irc.oftc.net channel #smxi +but be prepared to wait around for a while to get a response. Generally it's +better to use github issues. + +------------------------------------------------------------------------------- +ISSUES +------------------------------------------------------------------------------- + +https://github.com/smxi/inxi/issues No issues accepted for non current inxi versions. See below for more on that. Unfortunately as of 2.9, no support or issues can be accepted for older inxi's because inxi 2.9 (Perl) and newer is a full rewrite, and legacy inxi is not being supported since our time here on earth is finite (plus of course, one reason for the rewrite was to never have to work with Gawk->Bash again!). -SUPPORT FORUMS: https://techpatterns.com/forums/forum-33.html -This is the best place to place support issues that may be complicated. - -If you are developer, use: -DEVELOPER FORUMS: https://techpatterns.com/forums/forum-32.html - -SOURCE VERSION CONTROL: https://github.com/smxi/inxi -MAIN BRANCH: master -DEVELOPMENT BRANCHES: inxi-perl, one, two -inxi-perl is the dev branch, the others are rarely if ever used. inxi itself -has the built in feature to be able to update itself from anywhere, including -these branches, which is very useful for development and debugging on various -user systems. +Sys Admin type inxi users always get the first level of support. ie, convince +us you run real systems and networks, and your issue shoots to the top of the +line. As do any real bugs. -PULL REQUESTS: Please talk to me before starting to work on patches of any -reasonable complexity. inxi is hard to work on, and you have to understand how -it works before submitting patches, unless it's a trivial bug fix. Please: -NEVER even think about looking at or using previous inxi commits, previous to -the current master version, as a base for a patch. If you do, your patch / pull -request will probably be rejected. Developers, get your version from the -inxi-perl branch, pinxi, otherwise you may not be current to actual development -versions. inxi-perl pinxi is always equal to or ahead of master branch inxi. +Failure to supply requested debugger data will lead To a distinct lack of +interest on our part to help you with a bug. ie, saying, oh, it doesn't work, +doesn't cut it, unless it's obvious why. -Man page updates, doc page updates, etc, of course, are easy and will probably -be accepted, as long as they are properly formatted and logically coherent. +------------------------------------------------------------------------------- +SUPPORT FORUMS +------------------------------------------------------------------------------- -When under active development, inxi releases early, and releases often. +https://techpatterns.com/forums/forum-33.html +This is the best place to place support issues that may be complicated. -PACKAGERS: inxi has one and only one 'release', and that is the current -commit/version in the master branch (plus pinxi inxi-perl branch, of course, -but those should never be packaged). +If you are developer, use: +DEVELOPER FORUMS: https://techpatterns.com/forums/forum-32.html =============================================================================== -ABOUT INXI - CORE COMMITMENT TO LONG TERM STABILITY +ABOUT INXI +------------------------------------------------------------------------------- inxi is a command line system information tool. It was forked from the ancient and mindbendingly perverse yet ingenius infobash, by locsmif. @@ -193,15 +247,15 @@ automatically turns off color codes, so the old suggestion to use -c 0 to turn off colors is no longer required. -inxi should always show you your current system state, as far as possible, and -should be more reliable than your own beliefs about what is in your system, -ideally. In other words, the goal in inxi is to have it be right more than it -is wrong about any system that it runs on. And not to rely on non current -system state data if at all possible. Some things, like memory/ram data, rely -on radically unreliable system self reporting based on OEM filling out data -correctly, which doesn't often happen, so in those cases, you want to confirm -things like ram capacity with a reputable hardware source, like crucial.com, -which has the best ram hardware tool I know of. +inxi strives to be as accurate as possible, but some things, like memory/ram +data, depend on radically unreliable system self reporting based on OEM +filling out data correctly, which doesn't often happen, so in those cases, +you want to confirm things like ram capacity with a reputable hardware source, +like crucial.com, which has the best ram hardware tool I know of. + +------------------------------------------------------------------------------- +COMMITMENT TO LONG TERM STABILITY +------------------------------------------------------------------------------- The core mission of inxi is to always work on all systems all the time. Well, all systems with the core tools inxi requires to operate installed. Ie, not @@ -216,60 +270,9 @@ system that runs Perl 5.08 or later. Pre 2.9.0 Gawk/Bash inxi will also run on any system no matter how old, within reason, so there should be no difference. -=============================================================================== -BSD SUPPORT - -Real BSDs: -BSD support is not as complete as GNU/Linux support due to the fact some of the -data simply is not available, or is structured in a way that makes it unique to -each BSD. This fragmentation makes supporting BSDs far more difficult than it -should be in the 21st century. The BSD support in inxi is an ongoing process, -with more features being added as new data sources and types are discovered. - -All BSD issue reports unless trivial and obvious will require 1 of two things: - -1. a full --debug 21 data dump so I don't have to spend days trying to get the -information I need to resolve the issue file by painful file from the issue -poster. This is only the start of the process, and realistically requires 2. to -complete it. - -2. direct SSH access to at least a comparable live BSD version/system, that is, -if the issue is on a laptop, access has to be granted to the laptop, or a -similar one. - -Option 2 is far preferred because in terms of my finite time on this planet of -ours, the fact is, if I don't have direct (or SSH) access, I can't get much -done, and the little I can get done will take 10 to 1000x longer than it -should. That's my time spent (and sadly, with BSDs, largely lost), not yours. - -I decided I have to adopt this much more strict policy with BSDs after wasting -untold hours on trying to get good BSD support, only to see that support break -a few years down the road as the data inxi relied in changed structure or -syntax, or the tools changed, or whatever else makes the BSDs such a challenge -to support. In the end, I realized, the only BSDs that are well supported are -ones that I have had direct access to for debugging and testing. - -I will always accept patches that are well done, if they do not break -GNU/Linux, and extend BSD support, or add new BSD features, and follow the -internal inxi logic, and aren't too long. inxi sets initial internal flags to -identify that it is a BSD system vs a GNU/Linux system, and preloads some data -structures for BSD use, so make sure you understand what inxi is doing before -you get into it. - -OSX: -Do not insult real BSDs by calling OSX a BSD. OSX is the least Unix-like -operating system I've ever seen that claims to be a Unix, its tools are -mutated, its data randomly and non-standardly organized, and it totally fails -to respect the 'spirit' of Unix, even though it might pass some random tests -that certify a system as a 'Unix'. - -If you want me to use my time on OSX features or issues, you have to pay me, -because Apple is all about money, not freedom (that's what the 'free' in 'free -software' is referring to, not cost), and I'm not donating my finite time in -support of non-free operating systems. - -=============================================================================== -INXI FEATURES AND FUNCTIONALITY +------------------------------------------------------------------------------- +FEATURES AND FUNCTIONALITY +------------------------------------------------------------------------------- inxi's functionality continues to grow over time, but it's also important to understand that each core new feature usually requires about 30 days work to @@ -282,8 +285,9 @@ rejected, it's likely because you have not thought it through adequately, have not done adequate testing cross system and platform, etc. -=============================================================================== -INXI VERSION/SUPPORT/ISSUES/BUGS INFORMATION: +------------------------------------------------------------------------------- +SUPPORTED VERSIONS / DISTRO VERSIONS +------------------------------------------------------------------------------- Important: the only version of inxi that is supported is the latest current master branch version/commit. No issue reports or bug reports will be accepted @@ -293,12 +297,6 @@ ages ago. If your distro isn't packaging a current inxi, then file a bug report with your packager, not here. -Sys Admin type inxi users always get the first level of support. ie, convince -us you run real systems and networks, and your issue shoots to the top of the -line. As do any real bugs. Failure to supply requested debugger data will lead -to a distinct lack of interest on our part to help you with a bug. ie, saying, -oh, it doesn't work, doesn't cut it, unless it's obvious why. - inxi is 'rolling release' software, just like Debian Sid, Gentoo, or Arch Linux are rolling release GNU/Linux distributions, with no 'release points'. @@ -320,9 +318,9 @@ exception, the Slackware based Puppy Linux release, which ships without the full Perl language. The Debian based one works fine). -=============================================================================== - -INXI VERSION NUMBERING: +------------------------------------------------------------------------------- +SEMANTIC VERSION NUMBERING +------------------------------------------------------------------------------- inxi uses 'semantic' version numbering, where the version numbers actually mean something. @@ -372,4 +370,68 @@ unless so many new features are added that it actually hits 3.9, then it would roll over to 4. +=============================================================================== +BSD / UNIX +------------------------------------------------------------------------------- + +BSD support is not as complete as GNU/Linux support due to the fact some of the +data simply is not available, or is structured in a way that makes it unique to +each BSD. This fragmentation makes supporting BSDs far more difficult than it +should be in the 21st century. The BSD support in inxi is an ongoing process, +with more features being added as new data sources and types are discovered. + +Note that due to time/practicality constraints, in general, only the original +BSD branches will be actively supported: FreeBSD+derived; OpenBSD+derived; +NetBSD+derived. Other UNIX variants will generally only get the work required +to make internal BSD flags get set and to remove visible output errors. + +------------------------------------------------------------------------------- +TRUE BSDs +------------------------------------------------------------------------------- + +All BSD issue reports unless trivial and obvious will require 1 of two things: + +1. a full --debug 21 data dump so I don't have to spend days trying to get the +information I need to resolve the issue file by painful file from the issue +poster. This is only the start of the process, and realistically requires 2. to +complete it. + +2. direct SSH access to at least a comparable live BSD version/system, that is, +if the issue is on a laptop, access has to be granted to the laptop, or a +similar one. + +Option 2 is far preferred because in terms of my finite time on this planet of +ours, the fact is, if I don't have direct (or SSH) access, I can't get much +done, and the little I can get done will take 10 to 1000x longer than it +should. That's my time spent (and sadly, with BSDs, largely lost), not yours. + +I decided I have to adopt this much more strict policy with BSDs after wasting +untold hours on trying to get good BSD support, only to see that support break +a few years down the road as the data inxi relied in changed structure or +syntax, or the tools changed, or whatever else makes the BSDs such a challenge +to support. In the end, I realized, the only BSDs that are well supported are +ones that I have had direct access to for debugging and testing. + +I will always accept patches that are well done, if they do not break +GNU/Linux, and extend BSD support, or add new BSD features, and follow the +internal inxi logic, and aren't too long. inxi sets initial internal flags to +identify that it is a BSD system vs a GNU/Linux system, and preloads some data +structures for BSD use, so make sure you understand what inxi is doing before +you get into it. + +------------------------------------------------------------------------------- +APPLE CORPORATION OSX +------------------------------------------------------------------------------- + +Non-free/libre OSX is in my view a BSD in name only. It is the least Unix-like +operating system I've ever seen that claims to be a Unix, its tools are +mutated, its data randomly and non-standardly organized, and it totally fails +to respect the 'spirit' of Unix, even though it might pass some random tests +that certify a system as a 'Unix'. + +If you want me to use my time on OSX features or issues, you have to pay me, +because Apple is all about money, not freedom (that's what the 'free' in 'free +software' is referring to, not cost), and I'm not donating my finite time in +support of non-free operating systems. + ### EOF ### diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' old/inxi-3.0.26-1/inxi new/inxi-3.0.27-1/inxi --- old/inxi-3.0.26-1/inxi 2018-09-29 03:38:30.000000000 +0200 +++ new/inxi-3.0.27-1/inxi 2018-10-15 04:13:25.000000000 +0200 @@ -31,8 +31,8 @@ ## INXI INFO ## my $self_name='inxi'; -my $self_version='3.0.26'; -my $self_date='2018-09-28'; +my $self_version='3.0.27'; +my $self_date='2018-10-14'; my $self_patch='00'; ## END INXI INFO ## @@ -383,9 +383,9 @@ } } # this lets you set different size for in or out of display server - # if ( ! $b_running_in_display && $configs{'COLS_MAX_NO_DISPLAY'} != 0 ){ - # $size{'console'}=$configs{'COLS_MAX_NO_DISPLAY'}; - # } + if ( ! $b_running_in_display && $size{'no-display'} ){ + $size{'console'}=$size{'no-display'}; + } # term_cols is set in top globals, using tput cols # print "tc: $size{'term'} cmc: $size{'console'}\n"; if ( $size{'term'} < $size{'console'} ){ @@ -914,7 +914,7 @@ if ($response == ($count + 3) ){ @data = ([0, '', '', "Ok, exiting $self_name now. You can set the colors later."],); main::print_basic(@data); - exit 1; + exit 0; } elsif ($response == ($count + 2)){ @data = ( @@ -1009,7 +1009,7 @@ [ 0, '', '', "99 (global^-^$status{'global'})"] ); main::print_basic(@data); - exit 1; + exit 0; } } @@ -1329,7 +1329,9 @@ system_files(); print $line3; if (!$b_debug){ - if ( -d '/sys' && main::count_dir_files('/sys') ){ + # note: android has unreadable /sys, but -x and -r tests pass + # main::globber('/sys/*') && + if ( main::count_dir_files('/sys') ){ build_tree('sys'); # kernel crash, not sure what creates it, for ppc, as root sys_traverse_data() if ($debugger{'sys'} && ($debugger{'sys-force'} || !$b_root || !$b_ppc )) ; @@ -1340,7 +1342,7 @@ print $line3; # note: proc has some files that are apparently kernel processes, I've tried # filtering them out but more keep appearing, so only run proc debugger if not root - if ( (!$b_root || $debugger{'proc'} ) && -d '/proc' && main::count_dir_files('/proc') ){ + if ( !$debugger{'no-proc'} && (!$b_root || $debugger{'proc'} ) && -d '/proc' && main::count_dir_files('/proc') ){ build_tree('proc'); proc_traverse_data(); } @@ -1949,7 +1951,7 @@ elsif ( $depth == 3 ){ "ls -l $exclude /$dir/$include*/*/ 2>/dev/null" } elsif ( $depth == 4 ){ "ls -l $exclude /$dir/$include*/*/*/ 2>/dev/null" } elsif ( $depth == 5 ){ "ls -l $exclude /$dir/$include*/*/*/*/ 2>/dev/null" } - elsif ( $depth == 5 ){ "ls -l $exclude /$dir/$include*/*/*/*/ 2>/dev/null" } + elsif ( $depth == 6 ){ "ls -l $exclude /$dir/$include*/*/*/*/*/ 2>/dev/null" } }; my @working = (); my $output = ''; @@ -2397,7 +2399,7 @@ print_line("See --recommends for more information.\n"); } eval $end if $b_log; - exit 0 if $b_exit; + exit $errno if $b_exit && !$debugger{'no-exit'}; } sub error_defaults { @@ -2447,7 +2449,7 @@ push @rows,@data; #print Data::Dumper::Dumper \@rows; main::print_basic(@rows); - exit 1; + exit 0; # shell true } sub basic_data { @@ -3301,6 +3303,7 @@ 'lxqt' => ['^lxqt-panel',2,'--version','LXQt',0,1,0], 'lxqt-variant' => ['^lxqt-panel',0,'0','LXQt-Variant',0,1,0], 'lxsession' => ['^lxsession',0,'0','lxsession',0,1,0], + 'ly' => ['^ly',3,'--version','Ly',0,1,0], 'manokwari' => ['^manokwari',0,'0','Manokwari',0,1,0], 'marco' => ['^marco',2,'--version','marco',0,1,0], 'matchbox' => ['^matchbox',0,'0','Matchbox',0,1,0], @@ -3650,7 +3653,7 @@ else { print "Skipping man download because branch version is being used.\n"; } - exit 1; + exit 0; } else { error_handler('file-corrupt', "$self_name"); @@ -4146,6 +4149,15 @@ else { error_handler('bad-arg', $opt, $arg); } }, + 'debug-no-eps' => sub { + $debugger{'no-exit'} = 1; + $debugger{'no-proc'} = 1; + $debugger{'sys'} = 0; + }, + 'debug-no-exit' => sub { + $debugger{'no-exit'} = 1 }, + 'debug-no-proc' => sub { + $debugger{'no-proc'} = 1; }, 'debug-no-sys' => sub { $debugger{'sys'} = 0; }, 'debug-proc' => sub { @@ -4514,6 +4526,8 @@ @rows = ( ['1', '-x', '--extra', "Adds the following extra data (only works with verbose or line output, not short form):" ], + ['2', '-A', '', "Specific vendor/product information (if relevant); + PCI Bus ID/USB ID number of card; Version/port(s)/driver version (if available)." ], ['2', '-B', '', "Vendor/model, status (if available); attached devices (e.g. wireless mouse, keyboard, if present)." ], ['2', '-C', '', "CPU $flags, Bogomips on CPU; CPU microarchitecture + @@ -4523,16 +4537,17 @@ ['2', '-D', '', "HDD temp with disk data if you have hddtemp installed, if you are root, or if you have added to /etc/sudoers (sudo v. 1.7 or newer). Example:^<username>^ALL^=^NOPASSWD:^/usr/sbin/hddtemp" ], - ['2', '-G', '', "Direct rendering status (in X); Screen number GPU is - running on (Nvidia only)." ], + ['2', '-G', '', "Specific vendor/product information (if relevant); + PCI Bus ID/USB ID number of card; Direct rendering status (in X); Screen + number GPU is running on (Nvidia only)." ], ['2', '-i', '', "For IPv6, show additional scope addresses: Global, Site, Temporary, Unknown. See --limit for large counts of IP addresses." ], ['2', '-I', '', "Default system GCC. With -xx, also shows other installed GCC versions. If running in shell, not in IRC client, shows shell version number, if detected. Init/RC type and runlevel (if available)." ], ['2', '-m', '', "Max memory module size (if available), device type." ], - ['2', '-N -A', '', "Version/port(s)/driver version (if available)." ], - ['2', '-N -A -G', '', "PCI Bus ID/USB ID number of card." ], + ['2', '-N', '', "Specific vendor/product information (if relevant); + PCI Bus ID/USB ID number of card; Version/port(s)/driver version (if available)." ], ['2', '-R', '', "md-raid: second RAID Info line with extra data: blocks, chunk size, bitmap (if present). Resync line, shows blocks synced/total blocks. Hardware RAID driver version, bus ID." ], @@ -4583,19 +4598,18 @@ @rows = ( ['1', '-xxx', '--extra 3', "Show extra, extra, extra data (only works with verbose or line output, not short form):" ], - ['2', '-A', '', "Specific vendor/product information (if relevant), serial number." ], + ['2', '-A', '', "Serial number." ], ['2', '-B', '', "Chemistry, cycles, location (if available)." ], ['2', '-C', '', "CPU boost (turbo) enabled/disabled, if present." ], ['2', '-D', '', "Firmware rev. if available; partition scheme, in some cases; disk rotation speed (if detected)." ], - ['2', '-G', '', "Specific vendor/product information (if relevant); compositor - version (if detectable)." ], + ['2', '-G', '', "Compositor version (if detectable)." ], ['2', '-I', '', "For 'Shell:' adds ([su|sudo|login]) to shell name if present; for 'running in:' adds (SSH) if SSH session." ], ['2', '-m', '', "Width of memory bus, data and total (if present and greater than data); Detail for Type, if present; module voltage, if available; serial number." ], - ['2', '-N', '', "Specific vendor/product information (if relevant); serial number." ], + ['2', '-N', '', "Serial number." ], ['2', '-R', '', "zfs-raid: portion allocated (used) by RAID devices/arrays. md-raid: system md-raid support types (kernel support, read ahead, RAID events). Hardware RAID rev, ports, specific vendor/product information." ], @@ -4709,6 +4723,8 @@ automatically, removes debugger data directory and debugger tar.gz file." ], ['1', '', '--debug-proc', "Force debugger parsing of /proc as sudo/root." ], ['1', '', '--debug-proc-print', "To locate file that /proc debugger hangs on." ], + ['1', '', '--debug-no-exit', "Skip exit on error to allow completion." ], + ['1', '', '--debug-no-proc', "Skip /proc debugging in case of a hang." ], ['1', '', '--debug-no-sys', "Skip /sys debugging in case of a hang." ], ['1', '', '--debug-sys', "Force PowerPC debugger parsing of /sys as sudo/root." ], ['1', '', '--debug-sys-print', "To locate file that /sys debugger hangs on." ], @@ -4719,7 +4735,7 @@ ); push @data, @rows; print_basic(@data); - exit 1; + exit 0; # shell true } sub show_version { @@ -4780,7 +4796,7 @@ push @data, @rows; } print_basic(@data); - exit 1; + exit 0; # shell true } ######################################################################## @@ -5886,7 +5902,7 @@ main::key($num++,'Device') => $card, },); @rows = (@rows,@data); - if ($extra > 2 && $b_pci_tool && $row[12]){ + if ($extra > 0 && $b_pci_tool && $row[12]){ my $item = main::get_pci_vendor($row[4],$row[12]); $rows[$j]{main::key($num++,'vendor')} = $item if $item; } @@ -7520,12 +7536,19 @@ ($cur,$min,$max) = ('scaling_cur_freq','cpuinfo_min_freq','cpuinfo_max_freq'); } if (-d $sys){ - $speeds{'cur-freq'} = (main::reader("$sys/$cur"))[0]; - $speeds{'cur-freq'} = speed_cleaner($speeds{'cur-freq'},'khz'); - $speeds{'min-freq'} = (main::reader("$sys/$min"))[0]; - $speeds{'min-freq'} = speed_cleaner($speeds{'min-freq'},'khz'); - $speeds{'max-freq'} = (main::reader("$sys/$max"))[0]; - $speeds{'max-freq'} = speed_cleaner($speeds{'max-freq'},'khz'); + # corner cases, android, will have the files but they may be unreadable + if (-r "$sys/$cur"){ + $speeds{'cur-freq'} = (main::reader("$sys/$cur"))[0] ; + $speeds{'cur-freq'} = speed_cleaner($speeds{'cur-freq'},'khz'); + } + if (-r "$sys/$min"){ + $speeds{'min-freq'} = (main::reader("$sys/$min"))[0]; + $speeds{'min-freq'} = speed_cleaner($speeds{'min-freq'},'khz'); + } + if (-r "$sys/$max"){ + $speeds{'max-freq'} = (main::reader("$sys/$max"))[0]; + $speeds{'max-freq'} = speed_cleaner($speeds{'max-freq'},'khz'); + } if ($b_arm){ @arm = main::globber('/sys/devices/system/cpu/cpufreq/policy*/'); # there are arm chips with two dies, that run at different min max speeds!! @@ -7533,21 +7556,21 @@ # it would be slick to show both die min/max/cur speeds, but this is # ok for now. if (scalar @arm > 1){ - my ($current,$max,$min) = (0,0,0); + my ($current,$cur_temp,$max,$max_temp,$min,$min_temp) = (0,0,0,0,0,0); foreach (@arm){ $_ =~ s/\/$//; # strip off last slash in case globs have them - my $max_temp = main::reader("$_/cpuinfo_max_freq"); - $max_temp = speed_cleaner($max_temp,'khz'); + $max_temp = (-r "$_/cpuinfo_max_freq") ? main::reader("$_/cpuinfo_max_freq") : 0; + $max_temp = speed_cleaner($max_temp,'khz') if $max_temp; if ($max_temp > $max){ $max = $max_temp; } - my $min_temp = main::reader("$_/cpuinfo_min_freq"); - $min_temp = speed_cleaner($min_temp,'khz'); + $min_temp = (-r "$_/cpuinfo_min_freq") ? main::reader("$_/cpuinfo_min_freq") : 0; + $min_temp = speed_cleaner($min_temp,'khz') if $min_temp; if ($min_temp < $min || $min == 0){ - $max = $min_temp; + $min = $min_temp; } - my $cur_temp = main::reader("$_/cpuinfo_max_freq"); - $cur_temp = speed_cleaner($cur_temp,'khz'); + $cur_temp = (-r "$_/cpuinfo_max_freq") ? main::reader("$_/cpuinfo_max_freq") : 0; + $cur_temp = speed_cleaner($cur_temp,'khz') if $cur_temp; if ($cur_temp > $current){ $current = $cur_temp; } @@ -7559,7 +7582,8 @@ } # policy4/cpuinfo_max_freq:["2000000"] # policy4/cpuinfo_min_freq:["200000"] - if ($speeds{'min-freq'} > $speeds{'max-freq'} || $speeds{'min-freq'} == $speeds{'max-freq'}){ + if ((defined $speeds{'min-freq'} && defined $speeds{'max-freq'}) && + ($speeds{'min-freq'} > $speeds{'max-freq'} || $speeds{'min-freq'} == $speeds{'max-freq'} )){ $speeds{'min-freq'} = 0; } } @@ -7986,7 +8010,8 @@ } } $size ||= 'N/A'; - @sizing = main::get_size($disks[0]{'used'}) if $disks[0]{'used'}; + @sizing = (); + @sizing = main::get_size($disks[0]{'used'}) if defined $disks[0]{'used'}; if (@sizing){ $used = $sizing[0]; if (defined $sizing[0] && $sizing[1]){ @@ -8083,7 +8108,7 @@ my %row = %$ref; # don't count remote used, also, some cases mount # panfs is parallel NAS volume manager, need more data - next if ($row{'fs'} && $row{'fs'} =~ /nfs|panfs|sshfs|smbfs|unionfs/); + next if ($row{'fs'} && $row{'fs'} =~ /cifs|iso9660|nfs|panfs|sshfs|smbfs|unionfs/); # in some cases, like redhat, mounted cdrom/dvds show up in partition data next if ($row{'dev-base'} && $row{'dev-base'} =~ /^sr[0-9]+$/); # this is used for specific cases where bind, or incorrect multiple mounts @@ -8361,8 +8386,8 @@ } #print "$i\n"; if ($bsd_type eq 'openbsd'){ - if ($row[1] =~ /,\s*([0-9\.]+[MGTPE][B]?),.*\ssectors$|^</){ - $working = main::translate_size($1); + if ($row[1] =~ /(^|,\s*)([0-9\.]+[MGTPE][B]?),.*\ssectors$|^</){ + $working = main::translate_size($2); $size += $working if $working; $drives[$i]{'size'} = $working; } @@ -8595,18 +8620,18 @@ # Data URLs: inxi-resources.txt Section: DiskData device_vendor() my @vendors = ( ## These go first because they are the most likely and common ## - ['(Crucial|^CT|-CT|^M4\b)','Crucial','Crucial',''], + ['(Crucial|^(FC)?CT|-CT|^M4\b)','Crucial','Crucial',''], ['^(INTEL|SSDPAM)','^INTEL','Intel',''], - ['(KINGSTON|DataTraveler|^SMS|^SHS|^SUV)','KINGSTON','Kingston',''], # maybe SHS: SHSS37A SKC SUV + ['(KINGSTON|DataTraveler|^SMS|^SHS|^SUV|^Ultimate CF)','KINGSTON','Kingston',''], # maybe SHS: SHSS37A SKC SUV # must come before samsung MU. NOTE: toshiba can have: TOSHIBA_MK6475GSX: mush: MKNSSDCR120GB_ ['(^MKN|Mushkin)','Mushkin','Mushkin',''], # MKNS # MU = Multiple_Flash_Reader too risky: |M[UZ][^L] - ['(SAMSUNG|^MCG[0-9]+GC|^G2 Portable|^DUO\b|^SP[0-9][0-9])','SAMSUNG','Samsung',''], # maybe ^SM - ['(SanDisk|^SDS[S]?[DQ]|^SL([0-9]+)G|^AFGCE|ULTRA\sFIT|Clip Sport|Cruzer)','SanDisk','SanDisk',''], + ['(SAMSUNG|^MCG[0-9]+GC|^MCC|^G2 Portable|^DUO\b|^SP[0-9][0-9])','SAMSUNG','Samsung',''], # maybe ^SM, ^HM + ['(SanDisk|^SDS[S]?[DQ]|^SL([0-9]+)G|^AFGCE|ULTRA\sFIT|Clip Sport|Cruzer|^Extreme)','SanDisk','SanDisk',''], ['^STEC\b','^STEC\b','STEC',''], # ssd drive, must come before seagate ST test # real, SSEAGATE Backup+; XP1600HE30002 - ['(^ST[^T]|[S]?SEAGATE|^X[AFP]|^BUP|Expansion Desk|GoFlex|Backup(\+|\s?Plus)\s?Hub)','[S]?SEAGATE','Seagate',''], - ['^(WD|Western Digital|My (Book|Passport)|\d*LPCX|Elements|M000|EARX|EFRX|\d*EAVS|0JD)','(^WDC|Western Digital)','Western Digital',''], + ['(^ST[^T]|[S]?SEAGATE|^X[AFP]|^BUP|Expansion Desk|FreeAgent|GoFlex|Backup(\+|\s?Plus)\s?Hub)','[S]?SEAGATE','Seagate',''], + ['^(WD|Western Digital|My (Book|Passport)|\d*LPCX|Elements|M000|EARX|EFRX|\d*EAVS|0JD|JPVX)','(^WDC|Western\s?Digital)','Western Digital',''], ## Then better known ones ## ['^(A-DATA|ADATA|AXN)','^(A-DATA|ADATA)','A-Data',''], ['^ADTRON','^(ADTRON)','Adtron',''], @@ -8618,7 +8643,8 @@ ['^(HGST|Touro)','^HGST','HGST (Hitachi)',''], # HGST HUA ['^(Hitachi|HDS|HDT|IC|HT|HU)','^Hitachi','Hitachi',''], ['^Hoodisk','^Hoodisk','Hoodisk',''], - ['^(HP\b|MB0|GJ0|v210w)','^HP','HP',''], # vb: VB0250EAVER but clashes with vbox; HP_SSD_S700_120G + # vb: VB0250EAVER but clashes with vbox; HP_SSD_S700_120G ;GB0500EAFYL GB starter too generic? + ['^(HP\b|MB0|GJ0|v210w)','^HP','HP',''], ['^(LSD|Lexar|JumpDrive)','^Lexar','Lexar',''], # mmc-LEXAR_0xb016546c # OCZSSD2-2VTXE120G is OCZ-VERTEX2_3.5 ['^(OCZ|APOC|D2|DEN|DEN|DRSAK|EC188|FTNC|GFGC|MANG|MMOC|NIMC|NIMR|PSIR|TALOS2|TMSC|TRSAK)','^OCZ[\s\-]','OCZ',''], @@ -8634,6 +8660,8 @@ # must come before AP|Apacer ['^APPLE','^APPLE','Apple',''], ['^(AP|Apacer)','^Apacer','Apacer',''], + ['^BHT','^BHT','BHT',''], + ['^BIWIN','^BIWIN','BIWIN',''], ['^BUFFALO','^BUFFALO','Buffalo',''], ['^CHN\b','','Zheino',''], ['^Colorful\b','^Colorful','Colorful',''], @@ -8647,6 +8675,8 @@ ['^GALAX\b','^GALAX','GALAX',''], ['^Galaxy\b','^Galaxy','Galaxy',''], ['^Generic','^Generic','Generic',''], + ['^Gigabyte','^Gigabyte','Gigabyte',''], # SSD + ['^Gigastone','^Gigastone','Gigastone',''], ['^Gloway','^Gloway','Gloway',''], ['^GOODRAM','^GOODRAM','GOODRAM',''], # supertalent also has FM: |FM @@ -8654,11 +8684,13 @@ ['^HUAWEI','^HUAWEI','Huawei',''], ['^(IBM|DT)','^IBM','IBM',''], ['^IEI Tech','^IEI Tech(\.|nology)?( Corp(\.|oration)?)?','IEI Technology',''], - ['^Imation','^Imation(\sImation)?','Imation',''], # Imation_ImationFlashDrive; TF20 is imation/tdk + ['^(Imation|Nano\s?Pro)','^Imation(\sImation)?','Imation',''], # Imation_ImationFlashDrive; TF20 is imation/tdk ['^(InnoDisk|Innolite)','^InnoDisk( Corp.)?','InnoDisk',''], ['^Innostor','^Innostor','Innostor',''], + ['^Innovation','^Innovation','Innovation',''], ['^(Intenso|(Alu|Mobile|Rainbow|Speed) Line)','^Intenso','Intenso',''], - ['^(Iomega|ZIP\b)','^Iomega','Iomega',''], + ['^(Iomega|ZIP\b)','^Iomega','Iomega',''], + # NOTE: ITY2 120GB hard to find ['^JMicron','^JMicron','JMicron',''], #JMicron H/W raid ['^KingDian','^KingDian','KingDian',''], ['^Kingfast','^Kingfast','Kingfast',''], @@ -8683,7 +8715,7 @@ ['QEMU','^[0-9]*QEMU( QEMU)?','QEMU',''], # 0QUEMU QEMU HARDDISK ['(^Quantum|Fireball)','^Quantum','Quantum',''], ['^QUMO','^QUMO','Qumo',''], - ['^R3','','AMD Radeon',''], # ssd + ['^(R3|AMD\s?(RADEON)?)','AMD\s?(RADEON)?','AMD Radeon',''], # ssd ['^RENICE','^RENICE','Renice',''], ['^RIM[\s]','^RIM','RIM',''], ['^SigmaTel','^SigmaTel','SigmaTel',''], @@ -8963,7 +8995,7 @@ main::key($num++,'Device') => $card, },); @rows = (@rows,@data); - if ($extra > 2 && $b_pci_tool && $row[12]){ + if ($extra > 0 && $b_pci_tool && $row[12]){ my $item = main::get_pci_vendor($row[4],$row[12]); $rows[$j]{main::key($num++,'vendor')} = $item if $item; } @@ -9614,7 +9646,8 @@ # otherwise the version information is going to be different in all cases I think if ( ($data{'sys_vendor'} && $data{'sys_vendor'} eq $data{'board_vendor'} ) && ( ($data{'product_version'} && $data{'product_version'} eq $data{'board_version'} ) || - (!$data{'product_version'} && $data{'product_name'} eq $data{'board_name'} ) ) ){ + (!$data{'product_version'} && $data{'product_name'} && $data{'board_name'} && + $data{'product_name'} eq $data{'board_name'} ) ) ){ $b_skip_system = 1; } } @@ -10232,7 +10265,7 @@ main::key($num++,'Device') => $card, },); @rows = (@rows,@data); - if ($extra > 2 && $b_pci_tool && $row[12]){ + if ($extra > 0 && $b_pci_tool && $row[12]){ my $item = main::get_pci_vendor($row[4],$row[12]); $rows[$j]{main::key($num++,'vendor')} = $item if $item; } @@ -11096,32 +11129,10 @@ $used = $size = (!$b_root) ? main::row_defaults('root-required') : main::row_defaults('partition-hidden'); } %part = (); - if (defined $row{'dev-base'}){ - if ($row{'dev-base'} =~ /^non-dev-/){ - $row{'dev-base'} =~ s/^non-dev-//; - $dev_type = 'raid'; - $dev = $row{'dev-base'}; - } - # note: I have seen this: beta:data/ for sshfs path - elsif ($row{'dev-base'} =~ /^\/\/|:\//){ - $dev_type = 'remote'; - $dev = $row{'dev-base'}; - } - # an error has occurred almost for sure - elsif (!$row{'dev-base'}){ - $dev_type = 'dev'; - $dev = main::row_defaults('unknown-dev'); - } - else { - $dev_type = 'dev'; - $dev = '/dev/' . $row{'dev-base'}; - } - } - else { - $dev_type = 'dev'; - } $fs = ($row{'fs'}) ? lc($row{'fs'}): 'N/A'; - $dev ||= 'N/A'; + $dev_type = ($row{'dev-type'}) ? $row{'dev-type'} : 'dev'; + $row{'dev-base'} = '/dev/' . $row{'dev-base'} if $dev_type eq 'dev' && $row{'dev-base'}; + $dev = ($row{'dev-base'}) ? $row{'dev-base'} : 'N/A'; $j = scalar @rows; @data = ({ main::key($num++,'ID') => $row{'id'}, @@ -11171,10 +11182,10 @@ eval $start if $b_log; #return if $bsd_type && $bsd_type eq 'darwin'; # darwin has muated output, of course my (@data,@rows,@mapper,@mount,@partitions_working,%part,@working); - my ($b_fake_map,$b_fs,$b_load,$cols,$roots) = (0,1,0,6,0); + my ($b_fake_map,$b_fs,$b_load,$b_space,$cols,$roots) = (0,1,0,0,6,0); my ($back_size,$back_used) = (4,3); - my ($block_size,$blockdev,$dev_base,$fs,$id,$label,$percent_used,$raw_size, - $size_available,$size,$type,$uuid,$used); + my ($block_size,$blockdev,$dev_base,$dev_type,$fs,$id,$label,$percent_used, + $raw_size,$replace,$size_available,$size,$test,$type,$uuid,$used); $b_partitions = 1; if ($b_admin){ # for partition block size @@ -11221,24 +11232,37 @@ # so check for two string endings of / then slice out the rootfs one, I could check for it # before slicing it out, but doing that would require the same action twice re code execution foreach (@partitions_working){ - if (/\s\/$/){ - $roots++; - } + $roots++ if /\s\/$/; } @partitions_working = grep {!/^rootfs/} @partitions_working if $roots > 1; my $filters = '^(aufs|cgroup.*|cgmfs|configfs|debugfs|\/dev|dev|\/dev/loop[0-9]*|'; $filters .= 'devfs|devtmpfs|fdescfs|iso9660|linprocfs|none|procfs|\/run(\/.*)?|'; $filters .= 'run|shm|squashfs|sys|\/sys\/.*|sysfs|tmpfs|type|udev|unionfs|vartmp)$'; + #push @partitions_working, '//mafreebox.freebox.fr/Disque dur cifs 239216096 206434016 20607496 91% /freebox/Disque dur'; + #push @partitions_working, '//mafreebox.freebox.fr/AllPG cifs 436616192 316339304 120276888 73% /freebox/AllPG'; foreach (@partitions_working){ - # stupid apple bullshit + # apple crap, maybe also freebsd? $_ =~ s/^map\s+([\S]+)/map:\/$1/ if $b_fake_map; + $b_space = 0; + # handle spaces in remote filesystem names + # busybox df shows KM, sigh. + if (/^(.*)(\s[\S]+)\s+[a-z][a-z0-9]+\s+[0-9]+/){ + $replace = $test = "$1$2"; + if ($test =~ /\s/){ + $b_space = 1; + $replace =~ s/\s/^^/g; + #print ":$replace:\n"; + $_ =~ s/^$test/$replace/; + #print "$_\n"; + } + } my @row = split /\s+/, $_; # autofs is a bsd thing, has size 0 if ($row[0] =~ /$filters/ || $row[0] =~ /^ROOT/i || ($b_fs && ($row[2] == 0 || $row[1] eq 'tmpfs' || $row[1] eq 'autofs' ))){ next; } - ($dev_base,$fs,$id,$label,$type,$uuid) = ('','','','',''); + ($dev_base,$dev_type,$fs,$id,$label,$type,$uuid) = ('','','','','',''); ($b_load,$block_size,$percent_used,$raw_size,$size_available, $size,$used) = (0,0,0,0,0,0,0,0); %part = (); @@ -11264,7 +11288,8 @@ # note: Main/jails/transmission_1 path can be > 1 deep # Main zfs 3678031340 8156 3678023184 0% /mnt/Main if (!$dev_base && ($row[0] =~ /^([^\/]+\/)(.+)/ || ($row[0] =~ /^[^\/]+$/ && $row[1] =~ /^(btrfs|zfs)$/ ) ) ){ - $dev_base = "non-dev-$row[0]"; + $dev_base = $row[0]; + $dev_type = 'raid'; } # this handles yet another fredforfaen special case where a mounted drive # has the search string in its name @@ -11321,12 +11346,32 @@ $size_available = $working[1]; $block_size = $working[2]; } + $dev_base =~ s/\^\^/ /g if $b_space; + if (!$dev_type){ + if ($dev_base =~ /^map:\/(.*)/){ + $dev_type = 'mapped'; + $dev_base = $1; + } + # note: I have seen this: beta:data/ for sshfs path + elsif ($dev_base =~ /^\/\/|:\//){ + $dev_type = 'remote'; + } + # an error has occurred almost for sure + elsif (!$dev_base){ + $dev_type = 'source'; + $dev_base = main::row_defaults('unknown-dev'); + } + else { + $dev_type = 'dev'; + } + } $used = $row[$cols - $back_used]; - $percent_used = sprintf( "%.1f", ( $used/$size )*100 ) if ($size); + $percent_used = sprintf( "%.1f", ( $used/$size )*100 ) if ($size && main::is_numeric($size) ); @data = ({ 'block-size' => $block_size, 'id' => $id, 'dev-base' => $dev_base, + 'dev-type' => $dev_type, 'fs' => $fs, 'label' => $label, 'raw-size' => $raw_size, @@ -11386,6 +11431,7 @@ my @data = split /\s+/, $_; my $dev_base = $data[0]; $dev_base =~ s/^\/dev\///; + my $dev_type = 'dev'; my $size = $data[$size_id]; my $used = $data[$used_id]; my $percent_used = sprintf( "%.1f", ( $used/$size )*100 ); @@ -11405,6 +11451,7 @@ @data = ({ 'cache-pressure' => $cache_pressure, 'dev-base' => $dev_base, + 'dev-type' => $dev_type, 'fs' => 'swap', 'id' => "swap-$s", 'label' => $label, @@ -11804,7 +11851,8 @@ @rows = sort { my @a = split(/\s+/,$a); my @b = split(/\s+/,$b); - $b[5] <=> $a[5] } @ps_aux; + $b[5] <=> $a[5] } @ps_aux; # 5 + #$a[1] <=> $b[1] } @ps_aux; # 5 $pid_col = 1; } else { @@ -11830,7 +11878,7 @@ my @row = split /\s+/, $_; if ($ps_cols >= 10){ my $decimals = ($row[5]/1024 > 10 ) ? 1 : 2; - $mem = ($row[5]) ? sprintf( "%.${decimals}f", $row[5]/1024 ) . ' MiB' : 'N/A'; + $mem = (main::is_int($row[5])) ? sprintf( "%.${decimals}f", $row[5]/1024 ) . ' MiB' : 'N/A'; $mem .= " (" . $row[3] . "%)"; } else { @@ -13095,6 +13143,7 @@ my $slapt_get = '/etc/slapt-get/'; my $tce_app = '/usr/bin/tce'; my $tce_file = '/opt/tcemirror'; + my $tce_file2 = '/opt/localmirrors'; my $yum_conf = '/etc/yum.conf'; my $yum_repo_dir = '/etc/yum.repos.d/'; my $xbps_dir_1 = '/etc/xbps.d/'; @@ -13349,7 +13398,6 @@ if ($url && $title && $enabled){ push @content, "$title ~ $url"; } - if (! @content){ $key = repo_builder('missing',$repo); } @@ -13436,9 +13484,13 @@ @rows = (@rows,@data); } # TinyCore - if (-e $tce_app || -f $tce_file){ + if (-e $tce_app || -f $tce_file || -f $tce_file2){ @data = repo_builder($tce_file,'tce','^\s*[^#]+'); @rows = (@rows,@data); + if (-f $tce_file2){ + @data = repo_builder($tce_file2,'tce','^\s*[^#]+'); + @rows = (@rows,@data); + } } # void $xbps_dir_1 if (-d $xbps_dir_1 || -d $xbps_dir_2){ @@ -13683,7 +13735,7 @@ 'slackpkg' => 'No active slackpkg repos in', 'slackpkg+' => 'No active slackpkg+ repos in', 'slaptget' => 'No active slapt-get repos in', - 'tce' => 'No active tce mirrors in', + 'tce' => 'No tce mirrors in', 'xbps' => 'No active xbps repos in', 'yum' => 'No active yum repos in', 'zypp' => 'No active zypp repos in', @@ -13707,7 +13759,7 @@ 'slackpkg' => 'slackpkg repos in', 'slackpkg+' => 'slackpkg+ repos in', 'slaptget' => 'slapt-get repos in', - 'tce' => 'Active tce mirrors in', + 'tce' => 'tce mirrors in', 'xbps' => 'Active xbps repos in', 'yum' => 'Active yum repos in', 'zypp' => 'Active zypp repos in', @@ -15605,7 +15657,7 @@ if (my $file = system_files('version') ) { @compiler = get_compiler_version_linux($file); } - else { + elsif ($bsd_type) { @compiler = get_compiler_version_bsd(); } eval $end if $b_log; @@ -15615,7 +15667,7 @@ sub get_compiler_version_bsd { eval $start if $b_log; my (@compiler,@working); - if ($alerts{'sysctl'}{'action'} eq 'use'){ + if ($alerts{'sysctl'}{'action'} && $alerts{'sysctl'}{'action'} eq 'use'){ # for dragonfly, we will use free mem, not used because free is 0 my @working; foreach (@sysctl){ @@ -15631,9 +15683,6 @@ } } } - else { - @compiler = ('N/A',''); - } log_data('dump','@compiler',\@compiler) if $b_log; eval $end if $b_log; return @compiler; @@ -15655,7 +15704,6 @@ } } log_data('dump','@compiler',\@compiler) if $b_log; - eval $end if $b_log; return @compiler; } @@ -16270,11 +16318,17 @@ push @found, $working; } } - if (!@found && grep {/\/usr.*\/x/ && !/\/xprt/} @ps_cmd){ - if (awk (\@ps_cmd, 'startx') ){ + if (!@found){ + # ly does not have a run/pid file + if (grep {$_ eq 'ly'} @ps_gui) { + @data = main::program_data('ly','ly',3); + $found[0] = $data[0]; + $found[0] .= ' ' . $data[1] if $data[1]; + } + elsif (grep {/startx$/} @ps_gui) { $found[0] = 'startx'; } - elsif (awk (\@ps_cmd, 'xinit') ){ + elsif (grep {$_ eq 'xinit'} @ps_gui) { $found[0] = 'xinit'; } } @@ -16314,9 +16368,9 @@ $distro = join (' ', @data); } } - else { - $distro = "$uname[0] $uname[2]"; - } + # seen a case without osx file, or was it permissions? + # this covers all the other bsds anyway, no problem. + $distro = "$uname[0] $uname[2]" if !$distro; @distro_data = ($distro,''); eval $end if $b_log; } @@ -17065,17 +17119,19 @@ return $memory; } -# openbsd/linux +## openbsd/linux # procs memory page disks traps cpu # r b w avm fre flt re pi po fr sr wd0 wd1 int sys cs us sy id # 0 0 0 55256 1484092 171 0 0 0 0 0 2 0 12 460 39 3 1 96 -# freebsd: +## openbsd 6.3? added in M, sigh... +# 2 57 55M 590M 789 0 0 0... +## freebsd: # procs memory page disks faults cpu # r b w avm fre flt re pi po fr sr ad0 ad1 in sy cs us sy id # 0 0 0 21880M 6444M 924 32 11 0 822 827 0 0 853 832 463 8 3 88 # with -H # 2 0 0 14925812 936448 36 13 10 0 84 35 0 0 84 30 42 11 3 86 -# dragonfly +## dragonfly # procs memory page disks faults cpu # r b w avm fre flt re pi po fr sr ad0 ad1 in sy cs us sy id # 0 0 0 0 84060 30273993 2845 12742 1164 407498171 320960902 0 0 .... @@ -17083,21 +17139,36 @@ eval $start if $b_log; my ($type) = @_; my $memory = ''; - my ($avail,$total,$free_mem,$real_mem) = (0,0,0,0); + my ($avm,$av_pages,$cnt,$fre,$free_mem,$real_mem,$total) = (3,0,0,4,0,0,0); my (@data,$message); my $arg = ($bsd_type ne 'openbsd') ? '-H' : ''; if (my $program = check_program('vmstat')){ # see above, it's the last line. -H makes it hopefully all in kB so no need # for K/M/G tests - my $row = (grabber("vmstat $arg 2>/dev/null",'\n','strip'))[-1]; + my @vmstat = grabber("vmstat $arg 2>/dev/null",'\n','strip'); + my @header = split /\s+/, $vmstat[1]; + foreach ( @header){ + if ($_ eq 'avm'){$avm = $cnt} + elsif ($_ eq 'fre'){$fre = $cnt} + elsif ($_ eq 'flt'){last;} + $cnt++; + } + my $row = $vmstat[-1]; if ( $row ){ @data = split /\s+/, $row; + # 6.3 introduced an M character, sigh. + if ($data[$avm] && $data[$avm] =~ /^([0-9]+)M$/){ + $data[$avm] = $1 * 1024; + } + if ($data[$fre] && $data[$fre] =~ /^([0-9]+)M$/){ + $data[$fre] = $1 * 1024; + } # dragonfly can have 0 avg, but they may fix that so make test dynamic - if ($data[3] != 0){ - $avail = ($bsd_type ne 'openbsd') ? sprintf ('%.1f',$data[3]/1024) : $data[3]; + if ($data[$avm] != 0){ + $av_pages = ($bsd_type ne 'openbsd') ? sprintf ('%.1f',$data[$avm]/1024) : $data[$avm]; } - elsif ($data[4] != 0){ - $free_mem = sprintf ('%.1f',$data[4]); + elsif ($data[$fre] != 0){ + $free_mem = sprintf ('%.1f',$data[$fre]); } } } @@ -17132,9 +17203,9 @@ # not using, but leave in place for a bit in case we want it # my $type = ($free_mem) ? ' free':'' ; # hack: temp fix for openbsd/darwin: in case no free mem was detected but we have physmem - if (($avail || $free_mem) && !$real_mem){ + if (($av_pages || $free_mem) && !$real_mem){ my $error = ($message) ? $message: 'total N/A'; - my $used = (!$free_mem) ? $avail : $real_mem - $free_mem; + my $used = (!$free_mem) ? $av_pages : $real_mem - $free_mem; if ($type eq 'string'){ $used = sprintf("%.1f",$used/1024); $memory = "$used/($error) MB"; @@ -17144,8 +17215,8 @@ } } # use openbsd/dragonfly avail mem data if available - elsif (($avail || $free_mem) && $real_mem) { - my $used = (!$free_mem) ? $avail : $real_mem - $free_mem; + elsif (($av_pages || $free_mem) && $real_mem) { + my $used = (!$free_mem) ? $av_pages : $real_mem - $free_mem; my $percent = ($used && $real_mem) ? sprintf("%.1f", ($used/$real_mem)*100) : ''; if ($type eq 'string'){ $used = sprintf("%.1f",$used/1024); @@ -18155,7 +18226,9 @@ eval $start if $b_log; my $program = check_program('ip'); my @data = grabber("$program addr 2>/dev/null",'\n','strip') if $program; - #my @data = reader("$ENV{'HOME'}/bin/scripts/inxi/data/if/scope-ipaddr-1.txt",'strip') or die $!; + # my $file = "$ENV{'HOME'}/bin/scripts/inxi/data/if/scope-ipaddr-1.txt"; + # my $file = "$ENV{'HOME'}/bin/scripts/inxi/data/networking/ip-addr-blue-advance.txt"; + #my @data = reader($file,'strip') or die $!; my ($b_skip,$broadcast,$if,$ip,@ips,$scope,$if_id,$type,@temp,@temp2); foreach (@data){ if (/^[0-9]/){ @@ -18318,7 +18391,7 @@ $ps_cols = $#temp; if ($ps_cols < 10){ my $version = qx(ps --version 2>&1); - $b_bb_ps = 1 if $version =~/busybox/i; + $b_bb_ps = 1 if $version =~ /busybox/i; } return if !@ps_aux; # note: mips/openwrt ps has no 'a' $_=lc for @ps_aux; # this is a super fast way to set to lower @@ -18363,6 +18436,9 @@ deepin-metacity metacity metisse mir muffin deepin-mutter mutter xfwm4 xfwm5); @match = (@match,@temp); + # startx: /bin/sh /usr/bin/startx + @temp=qw(ly .*startx xinit); # possible dm values + @match = (@match,@temp); } # info: NOTE: glx-dock is cairo-dock if ($show{'system'} && $extra > 2){ diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' old/inxi-3.0.26-1/inxi.1 new/inxi-3.0.27-1/inxi.1 --- old/inxi-3.0.26-1/inxi.1 2018-09-29 03:38:30.000000000 +0200 +++ new/inxi-3.0.27-1/inxi.1 2018-10-15 04:13:25.000000000 +0200 @@ -1,4 +1,4 @@ -.TH INXI 1 "2018\-09\-28" inxi "inxi manual" +.TH INXI 1 "2018\-10\-14" inxi "inxi manual" .SH NAME inxi \- Command line system information script for console and IRC .SH SYNOPSIS @@ -203,6 +203,9 @@ shell, not IRC), inxi version. See \fB\-x\fR and \fB\-xx\fR for extra information (init type/version, runlevel). +Note: if \fB\-m\fR is used or triggered, the memory item will show in the main +Memory: report of \fB\-m\fR, not in \fB\Info:\fR. + Rasberry Pi only: uses \fBvcgencmd get_mem gpu\fR to get gpu RAM amount, if user is in video group and \fBvcgencmd\fR is installed. Uses this result to increase the \fBMemory:\fR amount and \fBused:\fR amounts. @@ -219,13 +222,13 @@ information. Devices shows locator data (highly variable in syntax), size, speed, type (eg: \fBtype: DDR3\fR). -Note that \fB\-m\fR uses \fBdmidecode\fR, which must be run as root (or start +Note: \fB\-m\fR uses \fBdmidecode\fR, which must be run as root (or start \fBinxi\fR with \fBsudo\fR), unless you figure out how to set up sudo to permit -dmidecode to read \fB/dev/mem\fR as user. Note that speed will not show if \fBNo Module -Installed\fR is found in \fBsize\fR. This will also turn off Bus Width data output if it is null. +dmidecode to read \fB/dev/mem\fR as user. \fBspeed\fR and \fBbus width\fR will not +show if \fBNo Module Installed\fR is found in \fBsize\fR. -If memory information was found, and if the \fB\-I\fR line or the \fB\-tm\fR item have -not been triggered, will also print the RAM used/total. +Note: If \fB\-m\fR is triggered RAM total/used report will appear in this section, +not in \fB\-I\fR or \fB\-tm\fR items. Because \fBdmidecode\fR data is extremely unreliable, inxi will try to make best guesses. If you see \fB(check)\fR after the capacity number, you should check it with the @@ -506,6 +509,9 @@ extra data level. .TP .B \-x \-A\fR +\- Adds (if available and/or relevant) \fBvendor:\fR item, which shows +specific vendor [product] information. + \- Adds version/port(s)/driver version (if available) for each Audio device. @@ -539,6 +545,9 @@ .B <username> ALL = NOPASSWD: /usr/sbin/hddtemp (sample) .TP .B \-x \-G\fR +\- Adds (if available and/or relevant) \fBvendor:\fR item, which shows +specific vendor [product] information. + \- Adds direct rendering status. \- Adds (for single GPU, nvidia driver) screen number that GPU is running on. @@ -589,6 +598,9 @@ \- Adds device type in the Device line. .TP .B \-x \-N\fR +\- Adds (if available and/or relevant) \fBvendor:\fR item, which shows +specific vendor [product] information. + \- Adds version/port(s)/driver version (if available) for each Network card; \- Adds PCI Bus ID/USB ID number of each Network card. @@ -736,9 +748,6 @@ \- Adds wind chill, heat index, and dew point if any of these are available. .TP .B \-xxx \-A\fR -\- Adds (if available and/or relevant) \fBvendor:\fR item, which shows -specific vendor [product] information. - \- Adds, if present, serial number. .TP .B \-xxx \-B\fR @@ -766,9 +775,6 @@ no data will show. .TP .B \-xxx \-G\fR -\- Adds (if available and/or relevant) \fBvendor:\fR item, which shows -specific vendor [product] information. - \- Adds (if available) \fBcompositor:\fR version \fBv:\fR. .TP .B \-xxx \-I\fR @@ -791,9 +797,6 @@ \- Adds device serial number. .TP .B \-xxx \-N\fR -\- Adds (if available and/or relevant) \fBvendor:\fR item, which shows -specific vendor [product] information. - \- Adds, if present, serial number. .TP .B \-xxx \-R\fR @@ -1083,6 +1086,14 @@ Use this to locate file that /proc debugger hangs on. .TP +.B \-\-debug\-no\-exit\fR +Skip exit on error when running debugger. + +.TP +.B \-\-debug\-no\-proc\fR +Skip /proc debugging in case of a hang. + +.TP .B \-\-debug\-no\-sys\fR Skip /sys debugging in case of a hang. @@ -1257,7 +1268,8 @@ .SH HOMEPAGE .I https://github.com/smxi/inxi -.I https://smxi.org/ + +.I https://smxi.org/docs/inxi.htm .SH AUTHOR AND CONTRIBUTORS TO CODE diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' old/inxi-3.0.26-1/inxi.changelog new/inxi-3.0.27-1/inxi.changelog --- old/inxi-3.0.26-1/inxi.changelog 2018-09-29 03:38:30.000000000 +0200 +++ new/inxi-3.0.27-1/inxi.changelog 2018-10-15 04:13:25.000000000 +0200 @@ -1,4 +1,121 @@ ===================================================================================== +Version: 3.0.27 +Patch Version: 00 +Script Date: 2018-10-14 +----------------------------------- +Changes: +----------------------------------- + +New version, new man. Fixes, stitches, and returns!! + +Bugs: +1. As a fix (3), failure to handle spaces in mount source names. More of a fix than +a bug, since it was an old issue #63. +2. OSX errors, BSD errors, but not really inxi errors or bugs, more weird data +tripping null data or unreadable file errors, but I'll call those bugs since they +look like bugs to end users. See Fixes for more. +3. See Fix 4, this is sort of a bug, inxi failed to return expected values on +success/failure. + +Fixes: +1. One of the documented config items, COLS_MAX_NO_DISPLAY had not been implemented +internally. This is now corrected. +2. Apple OSX was returning errors, those were fixed. +3. Finally handled ancient issue #63, support now there for spaces in remote source +name. This means that both spaces in source block name, and mount point name, are +in theory both handled now. This was also to fix an osx issue #164 despite the +fact that technically I do not support osx beyond fixing errors, but since in this +case the issue was a long standing one, I fixed it for everything. +4. Big fix, I'd completely left undone proper unix type error number returns in +inxi, oops. Thanks Unit193 for noticing that and prompting me to fix it. Now inxi +returns integer success/error numbers as expected. +5. OSX xml based version info broke, of course, naturally it would, so I added in +an osx fallback where if no distro version detected, use fallback unix method, which +is what all the other unices use. +6. Along with space in source name, fixed mapped handling a bit more too for +partitions. +6. Added cifs remote file system to disk size used blacklist, and iso9660. Not sure +how I'd missed those for so long. +7. OpenBSD vmstat in 6.3 changed the column order for avm/fre, and changed to a, +sigh, human readable default format, in M, so to handle this for all bsds, I had +to make a dynamic column detection for avm and fre, and use those after, and also +i had to add in a M detection, if found, *1024 and strip out M, sigh. +8. OpenBSD, another alternate ordering/syntax issue, the dmesg.boot data for disks +does not always use the same order in comma separated list, saw user case where +the first item after : was the MB size, not the second. Made detection dynamic. +9. Due to Android case, found types where no cpu speed data was found, no max speed +at least, which tripped an error due to null data for ARM, this is now handled, +now cpu speed min/max read permissions in /sys are checked first before trying to +read, and default failures are better handled. +10. On man page, added in clarification of the moving of Memory: item from Info: +line to ram Memory: line, explaining when it appears where. I do not removing the +item from -I, I may revert that change, I find it non-intuitive to move that +around. + +Enhancements: +1. Added display manager Ly, plus Ly version number. Thanks NamedKitten, this +closes issues #166 #165 #162 +2. Improved documentation a bit to avoid ambiguity re how to get colors in output. +That handles issue #161, thanks fugo for the nudge to improve the documentation. +3. First inxi on Android tests, using termux, which has a debian based apt +type installer, got inxi running on at least two devices, including pixel2, but +discovered that apparently as of android 5, /sys is now locked up in terms of +wildcard reads, but further analysis is required, but as of now, inxi works in +termux, but fails to get any Device data for A, G, or N. Thus it also fails to match +IF to Device, so none of the IP data shows up. The latter will probably be fixed +since Android has ip and ifconfig already, or termux does, but so far I found no +way to get device data for ARM in Android 5.x and greater (checked on +android 7 and 9 in real phones). +4. More disk vendors!! thanks linuxlite / linux hardware database for offering an +apparently never ending list of obscure and not so obscure disk vendors and +products. +5. While I was unable to get confirmation or documentation on file names for +tce repo files, I guessed that localmirrors would be used, but this may be +any random text file in /opt at all, no extensions, I'd have to test to confirm +or deny possible values. +6. To handle more complex debugger failures, added --debug-no-proc, +--debug-no-exit, to skip or enable completion where proc or sys debugger is hanging. + +Changes: +1. Changed vendor in A, G, and N to -x, not -xxx, this data seems much more useful +and reliable than I'd first expected when I made the feature, the -xxx was more +an indication of my lack of trust in the method and source, but so far it seems +pretty good, so I bumped it up to an -x option. Note that also, it's quite useful +to know the vendor of, say, your network or graphics card, not just the actual +device internal data, which is all inxi has ever shown previously. +2. Small change, if no partition type data is found, dev, remote, mapped, default +now says 'source:' instead of 'dev:' which makes more sense. Note that df calls +that column 'source', so I decided to go with their language for the default not +found case. Also changed mapped to say mapped. This was part of a bit of a +refactor of the partition type logic, enhanced by adding mapped to existing types, +and moved the entire type detection block into the main data generator, and out +of the data line constructor. + +Optimizations: +1. Tested, and dumped, List::Util first() as a possible way to speed up grep +searches of arrays, where the goal is just to see if something is in an array. My +expectation was that first(), returning the first found instance of the search term, +would of course be faster since it will always exit the search loop was met with +the sad fact that first() is about 2 to 4 times SLOWER than grep() native builtin. +I tested this fairly carefully, and used NYTProf optimizer tool and the results were +totally consistent, first() was always much slower than grep(), no matter what size +the array is. I assume this means the core C programming that makes grep is simply +much better than the File::Util module programming that makes first(). Removed +first() and now know that nothing will be faster than grep so no need to look there +for speed improvements. +The moral of the story: just because something should in theory be faster, does +sadly not mean it will be faster, for there are bigger things at work, skill of +the programmers who made the logic, how perl handles external vs internal tools, +and so on. As an aside, this forms a fairly consistent pattern where I've found +Perl by itself to be faster than modules in many cases, that is, it's faster to +write the code out than to use a module in many cases that I have tested, so I +will always test such ideas and dump every one that is in fact slower than native +Perl builtins. + +----------------------------------- +-- Harald Hope - Sun, 14 Oct 2018 15:24:34 -0700 + +===================================================================================== Version: 3.0.26 Patch Version: 00 Script Date: 2018-09-28
participants (1)
-
root