On Tuesday, December 29, 2015 at 5:33:43 PM UTC, Peter Otten wrote:
> xeon Mailinglist wrote:
>
> > On Tuesday, December 29, 2015 at 4:18:10 PM UTC, Peter Otten wrote:
> >> xeon Mailinglist wrote:
> >>
> >> > On Tuesday, December 29, 2015 at 11:16:10 AM UTC, xeon Mailinglist
> >> > wrote:
> >> >> 1. How do I create a global variable that can be accessed by all
> >> >> classes?
> >> >>
> >> >> 2. I am using `dogpile.cache` to store data in the cache [1], but if I
> >> >> set and get the same key from different modules, I don't get the
> >> >> value. Here is an example in [2]. The value than I get is
> >> >> `NO_VALUE.NO_VALUE`. Why this happens?
> >>
> >> >> region = make_region().configure('dogpile.cache.memory')
> >>
> >> The memory backend wraps a python dict whose contents are only available
> >> to a single script and forgotten when that script ends.
> >>
> >> My crystal ball tells me that you want to communicate between processes
> >> rather than "modules" and need a backend that implements persistence.
> >> "dogpile.cache.file" seems to be the one without dependencies outside the
> >> standard library.
> >
> >
> > No.
>
> Does "No" mean "I have run my code with another backend, and the modified
> script showed the same behaviour"?
>
> > My problem is that I have method1() that calls method2() which calls
> > myset(). method1() -> method2() -> myset(5). My problem is that, if I try
> > to get the value of myset() inside method1(), I can't have it. It seems
> > that the program has lost the value.
>
> I can't make sense of that. You should be able to nest methods to your
> heart's content (as long as you don't reach the recursion limit).
>
> Can you post minimal versions of your modules in such a way that I can
> easily run them over here?
>
> If you have only one process you probably have somehow managed to get two
> backend dicts. Unfortunately there's a blind spot on my crystal ball, and I
> can't see how exactly you did it...
No, I cannot get a simpler example. The simpler example works, and in my code,
it doesn't. I thought that it was something related to the variable `region`,
but I declare it as global. So, I think that all the sets will go to the same
variable.
--
https://mail.python.org/mailman/listinfo/python-list