OutputStreams C++ library 1.0 release

OutputStreams 1.0 is now available at GitHub (user: MikeBrownUK, repository: OutputStreams).

Pretty much everything you should need to get going is in the repository, but if you’d like to know more about the project and how it came to be then read on and allow me to indulge myself by means of some slightly meandering notes:

About twenty years ago, when running a small development studio in the games industry, I came across a rather nice piece of code written by one of the team which specialised a Standard Library stream allowing you to send diagnostic messages to a file or console window using the operator << syntax provided by the Standard Library.

This seemed a whole lot nicer than the cumbersome variadic syntax of printfs and sprintfs I was used to.

Consider the following:

std::cout << "The result of " << float1 << GetOperationSymbol() << float2 << “ = “ << GetOperationResult( float1, float2 ) << std::endl;

It’s a little easier to follow logically, I think, than:

printf( “The result of %f %s %f = %f”, float1, GetOperationSymbol(), float2, GetOperationResult( float1, float2 ) );

If you adopt stream syntax for output in C++ you can of course go on to serialise just about any data type you want by providing a specialisation for operator <<.

Add in other benefits you get out-of-the-box with Standard Library streams: locales that you can imbue at runtime to format numeric output automatically in a fashion appropriate for a particular geographic region; manipulators to handle padding, whitespace and other custom formatting requirements – and there is a convincing case for ditching those sprintfs and printfs forever. And that’s exactly what I did because I stole carried that original idea around with me from company to company for more than twenty years, until I had the time earlier this year to finish off some wish-list items with the idea of releasing the whole thing publicly.

Throughout those twenty-something years of on-and-off development of this project in its various forms I’ve always tried to adhere to the following goals:

  1. The library must be lightweight and performance-centric so it can be used in the games industry and other real-time environments.
  1. The library should be capable of meeting many runtime logging requirements, not just output of developer diagnostic information.
  1. I wanted each stream and channel object to compile away to zero code footprint if required. This was very relevant from my background on games platforms where standards prohibit the outputting of any debug information on the terminal for final consumer software. Fortunately, C++ 11 made this goal a whole lot easier without me having to resort to using preprocessor macros to hide the stream objects.

Standard Library streams can be used in multithreaded environments but interleaving of output is probable (source: N. Jousuttis, The C++ Standard Library, 2nd edition). Here’s a little example of such interleaving when writing to std::cout with a Win32 console application – I created three threads running this very tight loop:

while ( system_clock::now() <= wait )
{
    std::cout << "Thread " << threadNumber_ << " writing to channel " << channelNumber_ << std::endl;
}

Here’s the output:

Thread 1 writing to channel Thread 0
3Thread Thread 2 writing to channel writing to channel 11 writing to channel
0Thread 02
writing to channel
1Thread Thread 31 writing to channel
0 writing to channel Thread 02

Fragmentation of a sentence and indeed any loss of meaning in output logs isn’t acceptable but I decided that occasional interleaving of whole entries from different threads at destination would be fine providing each could be optionally timestamped for visual or automatic sorting (hence the message prefixing system). I soon decided that using thread-local channels and buffers that synchronised with their destination streams only during a flush operation would minimise contention between threads and maximise performance.

The basic OutputStreams code was fully thread-safe a good few years ago but during some free time earlier this year I started work on new features I had been wanting to add for some time: ‘channels’ to represent the output from particular program domains, runtime output filtering controls for both OutputStreams and these new OutputChannels, automatic timestamping for both stream types (actually an extendable message prefixing system) and the ability for OutputChannels to attach to and write to multiple OutputStreams. These few items required a fairly substantial rethink of my class design and as a result the new codebase barely resembles how it looked a couple of months ago…

The idea of using channels/domains and message filtering came from a spell spent contracting at a developer in the North East of England whilst rebuilding and updating some of their Playstation 3 projects for release by another publisher. I noticed that their diagnostic output system used traditional printf-style syntax to construct messages but allowed you to name diagnostic domains and apply runtime filtering to logs, so I determined to find a way to implement such a system into my streams code. Ten years later I finally got round to this non-trivial task so, with a tip of the hat to them and to Jim, or maybe Rob- they will know who they are, anyway – whom I think wrote that initial spark of code I found all those years ago, here is my OutputStreams library for you to use free of charge.

