diff options
author | Andreas Kling <awesomekling@gmail.com> | 2019-09-14 10:55:18 +0200 |
---|---|---|
committer | Andreas Kling <awesomekling@gmail.com> | 2019-09-14 10:55:18 +0200 |
commit | 813deaed450a6b87bd8dc7bbefa6cc5fa5dbff97 (patch) | |
tree | 8fa7b1c0b3203d31517888700ecbc1d356045500 /Ports/doom | |
parent | 24cc61aae24de7f80fd6a905f1e1151e491f6265 (diff) | |
download | serenity-813deaed450a6b87bd8dc7bbefa6cc5fa5dbff97.zip |
Ports: Remove now-unnecessary DOOM patch
Now that we're building our own DOOM fork, we don't need any patches.
Diffstat (limited to 'Ports/doom')
-rw-r--r-- | Ports/doom/serenity-port.patch | 337 |
1 files changed, 0 insertions, 337 deletions
diff --git a/Ports/doom/serenity-port.patch b/Ports/doom/serenity-port.patch deleted file mode 100644 index 6482d7e108..0000000000 --- a/Ports/doom/serenity-port.patch +++ /dev/null @@ -1,337 +0,0 @@ -commit 393753ace53e70ba759c5e5f04d1475425dd5194 -Author: Andreas Kling <awesomekling@gmail.com> -Date: Mon Sep 9 18:51:34 2019 +0200 - - Port doomgeneric to Serenity OS. - - Thanks for the awesome doomgeneric project, ozkl! - -diff --git a/doomgeneric/Makefile b/doomgeneric/Makefile -index f1d8df5..e43dde2 100644 ---- a/doomgeneric/Makefile -+++ b/doomgeneric/Makefile -@@ -12,17 +12,19 @@ else - endif - - --CC=gcc # gcc or g++ -+CC=i686-pc-serenity-gcc -+CXX=i686-pc-serenity-g++ - CFLAGS+=-ggdb3 -Os -+CXXFLAGS=$(CFLAGS) -std=c++17 -fno-rtti -fno-exceptions - LDFLAGS+=-Wl,--gc-sections - CFLAGS+=-ggdb3 -Wall -DNORMALUNIX -DLINUX -DSNDSERV # -DUSEASM --LIBS+=-lm -lc -lX11 -+LIBS+=-lm -lc -lgui -lcore -ldraw - - # subdirectory for objects - OBJDIR=build --OUTPUT=doomgeneric -+OUTPUT=doom - --SRC_DOOM = i_main.o dummy.o am_map.o doomdef.o doomstat.o dstrings.o d_event.o d_items.o d_iwad.o d_loop.o d_main.o d_mode.o d_net.o f_finale.o f_wipe.o g_game.o hu_lib.o hu_stuff.o info.o i_cdmus.o i_endoom.o i_joystick.o i_scale.o i_sound.o i_system.o i_timer.o memio.o m_argv.o m_bbox.o m_cheat.o m_config.o m_controls.o m_fixed.o m_menu.o m_misc.o m_random.o p_ceilng.o p_doors.o p_enemy.o p_floor.o p_inter.o p_lights.o p_map.o p_maputl.o p_mobj.o p_plats.o p_pspr.o p_saveg.o p_setup.o p_sight.o p_spec.o p_switch.o p_telept.o p_tick.o p_user.o r_bsp.o r_data.o r_draw.o r_main.o r_plane.o r_segs.o r_sky.o r_things.o sha1.o sounds.o statdump.o st_lib.o st_stuff.o s_sound.o tables.o v_video.o wi_stuff.o w_checksum.o w_file.o w_main.o w_wad.o z_zone.o w_file_stdc.o i_input.o i_video.o doomgeneric.o doomgeneric_xlib.o -+SRC_DOOM = i_main.o dummy.o am_map.o doomdef.o doomstat.o dstrings.o d_event.o d_items.o d_iwad.o d_loop.o d_main.o d_mode.o d_net.o f_finale.o f_wipe.o g_game.o hu_lib.o hu_stuff.o info.o i_cdmus.o i_endoom.o i_joystick.o i_scale.o i_sound.o i_system.o i_timer.o memio.o m_argv.o m_bbox.o m_cheat.o m_config.o m_controls.o m_fixed.o m_menu.o m_misc.o m_random.o p_ceilng.o p_doors.o p_enemy.o p_floor.o p_inter.o p_lights.o p_map.o p_maputl.o p_mobj.o p_plats.o p_pspr.o p_saveg.o p_setup.o p_sight.o p_spec.o p_switch.o p_telept.o p_tick.o p_user.o r_bsp.o r_data.o r_draw.o r_main.o r_plane.o r_segs.o r_sky.o r_things.o sha1.o sounds.o statdump.o st_lib.o st_stuff.o s_sound.o tables.o v_video.o wi_stuff.o w_checksum.o w_file.o w_main.o w_wad.o z_zone.o w_file_stdc.o i_input.o i_video.o doomgeneric.o doomgeneric_serenity.o - OBJS += $(addprefix $(OBJDIR)/, $(SRC_DOOM)) - - all: $(OUTPUT) -@@ -35,7 +37,7 @@ clean: - - $(OUTPUT): $(OBJS) - @echo [Linking $@] -- $(VB)$(CC) $(CFLAGS) $(LDFLAGS) $(OBJS) \ -+ $(VB)$(CXX) $(CXXFLAGS) $(LDFLAGS) $(OBJS) \ - -o $(OUTPUT) $(LIBS) -Wl,-Map,$(OUTPUT).map - @echo [Size] - -$(CROSS_COMPILE)size $(OUTPUT) -@@ -49,6 +51,13 @@ $(OBJDIR)/%.o: %.c - @echo [Compiling $<] - $(VB)$(CC) $(CFLAGS) -c $< -o $@ - -+$(OBJDIR)/%.o: %.cpp -+ @echo [Compiling $<] -+ $(VB)$(CXX) $(CXXFLAGS) -c $< -o $@ -+ - print: - @echo OBJS: $(OBJS) - -+install: -+ cp $(OUTPUT) $(DESTDIR)/bin -+ -diff --git a/doomgeneric/doomgeneric.h b/doomgeneric/doomgeneric.h -index 2588710..468fbbf 100644 ---- a/doomgeneric/doomgeneric.h -+++ b/doomgeneric/doomgeneric.h -@@ -3,9 +3,12 @@ - - #include <stdint.h> - --#define DOOMGENERIC_RESX 640 --#define DOOMGENERIC_RESY 400 -+#define DOOMGENERIC_RESX 320 -+#define DOOMGENERIC_RESY 200 - -+#ifdef __cplusplus -+extern "C" { -+#endif - - extern uint32_t* DG_ScreenBuffer; - -@@ -17,4 +20,8 @@ uint32_t DG_GetTicksMs(); - int DG_GetKey(int* pressed, unsigned char* key); - void DG_SetWindowTitle(const char * title); - -+#ifdef __cplusplus -+} -+#endif -+ - #endif //DOOM_GENERIC -diff --git a/doomgeneric/doomgeneric_serenity.cpp b/doomgeneric/doomgeneric_serenity.cpp -new file mode 100644 -index 0000000..fe749a6 ---- /dev/null -+++ b/doomgeneric/doomgeneric_serenity.cpp -@@ -0,0 +1,183 @@ -+#include "doomkeys.h" -+#include "doomgeneric.h" -+ -+#include <stdio.h> -+#include <string.h> -+#include <unistd.h> -+#include <ctype.h> -+#include <sys/time.h> -+ -+#include <LibDraw/GraphicsBitmap.h> -+#include <LibGUI/GWindow.h> -+#include <LibGUI/GWidget.h> -+#include <LibGUI/GEvent.h> -+#include <LibGUI/GPainter.h> -+#include <LibCore/CEventLoop.h> -+#include <LibCore/CTimer.h> -+ -+static GWindow* g_window; -+static RefPtr<GraphicsBitmap> g_bitmap; -+ -+#define KEYQUEUE_SIZE 16 -+ -+static unsigned short s_KeyQueue[KEYQUEUE_SIZE]; -+static unsigned int s_KeyQueueWriteIndex = 0; -+static unsigned int s_KeyQueueReadIndex = 0; -+ -+static unsigned char convertToDoomKey(const GKeyEvent& event) -+{ -+ unsigned char key = 0; -+ switch (event.key()) { -+ case Key_Return: -+ key = KEY_ENTER; -+ break; -+ case Key_Escape: -+ key = KEY_ESCAPE; -+ break; -+ case Key_Left: -+ key = KEY_LEFTARROW; -+ break; -+ case Key_Right: -+ key = KEY_RIGHTARROW; -+ break; -+ case Key_Up: -+ key = KEY_UPARROW; -+ break; -+ case Key_Down: -+ key = KEY_DOWNARROW; -+ break; -+ case Key_Control: -+ key = KEY_FIRE; -+ break; -+ case Key_Space: -+ key = KEY_USE; -+ break; -+ case Key_LeftShift: -+ case Key_RightShift: -+ key = KEY_RSHIFT; -+ break; -+ default: -+ if (!event.text().is_empty()) -+ key = tolower(event.text()[0]); -+ break; -+ } -+ -+ return key; -+} -+ -+static void addKeyToQueue(const GKeyEvent& event) -+{ -+ bool pressed = event.type() == GEvent::KeyDown; -+ unsigned char key = convertToDoomKey(event); -+ -+ unsigned short keyData = (pressed << 8) | key; -+ -+ s_KeyQueue[s_KeyQueueWriteIndex] = keyData; -+ s_KeyQueueWriteIndex++; -+ s_KeyQueueWriteIndex %= KEYQUEUE_SIZE; -+} -+ -+class DoomWidget final : public GWidget { -+ C_OBJECT(DoomWidget) -+public: -+ DoomWidget(GWidget* parent = nullptr) -+ : GWidget(parent) -+ { -+ } -+ -+ virtual void keydown_event(GKeyEvent&) override; -+ virtual void keyup_event(GKeyEvent&) override; -+ virtual void paint_event(GPaintEvent&) override; -+}; -+ -+void DoomWidget::keydown_event(GKeyEvent& event) -+{ -+ addKeyToQueue(event); -+ GWidget::keydown_event(event); -+} -+ -+void DoomWidget::keyup_event(GKeyEvent& event) -+{ -+ addKeyToQueue(event); -+ GWidget::keyup_event(event); -+} -+ -+void DoomWidget::paint_event(GPaintEvent& event) -+{ -+ GPainter painter(*this); -+ painter.add_clip_rect(event.rect()); -+ -+ painter.draw_scaled_bitmap(rect(), *g_bitmap, g_bitmap->rect()); -+} -+ -+static DoomWidget* g_doom_widget; -+ -+extern "C" void DG_Init() -+{ -+ memset(s_KeyQueue, 0, KEYQUEUE_SIZE * sizeof(unsigned short)); -+ -+ // window creation -+ -+ g_bitmap = GraphicsBitmap::create_wrapper(GraphicsBitmap::Format::RGB32, Size(DOOMGENERIC_RESX, DOOMGENERIC_RESY), DOOMGENERIC_RESX * 4, DG_ScreenBuffer); -+ -+ g_window = new GWindow; -+ g_window->set_double_buffering_enabled(false); -+ g_window->set_rect(100, 100, DOOMGENERIC_RESX * 2, DOOMGENERIC_RESY * 2); -+ -+ g_doom_widget = new DoomWidget; -+ g_window->set_main_widget(g_doom_widget); -+ -+ new CTimer(33, [] { -+ g_doom_widget->update(); -+ }); -+ -+ g_window->show(); -+} -+ -+ -+extern "C" void DG_DrawFrame() -+{ -+ CEventLoop::current().pump(CEventLoop::WaitMode::PollForEvents); -+} -+ -+extern "C" void DG_SleepMs(uint32_t ms) -+{ -+ usleep (ms * 1000); -+} -+ -+extern "C" uint32_t DG_GetTicksMs() -+{ -+ struct timeval tp; -+ struct timezone tzp; -+ -+ gettimeofday(&tp, &tzp); -+ -+ return (tp.tv_sec * 1000) + (tp.tv_usec / 1000); /* return milliseconds */ -+} -+ -+extern "C" int DG_GetKey(int* pressed, unsigned char* doomKey) -+{ -+ if (s_KeyQueueReadIndex == s_KeyQueueWriteIndex) -+ { -+ //key queue is empty -+ -+ return 0; -+ } -+ else -+ { -+ unsigned short keyData = s_KeyQueue[s_KeyQueueReadIndex]; -+ s_KeyQueueReadIndex++; -+ s_KeyQueueReadIndex %= KEYQUEUE_SIZE; -+ -+ *pressed = keyData >> 8; -+ *doomKey = keyData & 0xFF; -+ -+ return 1; -+ } -+} -+ -+extern "C" void DG_SetWindowTitle(const char * title) -+{ -+ if (g_window) -+ g_window->set_title(title); -+} -diff --git a/doomgeneric/hu_stuff.c b/doomgeneric/hu_stuff.c -index b63cac7..e61a243 100644 ---- a/doomgeneric/hu_stuff.c -+++ b/doomgeneric/hu_stuff.c -@@ -294,7 +294,7 @@ void HU_Init(void) - j = HU_FONTSTART; - for (i=0;i<HU_FONTSIZE;i++) - { -- DEH_snprintf(buffer, 9, "STCFN%.3d", j++); -+ DEH_snprintf(buffer, 9, "STCFN%03d", j++); - hu_font[i] = (patch_t *) W_CacheLumpName(buffer, PU_STATIC); - } - -diff --git a/doomgeneric/i_main.c b/doomgeneric/i_main.cpp -similarity index 93% -rename from doomgeneric/i_main.c -rename to doomgeneric/i_main.cpp -index b192227..0663ed8 100644 ---- a/doomgeneric/i_main.c -+++ b/doomgeneric/i_main.cpp -@@ -18,10 +18,14 @@ - - //#include "config.h" - -+#include <LibGUI/GApplication.h> -+ - #include <stdio.h> - -+extern "C" { - //#include "doomtype.h" - //#include "i_system.h" -+ - #include "m_argv.h" - - // -@@ -35,10 +39,11 @@ void D_DoomMain (void); - void M_FindResponseFile(void); - - void dg_Create(); -- -+} - - int main(int argc, char **argv) - { -+ GApplication app(argc, argv); - // save arguments - - myargc = argc; -diff --git a/doomgeneric/wi_stuff.c b/doomgeneric/wi_stuff.c -index ddb9a66..1b19f6f 100644 ---- a/doomgeneric/wi_stuff.c -+++ b/doomgeneric/wi_stuff.c -@@ -1593,7 +1593,7 @@ static void WI_loadUnloadData(load_callback_t callback) - if (wbs->epsd != 1 || j != 8) - { - // animations -- DEH_snprintf(name, 9, "WIA%d%.2d%.2d", wbs->epsd, j, i); -+ DEH_snprintf(name, 9, "WIA%d%02d%02d", wbs->epsd, j, i); - callback(name, &a->p[i]); - } - else |