diff options
author | Tim Smith <tsmith@chef.io> | 2017-01-20 15:00:14 -0800 |
---|---|---|
committer | Tim Smith <tsmith@chef.io> | 2017-01-20 15:00:14 -0800 |
commit | 8531650b5aa0fb46c984b160be6b008373a6fe8d (patch) | |
tree | 83893e2e545a295b12422ac1076a9785dc10c763 | |
parent | a927aa923604d03e98aa32fffdb5caee7424968c (diff) | |
download | ohai-8531650b5aa0fb46c984b160be6b008373a6fe8d.tar.gz |
Fix gcc data collection
None of the values were being populated with the refactoring. Also gcc
hadn’t been collecting anything for a while. This gives us real data
for gcc:
"c": {
"gcc": {
"configured_with":
"--prefix=/Applications/Xcode.app/Contents/Developer/usr
--with-gxx-include-dir=/usr/include/c++/4.2.1",
"description": "Apple LLVM version 8.0.0 (clang-800.0.42.1)",
"version": "8.0.0",
"target": "x86_64-apple-darwin16.3.0",
"thread_model": "posix"
}
},
-rw-r--r-- | lib/ohai/plugins/c.rb | 87 |
1 files changed, 51 insertions, 36 deletions
diff --git a/lib/ohai/plugins/c.rb b/lib/ohai/plugins/c.rb index 0d63c68c..0e100253 100644 --- a/lib/ohai/plugins/c.rb +++ b/lib/ohai/plugins/c.rb @@ -16,8 +16,6 @@ # limitations under the License. # -require "rbconfig" - Ohai.plugin(:C) do provides "languages/c" depends "languages" @@ -34,7 +32,7 @@ Ohai.plugin(:C) do end def xcode_installed? - Ohai::Log.debug("Checking for Xcode Command Line Tools.") + Ohai::Log.debug("Plugin C: Checking for Xcode Command Line Tools.") so = shell_out("/usr/bin/xcode-select -p") if so.exitstatus == 0 Ohai::Log.debug("Plugin C: Xcode Command Line Tools found.") @@ -65,57 +63,74 @@ Ohai.plugin(:C) do # Configured with: ../src/configure -v --with-pkgversion='Ubuntu 5.4.0-6ubuntu1~16.04.4' --with-bugurl=file:///usr/share/doc/gcc-5/README.Bugs --enable-languages=c,ada,c++,java,go,d,fortran,objc,obj-c++ --prefix=/usr --program-suffix=-5 --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-libmpx --enable-plugin --with-system-zlib --disable-browser-plugin --enable-java-awt=gtk --enable-gtk-cairo --with-java-home=/usr/lib/jvm/java-1.5.0-gcj-5-amd64/jre --enable-java-home --with-jvm-root-dir=/usr/lib/jvm/java-1.5.0-gcj-5-amd64 --with-jvm-jar-dir=/usr/lib/jvm-exports/java-1.5.0-gcj-5-amd64 --with-arch-directory=amd64 --with-ecj-jar=/usr/share/java/eclipse-ecj.jar --enable-objc-gc --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32,m64,mx32 --enable-multilib --with-tune=generic --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu # Thread model: posix # gcc version 5.4.0 20160609 (Ubuntu 5.4.0-6ubuntu1~16.04.4) + gcc = Mash.new + collect("gcc -v") do |so| + so.stderr.each_line do |line| + case line + when /^(.*version\s(\S*).*)/ + gcc[:description] = $1 + gcc[:version] = $2 + when /^Target:\s(.*)/ + gcc[:target] = $1 + when /^Configured with:\s(.*)/ + gcc[:configured_with] = $1 + when /^Thread model:\s(.*)/ + gcc[:thread_model] = $1 + end + end end + @c[:gcc] = gcc end def collect_glibc - #glibc + # glibc ["/lib/libc.so.6", "/lib64/libc.so.6"].each do |glibc| collect( Ohai.abs_path( glibc )) do |so| description = so.stdout.split($/).first if description =~ /(\d+\.\d+\.?\d*)/ - c[:glibc] = Mash.new - c[:glibc][:version] = $1 - c[:glibc][:description] = description + @c[:glibc] = Mash.new + @c[:glibc][:version] = $1 + @c[:glibc][:description] = description end + end end end def check_for_cl - #ms cl + # ms cl collect("cl /?") do |so| description = so.stderr.lines.first.chomp if description =~ /Compiler Version ([\d\.]+)/ - c[:cl] = Mash.new - c[:cl][:version] = $1 - c[:cl][:description] = description + @c[:cl] = Mash.new + @c[:cl][:version] = $1 + @c[:cl][:description] = description end end end def check_for_devenv - #ms vs + # ms vs collect("devenv.com /?") do |so| lines = so.stdout.split($/) description = lines[0].length == 0 ? lines[1] : lines[0] if description =~ /Visual Studio Version ([\d\.]+)/ - c[:vs] = Mash.new - c[:vs][:version] = $1.chop - c[:vs][:description] = description + @c[:vs] = Mash.new + @c[:vs][:version] = $1.chop + @c[:vs][:description] = description end end end def collect_xlc - #ibm xlc + # ibm xlc begin so = shell_out("xlc -qversion") if so.exitstatus == 0 || (so.exitstatus >> 8) == 249 description = so.stdout.split($/).first if description =~ /V(\d+\.\d+)/ - c[:xlc] = Mash.new - c[:xlc][:version] = $1 - c[:xlc][:description] = description.strip + @c[:xlc] = Mash.new + @c[:xlc][:version] = $1 + @c[:xlc][:description] = description.strip end end rescue Ohai::Exceptions::Exec @@ -123,56 +138,56 @@ Ohai.plugin(:C) do end def collect_cc - #sun pro + # sun pro collect("cc -V -flags") do |so| output = so.stderr.split if so.stderr =~ /^cc: Sun C/ && output.size >= 4 - c[:sunpro] = Mash.new - c[:sunpro][:version] = output[3] - c[:sunpro][:description] = so.stderr.chomp + @c[:sunpro] = Mash.new + @c[:sunpro][:version] = output[3] + @c[:sunpro][:description] = so.stderr.chomp end end end def collect_hpux_cc - #hpux cc + # hpux cc collect("what /opt/ansic/bin/cc") do |so| description = so.stdout.split($/).select { |line| line =~ /HP C Compiler/ }.first if description output = description.split - c[:hpcc] = Mash.new - c[:hpcc][:version] = output[1] if output.size >= 1 - c[:hpcc][:description] = description.strip + @c[:hpcc] = Mash.new + @c[:hpcc][:version] = output[1] if output.size >= 1 + @c[:hpcc][:description] = description.strip end end end collect_data(:darwin) do - c = Mash.new + @c = Mash.new collect_gcc if xcode_installed? - languages[:c] = c unless c.empty? + languages[:c] = @c unless @c.empty? end collect_data(:windows) do - c = Mash.new + @c = Mash.new check_for_cl check_for_devenv - languages[:c] = c unless c.empty? + languages[:c] = @c unless @c.empty? end collect_data(:hpux) do - c = Mash.new + @c = Mash.new collect_gcc collect_hpux_cc - languages[:c] = c unless c.empty? + languages[:c] = @c unless @c.empty? end - collect_data(:hpux) do - c = Mash.new + collect_data(:default) do + @c = Mash.new collect_gcc collect_glibc collect_xlc collect_cc - languages[:c] = c unless c.empty? + languages[:c] = @c unless @c.empty? end end |