Hey Eric,
(you might as well post these to the mailing list so that we can keep track of 
them... and so others can correct me when I'm wr^H^H ... mistaken)


>> In the CO_PACKAGE table, there is an id field. What type is this field 
>> supposed to be and where does it come from? (autogen by mkPackage, autogen 
>> by previous part of CoApp toolchain or set by the developer)


>> Are CoApp package IDs globally unique? If I say I want package with ID 1, I 
>> can be safe knowing no other package from any repo will have that ID? Are 
>> these the IDs you had mentioned should be generated in a consistent manner, 
>> say with MD5 hashes of name, version, architecture and I assume the 
>> developer's public key?

I think ID was intended to be a GUID generated as an MD5 of the {name + arch + 
version + publickeytoken}. Let's go with that assumption right now.


>>How does name and display_name differ?

Display name I believe was cosmetic in nature so possibly "Mozilla Firefox" 
whereas the name would just be "firefox" .

>>What is author_version in CO_PACKAGE_PROPERTY and how is that different from 
>>version in CO_PACKAGE?

Author version may be slightly different due to the way the original project 
names their versioning OpenSSL for example has stuff like 0.98k ... whereas our 
versions must be <num>.<num>.<num>.<num> where each num is 0-65535... This is 
dictated by the way .NET and WinSxS assemblies are versioned.

>> -What does CO_URL correspond to and what goes in 'type'?

There are several URLs associated with things... package location, original 
project page, Launchpad page, that type of thing. Type is just the type of 
URL-I suppose we should have a canonical list of what types we use.

>> - Do CO_ROLE, CO_TAG and CO_BINDING_POLICY actually get their 
>> FK_package_id's from CO_PACKAGE_PROPERTIES? That's what the diagram shows 
>> but it doesn't really make sense to me why that'd be. :)

The FK_package_id is the foreign key for the package id... which is simply the 
ID field in the CO_PACKAGE table.
FK_role_id is just the ID of the CO_ROLE table.


>> - Do we just allow any string into CO_ROLE flavor or does it have to be one 
>> of the ones we've already come up with like "debugging" and "pgo"?


Yeah, flavor is pretty flexible. It's wide open at this point.

>> Can there be multiple roles of the same type but different flavor in a 
>> package? Also can flavor be null?

Hmmm. Yes, it can be null. I suppose that multiple flavors can be in the same 
package. Not entirely sure that's thought out all the way tho.

>> - What is the type column of CO_LICENSE for?

I'm ... not... sure...

>> - What does CO_BINDING_POLICY do?

Ah, this allows us to say what this package supersedes.  (this is a concept 
from WinSxS) - we can say that version "1.1.150.77" is a replacement for 
versions "1.1.0.0" to "1.1.150.76"

>> - What does CO_TAG and its columns hold? Keywords or some sort?
Yeah, just for keyword tagging: "editor" "browser", etc...

>> - Is CO_DEPENDENCY id a GUID or sequentially created int? Same with CO_ROLE 
>> id and CO_URL id.

Let's assume GUID. I think.

>> - Is there a need for CO_DEPENDENCY to have an FK_package_child_id? Won't 
>> that always be the package id in a given msi?

You are probably correct.

>> - CO_INSTALL_PROPERTIES: You're going to have to totally explain it cuz I've 
>> got no idea :)

At this point in time, this is just the list of symbolic links that the engine 
creates at the end of installation.  It's going to be more complicated in the 
future, but for now assume that's all this is.

Enjoy your Thursday morning :)

Eric

Garrett Serack | Open Source Software Developer | Microsoft Corporation
I don't make the software you use; I make the software you use better on 
Windows.


_______________________________________________
Mailing list: https://launchpad.net/~coapp-developers
Post to     : coapp-developers@lists.launchpad.net
Unsubscribe : https://launchpad.net/~coapp-developers
More help   : https://help.launchpad.net/ListHelp

Reply via email to