Final updates for 3.9.2 release.

git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@2822 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
stephena 2013-08-31 13:49:19 +00:00
parent 963c5d621b
commit fa9951e95f
11 changed files with 147 additions and 74 deletions

View File

@ -9,7 +9,7 @@
SSSS ttt eeeee llll llll aaaaa SSSS ttt eeeee llll llll aaaaa
=========================================================================== ===========================================================================
Release 3.9.1 for Linux, MacOSX and Windows Release 3.9.2 for Linux, MacOSX and Windows
=========================================================================== ===========================================================================
The Atari 2600 Video Computer System (VCS), introduced in 1977, was the The Atari 2600 Video Computer System (VCS), introduced in 1977, was the
@ -21,28 +21,28 @@ all of your favourite Atari 2600 games again! Stella was originally
developed for Linux by Bradford W. Mott, however, it has been ported to a developed for Linux by Bradford W. Mott, however, it has been ported to a
number of other platforms and is currently maintained by Stephen Anthony. number of other platforms and is currently maintained by Stephen Anthony.
This is the 3.9.1 release of Stella for Linux, Mac OSX and Windows. The This is the 3.9.2 release of Stella for Linux, Mac OSX and Windows. The
distributions currently available are: distributions currently available are:
* Binaries for Windows XP/Vista/7/8 : * Binaries for Windows XP/Vista/7/8 :
Stella-3.9.1-win32.exe (32-bit EXE installer) Stella-3.9.2-win32.exe (32-bit EXE installer)
Stella-3.9.1-x64.exe (64-bit EXE installer) Stella-3.9.2-x64.exe (64-bit EXE installer)
Stella-3.9.1-windows.zip (32/64 bit versions) Stella-3.9.2-windows.zip (32/64 bit versions)
* Binary distribution for MacOS X 32-bit & 64-bit : * Binary distribution for MacOS X 32-bit & 64-bit :
Stella-3.9.1-macosx.dmg (32-bit Universal Binary) Stella-3.9.2-macosx.dmg (32-bit Universal Binary)
Stella-3.9.1_intel-macosx.dmg (32/64-bit Intel/OSX 10.6+) Stella-3.9.2_intel-macosx.dmg (32/64-bit Intel/OSX 10.6+)
* Binary distribution in 32-bit & 64-bit Ubuntu DEB format : * Binary distribution in 32-bit & 64-bit Ubuntu DEB format :
stella_3.9.1-1_i386.deb stella_3.9.2-1_i386.deb
stella_3.9.1-1_amd64.deb stella_3.9.2-1_amd64.deb
* Binary distribution in 32-bit & 64-bit RPM format : * Binary distribution in 32-bit & 64-bit RPM format :
stella-3.9.1-2.i386.rpm stella-3.9.2-2.i386.rpm
stella-3.9.1-2.x86_64.rpm stella-3.9.2-2.x86_64.rpm
* Source code distribution for all platforms : * Source code distribution for all platforms :
stella-3.9.1-src.tar.gz stella-3.9.2-src.tar.gz
Distribution Site Distribution Site

View File

@ -12,7 +12,7 @@
Release History Release History
=========================================================================== ===========================================================================
3.9.1 to 3.9.2: (August xx, 2013) 3.9.1 to 3.9.2: (August 31, 2013)
* Improved parsing of the DASM lst file for the debugger disassembly; * Improved parsing of the DASM lst file for the debugger disassembly;
it sometimes missed constant declarations. it sometimes missed constant declarations.
@ -31,6 +31,10 @@
* Renamed 'debuggerres' argument to 'dbg.res'. All future debugger- * Renamed 'debuggerres' argument to 'dbg.res'. All future debugger-
specific options will start with 'dbg.'. specific options will start with 'dbg.'.
* The TIA 'zoom' area in the debugger now supports scrolling the
mouse wheel (currently up/down only, as I don't have a sideways
scrolling mouse to test with).
-Have fun! -Have fun!

7
debian/changelog vendored
View File

