[
Date Prev][
Date Next][
Thread Prev][
Thread Next][
Date Index][
Thread Index]
[
List Home]
| Re: [udig-devel] refresh a catalog item | 
Hmmm.  Have you checked in your code.  I can try to help you debug.
Jesse
On Jul 24, 2007, at 2:56 AM, Andrea Antonello wrote:
I noticed one more thing by comparing the object ids that eclipse  
shows
when debugging. In fact the first time the DecoratingLabelProvider
getText is called, the JGrassService is a new one, created by the
drag&drop event (let's say id = 5966). Instead when I expand the  
three,
the getText is always (until I do not restart udig) called with a
JGrassService object of id = 5885, i.e. an old one.
So now I'm sure that the service is cached somewhere (I can imagine  
that
gives nice performance on services with large number of items and/or
connections to perform), but the question is: where?
Ciao,
Andrea
Andrea Antonello probaly wrote:
Hmmm.  I'm afraid I'm not sure what is happening.  There is some  
caching
of labels in the CatalogUIPlugin I think but I didn't think that  
would
affect the structure of the tree.
I'm also afraid I don't know exactly what happens. I'm just now
debugging the CatalogTreeViewer and I'm getting mad.
When I drag my location (with two mapsets in it, but udig  
remembers that
it had three, I just removed one) into the view, when it comes to  
create
the labels for the entry, when it comes to the method:
getText(Object element) of the DecoratingLabelProvide the element  
is in
fact a JGrassService and has 2 mapsets, which in this case it has to
have. So I'm glad and happy.
I click on the entry to expand the tree and what happens in the
DecoratingLabelProvide? I get also the nonexisting mapset. So I check
for the parent and get the JGrassService which was supposed to have 2
mapsets... but at that point it has 3! And I can't understand  
where this
happens.
I hope I was able to explain myself a bit...
Any hint?
Andrea
Jesse
On Jul 23, 2007, at 9:34 AM, Andrea Antonello wrote:
Let me add something more: I debugged down the line and before  
returning
 from the most top members(monitor) method (i.e. the IService  
method),
the array contains all the needed resources, which means they  
are read.
The problem is, they are then not visualized. It "remebers" the  
previous
tree. How can that be?
Andrea
Andrea Antonello probaly wrote:
Yes, I also think the ResetService could work, I just have to  
struggle
with the fact that when I reload (i.e. remove and redrag into  
catalog)
the JGrass service, it doesn't call the members method of the  
nested
resources. Instead when udig restarts it goes indeep again. Is  
there
some memory somewhere or is it my fault?
Andrea
Jesse Eichar probaly wrote:
Hi,
THe ServiceFactory.acquire() method creates a new instance of the
service but does not affect the catalog.  It is just a  
factory.  You
could probably do a find on the catalog for the service you  
want to
replace.  Delete that service from the catalog and then put  
the new
instance in the catalog.  I have used the ResetService and can  
verify
that it does do something.  I think it even works :P.
Jesse
On Jul 23, 2007, at 8:30 AM, Andrea Antonello wrote:
Finally I got time to get into this and...it doesn't work.
I'm trying to understand if it all depends on a strange  
behaviour
that I
notice. Perhaps someone can explaint that:
I open udig drag a grass location into the catalog and it reads
everything properly. So for example I have a location with  
two mapsets
and nested inside the maps. Now I create a map in one mapset.  
I remove
the service from the catalog and then drag the location into the
catalog
again. i thought it would read the whole thin g again, but it
remembers
something and the new map is not seen.
If I reastart udig, the map appears. So what does it remember  
and
where?
For your info the part:
        IServiceFactory locator = CatalogPlugin.getDefault()
                .getServiceFactory();
        List<IService> rereadService = locator.acquire(ID,
connectionParams);
in fact creates a proper service, but without internal  
members. But by
triggering manually the members method on the members fills  
everything
down the tree, so that should work. (in fact it doesn't since it
remembers the old tree)
Any hint?
Andrea
Jesse Eichar probaly wrote:
Trying to remember.  Take a look at the ResetService class.  It
essentially kicks the service so that the tree will be  
loaded again.
Remember that there is a chance that there is a bug with  
regards to
multi-level services since you are the trail-blazer here.
Jesse
On Jul 15, 2007, at 11:26 AM, Andrea Antonello wrote:
I need to add a created map to the catalog. That is easy with
shapefile
or so, but I can't figure out how to do that in a multilevel
service,
i.e. I want to add an entry to the JGrass location service,  
which is
something similar in the level management to the WMS service.
Do I have to re-read it and if yes how do I trigger the re- 
read of a
service? Is there a more performant way?
Ciao
Andrea
_______________________________________________
User-friendly Desktop Internet GIS (uDig)
http://udig.refractions.net
http://lists.refractions.net/mailman/listinfo/udig-devel
_______________________________________________
User-friendly Desktop Internet GIS (uDig)
http://udig.refractions.net
http://lists.refractions.net/mailman/listinfo/udig-devel