We've rebuilt Dev.Opera as a static site, powered by Jekyll, Sass and Grunt. In this repository, you find all the source files and content to build the site, make improvements, and submit new articles.
- Install Jekyll, Sass and all needed gems by running
sudo gem install jekyll kramdown stringex sass
in Terminal. - Download and install Node.js with the default installer options.
- Clone the project by running
git clone git@github.com:operasoftware/devopera.git
. - Run
npm install
inside thedevopera
folder. - Run
npm install grunt-cli -g
to install Grunt globally. - Run
grunt build
to build Dev.Opera inside the_site
folder.
Please install EditorConfig plugin for your editor to keep code style declared in the .editorconfig file.
There are two modes of development available:
- If you're developing some feature or article, run
grunt watch
and all your changes will be generated automatically (and as quick as possible) every time you save any Jekyll template or Sass file. To stop watching changes pressCtrl C
.- If you’ve just saved any of the
styles/*.scss
files, the watcher will compile and copy the styles to the_site/styles
folder in a few moments without doing a full build process. - If you’ve saved an
.md
or.html
file, the compilation could take up to 60 seconds, which is a bit long but there’s not much we can do (at least not as far as we can tell). - Please file an issue if you need the same quick watcher for anything else: scripts, images, etc.
- If you’ve just saved any of the
- If you need to build a production version of Dev.Opera, run
grunt build
and everything will not just be built inside the_site
folder, but also compressed and optimized. Just once.
To launch a simple server open another console instance or tab, navigate to the _site
folder and run python -m SimpleHTTPServer 8000
. You can then load the website in your browser by http://localhost:8000/
address. This server will be also available in the local Wi-Fi network by following address x.x.x.x:8000
where x.x.x.x
is your computer’s IP address. To get your IP address go to System Preferences > Network > Wi-Fi. For all Apple devices your server will be also available by your computer’s local network name like computername.local:8000
, which could be found in System Preferences > Sharing.
- All instructions are for Unix (OS X, Linux, etc.) because Jekyll is not compatible with Windows.
- You may require write access for all commands mentioned above. Type
sudo
, space and command if needed. - If you get an error running
grunt watch
, try to increase the file number limit with theulimit -n 10000
command