Skip to content

Commit

Permalink
new ext-test-autoshot
Browse files Browse the repository at this point in the history
new workflow artifacts

move ext-render-ass2iqm to fwk3d org
move ext-render-ase2ini to fwk3d org
move ext-script-tcc to fwk3d org

fix issue in EMBED makefile with dash `-` character in filename
chg change ui icon font style
chg remove ui icon oversampling

new editor: prototype alt scene tree UI (2)

fix editor: bring back object picking
fix editor: bring back object outlines
fix editor: bring back object selections

new obj_xform()
new editor: ctrl-d select none
new editor: ctrl-a/e toggle all/none selection
new editor: ctrl-i invert selection

fix luavm starts with gc disabled now

fix FXAA passes required bilinear samplers
chg replaced FXAA3 impl to official 3.11 version
fix fixed FXAA1/3 alpha
chg tweaked FXAA1 luma
new EDITOR_AA setting
resume editor work

chg reduced some build time (/MP flag)
fix do not cook audio recipes when ffmpeg transcoder is missing

new file_find()
fix text input sdl3 event in lite editor

new mouse_show()
fix mouse cursorshape was invalidated when cursor was requested to hide

minor ui changes

fix when converting modules, do not use ext-audio-ffmpeg fallback if main ext-mod2wav recipe exists
new wav loader
fix mid transcoder
fix fur transcoder
fix flac/mp3/s3m/mod/xm/it transcoders
chg minor clean ups (make, ui, editor)

fix init size arg also when file_read() fails to read any file
fix rebuilt assimp with vs19+/MT flag
fix rebuilt luajit with vs19+/MT flag
fix rebuilt openal with vs19+/MT flag
fix rebuilt tcclib with vs19+/MT flag

new lua_fn()
new ui_text()
add blasterD mesh
chg event-driven system heartbeats
new better ui widget for i/f uniforms
new ifdef(little/big) macro
del obj2 multiple parents feature

fix ui_list() colors
new ui_bitmask() prints hex value and hightlights hovered bit now
fix wrong endianess during ui_bitmask() buttons
del ui_toggle()

fix dll xcopy problem on some distros (@kibonu)
fix vs2019 const warnings
fix vs2019 c++ link error
fix bring back zip mount
new ext-cook, that cooks and optionally creates zipfiles as well
fix crash when using logger before being initialized
chg tweak ui colors
fix `make tidy` not deleting temporaries with spaces in them
add optional `make cook` buildstep
new display build times (MAKE.bat)
fix merge ext-ui-commandpalette into ext-backend-imgui
fix bring back lite editor
fix gizmo crash when transform matrix is null
lab enable camera damping and ui viewports by default
fix tick editor systems only when in editor
chg initial `undo` actions in property editor
new subeditors
new `MAKE embed`
chg rewrote embed/MAKE, now supporting paths in filenames
add app_recv("fullscreen")
add ui_window_show()/ui_window_shown()
new editor fps based on battery levels + fg/bg app status
fix missing KEY_ISO scancode
chg removed all c++ compilation units from native.cc (shaves off some compilation time)
fix bad initial ui panel Y position when viewports were enabled
add most common secondary keys to bindings (non-gaming/locale keys)
fix input_name()
add `MAKE asan` flag that can be combined together with `O0..3`
fix editor 3D labels
fix missing mouse cursor in recorded videos
new UI_FULLSCREEN, UI_TRANSPARENT flags
del prompt()
chg renamed a few ext/ folders
fix igConsole buttons
chg styled imgui tab colors
new APP_VIEWPORTS, APP_DOCKING flags
new igAddCommandPalette()
new igSpinner()
new added kind of support for c++ exts too
fix black thumbnail in recorded videos via ffmpeg
new begin scenetree
fix C4743 warning on O3 build tier
new editor bindings
new `MAKE O[0|1|2|3]` as build tier aliases
brk: changed a few ui signatures
start renaming v2 filenames for modules (this will get reverted eventually)
gizmo2 polish pass
tweak ui_slider/2()
modified ui_float2/3/4 variants to accept mouse drags
extra lean `MAKE tidy`
gizmo2 first pass
add cimguizmo dep
add trace in printfed "!messages"
new: ui_radio()
chg: do not render bar colors on NULL ui_labels()
fix ui_panel() ordering so Debug panel is always at top stack and UI_OPEN at bottom.
resume editor work
add `record=outfile.mp4` app command (mp4/mp1 supported)
add `screenshot=outfile.png` app command (png/jpg supported)
add `retail` flag in MAKE.bat
fix mouse in hidden/relative mode being blocked by window edges
new uniforms api (wip)
fix ffi generated headers case when all known extensions are installed
fix crash in model cache not duplicating shaderinfos
fix array_unique() bug trimming last item in list
initial model() trim
shader2 extra work
fix: v2 exts have to use ext-v2 tags
shader2 hashing
shader2dup
clean up shader() impl into new shader2() fn
new lua+teal demos
hello.c can launch lua scripts now
new audio3d api
windowed/borderless/exclusive fullscreen modes (--app.fullscreen=[0..N])
bind all engine+ext apis to luajit automatically
modify va() to use stb_vsnprintf if present
enabled signal traps by default (--sys.traps=0 to disable them)
disabled glDebug context by default (--gl.debug=1 to enable it)
enabled callstack traces in alert() dialogs (via !message)
ext-luajit
added scripts to generate C/FFI bindings
imFileDialog includes a <filesystem> fallback now on old compilers

