git-svn-id: http://svn2.nishi.boats/svn/milsko/trunk@643 b9cfdab3-6d41-4d17-bbe4-086880011989
This commit is contained in:
NishiOwO
2025-11-08 22:48:42 +00:00
parent 2f6a0d1ada
commit a9fa9cb83c
5 changed files with 85 additions and 77 deletions

View File

@@ -119,13 +119,16 @@ print("Target : " . $target . "\n");
my @l = (); my @l = ();
foreach my $e (param_list()) { foreach my $e (param_list()) {
if (not(param_get($e))) {
next;
}
if (($e eq "vulkan-string-helper") and param_get("vulkan")) { if (($e eq "vulkan-string-helper") and param_get("vulkan")) {
push(@l, $e); push(@l, $e);
} }
elsif (($e eq "xrender") and ($backend eq "x11")) { elsif (($e eq "xrender") and ($backend eq "x11")) {
push(@l, $e); push(@l, $e);
} }
elsif (not($e eq "vulkan-string-helper") and not($e eq "xrender") and param_get($e)) { elsif (not($e eq "vulkan-string-helper") and not($e eq "xrender")) {
push(@l, $e); push(@l, $e);
} }
} }

View File

@@ -1,6 +1,7 @@
# $Id$ # $Id$
add_incdir("-I/usr/X11R7/include -I/usr/pkg/include"); add_incdir("-I/usr/X11R7/include -I/usr/pkg/include");
add_libdir("-L/usr/X11R7/lib -Wl,-R/usr/X11R7/lib -L/usr/pkg/lib -Wl,-R/usr/pkg/lib"); add_libdir(
"-L/usr/X11R7/lib -Wl,-R/usr/X11R7/lib -L/usr/pkg/lib -Wl,-R/usr/pkg/lib");
use_backend("x11"); use_backend("x11");
1; 1;

View File

@@ -3,38 +3,40 @@ new_object("src/*.c");
my $gl_libs = ""; my $gl_libs = "";
if($backend eq "x11"){ if ($backend eq "x11") {
add_cflags("-DUSE_X11"); add_cflags("-DUSE_X11");
new_object("src/backend/x11.c"); new_object("src/backend/x11.c");
add_libs("-lX11 -lXrender -lXcursor"); add_libs("-lX11 -lXrender -lXcursor");
$gl_libs = "-lGL -lGLU"; $gl_libs = "-lGL -lGLU";
}elsif($backend eq "gdi"){ }
elsif ($backend eq "gdi") {
add_cflags("-DUSE_GDI"); add_cflags("-DUSE_GDI");
new_object("src/backend/gdi.c"); new_object("src/backend/gdi.c");
add_libs("-lgdi32"); add_libs("-lgdi32");
$gl_libs = "-lopengl32 -lglu32"; $gl_libs = "-lopengl32 -lglu32";
}elsif($backend eq "darwin"){ }
elsif ($backend eq "darwin") {
add_cflags("-DUSE_DARWIN"); add_cflags("-DUSE_DARWIN");
new_object("src/backend/mac/*.c"); new_object("src/backend/mac/*.c");
add_ldflags("-framework Carbon"); add_ldflags("-framework Carbon");
} }
if(param_get("stb-image")){ if (param_get("stb-image")) {
add_cflags("-DUSE_STB_IMAGE"); add_cflags("-DUSE_STB_IMAGE");
} }
if(param_get("stb-truetype")){ if (param_get("stb-truetype")) {
add_cflags("-DUSE_STB_TRUETYPE"); add_cflags("-DUSE_STB_TRUETYPE");
} }
if(param_get("freetype2")){ if (param_get("freetype2")) {
add_cflags("-DUSE_FREETYPE2"); add_cflags("-DUSE_FREETYPE2");
if(not($cross)){ if (not($cross)) {
add_cflags(`pkg-config --cflags freetype2`); add_cflags(`pkg-config --cflags freetype2`);
add_libs(`pkg-config --libs freetype2`); add_libs(`pkg-config --libs freetype2`);
} }
} }
if(param_get("xrender")){ if (param_get("xrender")) {
add_cflags("-DUSE_XRENDER"); add_cflags("-DUSE_XRENDER");
} }
@@ -57,10 +59,11 @@ new_object("src/widget/scrollbar.c");
new_object("src/widget/submenu.c"); new_object("src/widget/submenu.c");
new_object("src/widget/viewport.c"); new_object("src/widget/viewport.c");
new_object("src/widget/window.c"); new_object("src/widget/window.c");
if(param_get("opengl")){
if (param_get("opengl")) {
new_object("src/widget/opengl.c"); new_object("src/widget/opengl.c");
} }
if(param_get("vulkan")){ if (param_get("vulkan")) {
new_object("src/widget/vulkan.c"); new_object("src/widget/vulkan.c");
} }
@@ -70,7 +73,6 @@ new_object("src/abstract/*.c");
new_object("external/*.c"); new_object("external/*.c");
new_example("examples/basic/example"); new_example("examples/basic/example");
new_example("examples/basic/rotate"); new_example("examples/basic/rotate");
new_example("examples/basic/image"); new_example("examples/basic/image");
@@ -83,7 +85,7 @@ new_example("examples/basic/listbox");
new_example("examples/basic/progressbar"); new_example("examples/basic/progressbar");
new_example("examples/basic/colorpicker"); new_example("examples/basic/colorpicker");
if(param_get("opengl")){ if (param_get("opengl")) {
new_example("examples/gldemos/boing", $gl_libs); new_example("examples/gldemos/boing", $gl_libs);
new_example("examples/gldemos/clock", $gl_libs); new_example("examples/gldemos/clock", $gl_libs);
new_example("examples/gldemos/cube", $gl_libs); new_example("examples/gldemos/cube", $gl_libs);
@@ -92,7 +94,7 @@ if(param_get("opengl")){
new_example("examples/gldemos/tripaint", $gl_libs); new_example("examples/gldemos/tripaint", $gl_libs);
} }
if(param_get("vulkan")){ if (param_get("vulkan")) {
new_example("examples/vkdemos/vulkan"); new_example("examples/vkdemos/vulkan");
} }

View File

@@ -35,7 +35,7 @@ sub add_libs {
} }
sub new_example { sub new_example {
if(@_ == 2){ if (@_ == 2) {
$examples_libs{"$_[0]${executable_suffix}"} = $_[1]; $examples_libs{"$_[0]${executable_suffix}"} = $_[1];
} }
push(@examples_targets, "${_[0]}${executable_suffix}"); push(@examples_targets, "${_[0]}${executable_suffix}");
@@ -43,7 +43,7 @@ sub new_example {
sub new_object { sub new_object {
my @l = glob($_[0]); my @l = glob($_[0]);
foreach my $e (@l){ foreach my $e (@l) {
$e =~ s/\.c$/$object_suffix/; $e =~ s/\.c$/$object_suffix/;
push(@library_targets, $e); push(@library_targets, $e);
} }
@@ -54,15 +54,17 @@ sub use_backend {
} }
our %params = (); our %params = ();
sub param_set { sub param_set {
$params{$_[0]} = $_[1]; $params{ $_[0] } = $_[1];
} }
sub param_get { sub param_get {
if(not(defined($params{$_[0]}))){ if (not(defined($params{ $_[0] }))) {
return 0; return 0;
}else{ }
return $params{$_[0]}; else {
return $params{ $_[0] };
} }
} }