+#include <SUIT_MessageBox.h>
+
+static bool isEntryLess( const QString& e1, const QString& e2 )
+{
+ QStringList el1 = e1.split(":");
+ QStringList el2 = e2.split(":");
+ int e1c = el1.count(), e2c = el2.count();
+ for ( int i = 0; i < e1c && i < e2c; i++ ) {
+ int id1 = el1[i].toInt();
+ int id2 = el2[i].toInt();
+ if ( id1 < id2 ) return true;
+ else if ( id2 < id1 ) return false;
+ }
+ return el1.count() < el2.count();
+}
+
+static QStringList objectsToNames( const QMap<QString, QString>& objects )
+{
+ QStringList entries;
+ for ( QMap<QString, QString>::ConstIterator it = objects.begin(); it != objects.end(); ++it ) {
+ QString entry = it.key();
+ QStringList::Iterator it;
+ bool added = false;
+ for ( it = entries.begin(); it != entries.end() && !added; ++it ) {
+ if ( isEntryLess( entry, *it ) ) {
+ entries.insert( it, entry );
+ added = true;
+ }
+ }
+ if ( !added )
+ entries.append( entry );
+ }
+ QStringList names;
+ for ( int i = 0; i < entries.count(); i++ ) {
+ int level = entries[i].count(":")-3;
+ names.append( QString( level*2, ' ' ) + objects[ entries[i] ] );
+ }
+ return names;
+}