-
Notifications
You must be signed in to change notification settings - Fork 587
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Added caching of compiled build scripts. #859
Conversation
Requires fsharp/fsharp-compiler-docs#365. It has been merged, don't know when it will be released. |
Implementing support for #r'd DLLs looks to be all that's missing. Only thing that's keeping my build scripts from running. Will work on fixing that. |
Added support for build scripts with |
very very cool. is this ready?`whyt about the appveyor build? |
|
||
included.ShouldEqual(new string[] { "justname", "./relative/path", "C:/absolute/path" }); | ||
}; | ||
//It should_load_assembly = |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
why is this commented?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I was originally parsing out the included assemblies in the script files, that was the test for it. I switched to saving a list of all loaded assemblies paths and loading those on next run. Made the test not needed.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok so could you please remove these?
On Jul 13, 2015 18:36, "Xavier Zwirtz" [email protected] wrote:
In src/test/Test.FAKECore/FSIHelperSpecs.cs
#859 (comment):
var newHash = FSIHelper.getScriptHash(scriptContents);
hash.ShouldNotEqual(newHash);
};
It should_get_included_assemblies =
() =>
{
var script =
"#r \"justname\"\n" +
"#r \"./relative/path\"\n" +
"#r \"C:/absolute/path\"";
var included = FSIHelper.getIncludedAssembly(script);
included.ShouldEqual(new string[] { "justname", "./relative/path", "C:/absolute/path" });
};
//It should_load_assembly =
I was originally parsing out the included assemblies in the script files,
that was the test for it. I switched to saving a list of all loaded
assemblies paths and loading those on next run. Made the test not needed.—
Reply to this email directly or view it on GitHub
https://github.com/fsharp/FAKE/pull/859/files#r34482490.
Removed that dead code. |
The appveyor build seems to be swallowing the exception that occured. Any help with that? |
Ah, didn't realize that |
yes please send pull request. I can then update the FAKE 4.0 alpha package. I think this feature deserves it's own major version. |
Agreed, it has enough potential weirdness hiding in it. Are the |
I think we will put these to verbose mode before we release 4.0 |
#859 has the fixes. Now that I have it working though, FSReveal is not going to save the cache until you stop watching changes. Felt a little odd. |
mhm. I don't think that's an issue. or is it? |
Not a huge issue, if you hit a key it finishes and caches it. Thanks for the help getting this pulled in. On July 14, 2015 1:01:48 PM Steffen Forkmann [email protected] wrote:
|
@xavierzwirtz it seems we need a page in the docs which describes what happens here. Could you please create such a page? |
Created in #872. |
Caches the script file to a compiled dll when first run. Uses crc32 to hash the script, prevents using old dll when the script file has changed. Also recursively follows
#load
.Takes 3312 milliseconds to interpret script without saving cache.
Takes 3326 milliseconds to interpret script and save cache.
Takes 260 milliseconds to run cached dll.
Fixes #646, and makes #645 less needed.