From 9a7fabb66c83c976b993af88f18dd7086c9e60ae Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Axel=20D=C3=B6rfler?= Date: Sun, 12 Feb 2006 17:50:22 +0000 Subject: [PATCH] The IconView now also shows an icon for a MIME type if it got it from the super type's preferred application. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@16366 a95241bf-73f2-0310-859d-f6bbb57e9c96 --- src/preferences/filetypes/FileTypesWindow.cpp | 20 ++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/src/preferences/filetypes/FileTypesWindow.cpp b/src/preferences/filetypes/FileTypesWindow.cpp index 745d5ad166..971701273e 100644 --- a/src/preferences/filetypes/FileTypesWindow.cpp +++ b/src/preferences/filetypes/FileTypesWindow.cpp @@ -191,8 +191,10 @@ IconView::SetTo(BMimeType* type) fIconSource = kNoIcon; if (type != NULL) { - if (fIcon == NULL) - fIcon = new BBitmap(BRect(0, 0, B_LARGE_ICON - 1, B_LARGE_ICON - 1), B_CMAP8); + if (fIcon == NULL) { + fIcon = new BBitmap(BRect(0, 0, B_LARGE_ICON - 1, B_LARGE_ICON - 1), + B_CMAP8); + } if (type->GetIcon(fIcon, B_LARGE_ICON) == B_OK) fIconSource = kOwnIcon; @@ -204,7 +206,8 @@ IconView::SetTo(BMimeType* type) if (type->GetPreferredApp(preferred) == B_OK) { BMimeType preferredApp(preferred); - if (preferredApp.GetIconForType(type->Type(), fIcon, B_LARGE_ICON) == B_OK) + if (preferredApp.GetIconForType(type->Type(), fIcon, + B_LARGE_ICON) == B_OK) fIconSource = kApplicationIcon; } } @@ -216,6 +219,17 @@ IconView::SetTo(BMimeType* type) if (type->GetSupertype(&superType) == B_OK) { if (superType.GetIcon(fIcon, B_LARGE_ICON) == B_OK) fIconSource = kSupertypeIcon; + else { + // check the super type's preferred app + char preferred[B_MIME_TYPE_LENGTH]; + if (superType.GetPreferredApp(preferred) == B_OK) { + BMimeType preferredApp(preferred); + + if (preferredApp.GetIconForType(superType.Type(), + fIcon, B_LARGE_ICON) == B_OK) + fIconSource = kSupertypeIcon; + } + } } } }