Here’s what it can do out of the box:

  1. Handle char, wchar_t, char16_t and char32_t OutputStreams – the latter two with limitations inherent in the existing Standard Library implementations upon which the code relies.

  1. The example code allows you to send your output to files, std::cout and std::wcout, Windows consoles or the Windows debugger target (which is usually the Visual Studio output window) all using the provided sample OutputTarget class templates.

  1. You can add and combine OutputTargets very easily by implementing a new class with just two mandatory functions. At one point I had a class that encapsulated all the other OutputTargets and sent its output to all of them ( no longer necessary as an OutputChannel can now attach to multiple streams).

  1. You can use OutputStreams directly for best performance in a single thread context without any synchronisation bloat and still get the benefit of message filtering via member functions and stream manipulators.

  1. Create one or more OutputChannels for use by a single or multiple threads, giving you synchronised writing to one or more OutputStreams with message filtering for each individual channel.

  1. Use the provided OutputStamp classes to add a prefix to all messages sent to a stream or channel. The example templates provided will prefix each output segment sent to your stream with either a system date/time/millisecond string or the line number (actually the number of flush calls) since creation. You can expand the OutputStamp templates to do all sorts of things – perhaps output just portions of the date and time as they change, for example.

  1. Convert the three common UTF encodings to the correct format for the final target as they are passed through the output pipe, albeit with some limitations and assumptions – see my more detailed notes for an explanation.

All library and example code has been tested with the Microsoft and G++ compilers on 32-bit and 64-bit Windows and Linux and also G++ ARM running on a Raspberry Pi 4.

Usage examples and further design notes can be found here.

I will do my best to fix any bugs I find and update my GitHub project accordingly, other commitments permitting. I have further plans for this codebase which I will share in due course – mostly further performance optimisations for games console and embedded architectures. A small googletest suite also exists for OutputStreams and is included in the source package – you will need to download googletest if you wish to build and run the test program.

The software is released under the MIT license which is the most minimalistic license I could find to let anyone use it as they wish providing that its copyright notice is carried forward and therefore the people who inspired it get their well earned namechecks via this little blog post.

Thanks for reading and I hope you find the code and my notes useful in some way.

Mike Brown, September 2022.

Upcoming software release

I’ve almost finished preparing my upcoming C++ library release. This is free-to-use source code that extends existing standard library stream and buffer classes to provide thread-safe stream-style output to a variety of media including std::cout, std::wcout, files, console windows and pretty much anywhere else you might care to send streams of text for debugging or logging purposes via a simple statically polymorphic interface.

Source streams can send information to several stream targets concurrently and runtime filtering allows output verbosity to be changed at any point without a recompile by using member functions or via direct injection using stream manipulators – useful for filtering customer-facing logs as well as changing debug output verbosity on the fly. Information sent can be prefixed with a time & date stamp, line number or pretty much any other piece of information you could imagine, again by using my provided example classes as an interface guide.

Because the code is based upon established Standard Library stream classes you get almost all of the benefits of those classes including format manipulators and locale imbuing.

A simple aliasing of types through a preprocessor define can reduce the code footprint of the streams and all literals sent directly to them to zero: useful if debug output needs stripping from binaries easily during compilation – for a games console release candidate, for example.

The library requires only C++’11 support and has so far been tested on Windows and Linux (PC and ARM architectures). Most Unicode text formats and integral C++ character types are catered for, albeit with limitations already inherent in the existing Standard Library and the platforms it is implemented on – more on this in my next post.

Just getting the last code tests, tidy-ups and documentation finished, so check back in a week or two for the library release.

Visual Studio 2022 – promising but buggy

I’m a huge fan of Visual Studio – it’s by far the best IDE I’ve ever used. I’ve used it for C++ development on several platforms (mainly Windows and Sony consoles but most recently Windows and Linux using a shared codebase and cross-compiling then debugging various targets running on x32, x64 and ARM chipsets though the one IDE and PC).

I’m still in the early stages of getting to know VS 2022. Superficially it looks very much like VS 2019, at least to someone who uses it mainly for native C++ development, but if the whole IDE has indeed been updated to run natively as a suite of 64-bit processes then that’s quite some engineering feat in itself.

It feels a little quicker than 2019, though I’m not sure if that’s just an illusion from my assumption that all of its processes are now free to address the whole of whatever memory is available on a modern PC.

Adding new features probably wasn’t high on the list of goals for this release given the wholesale upgrade and the risks that must have introduced. I’m really rather glad as I’m a big fan of the adage ‘don’t fix what isn’t broken’ – very important when tools of the trade are concerned. Certainly most of the things I’ve loved about Visual Studio since its last major (and quite brilliant) revamp in 2015 seem largely unchanged.

I’m finding quite a few niggles and bugs, though, and some of them are really quite bad considering this is a release branch, with at least one update I can remember applying.

