include/utilities/memory.h
author Dmitriy Morozov <dmitriy@mrzv.org>
Tue, 20 Oct 2009 22:05:23 -0700
branchdev
changeset 169 c0bf4675697c
parent 110 430d9e71e921
child 174 3f1034dca432
permissions -rw-r--r--
Fixed a typo in documentation + added a warning and a tip about GCC 4.2 on a Mac

#ifndef __MEMORY_H__
#define __MEMORY_H__

#if LOGGING     // TODO: add check for Linux (and preferably the right version of Linux)

#include "log.h"
#include <fstream>
#include <sstream>
#include <string>
#include <unistd.h>

static rlog::RLogChannel* rlMemory =                   DEF_CHANNEL("memory",    rlog::Log_Debug);

void    report_memory()
{
    pid_t pid = getpid();
    std::stringstream smaps_name;
    smaps_name << "/proc/" << pid << "/smaps";
    std::ifstream in(smaps_name.str().c_str());

    std::string str;
    unsigned memory = 0, value;
    while (in)
    {
        in >> str;
        if (std::string(str, 0, 7) == "Private")
        {
            in >> value;
            memory += value;
        }
    }
    rLog(rlMemory, "Private memory usage: %d kB", memory);
}

#else

void report_memory() {}

#endif // LOGGING

#endif // __MEMORY_H__