shithub: misc

Download patch

ref: f700e826c2329297e4c00141bc5f8e101e4471d5
parent: 1e95b1cbb2a05e23ada69db3093b1a3d389c97f3
author: qwx <[email protected]>
date: Fri Mar 17 18:34:13 EDT 2023

mid2s: remove hacks, make nchan configurable instead

--- a/mid2s.c
+++ b/mid2s.c
@@ -4,8 +4,8 @@
 
 enum{
 	Rate = 44100,
-	Nchan = 16,//6,
-	Percch = 9,//5,
+	Nchan = 16,
+	Percch = 9,
 };
 
 typedef struct Trk Trk;
@@ -18,10 +18,11 @@
 	double t;
 	int ev;
 	int ended;
-	int chan[16];
+	int chan[Nchan];
 };
 Trk *tr;
-int chan[16];
+int chan[Nchan];
+int maxchan = Nchan;
 
 int trace;
 int mfmt, ntrk, div = 1, tempo;
@@ -175,7 +176,7 @@
 	else if(chan[c] >= 0)
 		return e;
 	else{
-		for(i=0; i<Nchan; i++){
+		for(i=0; i<maxchan; i++){
 			if(i == Percch)
 				continue;
 			if(chan[i] < 0)
@@ -185,12 +186,12 @@
 		 * or hope the last channel isn't one of the main ones,
 		 * which is usually the case; but we no longer have our
 		 * settings */
-		if(i == Nchan)
-			i = Nchan-2;
+		if(i == maxchan)
+			i = maxchan-1;
 	}
 	x->chan[c] = i;
 	chan[i] = Nchan * (x - tr) + c;
-	return e & ~(16-1) | i;
+	return e & ~(Nchan-1) | i;
 }
 
 int
@@ -199,7 +200,6 @@
 	int e, n, m;
 
 	x->q = x->p - 1;
-	//*x->q = 0;
 	dprint(" [%zd] ", x - tr);
 	e = get8(x);
 	if((e & 0x80) == 0){
@@ -206,7 +206,6 @@
 		x->p--;
 		e = x->ev;
 		x->q--;
-		//x->q[0] = 0;
 		x->q[1] = e;
 		if((e & 0x80) == 0)
 			sysfatal("invalid event");
@@ -291,7 +290,7 @@
 void
 usage(void)
 {
-	fprint(2, "usage: %s [-D] [mid]\n", argv0);
+	fprint(2, "usage: %s [-D] [-c nchan] [mid]\n", argv0);
 	exits("usage");
 }
 
@@ -304,6 +303,11 @@
 	debug = 0;
 	ARGBEGIN{
 	case 'D': debug = 1; break;
+	case 'c':
+		maxchan = strtol(EARGF(usage()), nil, 10);
+		if(maxchan < 1 || maxchan > Nchan)
+			usage();
+		break;
 	default: usage();
 	}ARGEND
 	readmid(*argv);
@@ -320,7 +324,7 @@
 			while(x->Δ <= 0){
 				if(x->ended = ev(x, 0)){
 					int c = x - tr;
-					for(int i=0; i<Nchan; i++){
+					for(int i=0; i<maxchan; i++){
 						if(chan[i] == c + i)
 							chan[i] = -1;
 					}