One more thing I&#39;d follow up with is if we were to have a SharedWorker just inherit an applicationcache from the first document that creates it, what happens after that document closes? How can the SharedWorker update its application cache if an update becomes available, since the only document associated with that cache is now closed?<div>
<br></div><div>-atw<br><br><div class="gmail_quote">2009/6/1 Michael Nordman <span dir="ltr">&lt;<a href="mailto:michaeln@google.com">michaeln@google.com</a>&gt;</span><br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
How workers and appcaches interact has been discussed on the WHATWG<br>
list. Ian&#39;s &quot;Worker feedback&quot; message on 3/27/09 tried to tie things<br>
up for the time being. I think where he left things was a reasonable<br>
stepping stone, although the answers to the questions being asked here<br>
about updates were not entirely resolved.<br>
<div class="im"><br>
&gt; What is the use case for this? It doesn&#39;t seem useful to me - to invoke update explicitly, one<br>
&gt; normally needs to have UI anyway, at which point it&#39;s much easier to call update() directly from a<br>
&gt; page.<br>
<br>
</div>The use case are workers that can be considered &quot;faceless<br>
applications&quot;. They are versioned independently of user interfaces<br>
that make use of them thru a stable message based API.<br>
<div class="im"><br>
&gt; A tangentially related question: what will happen to a SharedWorker whose cache got updated?<br>
&gt; Will the repository use a new source for new instances, while the old ones will continue to run?<br>
<br>
</div>I think the intent of the current spec is that a new instance would<br>
not be created provided there is an existing instance already running.<br>
How to reload an existing worker to utilize new resources in an<br>
updated cache was left as an exercise to the reader.<br>
<br>
At least that&#39;s my understanding of the current spec.<br>
<br>
<br>
2009/6/1 Drew Wilson &lt;<a href="mailto:atwilson@google.com">atwilson@google.com</a>&gt;:<br>
<div><div></div><div class="h5">&gt;<br>
&gt;<br>
&gt; 2009/6/1 Alexey Proskuryakov &lt;<a href="mailto:ap@webkit.org">ap@webkit.org</a>&gt;<br>
&gt;&gt;<br>
&gt;&gt; 01.06.2009, Χ 22:37, Drew Wilson ΞΑΠΙΣΑΜ(Α):<br>
&gt;&gt;<br>
&gt;&gt; 1) Since SharedWorkers aren&#39;t explicitly tied to a specific Document, it<br>
&gt;&gt; doesn&#39;t make sense to have them possibly get loaded from an out-of-date<br>
&gt;&gt; version of the app cache. If you have two separate documents running from<br>
&gt;&gt; different caches, it&#39;s weird (and indeterminate) if the version of the cache<br>
&gt;&gt; used to load the SharedWorker script is dependent on which one happens to<br>
&gt;&gt; call &quot;new SharedWorker()&quot; first.<br>
&gt;&gt;<br>
&gt;&gt; I don&#39;t see how exposing DOMApplicationCache methods to workers can help<br>
&gt;&gt; this š- a worker will only be able to call DOMApplicationCache.update()<br>
&gt;&gt; after it has started, which is too late.<br>
&gt;<br>
&gt; Not sure why that is &quot;too late&quot;? Can you clarify?<br>
&gt;<br>
&gt;&gt;<br>
&gt;&gt; Besides, won&#39;t the document using an old version of cache break if a newer<br>
&gt;&gt; SharedWorker is suddenly returned to it? The main idea of appcache is that<br>
&gt;&gt; all application resources are versioned, so if we see SharedWorkers as part<br>
&gt;&gt; of application, they should use the same cache version. And if they are<br>
&gt;&gt; independent entities with a stable API, using an out of date version for a<br>
&gt;&gt; while cannot hurt.<br>
&gt;<br>
&gt; Why would a document using an old version of cache break if a newer<br>
&gt; SharedWorker is returned? Why is that any more of a problem than a document<br>
&gt; using a new version of cache breaking if an older SharedWorker is returned,<br>
&gt; which is what would happen if SharedWorkers inherited appcache from the<br>
&gt; first document that instantiated them?<br>
&gt; It seems like there are several easy options available to apps:<br>
&gt; 1) Change the name of the shared worker if a non-backward-compatible change<br>
&gt; needs to be made to the worker script (so new documents don&#39;t share the same<br>
&gt; worker instance as old documents)<br>
&gt; 2) When updates are available, coordinate updates with all documents so<br>
&gt; everyone updates at once, possibly exiting the SharedWorker.<br>
&gt;<br>
&gt;&gt;<br>
&gt;&gt; As for what happens to a SharedWorker whose cache was updated? My<br>
&gt;&gt; presumption is that all future resource loads would use that cache. At that<br>
&gt;&gt; point, the SharedWorker has a few different things it could do:<br>
&gt;&gt;<br>
&gt;&gt; Reload all of its scripts again using importScripts(). This implies that<br>
&gt;&gt; its script loading is idempotent, but that&#39;s not too hard to do.<br>
&gt;&gt; Send messages to all of its client documents letting it know that it is<br>
&gt;&gt; shutting down, then invoke close() to shut itself down. The client documents<br>
&gt;&gt; can re-create the SharedWorker the next time they want one. This is<br>
&gt;&gt; inherently race-y, though, since you can&#39;t easily coordinate the shutdown of<br>
&gt;&gt; the worker with instantiations of new ones.<br>
&gt;&gt; Do nothing at all<br>
&gt;&gt;<br>
&gt;&gt; All of these options seem quite dangerous - it may be difficult for JS<br>
&gt;&gt; authors to write applications that won&#39;t break at update time.<br>
&gt;<br>
&gt; It might be tricky, although any application that does dynamic JS loading<br>
&gt; has to deal with versioning issues already. This is not particularly<br>
&gt; different.<br>
&gt;<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt; A document can reload itself after updating, but SharedWorkers do not have<br>
&gt;&gt; a way to reload themselves. As you mentioned, they can reload imported<br>
&gt;&gt; scripts (but the main script will remain the same, which would be<br>
&gt;&gt; inconsistent).<br>
&gt;<br>
&gt; Why can&#39;t they reload the main script? Again, there&#39;s a need to be<br>
&gt; idempotent if you need to maintain some cached state, but it&#39;s not totally<br>
&gt; impossible.<br>
&gt;<br>
&gt;&gt;<br>
&gt;&gt; Or they can shut down and ask a document to re-create themselves - at<br>
&gt;&gt; which point, we can as well say that the document can update the cache.<br>
&gt;<br>
&gt; I&#39;m not arguing against this, I just don&#39;t see how it works when you have<br>
&gt; multiple documents each of which are running from different versions of the<br>
&gt; app cache, where the shared worker itself is attached to some arbitrary<br>
&gt; instance.<br>
&gt;<br>
&gt;&gt;<br>
&gt;&gt; Interaction of SharedWorkers and appcache, explicit or not, sounds like a<br>
&gt;&gt; major issue to me. It can significantly affect the design (or even make<br>
&gt;&gt; SharedWorkers not worth being added, if no acceptable solution is found).<br>
&gt;<br>
&gt; My design doc just reflects the current spec - I don&#39;t really intend to be<br>
&gt; the defender of said spec. As I said previously, I think this is the wrong<br>
&gt; venue for us to describe issues with the spec - we should do it on the<br>
&gt; whatwg list to include other stakeholders.<br>
&gt; I&#39;d be happy to start that conversation on the whatwg list, but to be honest<br>
&gt; I don&#39;t think I&#39;m quite understanding what your objections to the current<br>
&gt; spec are. Would you mind kicking off that discussion with whatwg, outlining<br>
&gt; your concerns?<br>
&gt; -atw<br>
&gt;<br>
</div></div><div><div></div><div class="h5">&gt; _______________________________________________<br>
&gt; webkit-dev mailing list<br>
&gt; <a href="mailto:webkit-dev@lists.webkit.org">webkit-dev@lists.webkit.org</a><br>
&gt; <a href="http://lists.webkit.org/mailman/listinfo.cgi/webkit-dev" target="_blank">http://lists.webkit.org/mailman/listinfo.cgi/webkit-dev</a><br>
&gt;<br>
&gt;<br>
</div></div></blockquote></div><br></div>