Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6844481
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 27, 20262026-05-27T00:23:02+00:00 2026-05-27T00:23:02+00:00

I am working on a project in C under a Linux environment and I’m

  • 0

I am working on a project in C under a Linux environment and I’m looking for an efficient way to add errors to a log file.
I tried to use Syslog with the following initialization:

setlogmask(LOG_UPTO(7));
openlog(name, LOG_CONS | LOG_NDELAY | LOG_PID, LOG_USER);

But it seems that it works too slow. I need it to work very fast..
Can someone help with that? Maybe the syslog is not the right approach.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-27T00:23:02+00:00Added an answer on May 27, 2026 at 12:23 am

    You can write a custom light weight logger or may 3rd party open source one…

    For example 3rd part C++ logger [ http://logging.apache.org/log4cxx/%5D

    And Here is simple [buggy] custom logger [ From book C++ Timesaving Techniques For Dummies ]

    #ifndef __SimpleLogger__
    #define __SimpleLogger__
    
    
    #include <iostream>
    #include <string>
    #include <stdlib.h>
    #include <stdarg.h>
    #include <fstream>
    using namespace std;
    
    
    class SimpleLogger
    {
    
    
    public:
        SimpleLogger( void )
        {
            bOn = false;
            bForceFlush = false;
        }
        SimpleLogger( const char *strFileName )
    
        {
            sFileName = strFileName;
            bOn = false;
            bForceFlush = false;
        }
        SimpleLogger( const SimpleLogger& aCopy )
        {
            sFileName = aCopy.sFileName;
            bForceFlush = aCopy.bForceFlush;
            setOn( aCopy.bOn );
        }
        virtual ~SimpleLogger()
        {
            Flush();
            if ( bOn )
                file.close();
        }
        void setOn( bool flag )
        {
            bOn = flag;
            if ( bOn )
            {
                file.open( sFileName.c_str() ,fstream::in | fstream::out | fstream::app);
            }
        }
        bool getOn( void )
        {
            return bOn;
        }
        void setForceFlush( bool flag )
        {
            bForceFlush = flag;
        }
        bool getForceFlush( void )
        {
            return bForceFlush;
        }
        void setFileName ( const char
            *strFileName )
        {
            sFileName = strFileName;
        }
        string getFileName ( void )
        {
            return sFileName;
        }
        void Log( const char *strMessage )
        {
            sMessage += strMessage;
            sMessage += "\n";
            if ( bForceFlush )
                Flush();
        }
        void LogString( const char *fmt, ... )
    
        {
            char szBuffer[256];
            va_list marker;
            va_start( marker, fmt );     
            vsprintf(szBuffer, fmt, marker );
            sMessage += szBuffer;
            sMessage += "\n";
            if ( bForceFlush )
                Flush();
    
        }
        void Flush( void )
        {
            if ( bOn )
                file << sMessage << endl;
            sMessage = "";
        }
    
    
    private:
        bool   bOn;
        bool   bForceFlush;
        string   sMessage;
        string   sFileName;
        ofstream  file;
    
    };
    
    
    #endif
    

    Usage :

     SimpleLogger logger("MyLog.txt");
     logger.setForceFlush( true );
     logger.setOn(true);
    
     logger.Log("I am the buggy logger");
    

    Warning: This is “toy” logger with some bugs to just give you some idea about custom logger…Do not use directly in real applications..

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

While working on my GAE project under my dev environment, whenever I upload data
I'm working on a project under which i have to take a raw file
I am now working on a data transfer project under Linux. The Project Team
While working a project tonight, I ended up using one .js resource file for
I am working on project in Linux which involves 1) Static Lib in C++
I am working on project -online file management where we have to tore file
I am working on C++ project under SVN version control. Here is my typical
I'm working on a project that uses svn, but I like the way mercurial
I'm just wondering if its possible to have a Vaadin project working under google
I am working on a project under which i am going to control lights

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.