Пример #1
0
 public static void show_SourceCode_Ast_InTreeView(this TreeView treeView, string sourceCodeFile)
 {
     treeView.invokeOnThread(
         () =>
     {
         var ast = new Ast_CSharp(sourceCodeFile);
         treeView.show_SourceCode_Ast_InTreeView(ast.CompilationUnit);
     });
 }
Пример #2
0
 public void update(string sourceCode)
 {
     if (enabled)
     {
         var ast = new Ast_CSharp(sourceCode);
         ast_TreeView.show_Ast(ast);
         types_TreeView.show_List(ast.AstDetails.Types, "Text");
         usingDeclarations_TreeView.show_List(ast.AstDetails.UsingDeclarations, "Text");
         methods_TreeView.show_List(ast.AstDetails.Methods, "Text");
         fields_TreeView.show_List(ast.AstDetails.Fields, "Text");
         properties_TreeView.show_List(ast.AstDetails.Properties, "Text");
         comments_TreeView.show_List(ast.AstDetails.Comments, "Text");
         errors_TextBox.set_Text(ast.Errors);
     }
 }
 public void update(string sourceCode)
 {
     if (enabled)
     {
         var ast = new Ast_CSharp(sourceCode);
         ast_TreeView.show_Ast(ast);
         types_TreeView.show_List(ast.AstDetails.Types, "Text");
         usingDeclarations_TreeView.show_List(ast.AstDetails.UsingDeclarations, "Text");
         methods_TreeView.show_List(ast.AstDetails.Methods, "Text");
         fields_TreeView.show_List(ast.AstDetails.Fields, "Text");
         properties_TreeView.show_List(ast.AstDetails.Properties, "Text");
         comments_TreeView.show_List(ast.AstDetails.Comments, "Text");
         errors_TextBox.set_Text(ast.Errors);
     }
 }
Пример #4
0
 public void compileSourceCode(string sourceCode)
 {
     if (sourceCode.valid().isFalse())
     {
         "in CSharp_FastCompiler,compileSourceCode, provided sourceCode code was empty".error();
         if (onCompileFail != null)
         {
             onCompileFail();
         }
     }
     else
     {
         // we need to do make sure we include any extra references included in the code
         var astCSharp = new Ast_CSharp(sourceCode);
         mapCodeO2References(astCSharp);
         compileSourceCode(sourceCode, false);
     }
 }
Пример #5
0
 public static void show_Ast(this TreeView treeView, Ast_CSharp ast)
 {
     treeView.invokeOnThread(
         () => treeView.show_SourceCode_Ast_InTreeView(ast.CompilationUnit));
 }
