question-mark
Stuck on an issue?

Lightrun Answers was designed to reduce the constant googling that comes with debugging 3rd party libraries. It collects links to all the places you might be looking at while hunting down a tough bug.

And, if you’re still stuck at the end, we’re happy to hop on a call to see how we can help out.

Projects with workflow XAML do not compile

See original GitHub issue

Visual Studio Version: 16.2.0

Summary: Compiling project with XAML Service references fails with The target "CoreCompile" does not exist in the project.

Steps to Reproduce:

  1. Have a project with XAML service references (.xaml file with Build Action: Workflow definition, Custom Tool: MSBuild:Compile) or (.svcmap file with Custom Tool: Xaml Activity Generator which generates .xaml files with Build Action: XamlAppDef and Custom Tool: XamlIntelliSenseFileGenerator)

  2. Convert this project to new project format

  3. Rebuild the project

Expected Behavior: Works, works always and works on first attempt

Actual Behavior: Build fails with error C:\Windows\Microsoft.NET\Framework\v4.0.30319\Microsoft.Xaml.targets(333,43): error MSB4057: The target "CoreCompile" does not exist in the project. The build works if you do Rebuild + Build (i.e. 2nd time)

User Impact: Cannot convert projects with such files to new .csproj format. Cannot use new .csproj format consistently. This si especially issue for compiling such projects on build servers as locally it can be worked around by building the project twice.

More info: As has already been discussed on https://github.com/dotnet/project-system/issues/1467 under some circumstances projects containing .xaml files are build using 2-pass build. A temporary projects with extension .tmp_proj is generated and built in order to obtain some kind of reference assembly for the 2nd build (of the main .csproj project). Unfortunately the choice of extension (which is hard-coded in the task) confuses the new project system as it cannot determine from the .tmp_proj extension which language the project is (VB, C# or something else) and thus just some default common options are available. Specifying <LanguageTargets> (<LanguageTargets>$(MSBuildToolsPath)\Microsoft.CSharp.targets</LanguageTargets>) does not solve the issue, just brings bunch error messages like

  • obj\Debug\net472\1ny23niw.AssemblyInfo.cs(14,12,14,18): error CS0246: The type or namespace name 'System' could not be found (are you missing a using directive or an assembly reference?)
  • obj\Debug\net472\1ny23niw.AssemblyInfo.cs(14,55,14,76): error CS0518: Predefined type 'System.String' is not defined or imported
  • Service References\ChannelScheduleService\Reference.cs(182,6,182,12): error CS0518: Predefined type 'System.Object' is not defined or imported
  • Service References\LookupService\Reference.cs(15,6,15,12): error CS0518: Predefined type 'System.Enum' is not defined or imported
  • Service References\ReferenceDataService\Reference.cs(2642,156,2642,157): error CS0518: Predefined type 'System.Int32' is not defined or imported
  • Service References\ReferenceDataService\Reference.cs(2642,150,2642,155): error CS0246: The type or namespace name 'Order' could not be found (are you missing a using directive or an assembly reference?)
  • Service References\ChannelScheduleService\Reference.cs(15,51,15,60): error CS0246: The type or namespace name 'Namespace' could not be found (are you missing a using directive or an assembly reference?)
  • etc.

Workaround: As I have observer that in case I do Rebuild + Build in Visual Studio the 2nd build passed, it seems to be possible to work around this issue by doing exactly that: Before build of the offending project try to build it and ignore any build errors. This can be achieved by following MSBuild code in the new .csproj file:

    <Target Name="PreCompileSelf" BeforeTargets="XamlTemporaryAssemblyGeneration" Condition="'$(MSBuildProjectExtension)' == '.csproj' and '$(SelfPreCompile)' != 'true'">
        <Message Text="Pre-compiling $(MSBuildProjectFile)..." Importance="high"/>
        <MSBuild Projects="$(MSBuildProjectFile)" Properties="Configuration=$(Configuration);Platform=$(Platform);SelfPreCompile=true" ContinueOnError="WarnAndContinue"/>
    </Target>
    <Target Name="CoreCompile" Condition="'$(MSBuildProjectExtension)' != '.csproj'">
        <!--Fake target - workaround for 2-phases build of projects with XAML files-->
        <Message Text="CoreCompile target called"/>
    </Target>

Issue Analytics

  • State:open
  • Created 4 years ago
  • Reactions:4
  • Comments:8 (3 by maintainers)

github_iconTop GitHub Comments

3reactions
Nirmal4Gcommented, Apr 2, 2020

@DzonnyDZ @danielmeza

Some background on 2-Pass compilation of Xaml in WPF and WFF targets

The problem is similar to WPF’s CreateTemporaryTargetAssembly which was fixed for supporting project files without xmlns tag a while back, around v4.7.x. But the same fix was not applied for WorkFlow Xaml targets which was in many ways similar in structure and code path to the WPF targets.

