Suggested changes to the singleton.hpp file to make QuantLib work better with .Net

classic Classic list List threaded Threaded
4 messages Options
Reply | Threaded
Open this post in threaded view
|

Suggested changes to the singleton.hpp file to make QuantLib work better with .Net

Nathan Abbott
There has been a problem with using QuantLib with .Net Framework. The problem is in the T& Singleton<T>::instance() method in singleton.hpp. The method initializes a static variable.  Since singleton.hpp is a header file and if you use it with a cpp file that is complied to managed code, the Common Language Runtime (CLR) will initialized the variable. The CLR has the concept of AppDomains. An AppDomain is a light-weight process. Since native variables does not know anything about AppDomains, native variables does not know why it can leave the its AppDomain.


The lines 69-70  in the singleton.hpp solve this problem some what.
#if defined(QL_PATCH_MSVC)
inline  // this seems to be required when CLR support is enabled
#endif

This forces the T& Singleton<T>::instance() method to be compiled with the settings.cpp file. This only works if QuantLib is in the Primary AppDomain. If QuantLib is used with ASP.Net or for with Nunit, an error will occur. The better solution is to place the singleton class under the preprocessor "pragma managed" and get rid of lines 69-70. Here is the code for the new singleton.hpp that I included in this email.


#ifndef quantlib_singleton_hpp
#define quantlib_singleton_hpp

#include <ql/types.hpp>
#include <boost/shared_ptr.hpp>
#include <boost/noncopyable.hpp>
#include <map>

namespace QuantLib {

    //! Basic support for the singleton pattern.
    /*! The typical use of this class is:
        \code
        class Foo : public Singleton<Foo> {
            friend class Singleton<Foo>;
          private:
            Foo() {}
          public:
            ...
        };
        \endcode
        which, albeit sub-optimal, frees one from the concerns of
        creating and managing the unique instance and can serve later
        as a single implemementation point should synchronization
        features be added.

        \ingroup patterns
    */

    #if defined(QL_ENABLE_SESSIONS)
    // definition must be provided by the user
    Integer sessionId();
    #endif


    #if defined(QL_PATCH_MSVC)
    #pragma managed(push, off)
    #endif
    template <class T>
    class Singleton : private boost::noncopyable {
      public:
        //! access to the unique instance
        static T& instance();
      protected:
        Singleton() {}
    };

  
    // template definitions
    template <class T>
    T& Singleton<T>::instance() {
        static std::map<Integer, boost::shared_ptr<T> > instances_;
        #if defined(QL_ENABLE_SESSIONS)
        Integer id = sessionId();
        #else
        Integer id = 0;
        #endif
        boost::shared_ptr<T>& instance = instances_[id];
        if (!instance)
            instance = boost::shared_ptr<T>(new T);
        return *instance;
    }
    #if defined(QL_PATCH_MSVC)
    #pragma managed(pop)
    #endif
}

#endif


The "pragma managed" preprocessor will force the singleton class to be compiled to native code, if the singleton.hpp is used with a cpp file that is compiled to managed code. If the cpp file is compiled to native code, the preprocessor will do nothing.







------------------------------------------------------------------------------
Download Intel&#174; Parallel Studio Eval
Try the new software tools for yourself. Speed compiling, find bugs
proactively, and fine-tune applications for parallel performance.
See why Intel Parallel Studio got high marks during beta.
http://p.sf.net/sfu/intel-sw-dev
_______________________________________________
QuantLib-dev mailing list
[hidden email]
https://lists.sourceforge.net/lists/listinfo/quantlib-dev

singleton.hpp (3K) Download Attachment
Reply | Threaded
Open this post in threaded view
|

Re: Suggested changes to the singleton.hpp file to make QuantLib work better with .Net

Luigi Ballabio
On Wed, 2010-03-24 at 11:42 -0700, Nathan Abbott wrote:
> There has been a problem with using QuantLib with .Net Framework.
> [...] The better solution is to place the singleton class under the
> preprocessor "pragma managed" and get rid of lines 69-70.

Thanks, Nathan.  Does the pragma have any effects when compiling in the
usual, no-.Net way?  Also, is there any preprocessor define that can
tell us we're compiling for .Net?

Thanks,
        Luigi


--

The rule on staying alive as a forecaster is to give 'em a number or
give 'em a date, but never give 'em both at once.
-- Jane Bryant Quinn



------------------------------------------------------------------------------
Download Intel&#174; Parallel Studio Eval
Try the new software tools for yourself. Speed compiling, find bugs
proactively, and fine-tune applications for parallel performance.
See why Intel Parallel Studio got high marks during beta.
http://p.sf.net/sfu/intel-sw-dev
_______________________________________________
QuantLib-dev mailing list
[hidden email]
https://lists.sourceforge.net/lists/listinfo/quantlib-dev
Reply | Threaded
Open this post in threaded view
|

Re: Suggested changes to the singleton.hpp file to make QuantLib work better with .Net

Nathan Abbott
Does the pragma have any effects when compiling in the
usual, no-.Net way?
 
No

Also, is there any preprocessor define that can
tell us we're compiling for .Net?

Using pragma managed (push,off) with pragma managed (pop) is the prefer way of dealing with this issue.
------------------------------------------------------------------------------
Download Intel&#174; Parallel Studio Eval
Try the new software tools for yourself. Speed compiling, find bugs
proactively, and fine-tune applications for parallel performance.
See why Intel Parallel Studio got high marks during beta.
http://p.sf.net/sfu/intel-sw-dev
_______________________________________________
QuantLib-dev mailing list
[hidden email]
https://lists.sourceforge.net/lists/listinfo/quantlib-dev
Reply | Threaded
Open this post in threaded view
|

Re: Suggested changes to the singleton.hpp file to make QuantLib work better with .Net

Luigi Ballabio
In reply to this post by Nathan Abbott
On Wed, 2010-03-24 at 11:42 -0700, Nathan Abbott wrote:
> There has been a problem with using QuantLib with .Net Framework.
> [...] The better solution is to place the singleton class under the
> preprocessor "pragma managed" and get rid of lines 69-70.

Ok, done.

Thanks,
        Luigi


--

The first thing we do, let's kill all the lawyers.
-- W. Shakespeare, "King Henry VI, Part II"



------------------------------------------------------------------------------
Download Intel&#174; Parallel Studio Eval
Try the new software tools for yourself. Speed compiling, find bugs
proactively, and fine-tune applications for parallel performance.
See why Intel Parallel Studio got high marks during beta.
http://p.sf.net/sfu/intel-sw-dev
_______________________________________________
QuantLib-dev mailing list
[hidden email]
https://lists.sourceforge.net/lists/listinfo/quantlib-dev