Пример #6
0
        public string tryToCreateCSharpCodeWith_Class_Method_WithMethodText(string code)
        {
            if (code.empty())
                return null;
            code = code.line();	// make sure there is an empty line at the end

            try
            {
                // handle special incudes in source code
                foreach(var originalLine in code.lines())
                    originalLine.starts("//include", (includeText) =>
                        {
                            if (includeText.fileExists())
                                code = code.Replace(originalLine, originalLine.line().add(includeText.contents()));
                        });
                var snippetParser = new SnippetParser(SupportedLanguage.CSharp);

                var parsedCode = snippetParser.Parse(code);
                AstErrors = snippetParser.errors();
                CompilationUnit = new CompilationUnit();

                if (parsedCode is BlockStatement || parsedCode is CompilationUnit)
                {
                    Ast_CSharp astCSharp;
                    if (parsedCode is BlockStatement)
                    {
                        // map parsedCode into a new type and method

                        var blockStatement = (BlockStatement)parsedCode;
                        CompilationUnit.add_Type(default_TypeName)
                            .add_Method(default_MethodName, InvocationParameters, blockStatement);

                        astCSharp = new Ast_CSharp(CompilationUnit, snippetParser.Specials);
                        //astCSharp.AstDetails.mapSpecials();

                        // add references included in the original source code file
                        mapCodeO2References(astCSharp);

                        CreatedFromSnipptet = true;
                    }
                    else
                    {
                        CompilationUnit = (CompilationUnit)parsedCode;
                        if (CompilationUnit.Children.Count == 0)
                            return null;

                        astCSharp = new Ast_CSharp(CompilationUnit, snippetParser.Specials);
                        // add the comments from the original code

                        mapCodeO2References(astCSharp);
                        CreatedFromSnipptet = false;
                    }

                    // create sourceCode using Ast_CSharp & AstDetails
                    if(CompilationUnit.Children.Count > 0)
                    {
                        // reset the astCSharp.AstDetails object
                        astCSharp.mapAstDetails();
                        // add the comments from the original code
                        astCSharp.ExtraSpecials.AddRange(snippetParser.Specials);

                        SourceCode = astCSharp.AstDetails.CSharpCode;

                        //once we have the created SourceCode we need to create a new AST with it
                        var tempAstDetails = new Ast_CSharp(SourceCode).AstDetails;
                        //note we should try to add back the specials here (so that comments make it to the generated code
                        AstDetails = tempAstDetails;
                        DebugMode.ifDebug("Ast parsing was OK");
                        this.invoke(onAstOK);
                        return SourceCode;
                    }
                }
            }
            catch (Exception ex)
            {
                DebugMode.ifError("in createCSharpCodeWith_Class_Method_WithMethodText:{0}", ex.Message);
            }
            return null;
        }
Пример #7
0
        public void mapCodeO2References(Ast_CSharp astCSharp)
        {
            bool onlyAddReferencedAssemblies = false;
            //            generateDebugSymbols = false; // default to not generating debug symbols and creating the assembly only in memory
            ExtraSourceCodeFilesToCompile = new List<string>();
            ExtraSourceCodeFilesToCompile.Add(EXTRA_EXTENSION_METHODS_FILE); // add this one by default to make it easy to add new extension methods to the O2 Scripts
            var compilationUnit = astCSharp.CompilationUnit;
            ReferencedAssemblies = new List<string>();
            var FilesToDownload = new List<string>();

            var currentUsingDeclarations = new List<string>();
            foreach(var usingDeclaration in astCSharp.AstDetails.UsingDeclarations)
                currentUsingDeclarations.Add(usingDeclaration.Text);

            foreach (var comment in astCSharp.AstDetails.Comments)
            {
                comment.Text.eq("O2Tag_OnlyAddReferencedAssemblies", () => onlyAddReferencedAssemblies = true);
                comment.Text.starts("using ", false, value => astCSharp.CompilationUnit.add_Using(value));
                comment.Text.starts(new [] {"ref ", "O2Ref:"}, false,  value => ReferencedAssemblies.Add(value));
                comment.Text.starts(new[] { "Download:","download:", "O2Download:" }, false, value => FilesToDownload.Add(value));
                comment.Text.starts(new[] { "include", "file ", "O2File:" }, false, value => ExtraSourceCodeFilesToCompile.Add(value));
                comment.Text.starts(new[] { "dir ", "O2Dir:" }, false, value => ExtraSourceCodeFilesToCompile.AddRange(value.files("*.cs",true)));

                comment.Text.starts(new[] {"O2:debugSymbols",
                                        "generateDebugSymbols",
                                        "debugSymbols"}, true, (value) => generateDebugSymbols = true);
                comment.Text.eq("StaThread", () => { ExecuteInStaThread = true; });
                comment.Text.eq("MtaThread", () => { ExecuteInMtaThread = true; });
                comment.Text.eq("WorkOffline", () => { WorkOffline = true; });
                comment.Text.eq("ClearAssembliesCheckedIfExists", () => { FluentSharp.O2.Kernel.CodeUtils.O2Svn.clear_AssembliesCheckedIfExists(); });
            }

            //resolve location of ExtraSourceCodeFilesToCompile

            resolveFileLocationsOfExtraSourceCodeFilesToCompile();

            //make sure the referenced assemblies are in the current execution directory
            CompileEngine.tryToResolveReferencesForCompilation(ReferencedAssemblies, WorkOffline);
            //use the same technique to download files that are needed for this script (for example *.zip files or other unmanaged/support files)
            CompileEngine.tryToResolveReferencesForCompilation(FilesToDownload, WorkOffline);

            if (onlyAddReferencedAssemblies.isFalse())
            {
                foreach (var defaultRefAssembly in getDefaultReferencedAssemblies())
                    if (ReferencedAssemblies.Contains(defaultRefAssembly).isFalse())
                        ReferencedAssemblies.add(defaultRefAssembly);
                foreach (var usingStatement in getDefaultUsingStatements())
                    if (false == currentUsingDeclarations.Contains(usingStatement))
                        compilationUnit.add_Using(usingStatement);
            }
        }