new command() api that sends cmds to all registered systems
new all --args are redirected to command() calls internally

fix missing tooltips in buttons
add missing assets for shadertoys
top-left align ui_panels() at creation time
new ui_link()
add missing ui_collapse()/end() pair
fix mouse wheel absolute coord
start todo.h clean up
time api uses sdl3 backend now
audio stub
implemented ui_browser()
implemented ui_hue
font[1] bold style
new ui_console()/ui_printf()
fix ui_notify() with no body text
fix ui_alert()
new ui_filter() ( CTRL+F )
fix ui_string()
fix input() ctrl/shift/alt vks not checking rctrl/rshift/rlat counterpart vks
fix ui_image() return value
do not auto-close any severe ui_notify()
--fps=X (-1[adaptive],0[unlimited],1[vsync] .. N[specific])
upgrade sdl3 to latest
scan folder contents only once during boot
remove 3rd/3rd.??
ext-lua
ext-sdl3
new material symbols font for ui icons
new ui_notify(), ui_percent()
update mojoal
make.bat scans for x64/ library folders now (@zpl-zak)
`plug add/syn/del *` command
make.bat scans for ext/inc, ext/include/ paths now

chg moved repos to https://github.com/fwk3d organization

brk: dropped support for linux, osx, ems platforms
brk: dropped support for emcc, gcc, clang, clang-cl, tcc compilers
brk: dropped support for LOD models
brk: dropped support for texture recording + video recording
brk: dropped support for joysticks+input bindings+external input mappings
brk: dropped support for cooking into zipfiles
brk: dropped vfs module

brk: moved into extensions: enet, websockets, spine, steam, gui, editor
chg: changed implementation details within wget module (download() previously)
new: ext-tcc module to support further C scripts

allow small [...] button within ui_buttons()
added buttons to display each source code in hello.c
ui_buttons() right align
scan ext/ folders and add -I flags automatically (MAKE.bat)

new tools/ no longer required
new modular plugin system (ext/PLUG.bat)
new simplified MAKE
new simplified cookbook recipes and overall cook process
brk: dropped single-header distributions

new webcam support
new separate mouse,keyboard,gamepad modules
new simplified file module
new simplified memory module
new simplified panic module
new simplified logger module
new simplified cook module. see recipe()
new simplified app module (previously window module)

fix made make.bat to compile under vscode environment (@zpl-zak)
fix made make.bat to compile when using an older VS buildtools environment
fix shaved some initialization seconds when a dev environment is present (make.bat) (@zpl-zak)
fix improve entity type casts into scene module (@zpl-zak)

new simplified file2hash tool, within make.bat now

new simplified engine loop
new rewritten engine loop
new support for multi-viewport windows (via dearimgui) (see --viewports flag)

new ui module rewritten
new file module rewritten
new cook module rewritten
new app module rewritten (previously window module)
new embed module

ext new assimp extension
ext new videompg extension

brk renamed quad_fullscreen api to blit api

chg added #include hints in preprocessed shader sources
updated to latest lua

new SDL3 backend
new dear imgui + implot
new apis for 3rd party libraries and extensions available to all compilation units
new lightweight repository size

Initial commit
  • Loading branch information
r-lyeh committed Dec 7, 2024
0 parents commit 31de22d
Show file tree
Hide file tree
Showing 1,782 changed files with 736,329 additions and 0 deletions.
28 changes: 28 additions & 0 deletions .github/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
cmake_minimum_required(VERSION 3.13...${CMAKE_VERSION})
project(hello LANGUAGES C CXX)
add_executable(hello ../hello.c ../code/engine.c ../code/native.c ../code/backend.cc)

