aboutsummaryrefslogtreecommitdiffstats
path: root/audio/cdplay/files/patch-main.c
blob: f9bb8d8451819718aadc19f234fb79f186a81901 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
--- main.c.orig 1997-11-17 09:26:26 UTC
+++ main.c
@@ -35,11 +35,14 @@ extern struct termios old_ttyattr;
 int main(int argc, char **argv)
 {
   char cmd[1];
+  int repetivity;
   fd_set rset;
   struct timeval stime;
 
   /* Parse arguments */
-  cd_device=DEVICE;
+  cd_device=getenv("CDROM");
+  if (cd_device==NULL)
+    cd_device=DEVICE;
   if(argc>1 && !strcmp(argv[1],"-d"))
     cd_device=argv[2];
   else if(argc>1)
@@ -68,19 +71,20 @@ int main(int argc, char **argv)
 
   while(1){
     if(select(1,&rset,(fd_set *) 0,(fd_set *) 0,&stime)>0) {
-      read(STDIN_FILENO,cmd,FD_SETSIZE);
-      
+      getcommand(&cmd[0], &repetivity);
+
       if(cmd[0]=='p'){message="play";play_track(1);}
       else if(cmd[0]=='F'){message="next";next();}
       else if(cmd[0]=='R'){message="prev";prev();}
-      else if(cmd[0]=='f'){message="ff";ff();}
-      else if(cmd[0]=='r'){message="rew";rew();}
+      else if(cmd[0]=='f'){message="ff";ff(repetivity);}
+      else if(cmd[0]=='r'){message="rew";rew(repetivity);}
       else if(cmd[0]=='s'){message="stop";stop();}
-      else if(cmd[0]=='e'){message="eject";eject();}
-      else if(cmd[0]==' ') cdpause();
+      else if(cmd[0]=='E'){message="eject";eject();}
+      else if(cmd[0]==' ') cdsoftpause();
       else if(cmd[0]=='+'){message="more vol";more_vol();}
       else if(cmd[0]=='-'){message="less vol";less_vol();}
       else if(cmd[0]=='q'){message="bye!";do_exit(0);}
+      else if(cmd[0]=='P') cdpause();
     }
     update_cdinfo();
     move_up(5);
@@ -92,6 +96,36 @@ int main(int argc, char **argv)
     exit(0);
 }
 
+void getcommand(char *command, int *repetivity)
+{
+  static char stored_command;
+  int n;
+
+  fcntl(STDIN_FILENO, F_SETFL, O_NONBLOCK);
+
+  if (stored_command) {
+    *command=stored_command;
+  } else {
+    n=read(STDIN_FILENO,command,1);
+    if (n <= 0) {
+      *command='\0';
+      *repetivity=0;
+      return;
+    }
+  }
+
+  *repetivity=1;
+  while (read(STDIN_FILENO, &stored_command, 1) > 0) {
+    if (stored_command == *command) {
+      (*repetivity)++;
+    } else {
+      return;
+    }
+  }
+  stored_command='\0';
+  return;
+}
+
 void hs_cont(void)
 {
   init_term();