So, to solve this issue, you only need to add xmlns="http://schemas.microsoft.com/developer/msbuild/2003" back to your project file to generate the temporary project correctly.

So your project file becomes...
<Project Sdk="Microsoft.NET.Sdk" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
  <PropertyGroup>
    <TargetFramework>net472</TargetFramework>
    <OutputType>Exe</OutputType>
  </PropertyGroup>
  <ItemGroup>
    <None Remove="Activity2.xaml" />
    <None Remove="Workflow1.xaml" />
  </ItemGroup>
  <ItemGroup>
    <Reference Include="Microsoft.CSharp" />
    <Reference Include="System" />
    <Reference Include="System.Activities" />
    <Reference Include="System.Core" />
    <Reference Include="System.Data" />
    <Reference Include="System.Runtime.Serialization" />
    <Reference Include="System.ServiceModel" />
    <Reference Include="System.ServiceModel.Activities" />
    <Reference Include="System.Xaml" />
    <Reference Include="System.Xml" />
    <Reference Include="System.Xml.Linq" />
    <Reference Include="WindowsBase" />
  </ItemGroup>
  <ItemGroup>
    <XamlAppDef Include="Activity2.xaml">
      <Generator>MSBuild:Compile</Generator>
    </XamlAppDef>
    <XamlAppDef Include="Workflow1.xaml">
      <Generator>MSBuild:Compile</Generator>
    </XamlAppDef>
  </ItemGroup>
  <Choose>
    <When Condition="'$(MSBuildProjectExtension)' != '.csproj' and '$(MSBuildProjectExtension)' != '.vbproj'">
      <PropertyGroup>
        <LanguageTargets Condition="Exists('$(MSBuildProjectDirectory)\$(AssemblyName).csproj')">$(MSBuildToolsPath)\Microsoft.CSharp.targets</LanguageTargets>
        <LanguageTargets Condition="Exists('$(MSBuildProjectDirectory)\$(AssemblyName).vbproj')">$(MSBuildToolsPath)\Microsoft.VisualBasic.targets</LanguageTargets>
      </PropertyGroup>
    </When>
  </Choose>
</Project>

and with my Extras SDK (which extends from claire’s but her sdk don’t have wff or wcf yet), you’d essentially have

<Project Sdk="MSBuild.NET.Extras.Sdk" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">

  <PropertyGroup>
    <TargetFramework>net472</TargetFramework>
    <OutputType>Exe</OutputType>
    <EnableWffProjectSetup>true</EnableWffProjectSetup>
    <!--
        This is needed for Presentation tech used as a part of Activities lib.
        Only references are needed. Don't need to enable whole wpf support.
        You could also set `EnableWpfProjectSetup` to build both WPF and WFF in single exe!
     -->
    <EnableImplicitWpfReferences>true</EnableImplicitWpfReferences>
  </PropertyGroup>

</Project>

Note: I haven’t updated my readme yet but the package (latest from myget) requires Visual Studio v16 (2019) but the old one on nuget works from v15.6 (2017 Update 6) onwards.

@davkean @davidwengier May I ask why was the fix not added to the WFF targets?

1reaction
davidwengiercommented, Apr 7, 2020

May I ask why was the fix not added to the WFF targets?

Those targets don’t live in this repo so I’m afraid I couldn’t say.

Read more comments on GitHub >

github_iconTop Results From Across the Web

Project Wont Compile -> Invoke Workflow - Studio
So the transaction item is like the name of the workflow. This is not supported for compiled projects. Hi, This matter depends on...
Read more >
xaml - how do I solve build error on c# workflow project
The error is not systematic. I solve the problem by compiling the single project again. The nightly build is runned with the highest...
Read more >
Failed assembly resolution in XAML workflow projects
Workflows in this project may still run, if they do not require expression compilation. If the file is a platform-specific library or executable ......
Read more >
Authoring Workflows, Activities, and Expressions Using ...
C# expressions must be compiled before the workflow containing them is invoked. If the C# expressions are not compiled, a NotSupportedException ...
Read more >
Milestone 5 Requirements :: K-State CIS 400 Textbook
This assignment is intended to introduce you to Microsoft's Windows Presentation Foundations' approach to using Extensible Application Markup Language (XAML) to ...
Read more >

github_iconTop Related Medium Post

No results found

github_iconTop Related StackOverflow Question

No results found

github_iconTroubleshoot Live Code

Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free

github_iconTop Related Reddit Thread

No results found

github_iconTop Related Hackernoon Post

No results found

github_iconTop Related Tweet

No results found

github_iconTop Related Dev.to Post

No results found

github_iconTop Related Hashnode Post

No results found