@ -1,3 +1,10 @@
stella (3.9.2-1) stable; urgency=high
* Version 3.9.2 release
-- Stephen Anthony <stephena@users.sf.net> Sat, 31 Aug 2013 11:13:43 -0230
stella (3.9.1-1) stable; urgency=high stella (3.9.1-1) stable; urgency=high
* Version 3.9.1 release * Version 3.9.1 release

View File

@ -22,7 +22,7 @@
#include <cstdlib> #include <cstdlib>
#define STELLA_VERSION "3.9.2_beta1" #define STELLA_VERSION "3.9.2"
#define STELLA_BUILD atoi("$Rev$" + 6) #define STELLA_BUILD atoi("$Rev$" + 6)
#endif #endif

View File

@ -131,6 +131,14 @@ inline int BSPF_compareIgnoreCase(const string& s1, const string& s2)
return strcasecmp(s1.c_str(), s2.c_str()); return strcasecmp(s1.c_str(), s2.c_str());
#endif #endif
} }
inline int BSPF_compareIgnoreCase(const char* s1, const char* s2)
{
#if defined WIN32 && !defined __GNUG__
return _stricmp(s1, s2);
#else
return strcasecmp(s1, s2);
#endif
}
// Test whether the first string starts with the second one (case insensitive) // Test whether the first string starts with the second one (case insensitive)
inline bool BSPF_startsWithIgnoreCase(const string& s1, const string& s2) inline bool BSPF_startsWithIgnoreCase(const string& s1, const string& s2)
@ -141,6 +149,14 @@ inline bool BSPF_startsWithIgnoreCase(const string& s1, const string& s2)
return strncasecmp(s1.c_str(), s2.c_str(), s2.length()) == 0; return strncasecmp(s1.c_str(), s2.c_str(), s2.length()) == 0;
#endif #endif
} }
inline bool BSPF_startsWithIgnoreCase(const char* s1, const char* s2)
{
#if defined WIN32 && !defined __GNUG__
return _strnicmp(s1, s2, strlen(s2)) == 0;
#else
return strncasecmp(s1, s2, strlen(s2)) == 0;
#endif
}
// Test whether two strings are equal (case insensitive) // Test whether two strings are equal (case insensitive)
inline bool BSPF_equalsIgnoreCase(const string& s1, const string& s2) inline bool BSPF_equalsIgnoreCase(const string& s1, const string& s2)
@ -163,7 +179,7 @@ inline bool BSPF_endsWithIgnoreCase(const string& s1, const string& s2)
if(s1.length() >= s2.length()) if(s1.length() >= s2.length())
{ {
const char* end = s1.c_str() + s1.length() - s2.length(); const char* end = s1.c_str() + s1.length() - s2.length();
return BSPF_equalsIgnoreCase(end, s2.c_str()); return BSPF_compareIgnoreCase(end, s2.c_str()) == 0;
} }
return false; return false;
} }

View File

@ -45,7 +45,7 @@ TiaOutputWidget::TiaOutputWidget(GuiObject* boss, const GUI::Font& font,
l.push_back("Fill to scanline", "scanline"); l.push_back("Fill to scanline", "scanline");
l.push_back("Set breakpoint", "bp"); l.push_back("Set breakpoint", "bp");
l.push_back("Set zoom position", "zoom"); l.push_back("Set zoom position", "zoom");
l.push_back("Toggle fixed debug colors", "fixed"); l.push_back("Toggle fixed debug colors (from beam pos)", "fixed");
myMenu = new ContextMenu(this, font, l); myMenu = new ContextMenu(this, font, l);
} }

View File

