ref: ccc18d6ab171efa2a512f3c79c535a27b5baec7f
parent: 0cf1870f4b5a8a547ce1334e6e83cc0275b94774
	author: Ori Bernstein <ori@markovcorp.com>
	date: Thu Oct  5 14:23:28 EDT 2017
	
Allow passing some flags to the build.
--- a/mbld/deps.myr
+++ b/mbld/deps.myr
@@ -402,6 +402,9 @@
 const musecmd = {b, n, mt, mustd.slpush(&n.cmd, std.sldup(opt_muse))
+ for o : opt_museflags
+ std.slpush(&n.cmd, o)
+ ;;
 	std.slpush(&n.cmd, std.sldup("-o"))std.slpush(&n.cmd, std.sldup(mu))
 	std.slpush(&n.cmd, std.sldup("-p"))@@ -425,6 +428,9 @@
for c : config.Linkcmd
std.slpush(&n.cmd, std.sldup(c))
;;
+ for o : opt_ldflags
+ std.slpush(&n.cmd, o)
+ ;;
std.slpush(&n.cmd, std.sldup(bin))
if mt.ldscript.len > 0
 		std.slpush(&n.cmd, std.sldup("-T"))@@ -459,6 +465,9 @@
 const myrcmd = {b, n, mt, src, isteststd.slpush(&n.cmd, std.sldup(opt_mc))
+ for o : opt_mcflags
+ std.slpush(&n.cmd, o)
+ ;;
if opt_objdir.len > 0
pushopt(&n.cmd, "-O", std.sldup(opt_objdir))
;;
--- a/mbld/opts.myr
+++ b/mbld/opts.myr
@@ -4,18 +4,21 @@
use "config"
pkg bld =
- var opt_arch : byte[:]
- var opt_sys : byte[:]
- var opt_sysvers : (int, int, int)
- var opt_runtime : byte[:]
- var opt_genasm : bool
+ var opt_arch : byte[:]
+ var opt_sys : byte[:]
+ var opt_sysvers : (int, int, int)
+ var opt_runtime : byte[:]
+ var opt_genasm : bool
var opt_incpaths : byte[:][:]
+ var opt_mcflags : byte[:][:]
+ var opt_museflags : byte[:][:]
+ var opt_ldflags : byte[:][:]
var opt_instbase : byte[:]
- var opt_destdir : byte[:]
- var opt_objdir : byte[:]
- var opt_maxproc : std.size
- var opt_debug : bool
- var opt_silent : bool
+ var opt_destdir : byte[:]
+ var opt_objdir : byte[:]
+ var opt_maxproc : std.size
+ var opt_debug : bool
+ var opt_silent : bool
/* undocumented/unsupported opts */
var opt_mc : byte[:]
@@ -29,25 +32,26 @@
const parseversion : (v : byte[:] -> (int, int, int))
;;
-var opt_arch = ""
-var opt_sys = ""
-var opt_binname = ""
-var opt_libname = ""
-var opt_runtime = ""
+var opt_arch = ""
+var opt_sys = ""
+var opt_binname = ""
+var opt_libname = ""
+var opt_runtime = ""
var opt_incpaths /* FIXME: taking a constant slice is a nonconstant initializer */
var opt_instbase = ""
-var opt_destdir = ""
+var opt_destdir = ""
var opt_sysvers
-var opt_debug = false
-var opt_mc = "6m"
-var opt_as = "as"
-var opt_muse = "muse"
-var opt_ld = "ld"
-var opt_ar = "ar"
-var opt_objdir = "obj"
-var opt_genasm = false
-var opt_silent = false
-var opt_maxproc = 1
+var opt_debug = false
+var opt_mc = "6m"
+var opt_as = "as"
+var opt_muse = "muse"
+var opt_mcflags = [][:]
+var opt_museflags = [][:]
+var opt_ldflags = [][:]
+var opt_objdir = "obj"
+var opt_genasm = false
+var opt_silent = false
+var opt_maxproc = 1
 const initopts = {var si
@@ -78,6 +82,18 @@
 	opt_mc = std.getenvv("MYR_MC", "6m") 	opt_muse = std.getenvv("MYR_MUSE", "muse") 	opt_runtime = std.getenvv("MYR_RT", "")+	match std.getenv("MYR_MCFLAGS")+ | `std.Some s: opt_mcflags = std.strtok(s)
+ | `std.None: /* ok */
+ ;;
+	match std.getenv("MYR_MUSEFLAGS")+ | `std.Some s: opt_mcflags = std.strtok(s)
+ | `std.None: /* ok */
+ ;;
+	match std.getenv("MYR_LDFLAGS")+ | `std.Some s: opt_ldflags = std.strtok(s)
+ | `std.None: /* ok */
+ ;;
if opt_runtime.len == 0
opt_runtime = std.pathjoin([opt_instbase, config.Libpath, config.Runtime][:])
;;
--
⑨