The PositionSlider no longer allows to go beyond the last block (starting
with 0!) by one. Also, SetFileSize() now checks if the position is within valid bounds. The device offset is now correctly maintained (it also adds the view offset). The view offset is now taken into account, too (but it doesn't yet get any updates from the DataView). git-svn-id: file:///srv/svn/repos/haiku/trunk/current@6625 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
15fef5f790
commit
b95c3b6860
@ -93,11 +93,13 @@ class HeaderView : public BView, public BInvoker {
|
|||||||
private:
|
private:
|
||||||
void FormatValue(char *buffer, size_t bufferSize, off_t value);
|
void FormatValue(char *buffer, size_t bufferSize, off_t value);
|
||||||
void UpdatePositionViews(off_t position);
|
void UpdatePositionViews(off_t position);
|
||||||
|
void UpdateOffsetViews(off_t position, bool all = true);
|
||||||
void UpdateFileSizeView();
|
void UpdateFileSizeView();
|
||||||
|
|
||||||
const char *fAttribute;
|
const char *fAttribute;
|
||||||
off_t fFileSize;
|
off_t fFileSize;
|
||||||
uint32 fBlockSize;
|
uint32 fBlockSize;
|
||||||
|
off_t fOffset;
|
||||||
base_type fBase;
|
base_type fBase;
|
||||||
|
|
||||||
BTextControl *fPositionControl;
|
BTextControl *fPositionControl;
|
||||||
@ -249,7 +251,7 @@ PositionSlider::DrawBar()
|
|||||||
void
|
void
|
||||||
PositionSlider::Reset()
|
PositionSlider::Reset()
|
||||||
{
|
{
|
||||||
SetKeyIncrementValue(int32(1.0 * kMaxSliderLimit / (fSize / fBlockSize) + 0.5));
|
SetKeyIncrementValue(int32(1.0 * kMaxSliderLimit / ((fSize - 1) / fBlockSize) + 0.5));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -264,7 +266,7 @@ PositionSlider::Position() const
|
|||||||
// For example, with a block size of 512 bytes, it should be good enough for about
|
// For example, with a block size of 512 bytes, it should be good enough for about
|
||||||
// 1024 GB - and that's not really that far away these days.
|
// 1024 GB - and that's not really that far away these days.
|
||||||
|
|
||||||
return (off_t(1.0 * fSize * Value() / kMaxSliderLimit + 0.5) / fBlockSize) * fBlockSize;
|
return (off_t(1.0 * (fSize - 1) * Value() / kMaxSliderLimit + 0.5) / fBlockSize) * fBlockSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -272,7 +274,7 @@ void
|
|||||||
PositionSlider::SetPosition(off_t position)
|
PositionSlider::SetPosition(off_t position)
|
||||||
{
|
{
|
||||||
position /= fBlockSize;
|
position /= fBlockSize;
|
||||||
SetValue(int32(1.0 * kMaxSliderLimit * position / (fSize / fBlockSize) + 0.5));
|
SetValue(int32(1.0 * kMaxSliderLimit * position / ((fSize - 1) / fBlockSize) + 0.5));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -283,6 +285,9 @@ PositionSlider::SetSize(off_t size)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
off_t position = Position();
|
off_t position = Position();
|
||||||
|
if (position >= size)
|
||||||
|
position = size - 1;
|
||||||
|
|
||||||
fSize = size;
|
fSize = size;
|
||||||
Reset();
|
Reset();
|
||||||
SetPosition(position);
|
SetPosition(position);
|
||||||
@ -310,6 +315,7 @@ HeaderView::HeaderView(BRect frame, entry_ref *ref, DataEditor &editor)
|
|||||||
fAttribute(editor.Attribute()),
|
fAttribute(editor.Attribute()),
|
||||||
fFileSize(editor.FileSize()),
|
fFileSize(editor.FileSize()),
|
||||||
fBlockSize(editor.BlockSize()),
|
fBlockSize(editor.BlockSize()),
|
||||||
|
fOffset(0),
|
||||||
fBase(kHexBase)
|
fBase(kHexBase)
|
||||||
{
|
{
|
||||||
SetViewColor(ui_color(B_PANEL_BACKGROUND_COLOR));
|
SetViewColor(ui_color(B_PANEL_BACKGROUND_COLOR));
|
||||||
@ -380,6 +386,7 @@ HeaderView::HeaderView(BRect frame, entry_ref *ref, DataEditor &editor)
|
|||||||
fOffsetView = new BStringView(rect, B_EMPTY_STRING, "0x0");
|
fOffsetView = new BStringView(rect, B_EMPTY_STRING, "0x0");
|
||||||
fOffsetView->SetFont(&plainFont);
|
fOffsetView->SetFont(&plainFont);
|
||||||
AddChild(fOffsetView);
|
AddChild(fOffsetView);
|
||||||
|
UpdateOffsetViews(0LL, false);
|
||||||
|
|
||||||
rect.left = rect.right + 4;
|
rect.left = rect.right + 4;
|
||||||
rect.right = frame.right;
|
rect.right = frame.right;
|
||||||
@ -461,11 +468,25 @@ HeaderView::UpdatePositionViews(off_t position)
|
|||||||
FormatValue(buffer, sizeof(buffer), position / fBlockSize);
|
FormatValue(buffer, sizeof(buffer), position / fBlockSize);
|
||||||
fPositionControl->SetText(buffer);
|
fPositionControl->SetText(buffer);
|
||||||
|
|
||||||
FormatValue(buffer, sizeof(buffer), position);
|
FormatValue(buffer, sizeof(buffer), position + fOffset);
|
||||||
fFileOffsetView->SetText(buffer);
|
fFileOffsetView->SetText(buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
HeaderView::UpdateOffsetViews(off_t position, bool all)
|
||||||
|
{
|
||||||
|
char buffer[64];
|
||||||
|
FormatValue(buffer, sizeof(buffer), fOffset);
|
||||||
|
fOffsetView->SetText(buffer);
|
||||||
|
|
||||||
|
if (all) {
|
||||||
|
FormatValue(buffer, sizeof(buffer), position + fOffset);
|
||||||
|
fFileOffsetView->SetText(buffer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
HeaderView::UpdateFileSizeView()
|
HeaderView::UpdateFileSizeView()
|
||||||
{
|
{
|
||||||
@ -483,7 +504,10 @@ HeaderView::SetBase(base_type type)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
fBase = type;
|
fBase = type;
|
||||||
UpdatePositionViews(fPositionSlider->Position());
|
|
||||||
|
off_t position = fPositionSlider->Position();
|
||||||
|
UpdatePositionViews(position);
|
||||||
|
UpdateOffsetViews(position, false);
|
||||||
UpdateFileSizeView();
|
UpdateFileSizeView();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user