file(GLOB sources_list LIST_DIRECTORIES true "../ext/*/inc")
foreach(dir ${sources_list})
message(INC="${dir}")
IF(IS_DIRECTORY ${dir})
target_include_directories(hello PRIVATE ${dir})
ELSE()
CONTINUE()
ENDIF()
endforeach()

file(GLOB sources_list LIST_DIRECTORIES true "../ext/*/x64")
foreach(dir ${sources_list})
message(LIB="${dir}")
IF(IS_DIRECTORY ${dir})
target_link_directories(hello PRIVATE ${dir})
ELSE()
CONTINUE()
ENDIF()
endforeach()

target_include_directories(hello PRIVATE "../" "../code")
target_compile_options(hello PRIVATE /MT /GL /GF /arch:AVX2)
target_compile_definitions(hello PRIVATE $<$<CONFIG:Release>:FLAGS=FLAGS_REL>)
target_link_options(hello PRIVATE)
37 changes: 37 additions & 0 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
name: Build

on:
push:
paths:
- '.github/workflows/build.yml'
- 'src/**'
pull_request:
paths:
- '.github/workflows/build.yml'
- 'src/**'

env:
CMAKE_BUILD_TYPE: Release
CMAKE_GENERATOR_PLATFORM: x64

jobs:
build:
runs-on: windows-latest

steps:
- uses: actions/checkout@v4

- name: Configure CMake
run: >-
cmake
-S "${{github.workspace}}/.github"
-B "${{github.workspace}}/build"
-DCMAKE_BUILD_TYPE=${{env.CMAKE_BUILD_TYPE}}
-DCMAKE_GENERATOR_PLATFORM=${{env.CMAKE_GENERATOR_PLATFORM}}
- name: Build
run: >-
cmake
--build "${{github.workspace}}/build"
--config ${{env.CMAKE_BUILD_TYPE}}
--verbose
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
.*
275 changes: 275 additions & 0 deletions MAKE.bat
Original file line number Diff line number Diff line change
@@ -0,0 +1,275 @@
#!/bin/bash 2>nul || goto :windows

# linux + osx -----------------------------------------------------------------
cd `dirname $0`

# tidy environment
if [ "$1" = "tidy" ]; then
rm a.out 2> /dev/null
rm engine.o 2> /dev/null
exit
fi

# sync
if [ "$1" = "sync" ]; then
git reset --hard HEAD^1 && git pull
sh MAKE.bat tidy
exit
fi

export args=
export cc=cc
export o=-o

if [ "$(uname)" != "Darwin" ]; then
fi

if [ "$(uname)" = "Darwin" ]; then
fi

echo !cc! !o! hello.exe hello.c -I code code/engine.c !args! || exit 1
echo Compared to v1, osx/linux support is dropped till further notice.

exit


:: -----------------------------------------------------------------------------
:windows

@echo off
cd /d "%~dp0"

set "help="
if "%1"=="help" set help=1
if "%1"=="-h" set help=1
if "%1"=="-?" set help=1
if "%1"=="/?" set help=1
if defined help (
echo %0 [tidy]
echo %0 [sync]
echo %0 [asan] [debug^|devel^|release^|retail] [embed] [file1.c file2.cc ...]
exit /b
)

rem tidy environment
if "%1"=="tidy" (
del *.def > nul 2> nul
del *.mem > nul 2> nul
del *.exp > nul 2> nul
del *.lib > nul 2> nul
del *.exe > nul 2> nul
del *.obj > nul 2> nul
del *.o > nul 2> nul
del *.a > nul 2> nul
del *.pdb > nul 2> nul
del *.ilk > nul 2> nul
del *.log > nul 2> nul
rd /q /s .vs > nul 2> nul
del cook*.csv > nul 2> nul
del cook.zip > nul 2> nul
del *.dll > nul 2> nul
del .settings.ini > nul 2> nul
del .log.txt > nul 2> nul
del ";*" > nul 2> nul
rd /q /s include > nul 2> nul
rd /q /s lib > nul 2> nul
rd /q /s .embed > nul 2> nul

for /R art %%i in (.*) do del "%%i" > nul 2> nul
for /R lab %%i in (.*) do del "%%i" > nul 2> nul
for /R lab0 %%i in (.*) do del "%%i" > nul 2> nul
for /R demos %%i in (.*) do del "%%i" > nul 2> nul
for /R code %%i in (.*) do del "%%i" > nul 2> nul
for /R ext %%i in (.*) do del "%%i" > nul 2> nul
exit /b
)

rem sync
if "%1"=="sync" (
echo Updating all folders to latest commit
git reset --hard HEAD~1 && git pull
call MAKE.bat tidy
exit /b
)