Пример #8
0
 public void compileSourceCode(string sourceCode)
 {
     if (sourceCode.valid().isFalse())
     {
         "in CSharp_FastCompiler,compileSourceCode, provided sourceCode code was empty".error();
         if (onCompileFail !=null)
             onCompileFail();
     }
     else
     {
         // we need to do make sure we include any extra references included in the code
         var astCSharp = new Ast_CSharp(sourceCode);
         mapCodeO2References(astCSharp);
         compileSourceCode(sourceCode, false);
     }
 }
Пример #9
0
        public void mapCodeO2References(Ast_CSharp astCSharp)
        {
            bool onlyAddReferencedAssemblies = false;

//            generateDebugSymbols = false; // default to not generating debug symbols and creating the assembly only in memory
            ExtraSourceCodeFilesToCompile = new List <string>();
            ExtraSourceCodeFilesToCompile.Add(EXTRA_EXTENSION_METHODS_FILE); // add this one by default to make it easy to add new extension methods to the O2 Scripts
            var compilationUnit = astCSharp.CompilationUnit;

            ReferencedAssemblies = new List <string>();
            var FilesToDownload = new List <string>();

            var currentUsingDeclarations = new List <string>();

            foreach (var usingDeclaration in astCSharp.AstDetails.UsingDeclarations)
            {
                currentUsingDeclarations.Add(usingDeclaration.Text);
            }


            foreach (var comment in astCSharp.AstDetails.Comments)
            {
                comment.Text.eq("O2Tag_OnlyAddReferencedAssemblies", () => onlyAddReferencedAssemblies = true);
                comment.Text.starts("using ", false, value => astCSharp.CompilationUnit.add_Using(value));
                comment.Text.starts(new [] { "ref ", "O2Ref:" }, false, value => ReferencedAssemblies.Add(value));
                comment.Text.starts(new[] { "Download:", "download:", "O2Download:" }, false, value => FilesToDownload.Add(value));
                comment.Text.starts(new[] { "include", "file ", "O2File:" }, false, value => ExtraSourceCodeFilesToCompile.Add(value));
                comment.Text.starts(new[] { "dir ", "O2Dir:" }, false, value => ExtraSourceCodeFilesToCompile.AddRange(value.files("*.cs", true)));

                comment.Text.starts(new[] { "O2:debugSymbols",
                                            "generateDebugSymbols",
                                            "debugSymbols" }, true, (value) => generateDebugSymbols = true);
                comment.Text.eq("StaThread", () => { ExecuteInStaThread = true; });
                comment.Text.eq("MtaThread", () => { ExecuteInMtaThread = true; });
                comment.Text.eq("WorkOffline", () => { WorkOffline = true; });
                comment.Text.eq("ClearAssembliesCheckedIfExists", () => { FluentSharp.O2.Kernel.CodeUtils.O2Svn.clear_AssembliesCheckedIfExists(); });
            }

            //resolve location of ExtraSourceCodeFilesToCompile

            resolveFileLocationsOfExtraSourceCodeFilesToCompile();

            //make sure the referenced assemblies are in the current execution directory
            CompileEngine.tryToResolveReferencesForCompilation(ReferencedAssemblies, WorkOffline);
            //use the same technique to download files that are needed for this script (for example *.zip files or other unmanaged/support files)
            CompileEngine.tryToResolveReferencesForCompilation(FilesToDownload, WorkOffline);

            if (onlyAddReferencedAssemblies.isFalse())
            {
                foreach (var defaultRefAssembly in getDefaultReferencedAssemblies())
                {
                    if (ReferencedAssemblies.Contains(defaultRefAssembly).isFalse())
                    {
                        ReferencedAssemblies.add(defaultRefAssembly);
                    }
                }
                foreach (var usingStatement in getDefaultUsingStatements())
                {
                    if (false == currentUsingDeclarations.Contains(usingStatement))
                    {
                        compilationUnit.add_Using(usingStatement);
                    }
                }
            }
        }