@ -34,11 +34,11 @@ TiaZoomWidget::TiaZoomWidget(GuiObject* boss, const GUI::Font& font,
CommandSender(boss), CommandSender(boss),
myMenu(NULL) myMenu(NULL)
{ {
_flags = WIDGET_ENABLED | WIDGET_CLEARBG | WIDGET_RETAIN_FOCUS; _flags = WIDGET_ENABLED | WIDGET_CLEARBG |
WIDGET_RETAIN_FOCUS | WIDGET_TRACK_MOUSE;
_bgcolor = _bgcolorhi = kDlgColor; _bgcolor = _bgcolorhi = kDlgColor;
// Use all available space, up to the maximum bounds of the TIA image // Use all available space, up to the maximum bounds of the TIA image
// Width myst
_w = BSPF_min(w, 320); _w = BSPF_min(w, 320);
_h = BSPF_min(h, 260); _h = BSPF_min(h, 260);
@ -48,10 +48,10 @@ TiaZoomWidget::TiaZoomWidget(GuiObject* boss, const GUI::Font& font,
myZoomLevel = 2; myZoomLevel = 2;
myNumCols = ((_w - 4) >> 1) / myZoomLevel; myNumCols = ((_w - 4) >> 1) / myZoomLevel;
myNumRows = (_h - 4) / myZoomLevel; myNumRows = (_h - 4) / myZoomLevel;
myXoff = 0; myXOff = myYOff = 0;
myYoff = 0;
myXCenter = myNumCols >> 1; myMouseMoving = false;
myYCenter = myNumRows >> 1; myXClick = myYClick = 0;
// Create context menu for zoom levels // Create context menu for zoom levels
VariantList l; VariantList l;
@ -76,11 +76,9 @@ void TiaZoomWidget::loadConfig()
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void TiaZoomWidget::setPos(int x, int y) void TiaZoomWidget::setPos(int x, int y)
{ {
// Center zoom on given x,y point // Center on given x,y point
myXCenter = x >> 1; myXOff = (x >> 1) - (myNumCols >> 1);
myYCenter = y; myYOff = y - (myNumRows >> 1);
//cerr << " ==> myXCenter = " << myXCenter << ", myYCenter = " << myYCenter << endl;
recalc(); recalc();
} }
@ -92,8 +90,8 @@ void TiaZoomWidget::zoom(int level)
return; return;
myZoomLevel = level; myZoomLevel = level;
myNumCols = ((_w - 4) >> 1) / myZoomLevel; myNumCols = ((_w - 4) >> 1) / myZoomLevel;
myNumRows = (_h - 4) / myZoomLevel; myNumRows = (_h - 4) / myZoomLevel;
recalc(); recalc();
} }
@ -101,46 +99,85 @@ void TiaZoomWidget::zoom(int level)
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void TiaZoomWidget::recalc() void TiaZoomWidget::recalc()
{ {
const int tw = instance().console().tia().width(),
th = instance().console().tia().height();
// Don't go past end of framebuffer // Don't go past end of framebuffer
const int width = instance().console().tia().width(), myXOff = BSPF_clamp(myXOff, 0, tw - myNumCols);
height = instance().console().tia().height(); myYOff = BSPF_clamp(myYOff, 0, th - myNumRows);
// Figure out the bounding rectangle for the current center coords setDirty(); draw();
const int xoff = myNumCols >> 1,
yoff = myNumRows >> 1;
if(myXCenter < xoff)
myXCenter = xoff;
else if(myXCenter + xoff >= width)
myXCenter = width - xoff - 1;
else if(myYCenter < yoff)
myYCenter = yoff;
else if(myYCenter + yoff >= height)
myYCenter = height - yoff - 1;
// Only redraw when necessary
int oldXoff = myXoff, oldYoff = myYoff;
myXoff = BSPF_max(0, myXCenter - (myNumCols >> 1));
myYoff = BSPF_max(0, myYCenter - (myNumRows >> 1));
if(oldXoff != myXoff || oldYoff != myYoff)
{
setDirty(); draw();
//cerr << " OLD ==> myXoff: " << oldXoff << ", myYoff = " << oldYoff << endl;
//cerr << " NEW ==> myXoff: " << myXoff << ", myYoff = " << myYoff << endl << endl;
}
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void TiaZoomWidget::handleMouseDown(int x, int y, int button, int clickCount) void TiaZoomWidget::handleMouseDown(int x, int y, int button, int clickCount)
{ {
// Grab right mouse button for zoom context menu // Button 1 is for 'drag'/movement of the image
if(button == 2) // Button 2 is for context menu
if(button == 1)
{
// Indicate mouse drag started/in progress
myMouseMoving = true;
myXClick = x;
myYClick = y;
}
else if(button == 2)
{ {
// Add menu at current x,y mouse location // Add menu at current x,y mouse location
myMenu->show(x + getAbsX(), y + getAbsY()); myMenu->show(x + getAbsX(), y + getAbsY());
} }
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void TiaZoomWidget::handleMouseUp(int x, int y, int button, int clickCount)
{
myMouseMoving = false;
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void TiaZoomWidget::handleMouseWheel(int x, int y, int direction)
{
if(direction > 0)
handleEvent(Event::UIDown);
else
handleEvent(Event::UIUp);
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void TiaZoomWidget::handleMouseMoved(int x, int y, int button)
{
// TODO: Not yet working - finish for next release
#if 0
if(myMouseMoving)
{
if(x < 0 || y < 0 || x > _w || y > _h)
return;
int diffx = ((x - myXClick) >> 1);// / myZoomLevel;
int diffy = (y - myYClick);// / myZoomLevel;
// myXClick = x;
// myYClick = y;
//cerr << diffx << " " << diffy << endl;
myXOff -= diffx;
myYOff -= diffy;
recalc();
// cerr << x << ", " << y << endl;
}
#endif
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void TiaZoomWidget::handleMouseLeft(int button)
{
myMouseMoving = false;
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
bool TiaZoomWidget::handleEvent(Event::Type event) bool TiaZoomWidget::handleEvent(Event::Type event)
{ {
@ -149,35 +186,35 @@ bool TiaZoomWidget::handleEvent(Event::Type event)
switch(event) switch(event)
{ {
case Event::UIUp: case Event::UIUp:
myYCenter -= 4; myYOff -= 4;
break; break;
case Event::UIDown: case Event::UIDown:
myYCenter += 4; myYOff += 4;
break; break;
case Event::UILeft: case Event::UILeft:
myXCenter -= 2; myXOff -= 2;
break; break;
case Event::UIRight: case Event::UIRight:
myXCenter += 2; myXOff += 2;
break; break;
case Event::UIPgUp: case Event::UIPgUp:
myYCenter = 0; myYOff = 0;
break; break;
case Event::UIPgDown: case Event::UIPgDown:
myYCenter = 260; myYOff = _h;
break; break;
case Event::UIHome: case Event::UIHome:
myXCenter = 0; myXOff = 0;
break; break;
case Event::UIEnd: case Event::UIEnd:
myXCenter = 320; myXOff = _w;
break; break;
default: default:
@ -230,9 +267,9 @@ void TiaZoomWidget::drawWidget(bool hilite)
scanoffset = width * scany + scanx; scanoffset = width * scany + scanx;
int x, y, col, row; int x, y, col, row;
for(y = myYoff, row = 0; y < myNumRows+myYoff; ++y, row += hzoom) for(y = myYOff, row = 0; y < myNumRows+myYOff; ++y, row += hzoom)
{ {
for(x = myXoff, col = 0; x < myNumCols+myXoff; ++x, col += wzoom) for(x = myXOff, col = 0; x < myNumCols+myXOff; ++x, col += wzoom)
{ {
uInt32 idx = y*width + x; uInt32 idx = y*width + x;
uInt32 color = currentFrame[idx] | (idx > scanoffset ? 1 : 0); uInt32 color = currentFrame[idx] | (idx > scanoffset ? 1 : 0);

View File

@ -39,6 +39,10 @@ class TiaZoomWidget : public Widget, public CommandSender
protected: protected:
void handleMouseDown(int x, int y, int button, int clickCount); void handleMouseDown(int x, int y, int button, int clickCount);
void handleMouseUp(int x, int y, int button, int clickCount);
void handleMouseWheel(int x, int y, int direction);
void handleMouseMoved(int x, int y, int button);
void handleMouseLeft(int button);
bool handleEvent(Event::Type event); bool handleEvent(Event::Type event);
void handleCommand(CommandSender* sender, int cmd, int data, int id); void handleCommand(CommandSender* sender, int cmd, int data, int id);
@ -54,8 +58,10 @@ class TiaZoomWidget : public Widget, public CommandSender
int myZoomLevel; int myZoomLevel;
int myNumCols, myNumRows; int myNumCols, myNumRows;
int myXoff, myYoff; int myXOff, myYOff;
int myXCenter, myYCenter;
bool myMouseMoving;
int myXClick, myYClick;
}; };
#endif #endif

View File

@ -53,7 +53,7 @@
<key>CFBundleSignature</key> <key>CFBundleSignature</key>
<string>StLa</string> <string>StLa</string>
<key>CFBundleVersion</key> <key>CFBundleVersion</key>
<string>3.9.1</string> <string>3.9.2</string>
<key>NSMainNibFile</key> <key>NSMainNibFile</key>
<string>SDLMain.nib</string> <string>SDLMain.nib</string>
<key>NSPrincipalClass</key> <key>NSPrincipalClass</key>

View File

@ -1,5 +1,5 @@
%define name stella %define name stella
%define version 3.9.1 %define version 3.9.2
%define rel 1 %define rel 1
%define enable_gl 1 %define enable_gl 1
@ -108,6 +108,9 @@ rm -rf $RPM_BUILD_DIR/%{name}-%{version}
%_datadir/icons/large/%{name}.png %_datadir/icons/large/%{name}.png
%changelog %changelog
* Sat Aug 31 2013 Stephen Anthony <stephena@users.sf.net> 3.9.2-1
- Version 3.9.2 release
* Wed Aug 21 2013 Stephen Anthony <stephena@users.sf.net> 3.9.1-1 * Wed Aug 21 2013 Stephen Anthony <stephena@users.sf.net> 3.9.1-1
- Version 3.9.1 release - Version 3.9.1 release

View File

@ -36,8 +36,8 @@ IDI_ICON ICON "stella.ico"
// //
VS_VERSION_INFO VERSIONINFO VS_VERSION_INFO VERSIONINFO
FILEVERSION 3,9,1,0 FILEVERSION 3,9,2,0
PRODUCTVERSION 3,9,1,0 PRODUCTVERSION 3,9,2,0
FILEFLAGSMASK 0x3fL FILEFLAGSMASK 0x3fL
#ifdef _DEBUG #ifdef _DEBUG
FILEFLAGS 0x1L FILEFLAGS 0x1L
@ -55,12 +55,12 @@ BEGIN
VALUE "Comments", "The multi-platform Atari 2600 emulator. Stella is released under the GPLv2." VALUE "Comments", "The multi-platform Atari 2600 emulator. Stella is released under the GPLv2."
VALUE "CompanyName", "The Stella Team (http://stella.sourceforge.net)" VALUE "CompanyName", "The Stella Team (http://stella.sourceforge.net)"
VALUE "FileDescription", "Stella" VALUE "FileDescription", "Stella"
VALUE "FileVersion", "3.9.1" VALUE "FileVersion", "3.9.2"
VALUE "InternalName", "Stella" VALUE "InternalName", "Stella"
VALUE "LegalCopyright", "Copyright (C) 1995-2013 The Stella Team" VALUE "LegalCopyright", "Copyright (C) 1995-2013 The Stella Team"
VALUE "OriginalFilename", "Stella.exe" VALUE "OriginalFilename", "Stella.exe"
VALUE "ProductName", "Stella" VALUE "ProductName", "Stella"
VALUE "ProductVersion", "3.9.1" VALUE "ProductVersion", "3.9.2"
END END
END END
BLOCK "VarFileInfo" BLOCK "VarFileInfo"