Hi Patrick, On Thu, Aug 23, 2012 at 1:15 PM, Patrick Ohly <patrick.ohly@xxxxxxxxx> wrote: > On Thu, 2012-08-23 at 11:15 +0300, Luiz Augusto von Dentz wrote: >> Hi Patrick, >> >> On Thu, Aug 23, 2012 at 10:35 AM, Patrick Ohly <patrick.ohly@xxxxxxxxx> wrote: >> > On Thu, 2012-08-23 at 01:13 +0300, Luiz Augusto von Dentz wrote: >> >> Hi Patrick, >> >> >> >> On Wed, Aug 22, 2012 at 7:04 PM, Patrick Ohly <patrick.ohly@xxxxxxxxx> wrote: >> >> > Hello! >> >> > >> >> > For IVI use cases, Mikel and I were discussing how a phone's address >> >> > book could be cached intelligently by an IVI head unit. The rough idea >> >> > is that first all contacts get pulled without PHOTO data. This data is >> >> > used to match the current phone address book with some potentially >> >> > cached local data. Then in a second step, the PHOTO data of all contacts >> >> > is requested (*). This is all done in the same PBAP session, so the >> >> > numbering of contacts is the same in both steps. >> >> > >> >> > The goal is to get the essential data (names, phone numbers) quickly and >> >> > then add pictures later on. >> >> >> >> I think it is a good idea, but what about to download the full contact >> >> vcard only when it is to be displayed? >> > >> > There are other use cases that depend on having all data locally, for >> > example merging address books from several different phones into a >> > single unified address book. Browsing that unified address book is >> > expected to include photo data, so loading that on demand isn't an >> > option. >> >> How you deal with conflicts such as different pictures, names for the >> same contact? In theory merging seems to be the right thing to do but >> if you have used e.g. Nokia N9 it can cause many problems where the >> same phone number can be found in multiple contacts. What if we got in >> a situation where the IVI system show 'Joe' but the phone shows "John" >> with a different picture, I guess this is supposed to be consistent >> with the phone that is handling the call. > > That wasn't mentioned before as a requirement. I guess it could be done > so that the local cache is used as a first approximation while the phone > is asked to provide the final answer. Yep, that is my understanding too and since the phone has to give the final answer anyway, we might just download the essential things like name and number the rest is filled on demand, obviously if we already have done this in a previous session we keep in storage. >> >> When we connect we attempt to >> >> download the full phonebook which is cached for fast lookup but while >> >> ringing we can download the full vcard including the picture. >> > >> > Even if we wanted to do it that way, it also wouldn't work at the moment >> > because the PullAll download doesn't include the information that is >> > necessary to get the full vcard later on. Any comments about my >> > proposals for fixing this (download into dir and/or add X- prop to >> > vcards)? >> >> What about Search + Pull? If you have download the contact already you >> have the name then you search by name, otherwise search by number, >> with the response you can download the vcard with Pull. > > Isn't that very inefficient? One search request for each contact? It is, that why we need to download this info before hand, but since we cannot depend on the contact handle being unique across the sessions I don't see any other option except if we have fetched the handle in the same session then we can skip Search and Pull directly. > I also don't expect it to work reliably, for example when there is a > "John Doe, Sr." and John Doe, Jr." in the same address book. Phone > number also isn't unique (might have been added to two different persons > who are sharing the same address and phone). Yep, but that is the general problem isn't it? When you got a call you just have the number if it maps to multiple contacts that is something the user interface has to handle. -- Luiz Augusto von Dentz -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html