diff --git a/meta.json b/meta.json new file mode 100644 index 00000000..0b93d9be --- /dev/null +++ b/meta.json @@ -0,0 +1 @@ +{"slug":"etcher","type":"repository","version":"1.5.63","markers":[],"tags":[],"links":{},"active":true,"data":{"license":"Apache-2.0","name":"etcher","tagline":"Flash OS images to SD cards & USB drives, safely and easily.","images":{"banner":""},"description":"Flash OS images to SD cards & USB drives, safely and easily.","version":"1.5.63","type":"npm","links":{"issueTracker":null,"homepage":"https://etcher.io","repository":"https://github.com/balena-io/etcher.git"},"maintainers":["@thundron","@zvin","@jviotti","@nazrhom"],"changelog":[],"faq":[{"title":"Why is my drive not bootable?","content":[["para","Etcher copies images to drives byte by byte, without doing any transformation to the final device, which means images that require special treatment to be made bootable, like Windows images, will not work out of the box. In these cases, the general advice is to use software specific to those kind of images, usually available from the image publishers themselves. You can find more information ",["link",{"href":"https://github.com/balena-io/etcher/blob/master/docs/USER-DOCUMENTATION.md#why-is-my-drive-not-bootable"},"here"],"."]]},{"title":"How can I configure persistent storage?","content":[["para","Some programs, usually oriented at making GNU/Linux live USB drives, include an option to set persistent storage. This is currently not supported by Etcher, so if you require this functionality, we advise to fallback to ",["link",{"href":"https://unetbootin.github.io/"},"UNetbootin"],"."]]},{"title":"How do I flash Ubuntu ISOs","content":[["para","Ubuntu images (and potentially some other related GNU/Linux distributions) have a peculiar format that allows the image to boot without any further modification from both CDs and USB drives.\nA consequence of this enhancement is that some programs, like parted get confused about the drive's format and partition table, printing warnings such as:"],["blockquote",["para","/dev/xxx contains GPT signatures, indicating that it has a GPT table. However, it does not have a valid fake msdos partition table, as it should. Perhaps it was corrupted -- possibly by a program that doesn't understand GPT partition tables. Or perhaps you deleted the GPT table, and are now using an msdos partition table. Is this a GPT partition table? Both the primary and backup GPT tables are corrupt. Try making a fresh table, and using Parted's rescue feature to recover partitions."],["para","Warning: The driver descriptor says the physical block size is 2048 bytes, but Linux says it is 512 bytes."]],["para","All these warnings are safe to ignore, and your drive should be able to boot without any problems.\nRefer to ",["link",{"href":"https://lists.ubuntu.com/archives/ubuntu-devel/2011-June/033495.html"},"the following message from Ubuntu's mailing list"]," if you want to learn more."]]},{"title":"How do I run Etcher on Wayland?","content":[["para","The XWayland Server provides backwards compatibility to run any X client on Wayland, including Etcher.\nThis usually works out of the box on mainstream GNU/Linux distributions that properly support Wayland. If it doesn't, make sure the xwayland.so module is being loaded by declaring it in your ",["link",{"href":"http://manpages.ubuntu.com/manpages/wily/man5/weston.ini.5.html"},"weston.ini"],":"],["para",["inlinecode","\n[core]\nmodules=xwayland.so\n"]]]},{"title":"What are the runtime GNU/LINUX dependencies?","content":[["para",["link",{"href":"https://github.com/balena-io/etcher/blob/master/docs/USER-DOCUMENTATION.md#runtime-gnulinux-dependencies"},"This entry"]," aims to provide an up to date list of runtime dependencies needed to run Etcher on a GNU/Linux system."]]},{"title":"How can I recover the broken drive?","content":[["para","Sometimes, things might go wrong, and you end up with a half-flashed drive that is unusable by your operating systems, and common graphical tools might even refuse to get it back to a normal state.\nTo solve these kinds of problems, we've collected ",["link",{"href":"https://github.com/balena-io/etcher/blob/master/docs/USER-DOCUMENTATION.md#recovering-broken-drives"},"a list of fail-proof methods"]," to completely erase your drive in major operating systems."]]},{"title":"I receive ”No polkit authentication agent found” error in GNU/Linux","content":[["para","Etcher requires an available ",["link",{"href":"https://wiki.archlinux.org/index.php/Polkit#Authentication_agents"},"polkit authentication agent"]," in your system in order to show a secure password prompt dialog to perform elevation. Make sure you have one installed for the desktop environment of your choice."]]},{"title":"May I run Etcher in older macOS versions?","content":[["para","Etcher GUI is based on the ",["link",{"href":"http://electron.atom.io/"},"Electron"]," framework, ",["link",{"href":"https://github.com/electron/electron/blob/master/docs/tutorial/support.md#supported-platforms"},"which only supports macOS 10.9 and newer versions"],"."]]}],"contributing":{"architecture":{"filename":"ARCHITECTURE.md","mime":"text/markdown","title":"Etcher Architecture","data":{"markdown":"Etcher Architecture\n===================\n\nThis document aims to serve as a high-level overview of how Etcher works,\nspecially oriented for contributors who want to understand the big picture.\n\nTechnologies\n------------\n\nThis is a non exhaustive list of the major frameworks, libraries, and other\ntechnologies used in Etcher that you should become familiar with:\n\n- [Electron][electron]\n- [NodeJS][nodejs]\n- [AngularJS][angularjs]\n- [Redux][redux]\n- [ImmutableJS][immutablejs]\n- [Bootstrap][bootstrap]\n- [Sass][sass]\n- [Flexbox Grid][flexbox-grid]\n- [Mocha][mocha]\n- [JSDoc][jsdoc]\n\nModule architecture\n-------------------\n\nInstead of embedding all the functionality required to create a full-featured\nimage writer as a monolithic project, we try to hard to follow the [\"lego block\napproach\"][lego-blocks].\n\nThis has the advantage of allowing other applications to re-use logic we\nimplemented for Etcher in their own project, even for things we didn't expect,\nwhich leads to users benefitting from what we've built, and we benefitting from\nuser's bug reports, suggestions, etc, as an indirect way to make Etcher better.\n\nThe fact that low-level details are scattered around many different modules can\nmake it challenging for a new contributor to wrap their heads around the\nproject as a whole, and get a clear high level view of how things work or where\nto submit their work or bug reports.\n\nThese are the main Etcher components, in a nutshell:\n\n- [Drivelist](https://github.com/balena-io-modules/drivelist)\n\nAs the name implies, this module's duty is to detect the connected drives\nuniformly in all major operating systems, along with valuable metadata, like if\na drive is removable or not, to prevent users from trying to write an image to\na system drive.\n\n- [Etcher](https://github.com/balena-io/etcher)\n\nThis is the *\"main repository\"*, from which you're reading this from, which is\nbasically the front-end and glue for all previously listed projects.\n\nSummary\n-------\n\nWe always welcome contributions to Etcher as well as our documentation. If you\nwant to give back, but feel that your knowledge on how Etcher works is not\nenough to tackle a bug report or feature request, use that as your advantage,\nsince fresh eyes could help unveil things that we take for granted, but should\nbe documented instead!\n\n[lego-blocks]: https://github.com/sindresorhus/ama/issues/10#issuecomment-117766328\n[exit-codes]: https://github.com/balena-io/etcher/blob/master/lib/shared/exit-codes.js\n[gui-dir]: https://github.com/balena-io/etcher/tree/master/lib/gui\n[electron]: http://electron.atom.io\n[nodejs]: https://nodejs.org\n[angularjs]: https://angularjs.org\n[redux]: http://redux.js.org\n[immutablejs]: http://facebook.github.io/immutable-js/\n[bootstrap]: http://getbootstrap.com\n[sass]: http://sass-lang.com\n[flexbox-grid]: http://flexboxgrid.com\n[mocha]: http://mochajs.org\n[jsdoc]: http://usejsdoc.org\n","jsonml":[{"references":{"lego-blocks":{"href":"https://github.com/sindresorhus/ama/issues/10#issuecomment-117766328"},"exit-codes":{"href":"https://github.com/balena-io/etcher/blob/master/lib/shared/exit-codes.js"},"gui-dir":{"href":"https://github.com/balena-io/etcher/tree/master/lib/gui"},"electron":{"href":"http://electron.atom.io"},"nodejs":{"href":"https://nodejs.org"},"angularjs":{"href":"https://angularjs.org"},"redux":{"href":"http://redux.js.org"},"immutablejs":{"href":"http://facebook.github.io/immutable-js/"},"bootstrap":{"href":"http://getbootstrap.com"},"sass":{"href":"http://sass-lang.com"},"flexbox-grid":{"href":"http://flexboxgrid.com"},"mocha":{"href":"http://mochajs.org"},"jsdoc":{"href":"http://usejsdoc.org"}}},["header",{"level":1},"Etcher Architecture"],["para","This document aims to serve as a high-level overview of how Etcher works,\nspecially oriented for contributors who want to understand the big picture."],["header",{"level":2},"Technologies"],["para","This is a non exhaustive list of the major frameworks, libraries, and other\ntechnologies used in Etcher that you should become familiar with:"],["bulletlist",["listitem",["link_ref",{"ref":"electron","original":"[Electron][electron]"},"Electron"]],["listitem",["link_ref",{"ref":"nodejs","original":"[NodeJS][nodejs]"},"NodeJS"]],["listitem",["link_ref",{"ref":"angularjs","original":"[AngularJS][angularjs]"},"AngularJS"]],["listitem",["link_ref",{"ref":"redux","original":"[Redux][redux]"},"Redux"]],["listitem",["link_ref",{"ref":"immutablejs","original":"[ImmutableJS][immutablejs]"},"ImmutableJS"]],["listitem",["link_ref",{"ref":"bootstrap","original":"[Bootstrap][bootstrap]"},"Bootstrap"]],["listitem",["link_ref",{"ref":"sass","original":"[Sass][sass]"},"Sass"]],["listitem",["link_ref",{"ref":"flexbox-grid","original":"[Flexbox Grid][flexbox-grid]"},"Flexbox Grid"]],["listitem",["link_ref",{"ref":"mocha","original":"[Mocha][mocha]"},"Mocha"]],["listitem",["link_ref",{"ref":"jsdoc","original":"[JSDoc][jsdoc]"},"JSDoc"]]],["header",{"level":2},"Module architecture"],["para","Instead of embedding all the functionality required to create a full-featured\nimage writer as a monolithic project, we try to hard to follow the ",["link_ref",{"ref":"lego-blocks","original":"[\"lego block\napproach\"][lego-blocks]"},"\"lego block\napproach\""],"."],["para","This has the advantage of allowing other applications to re-use logic we\nimplemented for Etcher in their own project, even for things we didn't expect,\nwhich leads to users benefitting from what we've built, and we benefitting from\nuser's bug reports, suggestions, etc, as an indirect way to make Etcher better."],["para","The fact that low-level details are scattered around many different modules can\nmake it challenging for a new contributor to wrap their heads around the\nproject as a whole, and get a clear high level view of how things work or where\nto submit their work or bug reports."],["para","These are the main Etcher components, in a nutshell:"],["bulletlist",["listitem",["link",{"href":"https://github.com/balena-io-modules/drivelist"},"Drivelist"]]],["para","As the name implies, this module's duty is to detect the connected drives\nuniformly in all major operating systems, along with valuable metadata, like if\na drive is removable or not, to prevent users from trying to write an image to\na system drive."],["bulletlist",["listitem",["link",{"href":"https://github.com/balena-io/etcher"},"Etcher"]]],["para","This is the ",["em","\"main repository\""],", from which you're reading this from, which is\nbasically the front-end and glue for all previously listed projects."],["header",{"level":2},"Summary"],["para","We always welcome contributions to Etcher as well as our documentation. If you\nwant to give back, but feel that your knowledge on how Etcher works is not\nenough to tackle a bug report or feature request, use that as your advantage,\nsince fresh eyes could help unveil things that we take for granted, but should\nbe documented instead!"]]}},"guide":{"filename":"CONTRIBUTING.md","mime":"text/markdown","title":"Contributing Guide","data":{"markdown":"Contributing Guide\n==================\n\nThanks for your interest in contributing to this project! This document aims to\nserve as a friendly guide for making your first contribution.\n\nHigh-level Etcher overview\n--------------------------\n\nMake sure you checkout our [ARCHITECTURE.md][ARCHITECTURE] guide, which aims to\nexplain how all the pieces fit together.\n\nDeveloping\n----------\n\n### Prerequisites\n\n#### Common\n\n- [NodeJS](https://nodejs.org) (at least v6.11)\n- [Python 2.7](https://www.python.org)\n- [jq](https://stedolan.github.io/jq/)\n- [curl](https://curl.haxx.se/)\n- [npm](https://www.npmjs.com/) (version 6.7)\n\n```sh\npip install -r requirements.txt\n```\n\nYou might need to run this with `sudo` or administrator permissions.\n\n#### Windows\n\n- [NSIS v2.51](http://nsis.sourceforge.net/Main_Page) (v3.x won't work)\n- Either one of the following:\n - [Visual C++ 2015 Build Tools](http://landinghub.visualstudio.com/visual-cpp-build-tools) containing standalone compilers, libraries and scripts\n - Install the [windows-build-tools](https://github.com/felixrieseberg/windows-build-tools) via npm with `npm install --global windows-build-tools`\n - [Visual Studio Community 2015](https://www.microsoft.com/en-us/download/details.aspx?id=48146) (free) (other editions, like Professional and Enterprise, should work too)\n **NOTE:** Visual Studio 2015 doesn't install C++ by default. You have to rerun the\n setup, select \"Modify\" and then check `Visual C++ -> Common Tools for Visual\n C++ 2015` (see http://stackoverflow.com/a/31955339)\n- [MinGW](http://www.mingw.org)\n\nYou might need to `npm config set msvs_version 2015` for node-gyp to correctly detect\nthe version of Visual Studio you're using (in this example VS2015).\n\nThe following MinGW packages are required:\n\n- `msys-make`\n- `msys-unzip`\n- `msys-zip`\n- `msys-bash`\n- `msys-coreutils`\n\n#### macOS\n\n- [Xcode](https://developer.apple.com/xcode/)\n\nIt's not enough to have [Xcode Command Line Tools] installed. Xcode must be installed\nas well.\n\n#### Linux\n\n- `libudev-dev` for libusb (install with `sudo apt install libudev-dev` for example)\n\n### Cloning the project\n\n```sh\ngit clone --recursive https://github.com/balena-io/etcher\ncd etcher\n```\n\n### Installing npm dependencies\n\n**NOTE:** Please make use of the following command to install npm dependencies rather\nthan simply running `npm install` given that we need to do extra configuration\nto make sure native dependencies are correctly compiled for Electron, otherwise\nthe application might not run successfully.\n\nIf you're on Windows, **run the command from the _Developer Command Prompt for\nVS2015_**, to ensure all Visual Studio command utilities are available in the\n`%PATH%`.\n\n```sh\nmake electron-develop\n```\n\n### Running the application\n\n#### GUI\n\n```sh\n# Build the GUI\nmake webpack\n# Start Electron\nnpm start\n```\n\nTesting\n-------\n\nTo run the test suite, run the following command:\n\n```sh\nnpm test\n```\n\nGiven the nature of this application, not everything can be unit tested. For\nexample:\n\n- The writing operating on real raw devices.\n- Platform inconsistencies.\n- Style changes.\n- Artwork.\n\nWe encourage our contributors to test the application on as many operating\nsystems as they can before sending a pull request.\n\n*The test suite is run automatically by CI servers when you send a pull\nrequest.*\n\nWe also rely on various `make` targets to perform some common tasks:\n\n- `make lint`: Run the linter.\n- `make sass`: Compile SCSS files.\n\nWe make use of [EditorConfig] to communicate indentation, line endings and\nother text editing default. We encourage you to install the relevant plugin in\nyour text editor of choice to avoid having to fix any issues during the review\nprocess.\n\nUpdating a dependency\n---------------------\n\nGiven we use [npm shrinkwrap][shrinkwrap], we have to take extra steps to make\nsure the `npm-shrinkwrap.json` file gets updated correctly when we update a\ndependency.\n\nUse the following steps to ensure everything goes flawlessly:\n\n- Run `make electron-develop` to ensure you don't have extraneous dependencies\n you might have brought during development, or you are running older\n dependencies because you come from another branch or reference.\n\n- Install the new version of the dependency. For example: `npm install --save\n @`. This will update the `npm-shrinkwrap.json` file.\n\n- Commit *both* `package.json` and `npm-shrinkwrap.json`.\n\nDiffing Binaries\n----------------\n\nBinary files are tagged as \"binary\" in the `.gitattributes` file, but also have\na `diff=hex` tag, which allows you to see hexdump-style diffs for binaries,\nif you add the following to either your global or repository-local git config:\n\n```sh\n$ git config diff.hex.textconv hexdump\n$ git config diff.hex.binary true\n```\n\nAnd global, respectively:\n\n```sh\n$ git config --global diff.hex.textconv hexdump\n$ git config --global diff.hex.binary true\n```\n\nIf you don't have `hexdump` available on your platform,\nyou can try [hxd], which is also a bit faster.\n\nCommit Guidelines\n-----------------\n\nSee [COMMIT-GUIDELINES.md][COMMIT-GUIDELINES] for a thorough guide on how to\nwrite commit messages.\n\nSending a pull request\n----------------------\n\nWhen sending a pull request, consider the following guidelines:\n\n- Write a concise commit message explaining your changes.\n\n- If applies, write more descriptive information in the commit body.\n\n- Mention the operating systems with the corresponding versions in which you\ntested your changes.\n\n- If your change affects the visuals of the application, consider attaching a\nscreenshot.\n\n- Refer to the issue/s your pull request fixes, so they're closed automatically\nwhen your pull request is merged.\n\n- Write a descriptive pull request title.\n\n- Squash commits when possible, for example, when committing review changes.\n\nBefore your pull request can be merged, the following conditions must hold:\n\n- The linter doesn't throw any warning.\n\n- All the tests pass.\n\n- The coding style aligns with the project's convention.\n\n- Your changes are confirmed to be working in recent versions of the operating\nsystems we support.\n\nDon't hesitate to get in touch if you have any questions or need any help!\n\n[ARCHITECTURE]: https://github.com/balena-io/etcher/blob/master/docs/ARCHITECTURE.md\n[COMMIT-GUIDELINES]: https://github.com/balena-io/etcher/blob/master/docs/COMMIT-GUIDELINES.md\n[EditorConfig]: http://editorconfig.org\n[shrinkwrap]: https://docs.npmjs.com/cli/shrinkwrap\n[hxd]: https://github.com/jhermsmeier/hxd\n[Xcode Command Line Tools]: https://developer.apple.com/library/content/technotes/tn2339/_index.html\n","jsonml":[{"references":{"architecture":{"href":"https://github.com/balena-io/etcher/blob/master/docs/ARCHITECTURE.md"},"commit-guidelines":{"href":"https://github.com/balena-io/etcher/blob/master/docs/COMMIT-GUIDELINES.md"},"editorconfig":{"href":"http://editorconfig.org"},"shrinkwrap":{"href":"https://docs.npmjs.com/cli/shrinkwrap"},"hxd":{"href":"https://github.com/jhermsmeier/hxd"},"xcode command line tools":{"href":"https://developer.apple.com/library/content/technotes/tn2339/_index.html"}}},["header",{"level":1},"Contributing Guide"],["para","Thanks for your interest in contributing to this project! This document aims to\nserve as a friendly guide for making your first contribution."],["header",{"level":2},"High-level Etcher overview"],["para","Make sure you checkout our ",["link_ref",{"ref":"architecture","original":"[ARCHITECTURE.md][ARCHITECTURE]"},"ARCHITECTURE.md"]," guide, which aims to\nexplain how all the pieces fit together."],["header",{"level":2},"Developing"],["header",{"level":3},"Prerequisites"],["header",{"level":4},"Common"],["bulletlist",["listitem",["link",{"href":"https://nodejs.org"},"NodeJS"]," (at least v6.11)"],["listitem",["link",{"href":"https://www.python.org"},"Python 2.7"]],["listitem",["link",{"href":"https://stedolan.github.io/jq/"},"jq"]],["listitem",["link",{"href":"https://curl.haxx.se/"},"curl"]],["listitem",["link",{"href":"https://www.npmjs.com/"},"npm"]," (version 6.7)"]],["para",["inlinecode","sh\npip install -r requirements.txt\n"]],["para","You might need to run this with ",["inlinecode","sudo"]," or administrator permissions."],["header",{"level":4},"Windows"],["bulletlist",["listitem",["link",{"href":"http://nsis.sourceforge.net/Main_Page"},"NSIS v2.51"]," (v3.x won't work)"],["listitem","Either one of the following:",["bulletlist",["listitem",["link",{"href":"http://landinghub.visualstudio.com/visual-cpp-build-tools"},"Visual C++ 2015 Build Tools"]," containing standalone compilers, libraries and scripts"],["listitem","Install the ",["link",{"href":"https://github.com/felixrieseberg/windows-build-tools"},"windows-build-tools"]," via npm with ",["inlinecode","npm install --global windows-build-tools"]],["listitem",["link",{"href":"https://www.microsoft.com/en-us/download/details.aspx?id=48146"},"Visual Studio Community 2015"]," (free) (other editions, like Professional and Enterprise, should work too)\n",["strong","NOTE:"]," Visual Studio 2015 doesn't install C++ by default. You have to rerun the\nsetup, select \"Modify\" and then check ",["inlinecode","Visual C++ -> Common Tools for Visual\nC++ 2015"]," (see http://stackoverflow.com/a/31955339)"]]],["listitem",["link",{"href":"http://www.mingw.org"},"MinGW"]]],["para","You might need to ",["inlinecode","npm config set msvs_version 2015"]," for node-gyp to correctly detect\nthe version of Visual Studio you're using (in this example VS2015)."],["para","The following MinGW packages are required:"],["bulletlist",["listitem",["inlinecode","msys-make"]],["listitem",["inlinecode","msys-unzip"]],["listitem",["inlinecode","msys-zip"]],["listitem",["inlinecode","msys-bash"]],["listitem",["inlinecode","msys-coreutils"]]],["header",{"level":4},"macOS"],["bulletlist",["listitem",["link",{"href":"https://developer.apple.com/xcode/"},"Xcode"]]],["para","It's not enough to have ",["link_ref",{"ref":"xcode command line tools","original":"[Xcode Command Line Tools]"},"Xcode Command Line Tools"]," installed. Xcode must be installed\nas well."],["header",{"level":4},"Linux"],["bulletlist",["listitem",["inlinecode","libudev-dev"]," for libusb (install with ",["inlinecode","sudo apt install libudev-dev"]," for example)"]],["header",{"level":3},"Cloning the project"],["para",["inlinecode","sh\ngit clone --recursive https://github.com/balena-io/etcher\ncd etcher\n"]],["header",{"level":3},"Installing npm dependencies"],["para",["strong","NOTE:"]," Please make use of the following command to install npm dependencies rather\nthan simply running ",["inlinecode","npm install"]," given that we need to do extra configuration\nto make sure native dependencies are correctly compiled for Electron, otherwise\nthe application might not run successfully."],["para","If you're on Windows, ",["strong","run the command from the ",["em","Developer Command Prompt for\nVS2015"]],", to ensure all Visual Studio command utilities are available in the\n",["inlinecode","%PATH%"],"."],["para",["inlinecode","sh\nmake electron-develop\n"]],["header",{"level":3},"Running the application"],["header",{"level":4},"GUI"],["para",["inlinecode",""],"`sh"],["header",{"level":1},"Build the GUI"],["para","make webpack"],["header",{"level":1},"Start Electron"],["para","npm start\n",["inlinecode",""],"`"],["header",{"level":2},"Testing"],["para","To run the test suite, run the following command:"],["para",["inlinecode","sh\nnpm test\n"]],["para","Given the nature of this application, not everything can be unit tested. For\nexample:"],["bulletlist",["listitem","The writing operating on real raw devices."],["listitem","Platform inconsistencies."],["listitem","Style changes."],["listitem","Artwork."]],["para","We encourage our contributors to test the application on as many operating\nsystems as they can before sending a pull request."],["para",["em","The test suite is run automatically by CI servers when you send a pull\nrequest."]],["para","We also rely on various ",["inlinecode","make"]," targets to perform some common tasks:"],["bulletlist",["listitem",["inlinecode","make lint"],": Run the linter."],["listitem",["inlinecode","make sass"],": Compile SCSS files."]],["para","We make use of ",["link_ref",{"ref":"editorconfig","original":"[EditorConfig]"},"EditorConfig"]," to communicate indentation, line endings and\nother text editing default. We encourage you to install the relevant plugin in\nyour text editor of choice to avoid having to fix any issues during the review\nprocess."],["header",{"level":2},"Updating a dependency"],["para","Given we use ",["link_ref",{"ref":"shrinkwrap","original":"[npm shrinkwrap][shrinkwrap]"},"npm shrinkwrap"],", we have to take extra steps to make\nsure the ",["inlinecode","npm-shrinkwrap.json"]," file gets updated correctly when we update a\ndependency."],["para","Use the following steps to ensure everything goes flawlessly:"],["bulletlist",["listitem",["para","Run ",["inlinecode","make electron-develop"]," to ensure you don't have extraneous dependencies\nyou might have brought during development, or you are running older\ndependencies because you come from another branch or reference."]],["listitem",["para","Install the new version of the dependency. For example: ",["inlinecode","npm install --save\n@"],". This will update the ",["inlinecode","npm-shrinkwrap.json"]," file."]],["listitem",["para","Commit ",["em","both"]," ",["inlinecode","package.json"]," and ",["inlinecode","npm-shrinkwrap.json"],"."]]],["header",{"level":2},"Diffing Binaries"],["para","Binary files are tagged as \"binary\" in the ",["inlinecode",".gitattributes"]," file, but also have\na ",["inlinecode","diff=hex"]," tag, which allows you to see hexdump-style diffs for binaries,\nif you add the following to either your global or repository-local git config:"],["para",["inlinecode","sh\n$ git config diff.hex.textconv hexdump\n$ git config diff.hex.binary true\n"]],["para","And global, respectively:"],["para",["inlinecode","sh\n$ git config --global diff.hex.textconv hexdump\n$ git config --global diff.hex.binary true\n"]],["para","If you don't have ",["inlinecode","hexdump"]," available on your platform,\nyou can try ",["link_ref",{"ref":"hxd","original":"[hxd]"},"hxd"],", which is also a bit faster."],["header",{"level":2},"Commit Guidelines"],["para","See ",["link_ref",{"ref":"commit-guidelines","original":"[COMMIT-GUIDELINES.md][COMMIT-GUIDELINES]"},"COMMIT-GUIDELINES.md"]," for a thorough guide on how to\nwrite commit messages."],["header",{"level":2},"Sending a pull request"],["para","When sending a pull request, consider the following guidelines:"],["bulletlist",["listitem",["para","Write a concise commit message explaining your changes."]],["listitem",["para","If applies, write more descriptive information in the commit body."]],["listitem",["para","Mention the operating systems with the corresponding versions in which you\ntested your changes."]],["listitem",["para","If your change affects the visuals of the application, consider attaching a\nscreenshot."]],["listitem",["para","Refer to the issue/s your pull request fixes, so they're closed automatically\nwhen your pull request is merged."]],["listitem",["para","Write a descriptive pull request title."]],["listitem",["para","Squash commits when possible, for example, when committing review changes."]]],["para","Before your pull request can be merged, the following conditions must hold:"],["bulletlist",["listitem",["para","The linter doesn't throw any warning."]],["listitem",["para","All the tests pass."]],["listitem",["para","The coding style aligns with the project's convention."]],["listitem",["para","Your changes are confirmed to be working in recent versions of the operating\nsystems we support."]]],["para","Don't hesitate to get in touch if you have any questions or need any help!"]]}},"codeOfConduct":null,"security":null},"motivation":null,"introduction":null,"hardwareRequired":null,"softwareRequired":null,"highlights":null,"screenshot":null,"installation":null,"blog":[],"docs":{"latest":"1.5.63","tags":{"1.5.63":[{"filename":"docs/ARCHITECTURE.md","mime":"text/markdown","title":"Etcher Architecture","data":{"markdown":"Etcher Architecture\n===================\n\nThis document aims to serve as a high-level overview of how Etcher works,\nspecially oriented for contributors who want to understand the big picture.\n\nTechnologies\n------------\n\nThis is a non exhaustive list of the major frameworks, libraries, and other\ntechnologies used in Etcher that you should become familiar with:\n\n- [Electron][electron]\n- [NodeJS][nodejs]\n- [AngularJS][angularjs]\n- [Redux][redux]\n- [ImmutableJS][immutablejs]\n- [Bootstrap][bootstrap]\n- [Sass][sass]\n- [Flexbox Grid][flexbox-grid]\n- [Mocha][mocha]\n- [JSDoc][jsdoc]\n\nModule architecture\n-------------------\n\nInstead of embedding all the functionality required to create a full-featured\nimage writer as a monolithic project, we try to hard to follow the [\"lego block\napproach\"][lego-blocks].\n\nThis has the advantage of allowing other applications to re-use logic we\nimplemented for Etcher in their own project, even for things we didn't expect,\nwhich leads to users benefitting from what we've built, and we benefitting from\nuser's bug reports, suggestions, etc, as an indirect way to make Etcher better.\n\nThe fact that low-level details are scattered around many different modules can\nmake it challenging for a new contributor to wrap their heads around the\nproject as a whole, and get a clear high level view of how things work or where\nto submit their work or bug reports.\n\nThese are the main Etcher components, in a nutshell:\n\n- [Drivelist](https://github.com/balena-io-modules/drivelist)\n\nAs the name implies, this module's duty is to detect the connected drives\nuniformly in all major operating systems, along with valuable metadata, like if\na drive is removable or not, to prevent users from trying to write an image to\na system drive.\n\n- [Etcher](https://github.com/balena-io/etcher)\n\nThis is the *\"main repository\"*, from which you're reading this from, which is\nbasically the front-end and glue for all previously listed projects.\n\nSummary\n-------\n\nWe always welcome contributions to Etcher as well as our documentation. If you\nwant to give back, but feel that your knowledge on how Etcher works is not\nenough to tackle a bug report or feature request, use that as your advantage,\nsince fresh eyes could help unveil things that we take for granted, but should\nbe documented instead!\n\n[lego-blocks]: https://github.com/sindresorhus/ama/issues/10#issuecomment-117766328\n[exit-codes]: https://github.com/balena-io/etcher/blob/master/lib/shared/exit-codes.js\n[gui-dir]: https://github.com/balena-io/etcher/tree/master/lib/gui\n[electron]: http://electron.atom.io\n[nodejs]: https://nodejs.org\n[angularjs]: https://angularjs.org\n[redux]: http://redux.js.org\n[immutablejs]: http://facebook.github.io/immutable-js/\n[bootstrap]: http://getbootstrap.com\n[sass]: http://sass-lang.com\n[flexbox-grid]: http://flexboxgrid.com\n[mocha]: http://mochajs.org\n[jsdoc]: http://usejsdoc.org\n","jsonml":[{"references":{"lego-blocks":{"href":"https://github.com/sindresorhus/ama/issues/10#issuecomment-117766328"},"exit-codes":{"href":"https://github.com/balena-io/etcher/blob/master/lib/shared/exit-codes.js"},"gui-dir":{"href":"https://github.com/balena-io/etcher/tree/master/lib/gui"},"electron":{"href":"http://electron.atom.io"},"nodejs":{"href":"https://nodejs.org"},"angularjs":{"href":"https://angularjs.org"},"redux":{"href":"http://redux.js.org"},"immutablejs":{"href":"http://facebook.github.io/immutable-js/"},"bootstrap":{"href":"http://getbootstrap.com"},"sass":{"href":"http://sass-lang.com"},"flexbox-grid":{"href":"http://flexboxgrid.com"},"mocha":{"href":"http://mochajs.org"},"jsdoc":{"href":"http://usejsdoc.org"}}},["header",{"level":1},"Etcher Architecture"],["para","This document aims to serve as a high-level overview of how Etcher works,\nspecially oriented for contributors who want to understand the big picture."],["header",{"level":2},"Technologies"],["para","This is a non exhaustive list of the major frameworks, libraries, and other\ntechnologies used in Etcher that you should become familiar with:"],["bulletlist",["listitem",["link_ref",{"ref":"electron","original":"[Electron][electron]"},"Electron"]],["listitem",["link_ref",{"ref":"nodejs","original":"[NodeJS][nodejs]"},"NodeJS"]],["listitem",["link_ref",{"ref":"angularjs","original":"[AngularJS][angularjs]"},"AngularJS"]],["listitem",["link_ref",{"ref":"redux","original":"[Redux][redux]"},"Redux"]],["listitem",["link_ref",{"ref":"immutablejs","original":"[ImmutableJS][immutablejs]"},"ImmutableJS"]],["listitem",["link_ref",{"ref":"bootstrap","original":"[Bootstrap][bootstrap]"},"Bootstrap"]],["listitem",["link_ref",{"ref":"sass","original":"[Sass][sass]"},"Sass"]],["listitem",["link_ref",{"ref":"flexbox-grid","original":"[Flexbox Grid][flexbox-grid]"},"Flexbox Grid"]],["listitem",["link_ref",{"ref":"mocha","original":"[Mocha][mocha]"},"Mocha"]],["listitem",["link_ref",{"ref":"jsdoc","original":"[JSDoc][jsdoc]"},"JSDoc"]]],["header",{"level":2},"Module architecture"],["para","Instead of embedding all the functionality required to create a full-featured\nimage writer as a monolithic project, we try to hard to follow the ",["link_ref",{"ref":"lego-blocks","original":"[\"lego block\napproach\"][lego-blocks]"},"\"lego block\napproach\""],"."],["para","This has the advantage of allowing other applications to re-use logic we\nimplemented for Etcher in their own project, even for things we didn't expect,\nwhich leads to users benefitting from what we've built, and we benefitting from\nuser's bug reports, suggestions, etc, as an indirect way to make Etcher better."],["para","The fact that low-level details are scattered around many different modules can\nmake it challenging for a new contributor to wrap their heads around the\nproject as a whole, and get a clear high level view of how things work or where\nto submit their work or bug reports."],["para","These are the main Etcher components, in a nutshell:"],["bulletlist",["listitem",["link",{"href":"https://github.com/balena-io-modules/drivelist"},"Drivelist"]]],["para","As the name implies, this module's duty is to detect the connected drives\nuniformly in all major operating systems, along with valuable metadata, like if\na drive is removable or not, to prevent users from trying to write an image to\na system drive."],["bulletlist",["listitem",["link",{"href":"https://github.com/balena-io/etcher"},"Etcher"]]],["para","This is the ",["em","\"main repository\""],", from which you're reading this from, which is\nbasically the front-end and glue for all previously listed projects."],["header",{"level":2},"Summary"],["para","We always welcome contributions to Etcher as well as our documentation. If you\nwant to give back, but feel that your knowledge on how Etcher works is not\nenough to tackle a bug report or feature request, use that as your advantage,\nsince fresh eyes could help unveil things that we take for granted, but should\nbe documented instead!"]]}},{"filename":"docs/COMMIT-GUIDELINES.md","mime":"text/markdown","title":"Commit Guidelines","data":{"markdown":"Commit Guidelines\n=================\n\nWe enforce certain rules on commits with the following goals in mind:\n\n- Be able to reliably auto-generate the `CHANGELOG.md` *without* any human\nintervention.\n- Be able to automatically and correctly increment the semver version number\nbased on what was done since the last release.\n- Be able to get a quick overview of what happened to the project by glancing\nover the commit history.\n- Be able to automatically reference relevant changes from a dependency\nupgrade.\n\nThe guidelines are inspired by the [AngularJS git commit\nguidelines][angular-commit-guidelines].\n\nCommit structure\n----------------\n\nEach commit message consists of a header, a body and a footer. The header has a\nspecial format that includes a type, a scope and a subject.\n\n```\n(): \n\n\n\n