summaryrefslogtreecommitdiff
path: root/shell.nix
diff options
context:
space:
mode:
authorWilliam Chang <william@factual.com>2019-11-20 22:17:07 -0800
committerWilliam Chang <william@factual.com>2019-11-20 22:17:07 -0800
commite7f4d56592b3975c38af329e77b4efd9108495e8 (patch)
tree0a416bccbf70bfdbdb9ffcdb3bf136b47378c014 /shell.nix
parent71493b2f9bbd5f3d18373c518fa14ccafcbf48fc (diff)
parent8416a94ad27b3ff058576f09f35f0704a8b39ff3 (diff)
Merge remote-tracking branch 'upstream/master'
Diffstat (limited to 'shell.nix')
-rw-r--r--shell.nix45
1 files changed, 28 insertions, 17 deletions
diff --git a/shell.nix b/shell.nix
index 6ff8a7ad2d..d7c3b61744 100644
--- a/shell.nix
+++ b/shell.nix
@@ -1,14 +1,33 @@
-# dfu-programmer doesn't have darwin on it's list of supported platforms
-{ pkgs ? import <nixpkgs> { config = { allowUnsupportedSystem = true; }; }
-, avr ? true, arm ? true, teensy ? true }:
+{ avr ? true, arm ? true, teensy ? true }:
-with pkgs;
let
- avrbinutils = pkgsCross.avr.buildPackages.binutils;
- avrlibc = pkgsCross.avr.libcCross;
- gcc-arm-embedded = pkgsCross.arm-embedded.buildPackages.gcc;
+ overlay = self: super:
+ let addDarwinSupport = pkg: pkg.overrideAttrs (oldAttrs: {
+ meta.platforms = (oldAttrs.meta.platforms or []) ++ self.lib.platforms.darwin;
+ });
+ in {
+ dfu-programmer = addDarwinSupport super.dfu-programmer;
+ teensy-loader-cli = addDarwinSupport super.teensy-loader-cli;
+
+ avrgcc = super.avrgcc.overrideAttrs (oldAttrs: rec {
+ name = "avr-gcc-8.1.0";
+ src = super.fetchurl {
+ url = "mirror://gcc/releases/gcc-8.1.0/gcc-8.1.0.tar.xz";
+ sha256 = "0lxil8x0jjx7zbf90cy1rli650akaa6hpk8wk8s62vk2jbwnc60x";
+ };
+ });
+ };
- avr_incflags = [
+ nixpkgs = builtins.fetchTarball {
+ url = "https://github.com/NixOS/nixpkgs/archive/0260747427737b980f0.tar.gz";
+ sha256 = "1p2yc6b40xvvxvmlqd9wb440pkrimnlc2wsbpa5rddlpx1dn8qmf";
+ };
+
+ pkgs = import nixpkgs { overlays = [ overlay ]; };
+in
+
+with pkgs;
+let avr_incflags = [
"-isystem ${avrlibc}/avr/include"
"-B${avrlibc}/avr/lib/avr5"
"-L${avrlibc}/avr/lib/avr5"
@@ -17,19 +36,11 @@ let
"-B${avrlibc}/avr/lib/avr51"
"-L${avrlibc}/avr/lib/avr51"
];
- avrgcc = pkgsCross.avr.buildPackages.gcc.overrideAttrs (oldAttrs: rec {
- name = "avr-gcc-8.1.0";
- src = fetchurl {
- url = "mirror://gcc/releases/gcc-8.1.0/gcc-8.1.0.tar.xz";
- sha256 = "0lxil8x0jjx7zbf90cy1rli650akaa6hpk8wk8s62vk2jbwnc60x";
- };
- });
in
-
stdenv.mkDerivation {
name = "qmk-firmware";
- buildInputs = [ dfu-programmer dfu-util diffutils git ]
+ buildInputs = [ dfu-programmer dfu-util diffutils git python3 ]
++ lib.optional avr [ avrbinutils avrgcc avrlibc avrdude ]
++ lib.optional arm [ gcc-arm-embedded ]
++ lib.optional teensy [ teensy-loader-cli ];