jack1 codebase
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123 lines
3.2KB

  1. /*
  2. Copyright (C) 2002 Jeremy Hall
  3. This program is free software; you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation; either version 2 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program; if not, write to the Free Software
  13. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  14. */
  15. #include <stdio.h>
  16. #include <errno.h>
  17. #include <unistd.h>
  18. #include <string.h>
  19. #include <stdlib.h>
  20. #include <jack/jack.h>
  21. jack_port_t *input_port;
  22. jack_port_t *output_port;
  23. int connecting, disconnecting;
  24. #define TRUE 1
  25. #define FALSE 0
  26. int
  27. main (int argc, char *argv[])
  28. {
  29. jack_client_t *client;
  30. char *my_name = strrchr(argv[0], '/');
  31. connecting = disconnecting = FALSE;
  32. if (my_name == 0) {
  33. my_name = argv[0];
  34. } else {
  35. my_name ++;
  36. }
  37. if (strstr(my_name, "disconnect")) {
  38. disconnecting = TRUE;
  39. } else
  40. if (strstr(my_name, "connect")) {
  41. connecting = TRUE;
  42. } else {
  43. fprintf(stderr, "ERROR! client should be called jack_connect or jack_disconnect. client is called %s\n", my_name);
  44. return 1;
  45. }
  46. if (argc != 3) {
  47. fprintf (stderr, "usage: %s <src_port> <dst_port>\n", my_name);
  48. fprintf(stderr, "The source port must be an output port of the source client.\n");
  49. fprintf (stderr, "The destination port must be an input port of the destination client.\n");
  50. return 1;
  51. }
  52. /* try to become a client of the JACK server */
  53. if ((client = jack_client_new (my_name)) == 0) {
  54. fprintf (stderr, "jack server not running?\n");
  55. return 1;
  56. }
  57. /* display the current sample rate. once the client is activated
  58. (see below), you should rely on your own sample rate
  59. callback (see above) for this value.
  60. */
  61. printf ("engine sample rate: %" PRIu32 "\n",
  62. jack_get_sample_rate (client));
  63. /* find the two ports */
  64. if ((input_port = jack_port_by_name(client, argv[1])) == 0) {
  65. fprintf (stderr, "ERROR %s not a valid port\n", argv[1]);
  66. return 1;
  67. }
  68. if ((output_port = jack_port_by_name(client, argv[2])) == 0) {
  69. fprintf (stderr, "ERROR %s not a valid port\n", argv[2]);
  70. return 1;
  71. }
  72. /* tell the JACK server that we are ready to roll */
  73. if (jack_activate (client)) {
  74. fprintf (stderr, "cannot activate client");
  75. return 1;
  76. }
  77. /* connect the ports. Note: you can't do this before
  78. the client is activated (this may change in the future).
  79. */
  80. /* jack_port_connect not implemented
  81. if (jack_port_connect(client, input_port, output_port)) {
  82. fprintf (stderr, "cannot connect ports\n");
  83. }
  84. */
  85. if (connecting) {
  86. if (jack_connect(client, jack_port_name(input_port), jack_port_name(output_port))) {
  87. fprintf (stderr, "cannot connect ports\n");
  88. return 1;
  89. }
  90. }
  91. if (disconnecting) {
  92. if (jack_disconnect(client, jack_port_name(input_port), jack_port_name(output_port))) {
  93. fprintf (stderr, "cannot disconnect ports\n");
  94. return 1;
  95. }
  96. }
  97. jack_client_close (client);
  98. exit (0);
  99. }