Where does one report bugs and feature requests to Microsoft these days? I have no idea… I’ve tried @VisualStudio on Twitter once but that almost certainly isn’t the correct avenue, so for now I’ll list them here in the hope that some Microsoft spider will find them and take them back to its bug-stash in the cloud where they can be expeditiously ignored:


All of the below are present in…

Microsoft Visual Studio Community 2022 (64-bit) – Current Version 17.1.6

… and for the record, I’m currently developing using CMake rather than a .vcxproj based project.

  1. Diagnostic Tools window prevents the edit/code window gaining focus when hitting a breakpoint:

This one is really annoying. The Diagnostics Tools window is enabled by default. This window can take so long to finish initialising when debugging a simple Win32 console application that it often hasn’t finished drawing its graphs and controls until some time after your program has been running. This messes up debug focusing when you hit a breakpoint in a console application: neither the console window nor the editor window are focused. Instead, it seems the focus when hitting your breakpoint needs to be on that Diagnostic Tools window, leaving your IDE’s editor window, with that all important breakpoint arrow and red dot, to finish a poor third behind (and I really do mean ‘behind’) your console window.

  1. Diagnostic Tools window not staying closed:

This is more bad design than bug, but I don’t recall this behaviour from VS 2019 and I only discovered it when trying to find a workaround for the previous bug:

Closing the Diagnostic Tools window when debugging is remembered between debug sessions but not between successive IDE sessions (i.e. after closing and restarting the IDE), unlike changes to visibility and position for nearly every other IDE component which persist between restarts. This unique behaviour seems to be be triggered by a hidden toggle in Tools->Options->Debug called ‘enable Diagnostics Tools whilst debugging’. I don’t know why this is needed when there is a perfectly good ‘Show Diagnostic Tools Window’ option in Debug->Windows where it has, unless I’m mistaken, been since the dawn of time (i.e. circa late 2014 in my modern Visual Studio calendar).

I strongly advise you to disable that checkbox in the options menu until the focusing problem mentioned in my first bug has been addressed.

  1. Typing three forward slashes into an editor window causes this to appear in my source code:
/// <summary>
/// 
/// </summary>
/// <returns></returns>

This happens when editing files with .CPP and .H extensions. I don’t really want this markup in my files and I already use multiple forward slashes to delimit my function and file headers. This new, built-in (or at least enabled-by-default) behaviour now prevents me from typing my own– instead I have to copy and paste my lines of ‘////’ from elsewhere. This behaviour wasn’t present in previous versions of Visual Studio and it also interferes with much better functionality offered by third party add-ons. I can’t yet see any obvious way to switch this annoying ‘feature’ off (if it is such – for now I have to assume it’s just a plain and dirty bug!)

  1. Visual Studio with Visual Assist. Sadly many problems spoil the interaction between a great IDE and one of its best (dare I suggest indispensable? I think so…) add-ons:

Visual Assist when installed for VS 2022 doesn’t import its options from previous Visual Studio installs (these are saved in the registry if I remember). This is a gripe with Whole Tomato, too – it’s your software. Some aspects of Visual Assist don’t even work correctly unless I run Visual Studio 2022 with administrator privileges every time I start it (highlighting of read and write references for the current symbol being one such example). Visual Assist is a fantastic productivity aid, but its VS 2022 support is poor at present.


I have no idea how the managed side of development (managed C++ and other .NET languages) are with the new 64-bit IDE. .NET isn’t a land I venture into often but I don’t doubt I will need to write some managed wrappers for my library code at some point soon. For the moment I have to assume all is great with Visual Studio 2022 in .NET-land.

That’s all for now. First impressions are that insufficient testing of the software happened before release, at least as far as native C++ development and support for existing add-ons is concerned. I shall post more bugs on this page as I find them though I realise that my history of (not) updating this website is hardly conducive to keeping that promise…

Update – July ’22

I’ve been rather busy these last few weeks preparing to release some free C++ library code into the wild – more on this soon – so I haven’t been back to post an update to say that Visual Studio Community Edition 17.2.0 fixes point 3 (markup) and, I’m fairly sure, point 1 (annoying diagnostic tools focus problem), so many thanks to Microsoft for a speedy resolution, even if those issues were already on their bugs list from other sources before I reported them here (and I jolly well hope that they were!) I’m back to enjoying writing C++ with Visual Studio again.

The Vox amPlug 2 – a little wonder

What does the practice-hungry, aspiring guitar player take on their travels when they don’t wish to be encumbered by a collection of amps/leads/wireless transmitters and other gubbins and need to be sympathetic to the prevailing ambient noise level (or, lack of)? An acoustic, played fingerstyle so as not to disturb the natives when a hotel practice session at 5am beckons? An electric guitar played completely naked?