rem compiler detection
if "%cc%"=="" (
echo Detecting VS 2022/2019/2017/2015/2013 x64 ...
(set "cc=cl" && where /q cl.exe) || (

if exist "%ProgramFiles%/microsoft visual studio/2022/community/VC/Auxiliary/Build/vcvarsall.bat" (
@call "%ProgramFiles%/microsoft visual studio/2022/community/VC/Auxiliary/Build/vcvarsall.bat" amd64 >nul && set "vs=22"
) else if exist "%ProgramFiles%/microsoft visual studio/2022/enterprise/VC/Auxiliary/Build/vcvarsall.bat" (
@call "%ProgramFiles%/microsoft visual studio/2022/enterprise/VC/Auxiliary/Build/vcvarsall.bat" amd64 >nul && set "vs=22"
) else if exist "%ProgramFiles(x86)%/microsoft visual studio/2019/community/VC/Auxiliary/Build/vcvarsall.bat" (
@call "%ProgramFiles(x86)%/microsoft visual studio/2019/community/VC/Auxiliary/Build/vcvarsall.bat" amd64 >nul && set "vs=19"
) else if exist "%ProgramFiles(x86)%/microsoft visual studio/2019/enterprise/VC/Auxiliary/Build/vcvarsall.bat" (
@call "%ProgramFiles(x86)%/microsoft visual studio/2019/enterprise/VC/Auxiliary/Build/vcvarsall.bat" amd64 >nul && set "vs=19"
) else if exist "%ProgramFiles(x86)%/microsoft visual studio/2017/community/VC/Auxiliary/Build/vcvarsall.bat" (
@call "%ProgramFiles(x86)%/microsoft visual studio/2017/community/VC/Auxiliary/Build/vcvarsall.bat" amd64 >nul && set "vs=17"
) else if exist "%ProgramFiles(x86)%/microsoft visual studio/2017/enterprise/VC/Auxiliary/Build/vcvarsall.bat" (
@call "%ProgramFiles(x86)%/microsoft visual studio/2017/enterprise/VC/Auxiliary/Build/vcvarsall.bat" amd64 >nul && set "vs=17"
) else if exist "%VS170COMNTOOLS%/../../VC/Auxiliary/Build/vcvarsall.bat" (
@call "%VS170COMNTOOLS%/../../VC/Auxiliary/Build/vcvarsall.bat" amd64 >nul && set "vs=22"
) else if exist "%VS160COMNTOOLS%/../../VC/Auxiliary/Build/vcvarsall.bat" (
@call "%VS160COMNTOOLS%/../../VC/Auxiliary/Build/vcvarsall.bat" amd64 >nul && set "vs=19"
) else if exist "%VS150COMNTOOLS%/../../VC/Auxiliary/Build/vcvarsall.bat" (
@call "%VS150COMNTOOLS%/../../VC/Auxiliary/Build/vcvarsall.bat" amd64 >nul && set "vs=17"
) else if exist "%VS140COMNTOOLS%/../../VC/bin/x86_amd64/vcvarsall.bat" (
@call "%VS140COMNTOOLS%/../../VC/bin/x86_amd64/vcvarsall.bat" amd64 >nul && set "vs=15"
) else if exist "%VS120COMNTOOLS%/../../VC/bin/x86_amd64/vcvarsall.bat" (
@call "%VS120COMNTOOLS%/../../VC/bin/x86_amd64/vcvarsall.bat" amd64 >nul && set "vs=13"
) else (
echo Detecting Mingw64 ...
(set "cc=gcc" && where /q gcc.exe) || (
echo Detecting TCC ... && set "cc=tcc"
)
)
)
)

if "%cc%"=="cl" (
set o=/Fe:
set args=/Zi /MT /EHsc /MP /nologo
) else (
set o=-o
set args=
)

setlocal enableDelayedExpansion

