Ok. I am not sure what you mean by similar to import clr, though. Because in my example, clr is available from outside test; its just named test.clr... Let me give you another example which is closer on how I ran into this...
Lets say you have in C#: --- iron.Example.cs namespace iron { public class Example { public Example() { } public int foo() { return 1; } } public static class ExampleExtension { public static int bar(this Example example) { return example.foo() + 1; } } } --- EOF Then I define an example.py to wrap this up: --- test.py import clr clr.AddReference("iron") import iron clr.ImportExtensions(iron.ExampleExtension) # lets use this just to test it out e = iron.Example() print e.foo() print e.bar() --- EOF now on my command line I get >>> import example 1 2 >>> ex = example.iron.Example() >>> ex.foo() 1 >>> ex.bar() Traceback (most recent call last): File "<stdin>", line 1, in <module> AttributeError: 'Example' object has no attribute 'bar' And so I don't find a nice way to wrap my C# functionality in just one python module, where I whish I could offer the extension methods just like any other method... or is my import strategy somehow flawed ? Greetings, Daniel namespace native { public class Example { } public static class ExampleExtension { public static void } add some extension methods to it, and then want to import everything in one python stub module. E.g. ----- Original Message ---- From: Dino Viehland <di...@microsoft.com> To: Discussion of IronPython <users@lists.ironpython.com> Sent: Thu, May 12, 2011 1:01:33 PM Subject: Re: [IronPython] clr.ImportExtensions are not available outside module ? Daniel wrote: > Just as Dave Wald, I have also trying out the ImportExtensions methods > which I personally find very useful, thank you for implementing. Everything is > working fine on using 2.7 (and .net 4), but extension methods loaded by one > module seem not available on another... This is by design. It works similar to how "import clr" only effects the current module and how extension methods work in C# where they are scoped by file. So if you want extension methods available in a file you'll need to import them in that file. If they were globally scoped it would be easy for one module to break another by bringing in the 'wrong' extension methods. > > > I will stick to Dave's code exmaple: > > import clr > clr.AddReference("System.Core") > import System > from System import Linq > > clr.ImportExtensions(Linq) > > class Product(object): > def __init__(self, cat, id, qtyOnHand ): > self.Cat = cat > self.ID = id > self.QtyOnHand = qtyOnHand > self.Q = self.QtyOnHand > > If I put this into a file, lets say test.py and now use the module on the > command line: > > >>> import test > >>> products = [test.Product('food', i, 10) for i in range(3)] > >>> > >>> > >>> products.Where > Traceback (most recent call last): > File "<stdin>", line 1, in <module> > AttributeError: 'list' object has no attribute 'Where' > > The linq extensions are not available. I have to re-import them: > > >>> test.clr.ImportExtensions(test.Linq) > >>> products.Where > <built-in method Where of list object at 0x000000000000002B> > >>> > > Is this a current limitation, or should I be doing things differently ? > Any help appreciated. > > Greetings, > Daniel > _______________________________________________ > Users mailing list > Users@lists.ironpython.com > http://lists.ironpython.com/listinfo.cgi/users-ironpython.com _______________________________________________ Users mailing list Users@lists.ironpython.com http://lists.ironpython.com/listinfo.cgi/users-ironpython.com _______________________________________________ Users mailing list Users@lists.ironpython.com http://lists.ironpython.com/listinfo.cgi/users-ironpython.com