Neither of the above. At least not since I picked up one of these beauties a few weeks ago:

Most of my practice time right now is spent sight-reading solo pieces and practising new chords and progressions, so I’m nearly always playing on a clean channel on my amp – mainly so I can hear when my finger placement or timing isn’t quite there (which is annoyingly frequent given that I’m still a rank amateur!)

Having read favourable reviews of these tiny headphone amplifiers in various places and having had some brief experience with a Vox MV50 clean amp-head in a local guitar shop (and liking the sound very much), I took the plunge and ordered one, despite there being cheaper alternatives available from names I wasn’t really familiar with.

I’m pleased to report that this little gadget works wonderfully with both my Sennheiser IE-60 earbuds and my Sony MDR-CD470 closed-cup headphones and the battery life so far has been very impressive indeed (more than two hours of playtime in and I haven’t had to recharge the two 700mah Energizer AAAs I put in when I first opened it -and it does come with two alkaline AAA batteries in the pack). For the record, manufacturer reported battery life is 11 hours with alkaline batteries and 17 hours if no effects are selected – I can’t confirm these figures yet but if so, that’s very, very impressive indeed.

There are three core sounds to choose from on the AP-CL2, accessed in cyclical fashion via a short press of the power switch (hold same to power on/off): Pure Clean, Twin Clean and Boutique OD. The first two are very much classic clean tones for digital amps with the Twin Clean channel offering a little more depth and warmth than the Pure version. Both sound great in combination with my Mexican Telecaster, especially when combined with a little delay or reverb. The three rotary dials on the top of the unit control Gain, Tone and Volume respectively and after a little experimentation (and for reference, my Telecaster is pretty much always locked at maximum volume), I found that setting the Gain to maximum (10) and the Volume to halfway (5) gave me a largely hiss-free sound-stage and more than enough volume for practice with the first two voices. Any hiss encountered when I ventured beyond these settings was far more evident through my little earbuds than through bigger cans.

Switching to the Boutique voice immediately introduces a noticeable spike in output volume and hiss, however, and strumming a chord with the above settings results in hugely excessive distortion especially if like me, your guitar might as well only have the one output volume: maximum – so it’s time to reach for that gain dial and turn things down to a more suitable level for this particular voice – around 5 or 6 worked for me with the earbuds. Still quite a noisy voice, but nonetheless a pleasing heavy crunch sound if that’s your thing.

On the top of the unit is another little button that chooses an optional digital effect to apply – chorus, delay and reverb are offered. Three styles for each of the effects give nine options in total, though note that they cannot be combined and their parameters are not user-configurable. The delay and reverb effects are nicely done and a worthy inclusion – the more pronounced third selections of both delay and reverb are especially pleasing when playing a lead voice. The chorus effects aren’t quite so nice, at least not to my ears: a little too much sickness-inducing phasing going on to make me wish to play them for too long in isolation – and of course you don’t get any choice in that regard.

Out of interest I also connected the unit to my 40W Blackstar practice amp’s line-in socket to see how the Vox would sound through a moderately-sized external speaker system and I was pleasantly surprised how full it sounded when I did.

The additional 3.5mm stereo line-in is very welcome and works beautifully well with an external source – in my case my Android phone and the Poweramp music app.

The 6mm instrument jack has five possible positions selected in increments of 45 degrees from fully-folded zero degrees (picture 2), through 90 degrees perpendicular to the unit (picture 1) to 180 degrees with the jack protruding around two inches from the left side of the unit and parallel to it. One small concern is whether the unit would snag the tremolo arm on a Stratocaster due to the position of the output socket – I have a wireless transmitter that has this very problem despite advertising itself as suitable for all guitars – but as I’ve yet to try my Stratocaster with the Vox I can’t report on it. I’m hopeful the 180 degree configuration would negate my slight worry in that regard and I’m pretty sure a company like Vox wouldn’t let something like that get through the design stage without being swiftly corrected anyway.

In summary, then – a nicely constructed and surprisingly impressive sounding little amplifier that will take no more space in your gig-bag than a Swiss Army Knife and weighing far less than the latter even with batteries in. Mine is already an ever-present on my travels.

Update – July ’22

I forgot to pop back and mention that this amp does snag the tremolo arm on a Stratocaster somewhat, so worth considering if that’s your setup -try before you buy, perhaps? Despite that small hassle, I continue to be delighted with this amp every time I use it and I was perhaps a little harsh on the chorus effects in my initial review as I’ve grown to really rather like the first one.