rem PAUSE at EOF only if double-clicked from Windows explorer
set "needs_pause="
(((echo .%cmdcmdline% | find /i "/c")>nul) && set "needs_pause=1")
(((echo .%cmdcmdline% | find /i "VsDevCmd")>nul) && set "needs_pause=")
set tier="devel"
:parse_args
if not "%1"=="" (
if "%1"=="embed" (
pushd embed
call make
popd
) else if exist "%1" (
set objs=!objs! %1
) else if "%1"=="asan" (
set args=!args! /fsanitize=address
) else if "%1"=="debug" (
set "tier=debug"
) else if "%1"=="devel" (
set "tier=devel"
) else if "%1"=="release" (
set "tier=release"
) else if "%1"=="retail" (
set "tier=retail"
) else if "%1"=="o0" (
set "tier=debug"
) else if "%1"=="O0" (
set "tier=debug"
) else if "%1"=="o1" (
set "tier=devel"
) else if "%1"=="O1" (
set "tier=devel"
) else if "%1"=="o2" (
set "tier=release"
) else if "%1"=="O2" (
set "tier=release"
) else if "%1"=="o3" (
set "tier=retail"
) else if "%1"=="O3" (
set "tier=retail"
) else (
set args=!args! %1
)
shift
goto parse_args
)
if "!objs!"=="" (
set objs=!o! hello.exe hello.c
)
if "!tier!" == "debug" (
set args=!args! /DEBUG /Od
)
if "!tier!" == "devel" (
set args=!args! /DNDEBUG=1
)
if "!tier!" == "release" (
set args=!args! /DNDEBUG=2 /Os /Ox /O2 /GL /GF
)
if "!tier!" == "retail" (
set args=!args! /DNDEBUG=3 /Os /Ox /O2 /GL /GF /Oy /Gw /arch:AVX2
set libs=!libs! /OPT:ICF /LTCG
)
rem generate ext/ext.h file
pushd ext & call make & popd
rem copy dlls/libs to root folder
for /D %%i in (ext\*) do if exist %%i\x64\* xcopy /ys %%i\x64\* >nul 2>nul
rem collect include folders iteratively
for /D %%i in (ext\*) do if exist "%%i\inc" set exts=!exts! -I%%i\inc
for /D %%i in (ext\*) do if exist "%%i\include" set exts=!exts! -I%%i\include
for /D %%i in (ext\*) do if exist "%%i\x64" set libs=!libs! /LIBPATH:%%i\x64
set args=!exts! !args!
rem since it takes a lot of time, compile dependencies at least once a day. hopefully ok for most users.
rem get system date and remove '/' chars on it. also remove spaces present on some configs.
set datestr=%date%
set datestr=%datestr:/=%
set datestr=%datestr:-=%
set datestr=%datestr:.=%
set datestr=%datestr: =%
set old=%time%
set "rebuild="
if not exist native-!datestr!.obj set rebuild=1
if not exist backend-!datestr!.obj set rebuild=1
rem generate FFI bindings
if defined rebuild (
set "cache=(cold build)"
set defs=-D__forceinline= -DSDL_DISABLE_ANALYZE_MACROS -DINT_MAX=2147483647 -DAPI= -DHAS_BITFIELDS=0
echo /* !datestr!: Auto-generated file. Do not edit */ > embed\engine.ffi
echo vs%vs%: !cc! /nologo !defs! -Icode -I. -EP code\engine.h -Icode\3rd\nil !args!
!cc! /nologo !defs! -Icode -I. -EP code\engine.h -Icode\3rd\nil !args! |^
findstr /R /C:"[^ ]" |^
find /V "static " |^
find /V "__pragma(" |^
find /V "#pragma once" |^
find /V "#pragma warning" |^
find /V "#pragma comment" |^
find /V "#pragma region" |^
find /V "#pragma endregion" >> embed\engine.ffi
)
if defined rebuild (
echo vs%vs%: !cc! -Icode -I. /c code\native.c code\backend.cc !args!
!cc! -Icode -I. /c code\native.c code\backend.cc !args! || set rc=1
move /y native.obj native-!datestr!.obj >nul && rem >2 nul
move /y backend.obj backend-!datestr!.obj >nul && rem >2 nul
)
echo vs%vs%: !cc! -Icode -I. !objs! native-!datestr!.obj backend-!datestr!.obj code\engine.c !args! /link !libs!
!cc! -Icode -I. !objs! native-!datestr!.obj backend-!datestr!.obj code\engine.c !args! /link !libs! || set rc=1
set now=%time%
set "old=!old::0=: !"
set "old=!old:,0=: !"
set "old=!old:.0=: !"
set "now=!now::0=: !"
set "now=!now:,0=: !"
set "now=!now:.0=: !"
set cs0=!old:~0,2!*3600*100+!old:~3,2!*60*100+!old:~6,2!*100+!old:~9,2!
set cs1=!now:~0,2!*3600*100+!now:~3,2!*60*100+!now:~6,2!*100+!now:~9,2!
set /A diff=!cs1!-^(!cs0!^)
set diff=!diff:~0,-2!.!diff:~-2!
if defined rebuild (echo !diff!s ^(cold build^)) else (echo !diff!s ^(warm build^))

:eof
if defined needs_pause ( pause )

cmd /c exit !rc!
Loading

0 comments on commit 31de22d

Please sign in to comment.