pkgsrc-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[pkgsrc/trunk]: pkgsrc/emulators/dosbox-x dosbox-x: update to 0.83.23



details:   https://anonhg.NetBSD.org/pkgsrc/rev/a711fe6f5100
branches:  trunk
changeset: 374946:a711fe6f5100
user:      nia <nia%pkgsrc.org@localhost>
date:      Fri Mar 04 07:41:14 2022 +0000

description:
dosbox-x: update to 0.83.23

0.83.23
  - Fixed XGA accelerated rendering for ViRGE emulation
    and 24 bits/pixel display modes. Since Windows drivers
    insist on 24bpp, this is necessary for
    "Truecolor (24-bit)" to display and render correctly.
  - dosbox.conf option "vesa vbe 1.2 modes are 32bpp" is
    now "true" "false" or "auto", where "auto" determines
    this setting based on which S3 chipset is being
    emulated. It seems the Windows drivers for ViRGE
    chipsets require 24bpp for truecolor modes, in fact,
    they do not even offer 32bpp as an option. Since
    the Windows 3.1/95/98 drivers use VESA BIOS calls to
    set video modes, this implies that the VESA BIOS on
    ViRGE cards are also making the base modes 24bpp rather
    than 32bpp. Note that the Windows drivers for older S3
    chipsets are perfectly happy to use 32bpp unless you
    select "16.7 million colors (1 Meg)" in Windows 3.1,
    which is the only option in those drivers to offer
    24bpp. To avoid grief with DOSBox-X users, "auto"
    is the default setting.
  - Added basic S3 ViRGE XGA acceleration. It's enough for
    90% of the GDI functions in Windows 3.1 so far.
  - Fixed S3 rectangle XGA accelerated pattern blit, when
    using display memory as the pattern mask source, to
    follow S3 Trio32/Trio64 documentation, instead of the
    DOSBox SVN educated guess, to resolve some edge cases
    where the wrong color is chosen to draw filled rectangles
    in Windows 3.1. This fixes the "basement" in Microsoft
    Creative Writer so that clicking around no longer leaves
    white boxes on the screen.
  - Extend 256-color foreground/background color behavior
    from S3 86c928 to Vision864 and Vision868 as Windows
    95 behavior suggests they handle the hardware cursor
    the same way in 256-color mode.
  - Extend "divide cursor X position by bytes per pixel"
    behavior from S3 86c928 to Vision864 and Vision868
    emulation as well, based on Windows 3.1 video driver
    behavior.
  - Gravis Ultrasound: Most I/O registers except port 3x4
    are intended for 8-bit I/O. If 16-bit I/O occurs to
    such registers, handle as two 8-bit I/O cycles. I
    found something in the Demoscene (1997 demo "Atlantis,
    Deep Like A Sea") that uses a 16-bit I/O write to write
    current channel and register select in one write.
    Prior to this fix, there was no music other than quiet
    popping noises in DOSBox-X.
  - Sound Blaster: Fixed DSP command 0x48 (Set DSP block
    transfer size) to accept block size as BYTES as
    standardized by Creative and convert to SAMPLES
    internally. This fixes stuttering voices in Freddy
    Pharkas when sbtype=sb16. (joncampbell123)
  - Avoid crashes due to assertion failure when media
    keys are pressed (maron2000)
  - Fix CD audio playback failure (cue + mp3) when
    trying to play from pregap sectors. (maron2000)
  - Change default value of mt32.rate to 48kHz to match
    default value of mt32.analog option. (maron2000)
  - Fix a buffer overflow issue in dos.cpp (maron2000)

diffstat:

 emulators/dosbox-x/Makefile                                |  14 +++-----------
 emulators/dosbox-x/distinfo                                |  10 +++++-----
 emulators/dosbox-x/patches/patch-src_dos_dos__programs.cpp |  11 ++++++-----
 3 files changed, 14 insertions(+), 21 deletions(-)

diffs (81 lines):

diff -r 3565df3aa50c -r a711fe6f5100 emulators/dosbox-x/Makefile
--- a/emulators/dosbox-x/Makefile       Fri Mar 04 07:13:06 2022 +0000
+++ b/emulators/dosbox-x/Makefile       Fri Mar 04 07:41:14 2022 +0000
@@ -1,7 +1,6 @@
-# $NetBSD: Makefile,v 1.32 2021/12/08 16:04:15 adam Exp $
+# $NetBSD: Makefile,v 1.33 2022/03/04 07:41:14 nia Exp $
 
-DISTNAME=      dosbox-x-0.83.16
-PKGREVISION=   3
+DISTNAME=      dosbox-x-0.83.23
 CATEGORIES=    emulators
 MASTER_SITES=  ${MASTER_SITE_GITHUB:=joncampbell123/}
 GITHUB_TAG=    dosbox-x-v${PKGVERSION_NOREV}
@@ -44,18 +43,11 @@
 NOT_PAX_MPROTECT_SAFE+=        bin/dosbox-x
 .endif
 
-PKGCONFIG_OVERRIDE+=   vs2015/libpng/libpng.pc.in
-PKGCONFIG_OVERRIDE+=   vs2015/sdl/sdl.pc.in
-PKGCONFIG_OVERRIDE+=   vs2015/sdl2/sdl2.pc.in
-PKGCONFIG_OVERRIDE+=   vs2015/sdlnet/SDL_net.pc.in
-PKGCONFIG_OVERRIDE+=   vs2015/zlib/zlib.pc.in
-
 INSTALLATION_DIRS+=    bin share/dosbox-x
 INSTALLATION_DIRS+=    share/applications
 INSTALLATION_DIRS+=    share/pixmaps
 
-CHECK_PORTABILITY_SKIP+=       vs2015/sdl2/build-scripts/androidbuildlibs.sh
-CHECK_PORTABILITY_SKIP+=       vs2015/sdl2/build-scripts/iosbuild.sh
+CHECK_PORTABILITY_SKIP+=       vs/sdl2/build-scripts/*.sh
 CHECK_PORTABILITY_SKIP+=       make-flatpak-sdl2.sh
 CHECK_PORTABILITY_SKIP+=       make-flatpak.sh
 # [[ is used in an developer target that isn't useful for us
diff -r 3565df3aa50c -r a711fe6f5100 emulators/dosbox-x/distinfo
--- a/emulators/dosbox-x/distinfo       Fri Mar 04 07:13:06 2022 +0000
+++ b/emulators/dosbox-x/distinfo       Fri Mar 04 07:41:14 2022 +0000
@@ -1,9 +1,9 @@
-$NetBSD: distinfo,v 1.19 2021/10/26 10:23:48 nia Exp $
+$NetBSD: distinfo,v 1.20 2022/03/04 07:41:14 nia Exp $
 
-BLAKE2s (dosbox-x-0.83.16.tar.gz) = 521ff7f0d9a88c0f967cfbb2637969259528d0871bfcd10e6c05a327dc32ee0c
-SHA512 (dosbox-x-0.83.16.tar.gz) = f2be5a3d16d2377719a78b9e0f98ef69128370d951e67257b58ba4fb5dc654e40dae14773cf2cf89104406a4608b58dcc89f70cbd00e03e41979cb4d9f23ba99
-Size (dosbox-x-0.83.16.tar.gz) = 61998617 bytes
+BLAKE2s (dosbox-x-0.83.23.tar.gz) = d6cff5e7e54f3f63757bf0f41f2aa6c635c5bc7c029ebb5b69a0d2c55afe2b8c
+SHA512 (dosbox-x-0.83.23.tar.gz) = 26ca2fd8753cee8c4c931c54b6a0d0af11144c6b770c16f2b482386b06529ce1567e74d355fb9163e9801e833b4546482469e67def80e1aa1b93652663f31fbe
+Size (dosbox-x-0.83.23.tar.gz) = 64494344 bytes
 SHA1 (patch-configure.ac) = 906aa99b5fce6224ef4c001d9bba1e4fc89a34f9
 SHA1 (patch-include_dosbox.h) = 6f7397b4a611511fc1782b1603c9f5cd51b74eb9
-SHA1 (patch-src_dos_dos__programs.cpp) = 1f64cdd66c5b850609dbe7634f60da96fba7655e
+SHA1 (patch-src_dos_dos__programs.cpp) = 64444c54b319fbfc7de7219d88fa6add953a0fb0
 SHA1 (patch-src_libs_physfs_physfs__platform__unix.c) = 5cde2acf3691478f1d91945b3942c968af2eadc6
diff -r 3565df3aa50c -r a711fe6f5100 emulators/dosbox-x/patches/patch-src_dos_dos__programs.cpp
--- a/emulators/dosbox-x/patches/patch-src_dos_dos__programs.cpp        Fri Mar 04 07:13:06 2022 +0000
+++ b/emulators/dosbox-x/patches/patch-src_dos_dos__programs.cpp        Fri Mar 04 07:41:14 2022 +0000
@@ -1,20 +1,21 @@
-$NetBSD: patch-src_dos_dos__programs.cpp,v 1.2 2021/08/10 11:03:50 nia Exp $
+$NetBSD: patch-src_dos_dos__programs.cpp,v 1.3 2022/03/04 07:41:14 nia Exp $
 
 dos_programs.cpp: In member function 'bool AUTOTYPE::ReadDoubleArg(const string&, const char*, const double&, const double&, const double&, double&)':
 dos_programs.cpp:5556:12: error: expected unqualified-id before '(' token
    if (std::isfinite(user_value)) {
 
---- src/dos/dos_programs.cpp.orig      2021-08-01 07:45:55.000000000 +0000
+--- src/dos/dos_programs.cpp.orig      2022-03-01 02:12:39.000000000 +0000
 +++ src/dos/dos_programs.cpp
-@@ -6446,11 +6446,7 @@ bool AUTOTYPE::ReadDoubleArg(const std::
+@@ -6756,11 +6756,7 @@ bool AUTOTYPE::ReadDoubleArg(const std::
        if (cmd->FindString(flag, str_value, true)) {
                // Can the user's value be parsed?
                const double user_value = to_finite<double>(str_value);
--#if defined(MACOSX) || defined(EMSCRIPTEN) || ((defined(ANDROID) || defined(__ANDROID__)) && defined(__clang__))
-               if (isfinite(user_value)) { /* *sigh* Really, clang, really? */
+-#if defined(__FreeBSD__) || defined(MACOSX) || defined(EMSCRIPTEN) || ((defined(ANDROID) || defined(__ANDROID__)) && defined(__clang__))
+-              if (isfinite(user_value)) { /* *sigh* Really, clang, really? */
 -#else
 -              if (std::isfinite(user_value)) {
 -#endif
++              if (isfinite(user_value)) {
                        result = true;
  
                        // Clamp the user's value if needed



Home | Main Index | Thread Index | Old Index