Added a TODO why our bitmap code is currently pretty inefficient.

git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@15390 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2005-12-07 10:50:01 +00:00
parent 9584d7e45e
commit ec17c60f5a

View File

@ -2244,16 +2244,11 @@ BBitmap::InitObject(BRect bounds, color_space colorSpace, uint32 flags,
link.Attach<int32>(bytesPerRow); link.Attach<int32>(bytesPerRow);
link.Attach<int32>(screenID.id); link.Attach<int32>(screenID.id);
// Reply Code: SERVER_TRUE
// Reply Data: // Reply Data:
// 1) int32 server token // 1) int32 server token
// 2) area_id id of the area in which the bitmap data resides // 2) area_id id of the area in which the bitmap data resides
// 3) int32 area pointer offset used to calculate fBasePtr // 3) int32 area pointer offset used to calculate fBasePtr
// alternatively, if something went wrong
// Reply Code: SERVER_FALSE
// Reply Data:
// None
error = B_ERROR; error = B_ERROR;
if (link.FlushWithReply(error) == B_OK && error == B_OK) { if (link.FlushWithReply(error) == B_OK && error == B_OK) {
// server side success // server side success
@ -2266,6 +2261,8 @@ BBitmap::InitObject(BRect bounds, color_space colorSpace, uint32 flags,
link.Read<int32>(&areaOffset); link.Read<int32>(&areaOffset);
// Get the area in which the data resides // Get the area in which the data resides
// TODO: the actual cloning doesn't have to happen before someone calls Bits()
// that would make bitmap creation a lot cheaper and faster...
fArea = clone_area("shared bitmap area", fArea = clone_area("shared bitmap area",
(void**)&fBasePtr, (void**)&fBasePtr,
B_ANY_ADDRESS, B_ANY_ADDRESS,
@ -2274,7 +2271,7 @@ BBitmap::InitObject(BRect bounds, color_space colorSpace, uint32 flags,
if (fArea >= B_OK) { if (fArea >= B_OK) {
// Jump to the location in the area // Jump to the location in the area
fBasePtr = (int8*)fBasePtr + areaOffset; fBasePtr = (int8*)fBasePtr + areaOffset;
fSize = size; fSize = size;
fColorSpace = colorSpace; fColorSpace = colorSpace;
fBounds = bounds; fBounds = bounds;