Hi again,

Continuing where I left off.

>        <sect id="unpackphase">
>       <heading>Details of unpack phase of installation or upgrade</heading>
[...]
> @@ -4540,31 +4595,29 @@       <chapt id="relationships">
>       </p>
>  
>       <p>
> -       For this reason packages in an installation run are usually
> -       all unpacked first and all configured later; this gives
> -       later versions of packages with dependencies on later
> -       versions of other packages the opportunity to have their
> -       dependencies satisfied.
> +       Since <tt>Depends</tt> only places requirements on the
> +       configuration step, packages in an installation run are usually
> +       all unpacked first and all configured later.  This makes it
> +       easier to satisfy all dependencies when multiple packages are
> +       being upgraded.
>       </p>

The new second sentence is less specific than the anthropomorphizing
original.  Intended?

[...]
> -       The <tt>Depends</tt> field thus allows package maintainers
> -       to impose an order in which packages should be configured.
>       </p>

Is this removal intended?

[...]
> @@ -4588,12 +4642,16 @@     <sect id="binarydeps">
>  
>             <p>
>               The <tt>Depends</tt> field should also be used if the
> -             <prgn>postinst</prgn>, <prgn>prerm</prgn> or
> -             <prgn>postrm</prgn> scripts require the package to be
> -             present in order to run.  Note, however, that the
> -             <prgn>postrm</prgn> cannot rely on any non-essential
> -             packages to be present during the <tt>purge</tt>
> -             phase.
> +             <prgn>postinst</prgn> or <prgn>prerm</prgn> scripts
> +             require the package to be unpacked or configured in order
> +             to run.

Huh?

postinst in the normal case requires the package being installed to be
unpacked and all its dependencies to be configured.  prerm requires
the package being removed to be halfconfigured.

I think part of my confusion is because:

 * this item is supposed to be about what the Depends field can
   be used to accomplish, not what requirements postinst and
   preinst have;

 * before, “the package” meant the package depended on, but now
   it means the package being installed or removed.

>                        In the case of <prgn>postinst</prgn>, the
> +             depended-on packages will be unpacked and configured
> +             first.  (If both packages are involved in a dependency
> +             loop, this might not work as expected; see the explanation
> +             a few paragraphs back.)  In the case
> +             of <prgn>prerm</prgn>, the package dependencies will be at
> +             least unpacked or "Half-Installed".
> +           </p>

So maybe something roughly like

        <p>
          The <tt>Depends</tt> field should also be used if the
          <prgn>postinst</prgn> or <prgn>prerm</prgn> scripts require
          the package to be present in order to run.  See the descriptions
          of postinst and prem in section 6.5 for details.[1]
        </p>

        [1] In the case of <prgn>postinst</prgn> <tt>configure</tt>,
        the depended-on packages will be unpacked and configured
        before the script is run.  When <prgn>postinst</prgn> or
        <prgn>prerm</prgn> is called for some other reason, the
        depended-on packages will have been unpacked and fully
        configured at some point since they were last removed, but
        they may have been deconfigured since then or even left
        "Half-Installed" after a partial upgrade.

would be less confusing.

> @@ -4652,11 +4710,21 @@ Build-Depends: foo [linux-any], bar [any-i386], baz 
> [!linux-any]
>             </p>
>  
>             <p>
> -             When the package declaring a pre-dependency is about
> -             to be <em>configured</em>, the pre-dependency will be
> -             treated as a normal <tt>Depends</tt>, that is, it will
> -             be considered satisfied only if the depended-on
> -             package has been correctly configured.
> +             When the package declaring a pre-dependency is about to
> +             be <em>configured</em>, the pre-dependency will be treated
> +             as a normal <tt>Depends</tt>.  It will be considered
> +             satisfied only if the depended-on package has been
> +             correctly configured.  However, unlike
> +             with <tt>Depends</tt>, <tt>Pre-Depends</tt> does not
> +             permit circular dependencies to be broken.  If a circular
> +             dependency is encountered while attempting to honor
> +             <tt>Pre-Depends</tt>, the installation will be aborted.
> +           </p>

Nice.

> +
> +           <p>
> +             <tt>Pre-Depends</tt> are also required if the
> +             <prgn>preinst</prgn> script depends on the named package.
> +             It is best to avoid this situation if possible.
>             </p>

This moves the instruction to above the warning, so the final
paragraph can emphasize that Pre-Depends should be avoided.
Makes sense.

> @@ -4696,7 +4757,7 @@     <sect id="breaks">
>       <p>
>         When one binary package declares that it breaks another,
>         <prgn>dpkg</prgn> will refuse to allow the package which
> -       declares <tt>Breaks</tt> be installed unless the broken
> +       declares <tt>Breaks</tt> be unpacked unless the broken
>         package is deconfigured first

Oh!  That’s true, and a very useful clarification.

>                                      , and it will refuse to
>         allow the broken package to be reconfigured.
>       </p>
> @@ -4749,7 +4810,7 @@     <sect id="conflicts">
>       <p>
>            When one binary package declares a conflict with another
>         using a <tt>Conflicts</tt> field, <prgn>dpkg</prgn> will
> -       refuse to allow them to be installed on the system at the
> +       refuse to allow them to be unpacked on the system at the
>         same time.  This is a stronger restriction than <tt>Breaks</tt>,
>         which just prevents both packages from being configured at the
>         same time.  Conflicting packages cannot be unpacked on the

Whoops.

              This is a stronger restriction than <tt>Breaks</tt>,
        which only prevents the broken package from being configured at
        the same time as the breaking package is unpacked.

> @@ -4757,8 +4818,8 @@     <sect id="conflicts">
>       </p>
>  
>       <p>
> -       If one package is to be installed, the other must be removed
> -       first.  If the package being installed is marked as replacing
> +       If one package is to be unpacked, the other must be removed
> +       first.  If the package being unpacked is marked as replacing
>         (see <ref id="replaces">, but note that <tt>Breaks</tt> should
>         normally be used in this case) the one on the system, or the one
>         on the system is marked as deselected, or both packages are

Yep.

With whatever subset of the above changes seems appropriate, this
looks good to me.

Regards,
Jonathan



--
To UNSUBSCRIBE, email to debian-policy-requ...@lists.debian.org
with a subject of "unsubscribe". Trouble? Contact listmas...@lists.debian.org
Archive: http://lists.debian.org/20100720235904.ga4...@burratino

Reply via email to