Keeping projects in sync across multiple .NET versions

前端 未结 2 1450
时光取名叫无心
时光取名叫无心 2020-12-21 02:09

I need to create some core libraries within my application which will be available in both .NET 3.5 and .NET 4.0. I\'m happy creating multiple projects, creating the require

相关标签:
2条回答
  • 2020-12-21 02:30

    What I do is:

    • have one "regular" csproj that I use for most of my dev, adding files etc - but remembering that really all files are "in"
    • for the other csproj, use something like:

      <ItemGroup>
        <Compile Include="..\Foo\**\*.cs" />
      </ItemGroup>
      

    (that is basically the same as "add as link", but without needing to be done on a per-file basis)

    This is a recursive include of all *.cs files, so everything is in. No file maintenance needed.


    If you were trying to target multiple frameworks (rather than multiple versions), then another option might be: use a Portable Class Library. This is a single project that works on multiple frameworks, but is limited to the strict intersection of features from the platforms you target. In VS2010 this is an add-in feature; it is included by default in VS 11.

    0 讨论(0)
  • 2020-12-21 02:37

    What I do with my cross platform projects is to have different slns, each for one platform.

    The shared code lives in a common location and is added "as a link" into the correct csproj's. This csproj also contain any platform specific files. If a "common code" file needs to be conditional based on current platform you can choose to replace that with two platform-specific files or put a #ifdef in it (depends on how much of it is different).

    Note that you can also add one solution to another inside Visual Studio. This "combined" solution can be used for automated builds for all platforms.

    Example: https://github.com/ananthonline/graffiti

    This works great for me, YMMV. Hope this helps.

    0 讨论(0)
提交回复
热议问题