Implement an XML-based LOG class

xiaoxiao2021-03-06  87

Many programs have a log feature, you can save some information at runtime to a file, so you can view the information at Release, you can also help debug, the following class accepts a file name as a parameter, you can make information XML file, then you can see the information of the HTML format with the XSL file AppLog.h

#include

#include

#include

Using namespace std;

Class capplog

{

PUBLIC:

CAPPLOG (Char * filename);

Bool LogMessage (char * msg, ...);

Virtual ~ CAPPLOG ();

Private:

Void Writexmlhead ();

Void WriteXMlend ();

Void BeginxmlRecord (OFStream & OS);

Void EndxmlRecord (OFSTream & OS);

String m_sfilename;

}

Implement AppLog.cpp

Capplog :: CAPPLOG (Char * filename)

{

IF (filename)

This-> m_sfilename = filename;

Else

m_sfilename = "app.xml";

Writexmlhead ();

}

Capplog :: ~ CAPPLOG ()

{

Writexmlend ();

}

Bool capplog :: LogMessage (char * msg, ...)

{

OFSTREAM OS (m_sfilename.c_str (), iOS_BASE :: App | iOS_BASE :: OUT;

IF (OS)

{

BeginxmlRecord (OS);

VA_LIST Argp;

VA_START (Argp, MSG);

Char sztmp [1024];

vSprintf (SZTMP, MSG, Argp);

VA_END (ARGP);

OS << SZTMP;

ENDXMLRECORD (OS);

Os.Close ();

Return True;

}

Return False;

}

Void Capplog :: Writexmlhead ()

{

String head = " / n"

" / n"

/ n / t Appname / n ";

OFSTREAM OS (m_sfilename.c_str (), iOS_BASE :: App | iOS_BASE :: OUT;

IF (OS)

{

OS << Head << Endl;

Os.Close ();

}

}

Void Capplog :: WriteXmlend ()

{

String end = "";

OFSTREAM OS (m_sfilename.c_str (), iOS_BASE :: App | iOS_BASE :: OUT;

IF (OS)

{

OS << End << Endl;

Os.Close ();

}

}

Void Capplog :: BeginxmlRecord (OFStream & OS) {

String msghead = "/ t / r / n";

Time_t now;

Now = Time (null);

String Stime = CTIME (& now);

INT n = stime.find ('/ n');

IF (n> 0)

{

Stime [n] = '/ 0';

}

String msgtime = "/ t / t

Msgtime = STIME;

OS << msghead << msgtime;

Msgtime = " / R / N / T / T ";

OS << msgtime;

Return;

}

Void Capplog :: EndxmlRecord (OFStream & OS)

{

String msgend = " / r / n / t / r / n";

OS << msgend;

}

When using:

CAPPLOG Applog ("C: //log.xml");

Char * s = "hello";

INT n = 100;

Applog.LogMessage ("My Log Info% D% S", N, S);

Place this log.xsl file in the same directory

<xsl: value-of select = "logfile / appname" /> õõ¾4îä1/1/1> <h1> <center> <xsl: value-of select = "Logfile / appname" /> ôëððõõõ4 îþ/1/10 </ center> </ h1></p> <p><table border = "0" cellspacing = "1" cellpadding = "0"> <tr> <td bgcolor = "# dddddd"> <table border = "1" cellpadding = "3" cellspacing = "1"></p> <p><xsl: for-each select = "loginfo / message"> <trunmouseover = "> <td bgcolor =" # ffffff "Valign =" TOP "> <xsl: Number Count =" message "/>>) > <Td bgcolor = "# ffffff" Valign = "TOP"> <nobr> <xsl: value-of select = "time" /> </ nobr> <xsl: value-of select = "time" /> </ TD> <TD BGCOLOR = "# ffffff" Valign = "TOP"> <XSL: Value-of select = "content" /> </ td> </ tr> </ xsl: for-energy> </ table> < / TD> </ tr> </ table> </ body> </ html></p> <p></ xsl: template> </ xsl: stylesheet></p></div><div class="text-center mt-3 text-grey"> 转载请注明原文地址:https://www.9cbs.com/read-106203.html</div><div class="plugin d-flex justify-content-center mt-3"></div><hr><div class="row"><div class="col-lg-12 text-muted mt-2"><i class="icon-tags mr-2"></i><span class="badge border border-secondary mr-2"><h2 class="h6 mb-0 small"><a class="text-secondary" href="tag-2.html">9cbs</a></h2></span></div></div></div></div><div class="card card-postlist border-white shadow"><div class="card-body"><div class="card-title"><div class="d-flex justify-content-between"><div><b>New Post</b>(<span class="posts">0</span>) </div><div></div></div></div><ul class="postlist list-unstyled"> </ul></div></div><div class="d-none threadlist"><input type="checkbox" name="modtid" value="106203" checked /></div></div></div></div></div><footer class="text-muted small bg-dark py-4 mt-3" id="footer"><div class="container"><div class="row"><div class="col">CopyRight © 2020 All Rights Reserved </div><div class="col text-right">Processed: <b>0.046</b>, SQL: <b>9</b></div></div></div></footer><script src="./lang/en-us/lang.js?2.2.0"></script><script src="view/js/jquery.min.js?2.2.0"></script><script src="view/js/popper.min.js?2.2.0"></script><script src="view/js/bootstrap.min.js?2.2.0"></script><script src="view/js/xiuno.js?2.2.0"></script><script src="view/js/bootstrap-plugin.js?2.2.0"></script><script src="view/js/async.min.js?2.2.0"></script><script src="view/js/form.js?2.2.0"></script><script> var debug = DEBUG = 0; var url_rewrite_on = 1; var url_path = './'; var forumarr = {"1":"Tech"}; var fid = 1; var uid = 0; var gid = 0; xn.options.water_image_url = 'view/img/water-small.png'; </script><script src="view/js/wellcms.js?2.2.0"></script><a class="scroll-to-top rounded" href="javascript:void(0);"><i class="icon-angle-up"></i></a><a class="scroll-to-bottom rounded" href="javascript:void(0);" style="display: inline;"><i class="icon-angle-down"></i></a></body></html><script> var forum_url = 'list-1.html'; var safe_token = 'vXfDv3dWye_2F4OnnT1NQgLGcwuhCbckHV3YL14EVQAZ8Y5uFg0oy4SxIIawoDnEfB4fveatu_2FWwUmpvuu1FagKA_3D_3D'; var body = $('body'); body.on('submit', '#form', function() { var jthis = $(this); var jsubmit = jthis.find('#submit'); jthis.reset(); jsubmit.button('loading'); var postdata = jthis.serializeObject(); $.xpost(jthis.attr('action'), postdata, function(code, message) { if(code == 0) { location.reload(); } else { $.alert(message); jsubmit.button('reset'); } }); return false; }); function resize_image() { var jmessagelist = $('div.message'); var first_width = jmessagelist.width(); jmessagelist.each(function() { var jdiv = $(this); var maxwidth = jdiv.attr('isfirst') ? first_width : jdiv.width(); var jmessage_width = Math.min(jdiv.width(), maxwidth); jdiv.find('img, embed, iframe, video').each(function() { var jimg = $(this); var img_width = this.org_width; var img_height = this.org_height; if(!img_width) { var img_width = jimg.attr('width'); var img_height = jimg.attr('height'); this.org_width = img_width; this.org_height = img_height; } if(img_width > jmessage_width) { if(this.tagName == 'IMG') { jimg.width(jmessage_width); jimg.css('height', 'auto'); jimg.css('cursor', 'pointer'); jimg.on('click', function() { }); } else { jimg.width(jmessage_width); var height = (img_height / img_width) * jimg.width(); jimg.height(height); } } }); }); } function resize_table() { $('div.message').each(function() { var jdiv = $(this); jdiv.find('table').addClass('table').wrap('<div class="table-responsive"></div>'); }); } $(function() { resize_image(); resize_table(); $(window).on('resize', resize_image); }); var jmessage = $('#message'); jmessage.on('focus', function() {if(jmessage.t) { clearTimeout(jmessage.t); jmessage.t = null; } jmessage.css('height', '6rem'); }); jmessage.on('blur', function() {jmessage.t = setTimeout(function() { jmessage.css('height', '2.5rem');}, 1000); }); $('#nav li[data-active="fid-1"]').addClass('active'); </script>