diff options
Diffstat (limited to 'src/mir_app')
-rw-r--r-- | src/mir_app/src/IcoLib.h | 9 | ||||
-rw-r--r-- | src/mir_app/src/icolib.cpp | 34 |
2 files changed, 23 insertions, 20 deletions
diff --git a/src/mir_app/src/IcoLib.h b/src/mir_app/src/IcoLib.h index acaa11b327..67e1ea779c 100644 --- a/src/mir_app/src/IcoLib.h +++ b/src/mir_app/src/IcoLib.h @@ -47,19 +47,16 @@ struct IconSourceItemKey int cx, cy;
};
-class IconSourceItem : public MZeroedObject, public IconSourceItemKey
+class IconSourceItem : public MZeroedObject
{
+ IconSourceItemKey key;
int ref_count;
BYTE* icon_data;
int icon_size;
public:
- __inline IconSourceItem(IconSourceFile *_file, int _indx, int _cxIcon, int _cyIcon) :
- ref_count(1)
- {
- file = _file; indx = _indx; cx = _cxIcon; cy = _cyIcon;
- }
+ IconSourceItem(const IconSourceItemKey&);
~IconSourceItem();
__inline void addRef() { ref_count++; }
diff --git a/src/mir_app/src/icolib.cpp b/src/mir_app/src/icolib.cpp index f3c7fe2d05..e22acb338d 100644 --- a/src/mir_app/src/icolib.cpp +++ b/src/mir_app/src/icolib.cpp @@ -189,9 +189,15 @@ static int InternalGetDIB(HBITMAP bitmap, HPALETTE palette, void *bitmapInfo, vo #define VER30 0x00030000
+IconSourceItem::IconSourceItem(const IconSourceItemKey &_key)
+ : key(_key),
+ ref_count(1)
+{
+}
+
IconSourceItem::~IconSourceItem()
{
- IconSourceFile_Release(file);
+ IconSourceFile_Release(key.file);
SafeDestroyIcon(icon);
mir_free(icon_data);
}
@@ -204,15 +210,14 @@ HICON IconSourceItem::getIcon() }
if (icon_size) {
- icon = CreateIconFromResourceEx(icon_data, icon_size, TRUE, VER30, cx, cy, LR_COLOR);
+ icon = CreateIconFromResourceEx(icon_data, icon_size, TRUE, VER30, key.cx, key.cy, LR_COLOR);
if (icon) {
icon_ref_count++;
return icon;
}
}
- //SHOULD BE REPLACED WITH GOOD ENOUGH FUNCTION
- _ExtractIconEx(file->file, indx, cx, cy, &icon, LR_COLOR);
+ _ExtractIconEx(key.file->file, key.indx, key.cx, key.cy, &icon, LR_COLOR);
if (icon)
icon_ref_count++;
@@ -283,28 +288,28 @@ int IconSourceItem::releaseIcon() int IconSourceItem::compare(const IconSourceItem *p1, const IconSourceItem *p2)
{
- if (p1->indx < p2->indx)
+ if (p1->key.indx < p2->key.indx)
return -1;
- if (p1->indx > p2->indx)
+ if (p1->key.indx > p2->key.indx)
return 1;
- if (p1->cx < p2->cx)
+ if (p1->key.cx < p2->key.cx)
return -1;
- if (p1->cx > p2->cx)
+ if (p1->key.cx > p2->key.cx)
return 1;
- if (p1->cy < p2->cy)
+ if (p1->key.cy < p2->key.cy)
return -1;
- if (p1->cy > p2->cy)
+ if (p1->key.cy > p2->key.cy)
return 1;
- if (p1->file == p2->file)
+ if (p1->key.file == p2->key.file)
return 0;
- return (p1->file > p2->file) ? 1 : -1;
+ return (p1->key.file > p2->key.file) ? 1 : -1;
}
IconSourceItem* GetIconSourceItem(const TCHAR *file, int indx, int cxIcon, int cyIcon)
@@ -321,7 +326,7 @@ IconSourceItem* GetIconSourceItem(const TCHAR *file, int indx, int cxIcon, int c return iconSourceList[ix];
}
- IconSourceItem *newItem = new IconSourceItem(r_file, indx, cxIcon, cyIcon);
+ IconSourceItem *newItem = new IconSourceItem(key);
iconSourceList.insert(newItem);
return newItem;
}
@@ -350,7 +355,8 @@ IconSourceItem* CreateStaticIconSourceItem(int cxIcon, int cyIcon) TCHAR tszName[100];
mir_sntprintf(tszName, _T("*StaticIcon_%d"), iStaticCount++);
- IconSourceItem *newItem = new IconSourceItem(IconSourceFile_Get(tszName, false), 0, cxIcon, cyIcon);
+ IconSourceItemKey key = { IconSourceFile_Get(tszName, false), 0, cxIcon, cyIcon };
+ IconSourceItem *newItem = new IconSourceItem(key);
iconSourceList.insert(newItem);
return newItem;
}
|