Even more work
This commit is contained in:
parent
0af1300fe0
commit
a939188406
15 changed files with 406 additions and 409 deletions
3
.envrc
3
.envrc
|
@ -1 +1,2 @@
|
|||
use flake path:. --impure --show-trace
|
||||
export NIXPKGS_ALLOW_BROKEN=1
|
||||
use nix
|
||||
|
|
42
flake.lock
42
flake.lock
|
@ -1,42 +0,0 @@
|
|||
{
|
||||
"nodes": {
|
||||
"nixpkgs": {
|
||||
"locked": {
|
||||
"lastModified": 1726755586,
|
||||
"narHash": "sha256-PmUr/2GQGvFTIJ6/Tvsins7Q43KTMvMFhvG6oaYK+Wk=",
|
||||
"owner": "NixOS",
|
||||
"repo": "nixpkgs",
|
||||
"rev": "c04d5652cfa9742b1d519688f65d1bbccea9eb7e",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
"owner": "NixOS",
|
||||
"ref": "nixos-unstable",
|
||||
"repo": "nixpkgs",
|
||||
"type": "github"
|
||||
}
|
||||
},
|
||||
"root": {
|
||||
"inputs": {
|
||||
"nixpkgs": "nixpkgs",
|
||||
"systems": "systems"
|
||||
}
|
||||
},
|
||||
"systems": {
|
||||
"locked": {
|
||||
"lastModified": 1681028828,
|
||||
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
|
||||
"owner": "nix-systems",
|
||||
"repo": "default",
|
||||
"rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
"id": "systems",
|
||||
"type": "indirect"
|
||||
}
|
||||
}
|
||||
},
|
||||
"root": "root",
|
||||
"version": 7
|
||||
}
|
61
flake.nix
61
flake.nix
|
@ -1,61 +0,0 @@
|
|||
{
|
||||
description = "A flake to use Chicken 6 with TinyCC.";
|
||||
|
||||
inputs = {
|
||||
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
||||
};
|
||||
|
||||
outputs = inputs @ {
|
||||
self,
|
||||
nixpkgs,
|
||||
systems,
|
||||
...
|
||||
}: let
|
||||
inherit (nixpkgs) lib;
|
||||
forAllSystems = lib.genAttrs [
|
||||
"aarch64-linux"
|
||||
"i686-linux"
|
||||
"x86_64-linux"
|
||||
"aarch64-darwin"
|
||||
"x86_64-darwin"
|
||||
];
|
||||
pkgsFor = forAllSystems (system:
|
||||
import nixpkgs {
|
||||
localSystem.system = system;
|
||||
overlays = with self.overlays; [chicken];
|
||||
});
|
||||
mkDate = longDate: (lib.concatStringsSep "-" [
|
||||
(builtins.substring 0 4 longDate)
|
||||
(builtins.substring 4 2 longDate)
|
||||
(builtins.substring 6 2 longDate)
|
||||
]);
|
||||
version = "5.4.0";
|
||||
in {
|
||||
overlays = {
|
||||
default = self.overlays.sdl3;
|
||||
|
||||
sdl3 = final: prev: {
|
||||
sdl3 = final.callPackage ./nix/sdl3.nix {
|
||||
stdenv = final.gcc13Stdenv;
|
||||
version = "2.99.0+date=" + (mkDate (self.lastModifiedDate or "19700101")) + "_" + (self.shortRev or "dirty");
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
devShells = forAllSystems (system: {
|
||||
default = let
|
||||
pkgs = import nixpkgs {
|
||||
overlays = [ self.overlays.sdl3 ];
|
||||
};
|
||||
in pkgs.mkShell {
|
||||
packages = with pkgs; [
|
||||
pkg-config rlwrap sdl3
|
||||
chicken chickenPackages_5.chickenEggs.apropos
|
||||
] ++ (with pkgs.chickenPackages_5.chickenEggs; [
|
||||
apropos chicken-doc srfi-1 srfi-18 lsp-server
|
||||
r7rs srfi-152
|
||||
]);
|
||||
};
|
||||
});
|
||||
};
|
||||
}
|
|
@ -1,5 +1,6 @@
|
|||
(import (scheme)
|
||||
(chicken base)
|
||||
(chicken bitwise)
|
||||
(chicken syntax)
|
||||
(srfi 152))
|
||||
|
||||
|
@ -10,18 +11,7 @@
|
|||
(char-upcase c)))
|
||||
in))
|
||||
|
||||
(define-syntax define-sdl-flag
|
||||
(er-macro-transformer
|
||||
(lambda (exp rename compare)
|
||||
(let ((flag (cadr exp)))
|
||||
`(begin
|
||||
(export ,flag)
|
||||
(define ,flag
|
||||
(foreign-value
|
||||
,(string-append "SDL_" (snake-upcase (symbol->string flag)))
|
||||
unsigned-int32)))))))
|
||||
|
||||
(define-syntax define-sdl-enum-values
|
||||
(define-syntax define-sdl-const-values
|
||||
(er-macro-transformer
|
||||
(lambda (exp rename compare)
|
||||
(let ((prefix (cadr exp))
|
||||
|
@ -38,3 +28,6 @@
|
|||
,(string-append "SDL_" (snake-upcase full-str))
|
||||
,type)))))
|
||||
enum-labels))))))
|
||||
|
||||
(define (foldl-uint-flags flags)
|
||||
(foldl bitwise-ior (car flags) (cdr flags)))
|
||||
|
|
|
@ -1,33 +1,43 @@
|
|||
(import (scheme)
|
||||
(chicken base)
|
||||
(chicken bitwise)
|
||||
(chicken foreign))
|
||||
(chicken foreign)
|
||||
(sdl internal utilities))
|
||||
(import-for-syntax (sdl3 internal utilities))
|
||||
|
||||
(foreign-declare "#include <SDL3/SDL_init.h>")
|
||||
|
||||
(define init-audio (foreign-value "SDL_INIT_AUDIO" unsigned-int32))
|
||||
(define init-video (foreign-value "SDL_INIT_VIDEO" unsigned-int32))
|
||||
(define init-joystick (foreign-value "SDL_INIT_JOYSTICK" unsigned-int32))
|
||||
(define init-haptic (foreign-value "SDL_INIT_HAPTIC" unsigned-int32))
|
||||
(define init-gamepad (foreign-value "SDL_INIT_GAMEPAD" unsigned-int32))
|
||||
(define init-events (foreign-value "SDL_INIT_EVENTS" unsigned-int32))
|
||||
(define init-sensor (foreign-value "SDL_INIT_SENSOR" unsigned-int32))
|
||||
(define init-camera (foreign-value "SDL_INIT_CAMERA" unsigned-int32))
|
||||
;;; Types
|
||||
|
||||
(define-foreign-type SDL_InitFlags unsigned-int32)
|
||||
(define-foreign-type SDL_AppResult (enum "SDL_AppResult"))
|
||||
|
||||
;;; Constants
|
||||
|
||||
(define-sdl-const-values
|
||||
init SDL_InitFlags
|
||||
(audio video joystick haptic gamepad events sensor camera))
|
||||
|
||||
(define-sdl-const-values
|
||||
app SDL_AppResult
|
||||
(continue success failure))
|
||||
|
||||
;;; Procedures
|
||||
|
||||
(define (init #!rest flags)
|
||||
((foreign-lambda bool "SDL_Init" unsigned-int32)
|
||||
(foldl bitwise-ior (car flags) (cdr flags))))
|
||||
((foreign-lambda bool "SDL_Init" SDL_InitFlags)
|
||||
(foldl-uint-flags flags)))
|
||||
|
||||
(define (init-sub-system #!rest flags)
|
||||
((foreign-lambda bool "SDL_InitSubSystem" unsigned-int32)
|
||||
(foldl bitwise-ior (car flags) (cdr flags))))
|
||||
((foreign-lambda bool "SDL_InitSubSystem" SDL_InitFlags)
|
||||
(foldl-uint-flags flags)))
|
||||
|
||||
(define quit
|
||||
(foreign-lambda void "SDL_Quit" void))
|
||||
|
||||
(define (quit-sub-system #!rest flags)
|
||||
((foreign-lambda void "SDL_QuitSubSystem" unsigned-int32)
|
||||
(foldl bitwise-ior (car flags) (cdr flags))))
|
||||
((foreign-lambda void "SDL_QuitSubSystem" SDL_InitFlags)
|
||||
(foldl-uint-flags flags)))
|
||||
|
||||
(define set-app-metadata
|
||||
(foreign-lambda bool "SDL_SetAppMetadata" c-string c-string c-string))
|
||||
|
@ -39,5 +49,5 @@
|
|||
(foreign-lambda c-string "SDL_GetAppMetadataProperty" c-string))
|
||||
|
||||
(define (was-init #!rest flags)
|
||||
((foreign-lambda unsigned-int32 "SDL_WasInit" unsigned-int32)
|
||||
(foldl bitwise-ior (car flags) (cdr flags))))
|
||||
((foreign-lambda SDL_InitFlags "SDL_WasInit" SDL_InitFlags)
|
||||
(foldl-uint-flags flags)))
|
||||
|
|
|
@ -5,84 +5,129 @@
|
|||
|
||||
(foreign-declare "#include <SDL3/SDL_video.h>")
|
||||
|
||||
(define-sdl-flag window-fullscreen)
|
||||
(define-sdl-flag window-opengl)
|
||||
(define-sdl-flag window-occluded)
|
||||
(define-sdl-flag window-hidden)
|
||||
(define-sdl-flag window-borderless)
|
||||
(define-sdl-flag window-resizable)
|
||||
(define-sdl-flag window-minimized)
|
||||
(define-sdl-flag window-maximized)
|
||||
(define-sdl-flag window-mouse-grabbed)
|
||||
(define-sdl-flag window-input-focus)
|
||||
(define-sdl-flag window-mouse-focus)
|
||||
(define-sdl-flag window-external)
|
||||
(define-sdl-flag window-modal)
|
||||
(define-sdl-flag window-high-pixel-density)
|
||||
(define-sdl-flag window-mouse-capture)
|
||||
(define-sdl-flag window-mouse-relative-mode)
|
||||
(define-sdl-flag window-always-on-top)
|
||||
(define-sdl-flag window-utility)
|
||||
(define-sdl-flag window-tooltip)
|
||||
(define-sdl-flag window-popup-menu)
|
||||
(define-sdl-flag window-keyboard-grabbed)
|
||||
(define-sdl-flag window-vulkan)
|
||||
(define-sdl-flag window-metal)
|
||||
(define-sdl-flag window-transparent)
|
||||
(define-sdl-flag window-not-focusable)
|
||||
;;; Types
|
||||
|
||||
(define create-popup-window
|
||||
(foreign-lambda (c-pointer (struct "SDL_Window")) "SDL_CreatePopupWindow"
|
||||
(struct "SDL_Window") int int int int unsigned-int32))
|
||||
(define-foreign-type SDL_DisplayID unsigned-int32)
|
||||
(define-foreign-type SDL_WindowID unsigned-int32)
|
||||
(define-foreign-type SDL_EGLAttrib size_t)
|
||||
(define-foreign-type SDL_EGLAttribArrayCallback
|
||||
(function SDL_EGLAttrib () "SDLCALL"))
|
||||
(define-foreign-type SDL_EGLDisplay c-pointer)
|
||||
(define-foreign-type SDL_GLContext (struct "SDL_GLContext"))
|
||||
(define-foreign-type SDL_HitTest
|
||||
(function SDL_HitTestResult ((c-pointer SDL_Window) (c-pointer SDL_Point) c-pointer)))
|
||||
(define-foreign-type SDL_Window (struct "SDL_Window"))
|
||||
(define-foreign-type SDL_DisplayMode (struct "SDL_DisplayMode"))
|
||||
|
||||
;;; Constants
|
||||
|
||||
(define-foreign-type SDL_DisplayOrientation (enum "SDL_DisplayOrientation"))
|
||||
(define-sdl-const-values
|
||||
orientation SDL_DisplayOrientation
|
||||
(unknown landscape landscape-flipped portrait portrait-flipped))
|
||||
|
||||
(define-foreign-type SDL_FlashOperation (enum "SDL_FlashOperation"))
|
||||
(define-sdl-const-values
|
||||
flash SDL_FlashOperation
|
||||
(cancel briefly until-focused))
|
||||
|
||||
(define-foreign-type SDL_GLattr (enum "SDL_GLattr"))
|
||||
(define-sdl-const-values
|
||||
(gl SDL_GLattr
|
||||
red-size green-size blue-size alpha-size buffer-size doublebuffer depth-size
|
||||
stencil-size accum-red-size accum-green-size accum-blue-size accum-alpha-size
|
||||
stereo multisamplebuffers multisamplesamples accelerated-visual retained-backing
|
||||
context-major-version context-minor-version context-flags context-profile-mask
|
||||
share-with-current-context framebuffer-srgb-capable context-release-behavior
|
||||
context-reset-notification context-no-error floatbuffers egl-platform))
|
||||
|
||||
(define-foreign-type SDL_GLcontextFlag (enum "SDL_GLcontextFlag"))
|
||||
(define-sdl-const-values
|
||||
gl-context SDL_GLcontextFlag
|
||||
(debug-flag forward-compatible-flag robust-access-flag reset-isolation-flag))
|
||||
|
||||
(define-foreign-type SDL_GLcontextReleaseFlag (enum "SDL_GLcontextReleaseFlag"))
|
||||
(define-sdl-const-values
|
||||
gl-context-release-behavior SDL_GLcontestReleaseFlag
|
||||
(none flush))
|
||||
|
||||
(define-foreign-type SDL_GLContextResetNotification (enum "SDL_GLContextResetNotification"))
|
||||
(define-sdl-const-values
|
||||
gl-context-reset SDL_GLContextResetNotification
|
||||
(no-notification lose-context))
|
||||
|
||||
(define-foreign-type SDL_GLprofile (enum "SDL_GLprofile"))
|
||||
(define-sdl-const-values
|
||||
gl-context-profile SDL_GLprofile
|
||||
(core compatibility es))
|
||||
|
||||
(define-foreign-type SDL_HitTestResult (enum "SDL_HitTestResult"))
|
||||
(define-sdl-const-values
|
||||
hittest SDL_HitTestResult
|
||||
(normal draggable resize-topleft resize-top resize-topright resize-right
|
||||
resize-bottomright resize-bottom resize-bottomleft resize-left))
|
||||
|
||||
(define-foreign-type SDL_SystemTheme (enum "SDL_SystemTheme"))
|
||||
(define-sdl-const-values
|
||||
system-theme SDL_SystemTheme
|
||||
(unknown light dark))
|
||||
|
||||
(define-foreign-type SDL_WindowFlags unsigned-int64)
|
||||
(define-sdl-const-values
|
||||
window SDL_WindowFlags
|
||||
(fullscreen opengl occluded hidden borderless resizable minimized maximized
|
||||
mouse-grabbed input-focus mouse-focus external modal high-pixel-density
|
||||
mouse-capture mouse-relative-mode always-on-top utility tooltip popup-menu
|
||||
keyboard-grabbed vulkan metal transparent not-focusable))
|
||||
|
||||
;; These are weird string properties for CreateWindowWithProperties
|
||||
(define-sdl-const-values
|
||||
prop-window-create c-string
|
||||
(always-on-top-boolean borderless-boolean external-graphics-context-boolean
|
||||
focusable-boolean fullscreen-boolean height-number hidden-boolean
|
||||
high-pixel-density-boolean maximized-boolean menu-boolean
|
||||
metal-boolean minimized-boolean modal-boolean
|
||||
mouse-grabbed-boolean opengl-boolean parent-pointer
|
||||
resizable-boolean title-string transparent-boolean tooltip-boolean
|
||||
utility-boolean vulkan-boolean width-number x-number y-number
|
||||
cocoa-window-pointer cocoa-view-pointer
|
||||
wayland-surface-role-custom-boolean
|
||||
wayland-create-egl-window-boolean wayland-wl-surface-pointer
|
||||
win32-hwnd-pointer win32-pixel-format-hwnd-pointer
|
||||
x11-window-number))
|
||||
|
||||
(define-sdl-const-values
|
||||
pixelformat unsigned-int32
|
||||
(unknown index1lsb index1msb index2lsb index2msb index4lsb index4msb index8 rgb332
|
||||
xrgb4444 xbgr4444 xrgb1555 xbgr1555 argb4444 rgba4444 abgr4444 bgra4444 argb1555
|
||||
rgba5551 abgr1555 bgra5551 rgb565 bgr565 rgb24 bgr24 xrgb8888 rgbx8888
|
||||
pixelformat-xbgr8888 pbgrx8888 pargb8888 prgba8888 pabgr8888 pbgra8888
|
||||
pxrgb2101010 pxbgr2101010 pargb2101010 pabgr2101010 prgb48 pbgr48 prgba64
|
||||
pargb64 pbgra64 pabgr64 prgb48-float pbgr48-float prgba64-float pargb64-float
|
||||
pbgra64-float pabgr64-float prgb96-float pbgr96-float prgba128-float
|
||||
pargb128-float pbgra128-float pabgr128-float pyv12 piyuv pyuy2 puyvy pyvyu pnv12
|
||||
pnv21 pp010 external-oes rgba32 argb32 bgra32 abgr32 rgbx32 xrgb32 bgrx32
|
||||
xbgr32))
|
||||
|
||||
;;; Procedures
|
||||
|
||||
(define (create-popup-window parent offset-x offset-y w h #!rest flags)
|
||||
((foreign-lambda (c-pointer SDL_Window) "SDL_CreatePopupWindow"
|
||||
(struct SDL_Window) int int int int unsigned-int64)
|
||||
parent offset-x offset-y w h (foldl-uint-flags flags)))
|
||||
|
||||
(define (create-window title w h #!rest flags)
|
||||
((foreign-lambda (c-pointer (struct "SDL_Window")) "SDL_CreateWindow"
|
||||
((foreign-lambda (c-pointer SDL_Window) "SDL_CreateWindow"
|
||||
c-string int int unsigned-int32)
|
||||
title w h (foldl bitwise-ior (car flags) (cdr flags))))
|
||||
title w h (foldl-uint-flags flags)))
|
||||
|
||||
(define-sdl-flag prop-window-create-always-on-top-boolean)
|
||||
(define-sdl-flag prop-window-create-borderless-boolean)
|
||||
(define-sdl-flag prop-window-create-external-graphics-context-boolean)
|
||||
(define-sdl-flag prop-window-create-focusable-boolean)
|
||||
(define-sdl-flag prop-window-create-fullscreen-boolean)
|
||||
(define-sdl-flag prop-window-create-height-number)
|
||||
(define-sdl-flag prop-window-create-hidden-boolean)
|
||||
(define-sdl-flag prop-window-create-high-pixel-density-boolean)
|
||||
(define-sdl-flag prop-window-create-maximized-boolean)
|
||||
(define-sdl-flag prop-window-create-menu-boolean)
|
||||
(define-sdl-flag prop-window-create-metal-boolean)
|
||||
(define-sdl-flag prop-window-create-minimized-boolean)
|
||||
(define-sdl-flag prop-window-create-modal-boolean)
|
||||
(define-sdl-flag prop-window-create-mouse-grabbed-boolean)
|
||||
(define-sdl-flag prop-window-create-opengl-boolean)
|
||||
(define-sdl-flag prop-window-create-parent-pointer)
|
||||
(define-sdl-flag prop-window-create-resizable-boolean)
|
||||
(define-sdl-flag prop-window-create-title-string)
|
||||
(define-sdl-flag prop-window-create-transparent-boolean)
|
||||
(define-sdl-flag prop-window-create-tooltip-boolean)
|
||||
(define-sdl-flag prop-window-create-utility-boolean)
|
||||
(define-sdl-flag prop-window-create-vulkan-boolean)
|
||||
(define-sdl-flag prop-window-create-width-number)
|
||||
(define-sdl-flag prop-window-create-x-number)
|
||||
(define-sdl-flag prop-window-create-y-number)
|
||||
(define-sdl-flag prop-window-create-cocoa-window-pointer)
|
||||
(define-sdl-flag prop-window-create-cocoa-view-pointer)
|
||||
(define-sdl-flag prop-window-create-wayland-surface-role-custom-boolean)
|
||||
(define-sdl-flag prop-window-create-wayland-create-egl-window-boolean)
|
||||
(define-sdl-flag prop-window-create-wayland-wl-surface-pointer)
|
||||
(define-sdl-flag prop-window-create-win32-hwnd-pointer)
|
||||
(define-sdl-flag prop-window-create-win32-pixel-format-hwnd-pointer)
|
||||
(define-sdl-flag prop-window-create-x11-window-number)
|
||||
|
||||
(define (create-window-with-properties #!rest props)
|
||||
((foreign-lambda (c-pointer (struct "SDL_Window")) "SDL_CreateWindowWithProperties"
|
||||
(foldl bitwise-ior (car props) (cdr props)))))
|
||||
;; TODO: SDL_CreateWindowWithProperties
|
||||
|
||||
(define destroy-window
|
||||
(foreign-lambda void "SDL_DestroyWindow" (c-pointer (struct "SDL_Window"))))
|
||||
(foreign-lambda void "SDL_DestroyWindow" (c-pointer SDL_Window)))
|
||||
|
||||
(define destroy-window-surface
|
||||
(foreign-lambda bool "SDL_DestroyWindowSurface" (c-pointer (struct "SDL_Window"))))
|
||||
(foreign-lambda bool "SDL_DestroyWindowSurface" (c-pointer SDL_Window)))
|
||||
|
||||
(define disable-screen-saver
|
||||
(foreign-lambda bool "SDL_DisableScreenSaver"))
|
||||
|
@ -97,41 +142,33 @@
|
|||
(foreign-lambda c-pointer "SDL_EGL_GetProcAddress" c-string))
|
||||
|
||||
(define egl-get-window-surface
|
||||
(foreign-lambda c-pointer "SDL_EGL_GetWindowSurface" (c-pointer (struct "SDL_Window"))))
|
||||
(foreign-lambda c-pointer "SDL_EGL_GetWindowSurface" (c-pointer SDL_Window)))
|
||||
|
||||
;; TODO: SDL_EGL_SetAttributeCallbacks
|
||||
|
||||
(define enable-screen-saver
|
||||
(foreign-lambda bool "SDL_EnableScreenSaver"))
|
||||
|
||||
(define-sdl-enum-values
|
||||
flash int
|
||||
(cancel briefly until-focused))
|
||||
|
||||
(define flash-window
|
||||
(foreign-lambda bool "SDL_FlashWindow" (c-pointer (struct "SDL_Window")) (enum "SDL_FlashOperation")))
|
||||
(foreign-lambda bool "SDL_FlashWindow" (c-pointer SDL_Window) SDL_FlashOperation))
|
||||
|
||||
(define get-closest-fullscreen-display-mode
|
||||
(foreign-lambda bool "SDL_GetClosestFullscreenDisplayMode"
|
||||
unsigned-int32 int int float bool (c-pointer (struct "SDL_DisplayMode"))))
|
||||
SDL_DisplayID int int float bool (c-pointer SDL_DisplayMode)))
|
||||
|
||||
(define get-current-display-mode
|
||||
(foreign-lambda (c-pointer (struct "SDL_DisplayMode")) "SDL_DisplayMode" unsigned-int32))
|
||||
|
||||
(define-sdl-enum-values
|
||||
orientation int
|
||||
unknown landscape landscape-flipped portrait portrait-flipped)
|
||||
(foreign-lambda (c-pointer SDL_DisplayMode) "SDL_DisplayMode" SDL_DisplayID))
|
||||
|
||||
(define get-current-display-orientation
|
||||
(foreign-lambda (enum "SDL_DisplayOrientation") "SDL_GetCurrentDisplayOrientation"
|
||||
unsigned-int32))
|
||||
(foreign-lambda SDL_DisplayOrientation "SDL_GetCurrentDisplayOrientation"
|
||||
SDL_DisplayID))
|
||||
|
||||
(define get-current-video-driver
|
||||
(foreign-lambda c-string "SDL_GetCurrentVideoDriver"))
|
||||
|
||||
(define get-desktop-display-mode
|
||||
(foreign-lambda (c-pointer (struct "SDL_DisplayMode")) "SDL_GetDesktopDisplayMode"
|
||||
unsigned-int32))
|
||||
(foreign-lambda (c-pointer SDL_DisplayMode) "SDL_GetDesktopDisplayMode"
|
||||
SDL_DisplayID))
|
||||
|
||||
(define get-display-bounds
|
||||
(foreign-lambda bool "SDL_GetDisplayBounds"
|
||||
|
@ -178,7 +215,7 @@
|
|||
(define get-primary-display
|
||||
(foreign-lambda unsigned-int22 "SDL_GetPrimaryDisplay"))
|
||||
|
||||
(define-sdl-enum-values
|
||||
(define-sdl-const-values
|
||||
system-theme int
|
||||
(unknown light dark))
|
||||
|
||||
|
@ -234,19 +271,6 @@
|
|||
(define get-window-pixel-density
|
||||
(foreign-lambda float "SDL_GetWindowPixelDensity" (c-pointer (struct "SDL_Window"))))
|
||||
|
||||
(define-sdl-enum-values
|
||||
pixelformat unsigned-int32
|
||||
(unknown index1lsb index1msb index2lsb index2msb index4lsb index4msb
|
||||
index8 rgb332 xrgb4444 xbgr4444 xrgb1555 xbgr1555 argb4444
|
||||
rgba4444 abgr4444 bgra4444 argb1555 rgba5551 abgr1555 bgra5551 rgb565
|
||||
bgr565 rgb24 bgr24 xrgb8888 rgbx8888 pixelformat-xbgr8888 pbgrx8888
|
||||
pargb8888 prgba8888 pabgr8888 pbgra8888 pxrgb2101010 pxbgr2101010 pargb2101010
|
||||
pabgr2101010 prgb48 pbgr48 prgba64 pargb64 pbgra64 pabgr64 prgb48-float pbgr48-float
|
||||
prgba64-float pargb64-float pbgra64-float pabgr64-float prgb96-float
|
||||
pbgr96-float prgba128-float pargb128-float pbgra128-float pabgr128-float
|
||||
pyv12 piyuv pyuy2 puyvy pyvyu pnv12 pnv21 pp010 external-oes rgba32 argb32
|
||||
bgra32 abgr32 rgbx32 xrgb32 bgrx32 xbgr32))
|
||||
|
||||
(define get-window-pixel-format
|
||||
(foreign-lambda (enum "SDL_PixelFormat") "SDL_GetWindowPixelFormat"
|
||||
(c-pointer (struct "SDL_Window"))))
|
||||
|
@ -307,15 +331,6 @@
|
|||
(define gl-reset-attributes
|
||||
(foreign-lambda void "SDL_GL_ResetAttributes"))
|
||||
|
||||
(define-sdl-enum-values
|
||||
gl int
|
||||
red-size green-size blue-size alpha-size buffer-size doublebuffer depth-size
|
||||
stencil-size accum-red-size accum-green-size accum-blue-size accum-alpha-size
|
||||
stereo multisamplebuffers multisamplesamples accelerated-visual retained-backing
|
||||
context-major-version context-minor-version context-flags context-profile-mask
|
||||
share-with-current-context framebuffer-srgb-capable context-release-behavior
|
||||
context-reset-notification context-no-error floatbuffers egl-platform)
|
||||
|
||||
(define gl-set-attribute
|
||||
(foreign-lambda bool "SDL_GL_SetAttribute" (enum "SDL_GLattr") int))
|
||||
|
||||
|
|
|
@ -1,5 +1,15 @@
|
|||
{ lib, stdenv, fetchurl, makeWrapper, darwin, tcc-mob, bootstrap-chicken ? null, testers }:
|
||||
|
||||
{
|
||||
pkgs,
|
||||
lib,
|
||||
stdenv,
|
||||
fetchgit,
|
||||
fetchurl,
|
||||
makeWrapper,
|
||||
darwin,
|
||||
tcc-mob,
|
||||
version ? "git",
|
||||
testers
|
||||
}:
|
||||
let
|
||||
platform = with stdenv;
|
||||
if isDarwin then "macosx"
|
||||
|
@ -10,27 +20,57 @@ let
|
|||
in
|
||||
stdenv.mkDerivation (finalAttrs: {
|
||||
pname = "chicken";
|
||||
version = "5.4.0";
|
||||
inherit version;
|
||||
|
||||
binaryVersion = 11;
|
||||
binaryVersion = 12;
|
||||
|
||||
src = fetchurl {
|
||||
url = "https://code.call-cc.org/releases/${finalAttrs.version}/chicken-${finalAttrs.version}.tar.gz";
|
||||
sha256 = "sha256-PF1KphwRZ79tm/nq+JHadjC6n188Fb8JUVpwOb/N7F8=";
|
||||
};
|
||||
srcs = [
|
||||
(fetchgit {
|
||||
url = "git://code.call-cc.org/chicken-core";
|
||||
rev = "2c80bbab33302444bebc7eaac7f42ee9cda50301";
|
||||
sha256 = "sha256-KWL9/s03ZGwjsjvxZxluXtaKvBuimHGH5UXaQVf68Mg=";
|
||||
})
|
||||
(fetchurl {
|
||||
url = "https://code.call-cc.org/dev-snapshots/2024/07/01/chicken-6.0.0-bootstrap.tar.gz";
|
||||
sha256 = "sha256-qkcyWzsaN9+HbMBolmv7zeaPrtbaCTGa9HoF2g/3//o=";
|
||||
})
|
||||
];
|
||||
|
||||
# Disable two broken tests: "static link" and "linking tests"
|
||||
unpackPhase = ''
|
||||
cp -r `echo $srcs | awk '{print $1}'`/* .
|
||||
cp -r `echo $srcs | awk '{print $1}'`/.* .
|
||||
chmod -R 777 .
|
||||
mkdir -p boot/snapshot
|
||||
cd boot
|
||||
tar xzf `echo $srcs | awk '{print $2}'`
|
||||
cd ..
|
||||
echo ${version} > buildid
|
||||
|
||||
cd boot/chicken-6.0.0
|
||||
case "${platform}" in
|
||||
bsd)
|
||||
mkcmd=gmake;;
|
||||
*)
|
||||
mkcmd=make;;
|
||||
esac
|
||||
export CC="${tcc-mob}/bin/tcc"
|
||||
$mkcmd C_COMPILER=$CC PREFIX="$(pwd)"/../snapshot
|
||||
$mkcmd C_COMPILER=$CC PREFIX="$(pwd)"/../snapshot install
|
||||
cd ../..
|
||||
./configure --chicken "$(pwd)"/boot/snapshot/bin/chicken --c-compiler "${tcc-mob}/bin/tcc"
|
||||
$mkcmd boot-chicken
|
||||
'';
|
||||
|
||||
# Disable two broken tests: "static link" and "linking tests"
|
||||
postPatch = ''
|
||||
sed -i tests/runtests.sh -e "/static link/,+4 { s/^/# / }"
|
||||
sed -i tests/runtests.sh -e "/linking tests/,+11 { s/^/# / }"
|
||||
'';
|
||||
|
||||
setupHook = lib.optional (bootstrap-chicken != null) ./setup-hook.sh;
|
||||
|
||||
# -fno-strict-overflow is not a supported argument in clang
|
||||
hardeningDisable = lib.optionals stdenv.cc.isClang [ "strictoverflow" ];
|
||||
|
||||
makeFlags = [
|
||||
makeFlags = [
|
||||
"PLATFORM=${platform}"
|
||||
"PREFIX=$(out)"
|
||||
"C_COMPILER=${tcc-mob}/bin/tcc"
|
||||
|
@ -47,14 +87,15 @@ stdenv.mkDerivation (finalAttrs: {
|
|||
|
||||
nativeBuildInputs = [
|
||||
makeWrapper
|
||||
pkgs.hostname
|
||||
tcc-mob
|
||||
] ++ lib.optionals (stdenv.isDarwin && stdenv.isAarch64) [
|
||||
darwin.autoSignDarwinBinariesHook
|
||||
];
|
||||
|
||||
buildInputs = lib.optionals (bootstrap-chicken != null) [
|
||||
bootstrap-chicken
|
||||
];
|
||||
configurePhase = ''
|
||||
./configure --chicken ./chicken-boot --prefix $PREFIX --platform=$PLATFORM --c-compiler "${tcc-mob}/bin/tcc"
|
||||
'';
|
||||
|
||||
doCheck = !stdenv.isDarwin;
|
||||
postCheck = ''
|
||||
|
@ -81,4 +122,5 @@ stdenv.mkDerivation (finalAttrs: {
|
|||
Windows, and many Unix flavours.
|
||||
'';
|
||||
};
|
||||
|
||||
})
|
||||
|
|
26
nix/sdl3.nix
26
nix/sdl3.nix
|
@ -7,15 +7,21 @@
|
|||
makeWrapper,
|
||||
darwin,
|
||||
version ? "git",
|
||||
testers
|
||||
testers,
|
||||
}:
|
||||
let
|
||||
platform = with stdenv;
|
||||
if isDarwin then "macosx"
|
||||
else if isCygwin then "cygwin"
|
||||
else if (isFreeBSD || isOpenBSD) then "bsd"
|
||||
else if isSunOS then "solaris"
|
||||
else "linux"; # Should be a sane default
|
||||
platform =
|
||||
with stdenv;
|
||||
if isDarwin then
|
||||
"macosx"
|
||||
else if isCygwin then
|
||||
"cygwin"
|
||||
else if (isFreeBSD || isOpenBSD) then
|
||||
"bsd"
|
||||
else if isSunOS then
|
||||
"solaris"
|
||||
else
|
||||
"linux"; # Should be a sane default
|
||||
in
|
||||
stdenv.mkDerivation (finalAttrs: {
|
||||
pname = "SDL3";
|
||||
|
@ -38,9 +44,7 @@ stdenv.mkDerivation (finalAttrs: {
|
|||
makeWrapper
|
||||
pkgs.hostname
|
||||
pkgs.cmake
|
||||
] ++ lib.optionals (stdenv.isDarwin && stdenv.isAarch64) [
|
||||
darwin.autoSignDarwinBinariesHook
|
||||
];
|
||||
] ++ lib.optionals (stdenv.isDarwin && stdenv.isAarch64) [ darwin.autoSignDarwinBinariesHook ];
|
||||
|
||||
meta = {
|
||||
homepage = "https://libsdl.org/";
|
||||
|
@ -48,7 +52,7 @@ stdenv.mkDerivation (finalAttrs: {
|
|||
platforms = lib.platforms.unix;
|
||||
description = "SDL3";
|
||||
longDescription = ''
|
||||
SDL3
|
||||
SDL3
|
||||
'';
|
||||
};
|
||||
|
||||
|
|
|
@ -1,6 +1,9 @@
|
|||
(define-library (sdl3 features)
|
||||
(module (sdl3 features)
|
||||
()
|
||||
(import (scheme)
|
||||
(chicken foreign))
|
||||
(chicken base)
|
||||
(chicken foreign)
|
||||
(chicken platform))
|
||||
(begin
|
||||
(foreign-declare "#include <SDL3/SDL_version.h>")
|
||||
(register-feature! 'sdl3)
|
||||
|
|
|
@ -1,22 +1,16 @@
|
|||
(define-library (sdl3 init)
|
||||
(module (sdl3 init)
|
||||
(SDL_InitFlags
|
||||
SDL_AppResult
|
||||
|
||||
init
|
||||
init-sub-system
|
||||
quit
|
||||
quit-sub-system
|
||||
set-app-metadata
|
||||
set-app-metadata-property
|
||||
get-app-metadata-property
|
||||
was-init)
|
||||
(import (scheme)
|
||||
(chicken base))
|
||||
(export init-audio
|
||||
init-video
|
||||
init-joystick
|
||||
init-haptic
|
||||
init-gamepad
|
||||
init-events
|
||||
init-sensor
|
||||
init-camera
|
||||
|
||||
init
|
||||
init-sub-system
|
||||
quit
|
||||
quit-sub-system
|
||||
set-app-metadata
|
||||
set-app-metadata-property
|
||||
get-app-metadata-property
|
||||
was-init)
|
||||
(begin
|
||||
(include-relative "lib/sdl3-init-impl.scm")))
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
(define-library (sdl3 internal utilities)
|
||||
(module (sdl3 internal utilities)
|
||||
(define-sdl-flag
|
||||
define-sdl-enum-values)
|
||||
(import (scheme)
|
||||
(chicken base))
|
||||
(export define-sdl-flag
|
||||
define-sdl-enum-values)
|
||||
(begin
|
||||
(include-relative "internal/utilities.scm")))
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
(define-library (sdl3 main)
|
||||
(module (sdl3 main)
|
||||
()
|
||||
(import (scheme)
|
||||
(chicken base))
|
||||
(export)
|
||||
(begin
|
||||
(include-relative "lib/sdl3-main-impl.scm")))
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
(define-library (sdl3 render)
|
||||
(module (sdl3 render)
|
||||
()
|
||||
(import (scheme)
|
||||
(chicken base))
|
||||
(export)
|
||||
(begin
|
||||
(include-relative "lib/sdl3-render-impl.scm")))
|
||||
|
|
222
sdl3-video.scm
222
sdl3-video.scm
|
@ -1,115 +1,115 @@
|
|||
(define-library (sdl3 video)
|
||||
(module (sdl3 video)
|
||||
(create-popup-window
|
||||
create-window
|
||||
create-window-with-properties
|
||||
destroy-window
|
||||
destroy-window-surface
|
||||
disable-screen-saver
|
||||
egl-get-current-config
|
||||
egl-get-current-display
|
||||
egl-get-proc-address
|
||||
egl-get-window-surface
|
||||
enable-screen-saver
|
||||
flash-window
|
||||
get-closest-fullscreen-display-mode
|
||||
get-current-display-mode
|
||||
get-current-display-orientation
|
||||
get-current-video-driver
|
||||
get-desktop-display-mode
|
||||
get-display-bounds
|
||||
get-display-content-scale
|
||||
get-display-for-point
|
||||
get-display-for-rect
|
||||
get-display-for-window
|
||||
get-display-name
|
||||
get-display-properties
|
||||
;; get-displays
|
||||
get-display-usable-bounds
|
||||
;; get-fullscreen-display-modes
|
||||
get-grabbed-window
|
||||
get-natural-display-orientation
|
||||
get-num-video-drivers
|
||||
get-primary-display
|
||||
get-system-theme
|
||||
get-video-driver
|
||||
;; get-window-aspect-ratio
|
||||
;; get-window-borders-size
|
||||
get-window-display-scale
|
||||
get-window-flags
|
||||
get-window-from-id
|
||||
get-window-fullscreen-mode
|
||||
;; get-window-icc-profile
|
||||
get-window-id
|
||||
get-window-keyboard-grab
|
||||
;; get-window-maximum-size
|
||||
;; get-window-minumum-size
|
||||
get-window-mouse-grab
|
||||
get-window-mouse-rect
|
||||
get-window-opacity
|
||||
get-window-parent
|
||||
get-window-pixel-density
|
||||
get-window-pixel-format
|
||||
;; get-window-position
|
||||
get-window-properties
|
||||
;; get-windows
|
||||
;; get-window-safe-area
|
||||
;; get-window-size
|
||||
;; get-window-size-in-pixels
|
||||
get-window-surface
|
||||
;; get-window-surface-vsync
|
||||
get-window-title
|
||||
gl-create-context
|
||||
gl-destroy-context
|
||||
gl-extension-supported
|
||||
;; gl-get-attribute
|
||||
gl-get-current-context
|
||||
gl-get-current-window
|
||||
gl-get-proc-address
|
||||
;; gl-get-swap-interval
|
||||
gl-load-library
|
||||
gl-make-current
|
||||
gl-reset-attributes
|
||||
gl-set-attribute
|
||||
gl-set-swap-interval
|
||||
gl-swap-window
|
||||
gl-unload-library
|
||||
hide-window
|
||||
maximize-window
|
||||
minimize-window
|
||||
raise-window
|
||||
restore-window
|
||||
screen-saver-enabled
|
||||
set-window-always-on-top
|
||||
set-window-aspect-ratio
|
||||
set-window-bordered
|
||||
set-window-focusable
|
||||
set-window-fullscreen
|
||||
set-window-fullscreen-mode
|
||||
;; set-window-hit-test
|
||||
set-window-icon
|
||||
set-window-keyboard-grab
|
||||
set-window-maximum-size
|
||||
set-window-minimum-size
|
||||
set-window-modal
|
||||
set-window-modal-for
|
||||
set-window-mouse-grab
|
||||
set-window-mouse-rect
|
||||
set-window-opacity
|
||||
set-window-parent
|
||||
set-window-position
|
||||
set-window-resizable
|
||||
set-window-shape
|
||||
set-window-size
|
||||
set-window-surface-vsync
|
||||
set-window-title
|
||||
show-window
|
||||
show-window-system-menu
|
||||
sync-window
|
||||
update-window-surface
|
||||
;; update-window-surface-rects
|
||||
window-has-surface
|
||||
)
|
||||
(import (scheme)
|
||||
(chicken base))
|
||||
(export create-popup-window
|
||||
create-window
|
||||
create-window-with-properties
|
||||
destroy-window
|
||||
destroy-window-surface
|
||||
disable-screen-saver
|
||||
egl-get-current-config
|
||||
egl-get-current-display
|
||||
egl-get-proc-address
|
||||
egl-get-window-surface
|
||||
enable-screen-saver
|
||||
flash-window
|
||||
get-closest-fullscreen-display-mode
|
||||
get-current-display-mode
|
||||
get-current-display-orientation
|
||||
get-current-video-driver
|
||||
get-desktop-display-mode
|
||||
get-display-bounds
|
||||
get-display-content-scale
|
||||
get-display-for-point
|
||||
get-display-for-rect
|
||||
get-display-for-window
|
||||
get-display-name
|
||||
get-display-properties
|
||||
;; get-displays
|
||||
get-display-usable-bounds
|
||||
;; get-fullscreen-display-modes
|
||||
get-grabbed-window
|
||||
get-natural-display-orientation
|
||||
get-num-video-drivers
|
||||
get-primary-display
|
||||
get-system-theme
|
||||
get-video-driver
|
||||
;; get-window-aspect-ratio
|
||||
;; get-window-borders-size
|
||||
get-window-display-scale
|
||||
get-window-flags
|
||||
get-window-from-id
|
||||
get-window-fullscreen-mode
|
||||
;; get-window-icc-profile
|
||||
get-window-id
|
||||
get-window-keyboard-grab
|
||||
;; get-window-maximum-size
|
||||
;; get-window-minumum-size
|
||||
get-window-mouse-grab
|
||||
get-window-mouse-rect
|
||||
get-window-opacity
|
||||
get-window-parent
|
||||
get-window-pixel-density
|
||||
get-window-pixel-format
|
||||
;; get-window-position
|
||||
get-window-properties
|
||||
;; get-windows
|
||||
;; get-window-safe-area
|
||||
;; get-window-size
|
||||
;; get-window-size-in-pixels
|
||||
get-window-surface
|
||||
;; get-window-surface-vsync
|
||||
get-window-title
|
||||
gl-create-context
|
||||
gl-destroy-context
|
||||
gl-extension-supported
|
||||
;; gl-get-attribute
|
||||
gl-get-current-context
|
||||
gl-get-current-window
|
||||
gl-get-proc-address
|
||||
;; gl-get-swap-interval
|
||||
gl-load-library
|
||||
gl-make-current
|
||||
gl-reset-attributes
|
||||
gl-set-attribute
|
||||
gl-set-swap-interval
|
||||
gl-swap-window
|
||||
gl-unload-library
|
||||
hide-window
|
||||
maximize-window
|
||||
minimize-window
|
||||
raise-window
|
||||
restore-window
|
||||
screen-saver-enabled
|
||||
set-window-always-on-top
|
||||
set-window-aspect-ratio
|
||||
set-window-bordered
|
||||
set-window-focusable
|
||||
set-window-fullscreen
|
||||
set-window-fullscreen-mode
|
||||
;; set-window-hit-test
|
||||
set-window-icon
|
||||
set-window-keyboard-grab
|
||||
set-window-maximum-size
|
||||
set-window-minimum-size
|
||||
set-window-modal
|
||||
set-window-modal-for
|
||||
set-window-mouse-grab
|
||||
set-window-mouse-rect
|
||||
set-window-opacity
|
||||
set-window-parent
|
||||
set-window-position
|
||||
set-window-resizable
|
||||
set-window-shape
|
||||
set-window-size
|
||||
set-window-surface-vsync
|
||||
set-window-title
|
||||
show-window
|
||||
show-window-system-menu
|
||||
sync-window
|
||||
update-window-surface
|
||||
;; update-window-surface-rects
|
||||
window-has-surface
|
||||
)
|
||||
(begin
|
||||
(include-relative "lib/sdl3-video-impl.scm")))
|
||||
|
|
38
shell.nix
Normal file
38
shell.nix
Normal file
|
@ -0,0 +1,38 @@
|
|||
with import <nixpkgs> {
|
||||
overlays = [
|
||||
(final: prev: {
|
||||
tcc-mob = final.callPackage ./nix/tinycc.nix { stdenv = final.gcc13Stdenv; };
|
||||
chicken = final.callPackage ./nix/chicken.nix { stdenv = final.gcc13Stdenv; };
|
||||
sdl3 = final.callPackage ./nix/sdl3.nix {
|
||||
stdenv = final.gcc13Stdenv;
|
||||
version = "2.99.0";
|
||||
};
|
||||
})
|
||||
];
|
||||
};
|
||||
mkShell {
|
||||
packages = with pkgs; [
|
||||
tcc-mob
|
||||
sdl3
|
||||
chicken
|
||||
rlwrap
|
||||
]
|
||||
# ++ (with pkgs.chickenPackages_5.chickenEggs; [
|
||||
# apropos
|
||||
# chicken-doc
|
||||
# srfi-1
|
||||
# srfi-18
|
||||
# lsp-server
|
||||
# srfi-152
|
||||
# ])
|
||||
;
|
||||
shellHook = ''
|
||||
export CC="${pkgs.tcc-mob}/bin/tcc"
|
||||
export CHICKEN_PREFIX="$(pwd)/.chicken"
|
||||
export CHICKEN_INSTALL_REPOSITORY="$(pwd)/.chicken/eggs"
|
||||
export CHICKEN_REPOSITORY_PATH="${pkgs.chicken}/lib/chicken/11:$(pwd)/.chicken/eggs"
|
||||
export PATH="$PATH:$CHICKEN_PREFIX"
|
||||
# chicken-install lsp-server salmonella
|
||||
export CHICKEN_PREFIX="${pkgs.chicken}"
|
||||
'';
|
||||
}
|
Loading…
Reference in a new issue