2012-11-25 12:19:50 -05:00
|
|
|
/*
|
|
|
|
* Copyright 2012 Matthew McCormick
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
* */
|
2010-02-24 19:49:10 -05:00
|
|
|
|
2013-02-21 00:08:14 -05:00
|
|
|
#include <cstring>
|
2009-09-09 02:28:04 -04:00
|
|
|
#include <fstream>
|
|
|
|
#include <iostream>
|
|
|
|
#include <sstream>
|
|
|
|
#include <string>
|
|
|
|
#include <unistd.h> // sleep
|
2013-06-09 20:49:21 -04:00
|
|
|
#include <cmath> // for floorf
|
2013-06-09 21:01:32 -04:00
|
|
|
#include <cstdlib> // EXIT_SUCCESS
|
2009-09-09 02:28:04 -04:00
|
|
|
|
2013-04-15 15:15:31 -04:00
|
|
|
// Apple specific.
|
|
|
|
#if defined(__APPLE__) && defined(__MACH__)
|
|
|
|
// Mach kernel includes for getting memory and CPU statistics
|
|
|
|
# include <mach/vm_statistics.h>
|
|
|
|
# include <mach/processor_info.h>
|
|
|
|
# include <mach/mach_types.h>
|
|
|
|
# include <mach/mach_init.h>
|
|
|
|
# include <mach/mach_host.h>
|
|
|
|
# include <mach/host_info.h>
|
|
|
|
# include <mach/mach_error.h>
|
|
|
|
# include <mach/vm_map.h>
|
|
|
|
# include <mach/mach.h>
|
|
|
|
# include <sys/sysctl.h> // for sysctl
|
|
|
|
# include <sys/types.h> // for integer types
|
|
|
|
#endif
|
2009-09-09 02:28:04 -04:00
|
|
|
|
2013-04-15 15:15:31 -04:00
|
|
|
// if we are on a BSD system
|
|
|
|
#if defined(__FreeBSD__) || defined(__OpenBSD__) || defined(__NetBSD__)
|
|
|
|
// TODO: Includes and *BSD support
|
|
|
|
# define BSD_BASED 1
|
|
|
|
#endif
|
2013-04-15 14:35:38 -04:00
|
|
|
|
2013-06-09 20:49:21 -04:00
|
|
|
// Tmux color lookup tables for the different metrics.
|
2013-04-30 06:38:39 -04:00
|
|
|
#include "luts.h"
|
|
|
|
|
2013-06-09 20:49:21 -04:00
|
|
|
// Function declarations.
|
2013-04-15 15:15:31 -04:00
|
|
|
float cpu_percentage( unsigned int cpu_usage_delay );
|
2013-06-09 20:49:21 -04:00
|
|
|
std::string cpu_string( unsigned int cpu_usage_delay,
|
|
|
|
unsigned int graph_lines,
|
|
|
|
bool use_colors = false );
|
|
|
|
std::string mem_string( bool use_colors = false );
|
|
|
|
std::string load_string( bool use_colors = false );
|
2009-09-09 02:28:04 -04:00
|
|
|
|
2010-02-24 19:49:10 -05:00
|
|
|
|
2013-04-15 15:15:31 -04:00
|
|
|
#if defined(BSD_BASED) || (defined(__APPLE__) && defined(__MACH__))
|
|
|
|
// OSX or BSD based system, use BSD APIs instead
|
|
|
|
|
|
|
|
// See: http://www.opensource.apple.com/source/xnu/xnu-201/osfmk/mach/host_info.h
|
|
|
|
// and: http://web.mit.edu/darwin/src/modules/xnu/osfmk/man/
|
|
|
|
host_cpu_load_info_data_t _get_cpu_percentage()
|
|
|
|
{
|
2013-06-09 20:49:21 -04:00
|
|
|
kern_return_t error;
|
|
|
|
mach_msg_type_number_t count;
|
|
|
|
host_cpu_load_info_data_t r_load;
|
|
|
|
mach_port_t mach_port;
|
|
|
|
|
|
|
|
count = HOST_CPU_LOAD_INFO_COUNT;
|
|
|
|
mach_port = mach_host_self();
|
|
|
|
error = host_statistics(mach_port, HOST_CPU_LOAD_INFO, (host_info_t)&r_load, &count);
|
|
|
|
if (error != KERN_SUCCESS)
|
|
|
|
{
|
|
|
|
return host_cpu_load_info_data_t();
|
|
|
|
}
|
|
|
|
|
|
|
|
return r_load;
|
2013-04-15 15:15:31 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
float cpu_percentage( unsigned int cpu_usage_delay )
|
|
|
|
{
|
2013-06-09 20:49:21 -04:00
|
|
|
// Get the load times from the XNU kernel
|
|
|
|
host_cpu_load_info_data_t load1 = _get_cpu_percentage();
|
|
|
|
usleep(cpu_usage_delay);
|
|
|
|
host_cpu_load_info_data_t load2 = _get_cpu_percentage();
|
|
|
|
|
|
|
|
// Current load times
|
|
|
|
unsigned long long current_user = load1.cpu_ticks[CPU_STATE_USER];
|
|
|
|
unsigned long long current_system = load1.cpu_ticks[CPU_STATE_SYSTEM];
|
|
|
|
unsigned long long current_nice = load1.cpu_ticks[CPU_STATE_NICE];
|
|
|
|
unsigned long long current_idle = load1.cpu_ticks[CPU_STATE_IDLE];
|
|
|
|
// Next load times
|
|
|
|
unsigned long long next_user = load2.cpu_ticks[CPU_STATE_USER];
|
|
|
|
unsigned long long next_system = load2.cpu_ticks[CPU_STATE_SYSTEM];
|
|
|
|
unsigned long long next_nice = load2.cpu_ticks[CPU_STATE_NICE];
|
|
|
|
unsigned long long next_idle = load2.cpu_ticks[CPU_STATE_IDLE];
|
|
|
|
// Difference between the two
|
|
|
|
unsigned long long diff_user = next_user - current_user;
|
|
|
|
unsigned long long diff_system = next_system - current_system;
|
|
|
|
unsigned long long diff_nice = next_nice - current_nice;
|
|
|
|
unsigned long long diff_idle = next_idle - current_idle;
|
|
|
|
|
|
|
|
#else // Linux
|
2010-02-25 09:54:18 -05:00
|
|
|
float cpu_percentage( unsigned int cpu_usage_delay )
|
2009-09-09 02:28:04 -04:00
|
|
|
{
|
2013-04-24 22:13:50 -04:00
|
|
|
std::string stat_line;
|
2010-02-24 19:49:10 -05:00
|
|
|
size_t line_start_pos;
|
|
|
|
size_t line_end_pos;
|
|
|
|
unsigned long long current_user;
|
|
|
|
unsigned long long current_system;
|
|
|
|
unsigned long long current_nice;
|
|
|
|
unsigned long long current_idle;
|
|
|
|
unsigned long long next_user;
|
|
|
|
unsigned long long next_system;
|
|
|
|
unsigned long long next_nice;
|
|
|
|
unsigned long long next_idle;
|
|
|
|
unsigned long long diff_user;
|
|
|
|
unsigned long long diff_system;
|
|
|
|
unsigned long long diff_nice;
|
|
|
|
unsigned long long diff_idle;
|
2013-04-24 22:13:50 -04:00
|
|
|
std::istringstream iss;
|
2010-02-24 19:49:10 -05:00
|
|
|
|
2013-04-24 22:13:50 -04:00
|
|
|
std::ifstream stat_file("/proc/stat");
|
2010-02-24 19:49:10 -05:00
|
|
|
getline(stat_file, stat_line);
|
|
|
|
stat_file.close();
|
2009-09-09 02:28:04 -04:00
|
|
|
|
2010-02-24 19:49:10 -05:00
|
|
|
// skip "cpu"
|
|
|
|
line_start_pos = stat_line.find_first_not_of(" ", 3);
|
|
|
|
line_end_pos = stat_line.find_first_of(' ', line_start_pos);
|
|
|
|
line_end_pos = stat_line.find_first_of(' ', line_end_pos + 1);
|
|
|
|
line_end_pos = stat_line.find_first_of(' ', line_end_pos + 1);
|
|
|
|
line_end_pos = stat_line.find_first_of(' ', line_end_pos + 1);
|
2009-09-09 02:28:04 -04:00
|
|
|
|
2010-02-24 19:49:10 -05:00
|
|
|
iss.str( stat_line.substr( line_start_pos, line_end_pos - line_start_pos ) );
|
|
|
|
iss >> current_user >> current_nice >> current_system >> current_idle;
|
|
|
|
iss.clear();
|
|
|
|
|
2010-02-25 09:54:18 -05:00
|
|
|
usleep( cpu_usage_delay );
|
2010-02-24 19:49:10 -05:00
|
|
|
|
|
|
|
stat_file.open("/proc/stat");
|
|
|
|
getline(stat_file, stat_line);
|
|
|
|
stat_file.close();
|
2009-09-09 02:28:04 -04:00
|
|
|
|
|
|
|
// skip "cpu"
|
2010-02-24 19:49:10 -05:00
|
|
|
line_start_pos = stat_line.find_first_not_of(" ", 3);
|
|
|
|
line_end_pos = stat_line.find_first_of(' ', line_start_pos);
|
|
|
|
line_end_pos = stat_line.find_first_of(' ', line_end_pos + 1);
|
|
|
|
line_end_pos = stat_line.find_first_of(' ', line_end_pos + 1);
|
|
|
|
line_end_pos = stat_line.find_first_of(' ', line_end_pos + 1);
|
|
|
|
|
|
|
|
iss.str( stat_line.substr( line_start_pos, line_end_pos - line_start_pos ) );
|
|
|
|
iss >> next_user >> next_nice >> next_system >> next_idle;
|
|
|
|
iss.clear();
|
|
|
|
|
|
|
|
diff_user = next_user - current_user;
|
|
|
|
diff_system = next_system - current_system;
|
|
|
|
diff_nice = next_nice - current_nice;
|
|
|
|
diff_idle = next_idle - current_idle;
|
2013-06-09 20:49:21 -04:00
|
|
|
#endif // platform
|
2010-02-24 19:49:10 -05:00
|
|
|
|
|
|
|
return static_cast<float>(diff_user + diff_system + diff_nice)/static_cast<float>(diff_user + diff_system + diff_nice + diff_idle)*100.0;
|
2009-09-09 02:28:04 -04:00
|
|
|
}
|
|
|
|
|
2013-04-30 06:38:39 -04:00
|
|
|
std::string cpu_string( unsigned int cpu_usage_delay,
|
|
|
|
unsigned int graph_lines,
|
2013-06-09 20:49:21 -04:00
|
|
|
bool use_colors )
|
2009-09-09 02:28:04 -04:00
|
|
|
{
|
2013-04-24 22:13:50 -04:00
|
|
|
std::string meter( graph_lines + 2, ' ' );
|
2010-08-01 11:17:42 -04:00
|
|
|
meter[0] = '[';
|
|
|
|
meter[meter.length() - 1] = ']';
|
2009-09-09 02:28:04 -04:00
|
|
|
int meter_count = 0;
|
2010-02-24 19:49:10 -05:00
|
|
|
float percentage;
|
2013-04-24 22:13:50 -04:00
|
|
|
std::ostringstream oss;
|
2010-02-24 19:49:10 -05:00
|
|
|
oss.precision( 1 );
|
2013-04-24 22:13:50 -04:00
|
|
|
oss.setf( std::ios::fixed | std::ios::right );
|
2010-02-24 19:49:10 -05:00
|
|
|
|
2010-02-25 09:54:18 -05:00
|
|
|
percentage = cpu_percentage( cpu_usage_delay );
|
2010-08-01 11:17:42 -04:00
|
|
|
float meter_step = 99.9 / graph_lines;
|
2010-02-24 19:49:10 -05:00
|
|
|
meter_count = 1;
|
2013-06-09 20:49:21 -04:00
|
|
|
while(meter_count*meter_step < percentage)
|
2009-09-09 02:28:04 -04:00
|
|
|
{
|
2010-02-24 19:49:10 -05:00
|
|
|
meter[meter_count] = '|';
|
|
|
|
meter_count++;
|
2009-09-09 02:28:04 -04:00
|
|
|
}
|
2010-02-24 19:49:10 -05:00
|
|
|
|
2013-04-30 06:38:39 -04:00
|
|
|
if( use_colors )
|
|
|
|
{
|
|
|
|
oss << cpu_percentage_lut[static_cast<unsigned int>( percentage )];
|
|
|
|
}
|
2010-02-24 19:49:10 -05:00
|
|
|
oss << meter;
|
|
|
|
oss.width( 5 );
|
|
|
|
oss << percentage;
|
|
|
|
oss << "%";
|
2013-04-30 06:38:39 -04:00
|
|
|
if( use_colors )
|
|
|
|
{
|
|
|
|
oss << "#[fg=default,bg=default]";
|
|
|
|
}
|
2010-02-24 19:49:10 -05:00
|
|
|
|
|
|
|
return oss.str();
|
|
|
|
}
|
|
|
|
|
2013-04-15 15:15:31 -04:00
|
|
|
|
2013-06-09 20:49:21 -04:00
|
|
|
std::string mem_string( bool use_colors )
|
2010-02-24 20:02:55 -05:00
|
|
|
{
|
2013-06-09 20:49:21 -04:00
|
|
|
std::ostringstream oss;
|
|
|
|
#if defined(BSD_BASED) || (defined(__APPLE__) && defined(__MACH__))
|
|
|
|
// OSX or BSD based system, use BSD APIs instead
|
2013-04-15 15:15:31 -04:00
|
|
|
|
2013-06-09 20:49:21 -04:00
|
|
|
#if defined(__APPLE__) && defined(__MACH__)
|
|
|
|
// These values are in bytes
|
|
|
|
int64_t total_mem;
|
|
|
|
int64_t used_mem;
|
|
|
|
int64_t unused_mem;
|
|
|
|
vm_size_t page_size;
|
|
|
|
mach_port_t mach_port;
|
|
|
|
mach_msg_type_number_t count;
|
|
|
|
vm_statistics_data_t vm_stats;
|
|
|
|
|
|
|
|
// Get total physical memory
|
|
|
|
int mib[2];
|
|
|
|
mib[0] = CTL_HW;
|
|
|
|
mib[1] = HW_MEMSIZE;
|
|
|
|
size_t length = sizeof(int64_t);
|
|
|
|
sysctl(mib, 2, &total_mem, &length, NULL, 0);
|
|
|
|
|
|
|
|
mach_port = mach_host_self();
|
|
|
|
count = sizeof(vm_stats) / sizeof(natural_t);
|
|
|
|
if (KERN_SUCCESS == host_page_size(mach_port, &page_size) &&
|
|
|
|
KERN_SUCCESS == host_statistics(mach_port, HOST_VM_INFO, (host_info_t)&vm_stats, &count))
|
|
|
|
{
|
|
|
|
unused_mem = (int64_t)vm_stats.free_count * (int64_t)page_size;
|
|
|
|
|
|
|
|
used_mem = ((int64_t)vm_stats.active_count +
|
|
|
|
(int64_t)vm_stats.inactive_count +
|
|
|
|
(int64_t)vm_stats.wire_count) * (int64_t)page_size;
|
|
|
|
}
|
|
|
|
|
|
|
|
// To kilobytes
|
|
|
|
#endif // Apple
|
|
|
|
// TODO BSD
|
|
|
|
|
|
|
|
used_mem /= 1024;
|
|
|
|
total_mem /= 1024;
|
|
|
|
|
|
|
|
#else // Linux
|
2010-02-25 00:37:21 -05:00
|
|
|
unsigned int total_mem;
|
|
|
|
unsigned int used_mem;
|
|
|
|
unsigned int unused_mem;
|
2010-02-24 20:02:55 -05:00
|
|
|
size_t line_start_pos;
|
|
|
|
size_t line_end_pos;
|
2013-04-24 22:13:50 -04:00
|
|
|
std::istringstream iss;
|
|
|
|
std::string mem_line;
|
2010-02-24 20:02:55 -05:00
|
|
|
|
2013-04-24 22:13:50 -04:00
|
|
|
std::ifstream meminfo_file( "/proc/meminfo" );
|
2010-02-24 20:02:55 -05:00
|
|
|
getline( meminfo_file, mem_line );
|
|
|
|
line_start_pos = mem_line.find_first_of( ':' );
|
|
|
|
line_start_pos++;
|
|
|
|
line_end_pos = mem_line.find_first_of( 'k' );
|
|
|
|
iss.str( mem_line.substr( line_start_pos, line_end_pos - line_start_pos ) );
|
|
|
|
iss >> total_mem;
|
|
|
|
|
2010-02-25 00:37:21 -05:00
|
|
|
used_mem = total_mem;
|
2010-02-24 20:02:55 -05:00
|
|
|
|
2010-02-25 00:37:21 -05:00
|
|
|
for( unsigned int i = 0; i < 3; i++ )
|
|
|
|
{
|
|
|
|
getline( meminfo_file, mem_line );
|
|
|
|
line_start_pos = mem_line.find_first_of( ':' );
|
|
|
|
line_start_pos++;
|
|
|
|
line_end_pos = mem_line.find_first_of( 'k' );
|
|
|
|
iss.str( mem_line.substr( line_start_pos, line_end_pos - line_start_pos ) );
|
|
|
|
iss >> unused_mem;
|
|
|
|
used_mem -= unused_mem;
|
|
|
|
}
|
2010-02-24 20:02:55 -05:00
|
|
|
meminfo_file.close();
|
|
|
|
|
2013-06-09 20:49:21 -04:00
|
|
|
#endif // platform
|
|
|
|
|
2013-04-30 06:38:39 -04:00
|
|
|
if( use_colors )
|
|
|
|
{
|
|
|
|
oss << mem_lut[(100 * used_mem) / total_mem];
|
|
|
|
}
|
2010-02-25 01:03:02 -05:00
|
|
|
oss << used_mem / 1024 << '/' << total_mem / 1024 << "MB";
|
2013-04-30 06:38:39 -04:00
|
|
|
if( use_colors )
|
|
|
|
{
|
|
|
|
oss << "#[fg=default,bg=default]";
|
|
|
|
}
|
2010-02-25 00:37:21 -05:00
|
|
|
|
2010-02-24 20:02:55 -05:00
|
|
|
return oss.str();
|
|
|
|
}
|
|
|
|
|
2013-04-15 15:15:31 -04:00
|
|
|
|
2013-06-09 20:49:21 -04:00
|
|
|
std::string load_string( bool use_colors )
|
2010-02-25 00:49:36 -05:00
|
|
|
{
|
2013-06-09 20:49:21 -04:00
|
|
|
std::ostringstream oss;
|
2010-02-25 00:49:36 -05:00
|
|
|
|
2013-06-09 20:49:21 -04:00
|
|
|
#if defined(BSD_BASED) || (defined(__APPLE__) && defined(__MACH__))
|
|
|
|
// Both apple and BSD style systems have these api calls
|
|
|
|
|
|
|
|
// Only get 3 load averages
|
|
|
|
int nelem = 3;
|
|
|
|
double averages[3];
|
|
|
|
// based on: http://www.opensource.apple.com/source/Libc/Libc-262/gen/getloadavg.c
|
|
|
|
if( getloadavg(averages, nelem) < 0 )
|
|
|
|
{
|
|
|
|
oss << "0.00 0.00 0.00"; // couldn't get averages.
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
for(int i = 0; i < nelem; ++i)
|
|
|
|
{
|
|
|
|
// Round to nearest, make sure this is only a 0.00 value not a 0.0000
|
|
|
|
float avg = floorf(static_cast<float>(averages[i]) * 100 + 0.5) / 100;
|
|
|
|
oss << avg << " ";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#else // Linux
|
2013-04-24 22:13:50 -04:00
|
|
|
std::ifstream loadavg_file( "/proc/loadavg" );
|
|
|
|
std::string load_line;
|
|
|
|
std::getline( loadavg_file, load_line );
|
2010-02-25 00:49:36 -05:00
|
|
|
loadavg_file.close();
|
2013-06-09 20:49:21 -04:00
|
|
|
|
|
|
|
#endif // platform
|
|
|
|
|
2013-04-30 06:38:39 -04:00
|
|
|
if( use_colors )
|
|
|
|
{
|
|
|
|
std::ifstream stat_file( "/proc/stat" );
|
|
|
|
std::string stat_line;
|
|
|
|
std::getline( stat_file, stat_line );
|
2013-06-09 20:49:21 -04:00
|
|
|
// Likely does not work on BSD, but not tested
|
|
|
|
unsigned int number_of_cpus = sysconf( _SC_NPROCESSORS_ONLN );
|
2013-04-30 06:38:39 -04:00
|
|
|
|
|
|
|
std::istringstream iss( load_line.substr( 0, 4 ) );
|
|
|
|
float recent_load;
|
|
|
|
iss >> recent_load;
|
|
|
|
// colors range from zero to twice the number of cpu's for the most recent
|
|
|
|
// load metric
|
|
|
|
unsigned int load_percent = static_cast< unsigned int >( recent_load / number_of_cpus * 0.5f * 100.0f );
|
|
|
|
if( load_percent > 100 )
|
|
|
|
{
|
|
|
|
load_percent = 100;
|
|
|
|
}
|
|
|
|
oss << load_lut[load_percent];
|
2013-06-09 20:49:21 -04:00
|
|
|
}
|
2013-04-30 06:38:39 -04:00
|
|
|
|
2013-06-09 20:49:21 -04:00
|
|
|
oss << load_line.substr( 0, 14 );
|
|
|
|
if( use_colors )
|
|
|
|
{
|
|
|
|
oss << "#[fg=default,bg=default]";
|
2013-04-30 06:38:39 -04:00
|
|
|
}
|
2010-02-25 00:49:36 -05:00
|
|
|
|
2013-06-09 20:49:21 -04:00
|
|
|
return oss.str();
|
2010-02-25 00:49:36 -05:00
|
|
|
}
|
|
|
|
|
2013-04-15 15:15:31 -04:00
|
|
|
|
2010-02-24 19:49:10 -05:00
|
|
|
int main(int argc, char** argv)
|
|
|
|
{
|
2010-02-25 09:54:18 -05:00
|
|
|
unsigned int cpu_usage_delay = 900000;
|
2013-06-09 20:58:47 -04:00
|
|
|
int graph_lines = 10;
|
2013-02-21 00:08:14 -05:00
|
|
|
bool use_colors = false;
|
2010-08-01 11:17:42 -04:00
|
|
|
try
|
2010-02-25 09:54:18 -05:00
|
|
|
{
|
2013-04-24 22:13:50 -04:00
|
|
|
std::istringstream iss;
|
|
|
|
iss.exceptions ( std::ifstream::failbit | std::ifstream::badbit );
|
2013-02-21 00:08:14 -05:00
|
|
|
std::string current_arg;
|
|
|
|
unsigned int arg_index = 1;
|
|
|
|
if( argc > arg_index )
|
2013-02-20 23:15:20 -05:00
|
|
|
{
|
2013-02-21 00:08:14 -05:00
|
|
|
if( strcmp( argv[arg_index], "--colors" ) == 0 )
|
|
|
|
{
|
|
|
|
use_colors = true;
|
|
|
|
++arg_index;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if( argc > arg_index )
|
|
|
|
{
|
|
|
|
iss.str( argv[arg_index] );
|
2010-02-25 09:54:18 -05:00
|
|
|
unsigned int status_interval;
|
|
|
|
iss >> status_interval;
|
|
|
|
cpu_usage_delay = status_interval * 1000000 - 100000;
|
2013-02-21 00:08:14 -05:00
|
|
|
++arg_index;
|
2013-02-20 23:15:20 -05:00
|
|
|
}
|
2013-02-21 00:08:14 -05:00
|
|
|
if( argc > arg_index )
|
2013-02-20 23:15:20 -05:00
|
|
|
{
|
2013-02-21 00:08:14 -05:00
|
|
|
iss.str( argv[arg_index] );
|
2013-02-20 23:15:20 -05:00
|
|
|
iss.clear();
|
|
|
|
iss >> graph_lines;
|
2013-06-09 20:58:47 -04:00
|
|
|
if( graph_lines < 1 )
|
|
|
|
{
|
|
|
|
std::cerr << "graph lines argument must be one or greater." << std::endl;
|
2013-06-09 21:01:32 -04:00
|
|
|
return EXIT_FAILURE;
|
2013-06-09 20:58:47 -04:00
|
|
|
}
|
2013-02-20 23:15:20 -05:00
|
|
|
}
|
2010-02-25 09:54:18 -05:00
|
|
|
}
|
2013-04-24 22:13:50 -04:00
|
|
|
catch(const std::exception &e)
|
2013-02-20 23:15:20 -05:00
|
|
|
{
|
2013-04-24 22:13:50 -04:00
|
|
|
std::cerr << "Usage: " << argv[0] << " [--colors] [tmux_status-interval(seconds)] [graph lines]" << std::endl;
|
2013-06-09 21:01:32 -04:00
|
|
|
return EXIT_FAILURE;
|
2013-02-20 23:15:20 -05:00
|
|
|
}
|
2010-08-01 11:17:42 -04:00
|
|
|
|
2013-04-30 06:38:39 -04:00
|
|
|
std::cout << mem_string( use_colors ) << ' ' << cpu_string( cpu_usage_delay, graph_lines, use_colors ) << ' ' << load_string( use_colors );
|
2010-02-25 09:54:18 -05:00
|
|
|
|
2013-06-09 21:01:32 -04:00
|
|
|
return EXIT_SUCCESS;
|
2009-09-09 02:28:04 -04:00
|
|
|
}
|
|
|
|
|