Пример #10
0
        public string tryToCreateCSharpCodeWith_Class_Method_WithMethodText(string code)
        {
            if (code.empty())
            {
                return(null);
            }
            code = code.line();                 // make sure there is an empty line at the end

            try
            {
                // handle special incudes in source code
                foreach (var originalLine in code.lines())
                {
                    originalLine.starts("//include", (includeText) =>
                    {
                        if (includeText.fileExists())
                        {
                            code = code.Replace(originalLine, originalLine.line().add(includeText.contents()));
                        }
                    });
                }
                var snippetParser = new SnippetParser(SupportedLanguage.CSharp);

                var parsedCode = snippetParser.Parse(code);
                AstErrors       = snippetParser.errors();
                CompilationUnit = new CompilationUnit();

                if (parsedCode is BlockStatement || parsedCode is CompilationUnit)
                {
                    Ast_CSharp astCSharp;
                    if (parsedCode is BlockStatement)
                    {
                        // map parsedCode into a new type and method

                        var blockStatement = (BlockStatement)parsedCode;
                        CompilationUnit.add_Type(default_TypeName)
                        .add_Method(default_MethodName, InvocationParameters, blockStatement);

                        astCSharp = new Ast_CSharp(CompilationUnit, snippetParser.Specials);
                        //astCSharp.AstDetails.mapSpecials();

                        // add references included in the original source code file
                        mapCodeO2References(astCSharp);

                        CreatedFromSnipptet = true;
                    }
                    else
                    {
                        CompilationUnit = (CompilationUnit)parsedCode;
                        if (CompilationUnit.Children.Count == 0)
                        {
                            return(null);
                        }

                        astCSharp = new Ast_CSharp(CompilationUnit, snippetParser.Specials);
                        // add the comments from the original code

                        mapCodeO2References(astCSharp);
                        CreatedFromSnipptet = false;
                    }

                    // create sourceCode using Ast_CSharp & AstDetails
                    if (CompilationUnit.Children.Count > 0)
                    {
                        // reset the astCSharp.AstDetails object
                        astCSharp.mapAstDetails();
                        // add the comments from the original code
                        astCSharp.ExtraSpecials.AddRange(snippetParser.Specials);

                        SourceCode = astCSharp.AstDetails.CSharpCode;

                        //once we have the created SourceCode we need to create a new AST with it
                        var tempAstDetails = new Ast_CSharp(SourceCode).AstDetails;
                        //note we should try to add back the specials here (so that comments make it to the generated code
                        AstDetails = tempAstDetails;
                        DebugMode.ifDebug("Ast parsing was OK");
                        this.invoke(onAstOK);
                        return(SourceCode);
                    }
                }
            }
            catch (Exception ex)
            {
                DebugMode.ifError("in createCSharpCodeWith_Class_Method_WithMethodText:{0}", ex.Message);
            }
            return(null);
        }