Sharing Projectsexplore Programming

OK, let's take an example. Let's say, that I have project: MyApp.Library win32 lib myClass.cpp myClass.h This library is compiled to.DLL file and then imported in a Win32 application. Leila is an interdisciplinary academic working at the intersection of urban planning, design and disaster management. Her research tackles the challenges of operationalising urban resilience, science and technology in DRR, post-disaster reconstruction and her recent research focuses on the applications of complex systems theory in urban resilience planning and developing models to better. Mod Share (modshare.org) is a great website. It's designed for sharing projects made in programming languages based on Scratch. As long as you have a Scratch account from Scratch, you can make a Mod Share account and share Explore projects. If someone wants to view a project you share, they'll have to download the project and Explore for it to.

Scratch Scratch is the world's most popular coding community for kids. Millions of kids around the world are using Scratch to program their own interactive stories, games, and animations—and share their creations in an active online community. Shared Project is a great way of sharing common code across multiple application We already have experienced with the Shared Project type in Visual Studio 2013 as part of Windows 8.1 Universal App Development, But with Visual Studio 2015, it is a Standalone New Project Template; and we can use it with other types of app like Console, Desktop, Phone, Store App etc.

Welcome back to part 2 of the ongoing saga of sharing code across platforms using Xamarin. 0002The last time we talked about the why and when to share code, today we’ll cover one of the ways of how to share code.

Unfortunately we won’t be sharing pizza today, but there are 3 ways to share code across projects:

Microsoft Project Sharing

  1. Linked files
  2. Shared Projects
  3. Portable Class Libraries

Linked files are going the way of the dodo and generally are not used any longer and are being replaced in favor of Shared Projects. 0002So let’s0002investigate how to share code using “Shared Projects”, and in the next post in this series we’ll investigate Portable Class Libraries, or PCLs.

What are Shared Projects?

Project

A good place to start with is defining exactly what is meant by a0002Shared Project. 0002To quote Xamarin:

Shared Projects let you write common code that is referenced by a number of different application projects. The code is compiled as part of each referencing project and can include compiler directives to help incorporate platform-specific functionality into the shared code base.

In other words, Shared Projects are a project type which get compiled directly into the project referencing them, and you can even use platform specific APIs within them0002– which are identified0002by preprocessor directives. 0002That means you can use specific iOS, Android or Windows Phone APIs within a Shared Project and the preprocessor directive ignores anything not a part of the platform you’re compiling for. 0002Under the hood, Visual Studio and Xamarin Studio treat Shared Projects the same way they treat linked files.

Shared Projects were introduced in Visual Studio 2013 R2 and also in Xamarin Studio 5.

Pros And Cons of Shared Projects

Advantages

One really0002cool thing about Shared Projects0002is that they0002have full access to all of the assemblies of .NET framework, which set them apart from the limited access that PCLs have.

You can use platform specific code within a Shared Project. 0002So that whiz-bang feature that you developed for Android, but don’t really need for iOS, can be included within the Shared Project itself. 0002Or more practically, certain folders within the file system are accessed differently across the platforms – but the differences in accessing those folders can be accounted for within a Shared Project.

One final benefit is that because the Shared Project is compiled directly into the referencing application’s binary – if there is a project in your solution which does not reference the Shared Project, it is not included at all in it’s binary. 0002No unnecessary bloat.

Disadvantages
Sharing

While a Shared Project does have full access to the .NET framework, you cannot add any references to the Shared Project itself. 0002That means any 3rd party libraries, even libraries that you’ve created elsewhere, are not available.

Another is no separate DLL is created – all of the Shared Project’s code is compiled to be a part of the referencing application’s binary itself. 0002Any assets, such as images or other media are compiled into the referencing binary as well. 0002So code sharing across different solutions is not possible with the Shared Project.

Refactoring is difficult with a Shared Project. 0002Any code within a preprocessor directive that is not a part of the active project will not be touched during a refactor. 0002That can lead to a mess very easily.

All of the preprocessor directives themselves can also lead to a real mess in your code.

How To Implement Shared Projects

Microsoft project sharing

Let’s get down to it and talk about0002how to implement a Shared Project. 0002One of the first things to know are the preprocessor directives. 0002For our purposes, we’re only interested in the ones associated with mobile projects:

  • IOS
  • ANDROID
  • WINDOWS_PHONE

Each directive is surrounded by two underscore characters. 0002It is also worth noting that0002specific versions of Android can be targeted with the following directive:

  • ANDROID_14

The code within the above preprocessor statement will only be compiled into applications targetingthe Android 14 level API and above.

Ms Project Sharing

Programming

Any code contained within the preprocessor directive will only be compiled into the platform the preprocessor directive is referring to. 0002Otherwise, using a Shared Project is no different than adding a “normal” class library into your solution.

Example

Let’s demonstrate this with an example. 0002Throughout this series of tutorials, we’ll be creating a Tabata app. 0002A Tabata is a high intensity interval exercise, where you exercise0002at a high intensity for a set amount of time, rest for a set amount of time, and repeat. 0002The app we’ll develop will let the user specify the exercise0002time, the rest time, and how many sets they want to do. 0002It will also keep a history of the Tabatas completed in a CSV file.

The first step in creating a shared code library is to identify the code which can be shared. 0002In our case, we’ll model the individual Tabata with properties of Date, Work Interval, Rest Interval and Number of Sets. 0002We’ll also have a list class which contains a history of all of the completed exercises and the ability to read them from the saved CSV file.

The next step is to create0002a solution that has both an iOS and Android project in it. 0002From there we’ll need to add a Shared Project. 0002That’s under the C# node in the “Add New Project” dialog box. 0002The naming convention usually follows

The full solution can be found out on GitHub here:0002https://github.com/codemillmatt/TabataShared. The cool thing about using the Shared Project is that all of the application logic is contained within it. 0002All of the timers, all of the file I/O. 0002The only thing that the respective platform projects implement is the UI.

Summary

We went through what exactly a Shared Project is, discussed the pros and cons of Shared Projects, how to implement them and a demoed quick code example. 0002The main thing to take away here is that Shared Projects enable you to use platform specific APIs in the same library referenced from projects targeting completely different0002platforms. 0002However, the Shared Project cannot be used outside of its current solution.

In the next post in this series of creating cross platform code, we’ll talk about Portable Class Libraries and how they stack up against Shared Projects.