Skip to content
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

Fix compile from interpreter context #2071

Merged

Conversation

hvacengi
Copy link
Member

Fixes #2069

YieldFinishedCompile.cs

  • Previously we switched to the program context every time a program
    compiled, which cause an issue with an empty program context if called
    from the interpreter.
  • Added a check for FILE CompileMode before switching contexts

YieldFinishedCompile.cs
* Previously we switched to the program context every time a program
compiled, which cause an issue with an empty program context if called
from the interpreter.
* Added a check for FILE CompileMode before switching contexts
@@ -40,7 +40,8 @@ private YieldFinishedCompile(GlobalPath scriptPath, int lineNumber, string fileC

public override void ThreadInitialize(SafeSharedObjects shared)
{
programContext = shared.Cpu.SwitchToProgramContext();
if (compileMode != CompileMode.FILE)
programContext = shared.Cpu.SwitchToProgramContext(); // only switch the context if executing
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This was a good catch. Yup, this is exactly what was the problem. This tries to run the program... that isn't being made.

@Dunbaratu Dunbaratu merged commit d828889 into KSP-KOS:develop Jul 21, 2017
@hvacengi hvacengi deleted the issue-2069-compile_from_terminal branch August 3, 2017 02:37
@Dunbaratu Dunbaratu added this to the v1.1.2.0 milestone Sep 13, 2017
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants