Crunchy is capable of downloading anime episodes from the popular CrunchyRoll streaming service. An episode is stored in the original video format (often H.264 in a MP4 container) and the configured subtitle format (ASS or SRT).The two output files are then merged into a single MKV file.
CrunchyRoll has been providing an amazing streaming service and offers the best way to enjoy anime in a convenient and legal way. As a streaming service, video files cannot be downloaded and watched offline. Understandable from a business perspective and considering possible contract implications, but annoying for users. This application enables episodes to be downloaded for offline convenience. Please do not abuse this application; download episodes for personal use and delete them if you do not have an active premium account. Continue to support CrunchyRoll; without our financial backing their service cannot exist!
This application is not endorsed or affliated with CrunchyRoll. The usage of this application enables episodes to be downloaded for offline convenience which may be forbidden by law in your country. Usage of this application may also cause a violation of the agreed Terms of Service between you and the stream provider. A tool is not responsible for your actions; please make an informed decision prior to using this application.
PLEASE ONLY USE THIS TOOL IF YOU HAVE A PREMIUM ACCOUNT
It is recommended to enable authentication (
-u) so your account permissions and settings are available for use. It is not possible to download non-free material without an account and premium subscription. Furthermore, the default account settings are used when downloading. If you want the highest quality videos, configure these preferences at https://www.crunchyroll.com/acct/?action=video.
Use the applicable instructions to install. Is your operating system not listed? Please ask or contribute!
sudo apt-get install nodejs npm mkvtoolnix rtmpdump ffmpeg
sudo ln -s /usr/bin/nodejs /usr/bin/node
sudo npm install -g crunchy
brew install node mkvtoolnix rtmpdump ffmpeg
npm install -g crunchy
npm install -g crunchy
Use the applicable instructions for the interface of your choice (currently limited to command-line).
The command-line interface does not have a graphical component and is ideal for automation purposes and headless machines. The interface can run using a sequence of series addresses (the site address containing the episode listing), or with a batch-mode source file. The
crunchy --help command will produce the following output:
Usage: crunchy [options] Options: -h, --help output usage information -V, --version output the version number -p, --pass <s> The password. -u, --user <s> The e-mail address or username. -c, --cache Disables the cache. -m, --merge Disables merging subtitles and videos. -e, --episode <i> The episode filter. -v, --volume <i> The volume filter. -f, --format <s> The subtitle format. (Default: ass) -o, --output <s> The output path. -s, --series <s> The series override. -t, --tag <s> The subgroup. (Default: CrunchyRoll)
When no sequence of series addresses is provided, the batch-mode source file will be read (which is CrunchyRoll.txt in the current work directory. Each line in this file is processed as a seperate command-line statement. This makes it ideal to manage a large sequence of series addresses with variating command-line options or incremental episode updates.
Download in batch-mode:
Download Fairy Tail to the current work directory:
Download Fairy Tail to
crunchy --output C:\Anime http://www.crunchyroll.com/fairy-tail
-p or --pass <s>sets the password.
-u or --user <s>sets the e-mail address or username.
Please remember that login has to be done for each call of Crunchy, as none of the credentials are stored
-c or --cachedisables the cache.
-m or --mergedisables merging subtitles and videos.
-e or --episode <i>filters episodes (positive is greater than, negative is smaller than).
-v or --volume <i>filters volumes (positive is greater than, negative is smaller than).
-f or --format <s>sets the subtitle format. (Default: ass)
-o or --output <s>sets the output path.
-s or --series <s>sets the series override.
-t or --tag <s>sets The subgroup. (Default: CrunchyRoll)
First, make sure you have the latest version of Crunchy installed, if you run an older version, the issue you face may have been solved.
Second thing to check, you have to give your credentials (-u and -p parameters) each time you run Crunchy. It does not actually store the token it receive when login and need to relog each time it is called. This may change in the future.
Third, is it a recently released episode? If yes, sometimes CR have issues were the requested format is not available, and Crunchy is not able to get it. When in doubt, try to watch CR website, if it does not work there, Crunchy will not either. This is valid in all cases even on non recently released.
Fourth, sometimes, CR website does weird things, and there are some transient errors, wait a couple of minutes (or hours) and try again. It often solved the issue on my side (yes I know that's not really a way of fixing, but if the error is on CR side, Crunchy can't do anything)
If really nothing works or you find a problem with Crunchy, then you can go and fill an Issue, first read the already open and closed one to make sure you are not reporting an existing problem. If your problem has been already reported, what you can do is to either:
If there is no comparable opened or close issue, you can create a new one.
It is really important for me to know:
Please be careful to remove your real account login and password if they appear!
Also don't hesitate to add labels you feel apropriate on your report.
Note: You can also use a bug report for a feature requests.
More information will be added at a later point. For now the recommendations are:
Since this project uses TypeScript, compile with
node ts or
If you want to help working on this project, Pull request are welcome, but please explain the goal of your changes, and do a pull request per change: you want to add support for X, Y and Z, make a pull request for X, one for Y and one for Z. I'm not saying a pull request per commit that would be idiotic. The idea is if your pull request changes lots of thing at the same time, if just a single part can't be accepted, if will delay the acceptation of the whole pull request where some of the feature could be integrated quicker is they were requested alone. Also if for example the change Y depends on X, you can wait for X to be accepted before requesting for Y, if they are independant you can send a pull request for each at the same time.