diff options
| -rw-r--r-- | drumgizmo/Makefile.am | 1 | ||||
| -rw-r--r-- | drumgizmo/drumgizmoc.cc | 95 | ||||
| -rw-r--r-- | drumgizmo/drumgizmoc.h | 45 | ||||
| -rw-r--r-- | drumgizmo/output/wavfile/Makefile.am | 2 | ||||
| -rw-r--r-- | src/drumgizmo.cc | 23 | ||||
| -rw-r--r-- | src/drumgizmo.h | 13 | 
6 files changed, 154 insertions, 25 deletions
| diff --git a/drumgizmo/Makefile.am b/drumgizmo/Makefile.am index b01b41f..5220ae3 100644 --- a/drumgizmo/Makefile.am +++ b/drumgizmo/Makefile.am @@ -27,6 +27,7 @@ drumgizmo_SOURCES = \  EXTRA_DIST = \  	audioinputenginedl.h \  	audiooutputenginedl.h \ +	drumgizmoc.h \  	jackclient.h  endif diff --git a/drumgizmo/drumgizmoc.cc b/drumgizmo/drumgizmoc.cc index ce4d9e2..6315491 100644 --- a/drumgizmo/drumgizmoc.cc +++ b/drumgizmo/drumgizmoc.cc @@ -30,8 +30,10 @@  #include <string.h>  #include <stdio.h>  #include <stdlib.h> +#include <unistd.h>  #include "drumgizmo.h" +#include "drumgizmoc.h"  #include "audiooutputenginedl.h"  #include "audioinputenginedl.h" @@ -54,17 +56,60 @@ static const char copyright_str[] =  static const char usage_str[] =  "Usage: %s [options] drumkitfile\n"  "Options:\n" -"  -p, --preload          Load entire kit audio files into memory (uses ALOT of memory).\n" -"  -i, --inputengine dummy|test|jackmidi|midifile  Use said event input engine.\n" -"  -I, --inputparms parmlist  Set input engine parameters.\n" -"  -o, --outputengine dummy|alsa|jackaudio|wavfile  Use said audio output engine.\n" -"  -O, --outputparms parmlist  Set output engine parameters.\n" -"  -e, --endpos Number of samples to process, -1: infinite.\n" +"  -a, --async-load       Load drumkit in the background and start the engine immediately.\n" +"  -i, --inputengine      dummy|test|jackmidi|midifile  Use said event input engine.\n" +"  -I, --inputparms       parmlist  Set input engine parameters.\n" +"  -o, --outputengine     dummy|alsa|jackaudio|sndfile  Use said audio output engine.\n" +"  -O, --outputparms      parmlist  Set output engine parameters.\n" +"  -e, --endpos           Number of samples to process, -1: infinite.\n"  "  -v, --version          Print version information and exit.\n"  "  -h, --help             Print this message and exit.\n" +"\n" +"Input engine parameters:\n" +"  jackmidi:  midimap=<midimapfile>\n" +"  midifile:  file=<midifile>, speed=<tempo> (default 1.0),\n" +"             track=<miditrack> (default -1, all tracks)\n" +"             midimap=<midimapfile>, loop=<true|false>\n" +"  test:      p=<hit_propability> (default 0.1)\n" +"             instr=<instrument> (default -1, random instrument)\n" +"             len=<seconds> (default -1, forever)\n" +"  dummy:\n" +"\n" +"Output engine parameters:\n" +"  alsa:      dev=<device> (default 'default'), frames=<frames> (default 32)\n" +"             srate=<samplerate> (default 441000)\n" +"  wavfile:   file=<filename> (default 'output'), srate=<samplerate> (default 44100)\n" +"  jackaudio:\n" +"  dummy:\n" +"\n"  ; -int main(int argc, char *argv[]) +CliMain::CliMain() : MessageReceiver(MSGRCV_UI) +{ +  loading = true; // Block by default +} + +CliMain::~CliMain() +{ +} + +void CliMain::handleMessage(Message *msg) +{ +  switch(msg->type()) { +  case Message::LoadStatus: +    { +      LoadStatusMessage *ls = (LoadStatusMessage*)msg; +      if(ls->numer_of_files_loaded == ls->number_of_files) { +        loading = false; +      } +    } +    break; +  default: +    break; +  } +} + +int CliMain::run(int argc, char *argv[])  {    int c; @@ -72,13 +117,13 @@ int main(int argc, char *argv[])    std::string inputengine;    std::string iparms;    std::string oparms; -  bool preload = false; +  bool async = false;    int endpos = -1;    int option_index = 0;    while(1) {      static struct option long_options[] = { -      {"preload", no_argument, 0, 'p'}, +      {"async-load", no_argument, 0, 'a'},        {"inputengine", required_argument, 0, 'i'},        {"inputparms", required_argument, 0, 'I'},        {"outputengine", required_argument, 0, 'o'}, @@ -119,8 +164,8 @@ int main(int argc, char *argv[])        oparms = optarg;        break; -    case 'p': -      preload = true; +    case 'a': +      async = true;        break;      case 'e': @@ -243,14 +288,30 @@ int main(int argc, char *argv[])    printf("Using kitfile: %s\n", kitfile.c_str());    DrumGizmo gizmo(oe, ie); +    if(kitfile == "" || !gizmo.loadkit(kitfile)) {      printf("Failed to load \"%s\".\n", kitfile.c_str());      return 1;    } +  printf("Loading drumkit, this may take a while..."); +  fflush(stdout); +  loading = true; +  while(async == false && loading) { +#ifdef WIN32 +    SleepEx(500, FALSE); +#else +    usleep(500000); +#endif/*WIN32*/ +    handleMessages(); +    printf("."); +    fflush(stdout); +  } +  printf("done.\n"); +    gizmo.setSamplerate(oe->samplerate()); -  if(!gizmo.init(preload)) { +  if(!gizmo.init()) {      printf("Failed init engine.\n");      return 1;    } @@ -264,3 +325,13 @@ int main(int argc, char *argv[])    return 0;  } + +int main(int argc, char *argv[]) +{ +  CliMain cli; + +  cli.run(argc, argv); + +  return 0; + +} diff --git a/drumgizmo/drumgizmoc.h b/drumgizmo/drumgizmoc.h new file mode 100644 index 0000000..4b6d4a1 --- /dev/null +++ b/drumgizmo/drumgizmoc.h @@ -0,0 +1,45 @@ +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/*************************************************************************** + *            drumgizmoc.h + * + *  Mon Jan 12 00:36:37 CET 2015 + *  Copyright 2015 Sergey 'Jin' Bostandzhyan + *  jin@mediatomb.cc + ****************************************************************************/ + +/* + *  This file is part of DrumGizmo. + * + *  DrumGizmo is free software; you can redistribute it and/or modify + *  it under the terms of the GNU General Public License as published by + *  the Free Software Foundation; either version 2 of the License, or + *  (at your option) any later version. + * + *  DrumGizmo is distributed in the hope that it will be useful, + *  but WITHOUT ANY WARRANTY; without even the implied warranty of + *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *  GNU General Public License for more details. + * + *  You should have received a copy of the GNU General Public License + *  along with DrumGizmo; if not, write to the Free Software + *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA. + */ + +#ifndef __DRUMGIZMOC_H__ +#define __DRUMGIZMOC_H__ + +#include "messagereceiver.h" + +class CliMain : public MessageReceiver { +public: +  CliMain(); +  virtual ~CliMain(); + +  int run(int argc, char *argv[]); +  void handleMessage(Message *msg); +private: +  bool loading; +}; + +#endif//__DRUMGIZMOC_H__ + diff --git a/drumgizmo/output/wavfile/Makefile.am b/drumgizmo/output/wavfile/Makefile.am index ae0eb76..ad26294 100644 --- a/drumgizmo/output/wavfile/Makefile.am +++ b/drumgizmo/output/wavfile/Makefile.am @@ -26,4 +26,4 @@ wavfile_la_LIBADD =  wavfile_la_SOURCES = $(wavfilebuildsources)  install-exec-hook: -	rm -f $(DESTDIR)$(libdir)/alsa.la +	rm -f $(DESTDIR)$(libdir)/wavfile.la diff --git a/src/drumgizmo.cc b/src/drumgizmo.cc index 5d7de70..2f2232c 100644 --- a/src/drumgizmo.cc +++ b/src/drumgizmo.cc @@ -49,6 +49,7 @@ DrumGizmo::DrumGizmo(AudioOutputEngine *o, AudioInputEngine *i)    : MessageReceiver(MSGRCV_ENGINE),      loader(), oe(o), ie(i)  { +  is_stopping = false;  }  DrumGizmo::~DrumGizmo() @@ -86,10 +87,8 @@ bool DrumGizmo::loadkit(std::string file)    return true;  } -bool DrumGizmo::init(bool preload) +bool DrumGizmo::init()  { -  (void)preload; -    if(!ie->init(kit.instruments)) return false;    if(!oe->init(kit.channels)) return false; @@ -257,7 +256,23 @@ bool DrumGizmo::run(size_t pos, sample_t *samples, size_t nsamples)      }      if(evs[e].type == TYPE_STOP) { -      return false; +      is_stopping = true; +    } + +    if(is_stopping) { +      // Count the number of active events. +      int num_active_events = 0; +      Channels::iterator j = kit.channels.begin(); +      while(j != kit.channels.end()) { +        Channel &ch = *j; +        num_active_events += activeevents[ch.num].size(); +        j++; +      } + +      if(num_active_events == 0) { +        // No more active events - now we can stop the engine. +        return false; +      }      }    } diff --git a/src/drumgizmo.h b/src/drumgizmo.h index 138e61c..f8d45f5 100644 --- a/src/drumgizmo.h +++ b/src/drumgizmo.h @@ -51,14 +51,13 @@  class DrumGizmo : public MessageReceiver {  public: -  DrumGizmo(AudioOutputEngine *outputengine, -            AudioInputEngine *inputengine); +  DrumGizmo(AudioOutputEngine *outputengine, AudioInputEngine *inputengine);    virtual ~DrumGizmo();    bool loadkit(std::string kitfile); -  bool init(bool preload = true); -   +  bool init(); +    /**     * @param endpos number of samples to process, -1 := never stop.     */ @@ -68,8 +67,6 @@ public:    void getSamples(int ch, int pos, sample_t *s, size_t sz); -  bool isRunning() { return is_running; } -    std::string configString();    bool setConfigString(std::string cfg); @@ -77,12 +74,12 @@ public:    int samplerate();    void setSamplerate(int samplerate); -   +  private:    DrumKitLoader loader;    Mutex mutex; -  bool is_running; +  bool is_stopping; ///< Is set to true when a TYPE_STOP event has been seen.    AudioOutputEngine *oe;    AudioInputEngine *ie; | 
