From 9ddbab04f248b8d3fd291fb87f19e3b94542235e Mon Sep 17 00:00:00 2001 From: Tomas Jansson Date: Sun, 1 Nov 2015 19:12:33 +0100 Subject: [PATCH 1/2] add basic npm support --- src/app/FakeLib/FakeLib.fsproj | 1 + src/app/FakeLib/NpmHelper.fs | 66 ++++++++++++++++++++++++++++++++++ 2 files changed, 67 insertions(+) create mode 100644 src/app/FakeLib/NpmHelper.fs diff --git a/src/app/FakeLib/FakeLib.fsproj b/src/app/FakeLib/FakeLib.fsproj index c844691a954..5ce32aaa401 100644 --- a/src/app/FakeLib/FakeLib.fsproj +++ b/src/app/FakeLib/FakeLib.fsproj @@ -55,6 +55,7 @@ + diff --git a/src/app/FakeLib/NpmHelper.fs b/src/app/FakeLib/NpmHelper.fs new file mode 100644 index 00000000000..b953ff0a1f3 --- /dev/null +++ b/src/app/FakeLib/NpmHelper.fs @@ -0,0 +1,66 @@ +/// Contains function to run npm tasks +module NpmHelper +open Fake +open System +open System.IO + +/// Default paths to Npm +let private npmFileName = + match isUnix with + | true -> "/usr/local/bin/npm" + | _ -> "./packages/Npm.js/tools/npm.cmd" + +/// Arguments for the Npm install command +type InstallArgs = +| Standard +| Forced + +/// The list of supported Npm commands. The `Custom` alternative +/// can be used for other commands not in the list until they are +/// implemented +type NpmCommand = +| Install of InstallArgs +| Run of string +| Custom of string + +/// The Npm parameter type +type NpmParams = + { Src: string + NpmFilePath: string + WorkingDirectory: string + Command: NpmCommand + Timeout: TimeSpan } + +/// Npm default parameters +let defaultNpmParams = + { Src = "" + NpmFilePath = npmFileName + Command = Install Standard + WorkingDirectory = "." + Timeout = TimeSpan.MaxValue } + +let private parseInstallArgs = function + | Standard -> "" + | Forced -> " --force" + +let private parse = function + | Install installArgs -> sprintf "install%s" (installArgs |> parseInstallArgs) + | Run str -> sprintf "run %s" str + | Custom str -> str + +let run npmParams = + let npmPath = Path.GetFullPath(npmParams.NpmFilePath) + let arguments = npmParams.Command |> parse + let ok = + execProcess (fun info -> + info.FileName <- npmPath + info.WorkingDirectory <- npmParams.WorkingDirectory + info.Arguments <- arguments) npmParams.Timeout + if not ok then failwith (sprintf "'npm %s' task failed" arguments) + +/// Runs npm with the given modification function +/// ## Parameters +/// +/// - `setParams` - Function used to overwrite the Npm default parameters. +let Npm setParams = + defaultNpmParams |> setParams |> run From c49cc2b539b463383cc182e0e831fb7d9cd739e5 Mon Sep 17 00:00:00 2001 From: Tomas Jansson Date: Mon, 2 Nov 2015 06:34:45 -0800 Subject: [PATCH 2/2] added sample to comment for npmhelper --- src/app/FakeLib/NpmHelper.fs | 23 +++++++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/src/app/FakeLib/NpmHelper.fs b/src/app/FakeLib/NpmHelper.fs index b953ff0a1f3..01bc2c4828c 100644 --- a/src/app/FakeLib/NpmHelper.fs +++ b/src/app/FakeLib/NpmHelper.fs @@ -1,5 +1,5 @@ /// Contains function to run npm tasks -module NpmHelper +module Fake.NpmHelper open Fake open System open System.IO @@ -58,9 +58,28 @@ let run npmParams = info.Arguments <- arguments) npmParams.Timeout if not ok then failwith (sprintf "'npm %s' task failed" arguments) -/// Runs npm with the given modification function +/// Runs npm with the given modification function. Make sure to have npm installed, +/// you can install npm with nuget or a regular install. To change which `Npm` executable +/// to use you can set the `NpmFilePath` parameter with the `setParams` function. +/// /// ## Parameters /// /// - `setParams` - Function used to overwrite the Npm default parameters. +/// +/// ## Sample +/// +/// Target "Web" (fun _ -> +/// Npm (fun p -> +/// { p with +/// Command = Install Standard +/// WorkingDirectory = "./src/FAKESimple.Web/" +/// }) +/// +/// Npm (fun p -> +/// { p with +/// Command = (Run "build") +/// WorkingDirectory = "./src/FAKESimple.Web/" +/// }) +/// ) let Npm setParams = defaultNpmParams |> setParams |> run