Returning a type from a C++ function

In C++, you can easily “pass a type” to a function by using templates, as if it was an extra parameter for the function. For example you can write this: tableLayout.addColumn<int>(“id”) We add a column of type int and whose name is “id” to a table’s layout. But “returning a type” is more complicated when the functions parameters are not known at compile-time. I would like to be able to write tableLayout.getColumnType(“id”) and have the function somehow return int. Well, you can do it by using a callback function. This is not something new, but C++14′s generic lambdas make it … Continue reading Returning a type from a C++ function

C++ standard library containers iterators quick cheatsheet

Here is a small cheat sheet for standard containers if you need to know when iterators and pointers stay valid and when you can no longer use them. Everything below is taken from the standard. I’m not aware of a compiler which would violate any of these rules. The swap function of containers never invalidates pointers or iterators to elements. The clear function obviously invalidates everything, but may also invalidates the past-to-end iterator (ie. the iterator returned by the end function) Note that a call to erase (or any function that deletes an element) obviously always invalidates the pointer and … Continue reading C++ standard library containers iterators quick cheatsheet

C++11 nested exceptions

A little known but very exciting feature of C++11 are nested exceptions. One of the common problems of C++ is that you can’t have a backtrace of the exceptions that you catch, which means that you won’t be able to know where and in which context they were thrown. For example, if you try to access a non-existing element in an unordered_map, you will catch an std::out_of_range exception with a message saying “invalid unordered_map<K, T> key”. But you will have no idea where in your program this was triggered. There exist platform-specific functions that allow you to read the current … Continue reading C++11 nested exceptions

unordered_map and const char*

Imagine that you want to write something like this: std::unordered_map<std::string,int> list; list["foo"] = 2; list["bar"] = 5; This works perfectly but is very inefficient. Every time you use the [] operator, a std::string is created, some memory is allocated on the heap, and the content of the C string is copied into this buffer. Instead we would like to directly read from the const char*. You can’t just write std::unordered_map<const char*,int> because it would compare pointers instead of their content. I quickly wrote this CStringUnorderedMap which does this: #include <unordered_map> namespace CStringUnorderedMapImpl_ { struct Hash { size_t operator()(const char* ptr) … Continue reading unordered_map and const char*

DirectX-compliant smart pointer

If you are using the DirectX library, you have probably understood that you can’t use regular smart pointers with DirectX objects because of the way Microsoft designed their API. Here is a small smart pointer class I created to handle this problem. #include <stdexcept> /** * Pointer to any IUnknown* object * T must be a derivate of IUnknown */ template<typename T> struct DXObjectPointer { DXObjectPointer() : pointer(nullptr) {} DXObjectPointer(const DXObjectPointer& ptr) : pointer(ptr.pointer) { pointer->AddRef(); } DXObjectPointer(DXObjectPointer&& ptr) : pointer(nullptr) { std::swap(pointer, ptr.pointer); } ~DXObjectPointer() { reset(); } DXObjectPointer& operator=(const DXObjectPointer& ptr) { reset(); pointer = ptr.pointer; pointer->AddRef(); return … Continue reading DirectX-compliant smart pointer

Random tricks when using AngularJS

If you don’t know AngularJS, it is a very good Javascript library that allows you to easily build web applications. Here are some random useful tricks that I found for AngularJS users. Ternary operator in expressions When you write an expression, like {{ id }}, you can’t use the ternary operator ?:. But you can use the && and || operators. These two lines are identical provided that b always equals true: a ? b : c a && b || c For example: <p>This feature is {{ feature.isActivated && "activated" || "not activated" }}</p> This reason why it works … Continue reading Random tricks when using AngularJS

Logging exceptions in C++11

It’s not a very well-known feature of C++11, but you are now able to get a pointer to the exception currently being processed. void foo() { try { throw anything; } catch(…) { auto exceptionPtr = std::current_exception(); } } In this example, exceptionPtr is of type std::exception_ptr. This type is kind of a smart pointer, which means that as long as the exceptionPtr variable or one of its copies exists, the thrown object still exists too. So what can you do with a std::exception_ptr ? Nothing, except rethrow it later. void foo() { std::exception_ptr exceptionPtr; try { throw std::exception(“Error!”); } … Continue reading Logging exceptions in C++11

[C++] Converting GUID to string and vice-versa

Here are two small functions to convert between a GUID and a string. #ifdef _MSC_VER # define snprintf _snprintf #endif std::string guidToString(GUID guid) { std::array<char,40> output; snprintf(output.data(), output.size(), “{%08X-%04hX-%04hX-%02X%02X-%02X%02X%02X%02X%02X%02X}”, guid.Data1, guid.Data2, guid.Data3, guid.Data4[0], guid.Data4[1], guid.Data4[2], guid.Data4[3], guid.Data4[4], guid.Data4[5], guid.Data4[6], guid.Data4[7]); return std::string(output.data()); } GUID stringToGUID(const std::string& guid) { GUID output; const auto ret = sscanf(guid.c_str(), “{%8X-%4hX-%4hX-%2hX%2hX-%2hX%2hX%2hX%2hX%2hX%2hX}”, &output.Data1, &output.Data2, &output.Data3, &output.Data4[0], &output.Data4[1], &output.Data4[2], &output.Data4[3], &output.Data4[4], &output.Data4[5], &output.Data4[6], &output.Data4[7]); if (ret != 11) throw std::logic_error(“Unvalid GUID, format should be {00000000-0000-0000-0000-000000000000}”); return output; }

AJAX application: adding a handy loading screen to your page

If you are developing an AJAX application, here is a small jQuery code to add a loading screen to your page whenever an AJAX request is made. No external dependency, should work everywhere. $(function() { $(‘<div style=”position:fixed;top:0;left:0;right:0;bottom:0;z-index:10000;background-color:gray;background-color:rgba(70,70,70,0.2);”><img style=”position:absolute;top:50%;left:50%;” alt=”” src=”” /></div>’) .appendTo($(‘body’)).hide() .ajaxStart(function() { $(this).show(); }).ajaxStop(function() { $(this).hide(); }); });

PHP: wrapper around XMLWriter

In PHP, when you want to write some XML data, the “correct” way is to use XMLWriter. However it can really be annoying to use for large documents. Take this simple XHTML page for example: <?xml version=”1.0″ encoding=”UTF-8″?> <html lang=”fr” xmlns=”http://www.w3.org/1999/xhtml”> <head> <title>Test</title> </head> <body> <p>Hello world</p> </body> </html> If you want to write this using XMLWriter, you get this: $xmlWriter = new XMLWriter(); $xmlWriter->openURI(‘php://output’); $xmlWriter->setIndentString(‘ ‘); $xmlWriter->setIndent(true); $xmlWriter->startDocument(’1.0′, ‘utf-8′); $xmlWriter->startElementNS(null, ‘html’, ‘http://www.w3.org/1999/xhtml’); $xmlWriter->writeAttribute(‘lang’, ‘fr’); $xmlWriter->startElement(‘head’); $xmlWriter->writeElement(‘title’, ‘Test’); $xmlWriter->endElement(); $xmlWriter->startElement(‘body’); $xmlWriter->writeElement(‘p’, ‘Hello world’); $xmlWriter->endElement(); $xmlWriter->endElement(); $xmlWriter->endDocument(); $xmlWriter->flush(); You can easily understand why it’s annoying to use! And for larger documents, … Continue reading PHP: wrapper around XMLWriter