Scroll to navigation

debhelper(7) Debhelper debhelper(7)

NOME

debhelper-compat-upgrade-checklist - Actualiza a lista de verificação para níveis de compatibilidade do debhelper suportados.

RESUMO

Este documento é uma lista de verificação de actualização para todos os níveis de compatibilidade do debhelper suportados. Também lista todos os níveis de compatibilidade de debhelper suportados.

Informação sobre como declarar os níveis de compatibilidade está em "NÍVEIS DE COMPATIBILIDADE" in debhelper(7).

Se você está a actualizar a partir de um nível de compatibilidade (agora) obsoleto, então por favor consulte debhelper-obsolete-compat(7).

DESCRIÇÃO

Actualizar lista de verificação para os níveis de compatibilidade suportados.

Estes são os níveis de compatibilidade disponíveis:

Este nível de compatibilidade ainda está aberto em desenvolvimento; use com cuidado.

As alterações a partir de v14 são:

  • The single-binary add-on for dh is no longer implicitly activated by source packages that have a single Package stanza in debian/control. If the package needs the short-cuts for single-binary packages, it must explicitly activate the single-binary add-in.

    This can be done via a Build-Depends on dh-sequence-single-binary.

    Any --without single-binary passed to dh to avoid the warning in compat 14 can now be removed to simplify debian/rules without triggering the warning.

  • Agora é um erro usar versões sem-pacote dos ficheiros de configuração do debhelper quando existem 2 ou mais pacotes binário listados em debian/control na maioria dos casos. Ficheiros legados devem ser renomeados para debian/pacote.foo (de debian/foo) onde pacote é o primeiro pacote binário listado em debian/control.

    A principal excepção a esta alteração são ficheiros como debian/changelog, debian/NEWS, e debian/copyright, onde o mesmo ficheiro é usado para todos os pacotes por predefinição. Estes casos irão continuar inalterados.

  • It is now an error to use a packaging file without the package prefix for --name even if the source package only produces one binary package. As example, if you had a debian/bar.service with the following snippet in debian/rules:

     override_dh_installsystemd:
        dh_installsystemd -p foo --name bar
        

    Then you need to rename debian/bar.service to debian/foo.bar.service.

Este nível de compatibilidade ainda está aberto em desenvolvimento; use com cuidado.

As alterações a partir de v13 são:

  • A ferramenta dh_installpam irá agora instalar ficheiros de configuração do PAM sob /usr/lib/pam.d/package em vez de /etc/pam.d/package.

    Por favor considere usar a funcionalidade "rm_conffile" de dh_installdeb(1) para assegurar a remoção apropriada dos ficheiros PAM anteriores.

  • Pacotes que usam o sequenciador dh devem estar conscientes das seguintes alterações:
  • The order and placement has changed for dh_strip_nondeterminism, dh_compress, and dh_fixperm. Previously, these three commands were run in the listed order between dh_installxfonts and dh_missing.

    Their new placement is after dh_missing (arch:all) or dh_shlibdeps (arch:any) and before dh_installdeb. Additionally, their new order is dh_fixperms, dh_strip_nondeterminism, and then dh_compress.

    This change may require updates to third-party add-ons that use either of these three commands as anchor or to hook targets for any of these commands that made assumptions about the command order.

    Additionally, dh_strip_nondeterminism and dh_compress plus any commands added by third-party add-ons using these as anchors will no longer be able to rely on the mode/ownership normalization by dh_fixperms, which may expose bugs in the form of incorrect mode or ownership in the resulting binary package.

    Please file any such bugs against the relevant tool. Feel free to include the debhelper maintainers in CC.

  • A ferramenta dh_installsysusers está agora incluída na sequência predefinida. Esta ferramenta de ajuda irá processar ficheiros sysusers do systemd.
  • A ferramenta dh_installsystemduser irá predefinir para activar unidades de utilizador de systemd, arranca-los na instalação, reinicia-los nas actualizações e para-los ao desinstalar o pacote.
  • Usar o comando dh_gconf em alvos de sobreposição e hook agora causa um erro. O comando dh_gconf foi um não-operativo durante anos e foi removido no debhelper 13.4.
  • A ferramenta dh_installalternatives irá agora correr após dh_link em vez de após dh_installinitramfs na sequência predefinida do dh.
  • Este item apenas se aplica a pacotes fonte que têm exactamente uma estrofe Package em debian/control.

    The dh_auto_install command now unconditionally uses --destdir=debian/tmp by default. The special-case for source packages building a single binary package is now moved to single-binary dh addon. Note, this add-on is activated by default in compat 14 but not in compat 15 (see next bullet item).

  • Este item apenas se aplica a pacotes fonte que têm exactamente uma estrofe Package em debian/control.

    The dh sequencer will warn if the single-binary addon is implicitly activated to warn maintainers of the pending compat 15 change in dh_auto_install. The implicit activation is a transitional feature to reduce the changes of risks with this change. In compat 15, the implicit activation will no longer trigger.

    Maintainers são incentivados a ou activar explicitamente o addon single-binary para preservar o comportamento existente (ex. ao adicionar <dh-sequence-single-binary> a Build-Depends), ou passar explicitamente --destdir a dh_auto_install se usado e depois passar --without single-binary a dh (a última para silenciar o aviso).

    A razão para esta alteração é evitar "surpresas" ao adicionar um segundo pacote binário mais tarde. Anteriormente, o debhelper iria em silêncio alterar o comportamento muitas vezes resultado em pacotes binários vazios a serem enviados para o arquivo por engano. Com o novo comportamento, o addon single-binary irá detectar a discrepância e avisar o maintainer do que está prestes a acontecer.

-
A ferramenta dh_gencontrol agora aplica automaticamente relacionamentos substvars aos campos relevantes. Isto significa que muitos substvars como ${misc:Depends} e ${shlibs:Depends} já não precisam de ser mencionados explicitamente no debian/control. Isto aplica-se a qualquer substvar nomeado após um campo que a versão instalada do dpkg considere um campo de relação ou tipo-dependência. Na altura desta escrita, a lista consiste de:
  • Pré-Dependências
  • Dependências
  • Recomendações
  • Sugestões
  • Melhorias
  • Conflitos
  • Quebras
  • Substituições
  • Fornecimentos
  • Utilização-Built
  • Utilização-Built-Estático

Isto significa que Depends: foo, ${misc:Depends} em debian/control pode agora ser reduzido a Depends: foo e Depends: ${misc:Depends}, ${shlibs:Depends} pode ser removido inteiramente como exemplos de como a funcionalidade trabalha.

Note que outros substvars como ${binary:Version} não são afetados por esta alteração e devem ainda ser usados explicitamente como necessário. Adicionalmente, para pacotes Essential: yes que promovem manualmente ${shlibs:Depends} no campo <Pre-Depends>, dh_shlibdeps irá lidar com isto automaticamente também (veja o próximo item de compatibilidade).

Veja <https://lists.debian.org/debian-devel/2024/02/msg00230.html> para os detalhes desta sugestão. O sumário em <https://lists.debian.org/debian-devel/2024/03/msg00030.html> também fala de quando os substvars precisam ser afinados. Os casos mais comuns envolvem usar a opção -d de dpkg-shlibdeps possivelmente via dh_shlibdeps.

Nota: Esta alteração irá causar falso-positivos a partir de um lintian(1) não corrigido. Por favor verifique <https://bugs.debian.org/1067653> para suporte do lintian(1) a esta alteração.

  • A ferramenta dh_shlibdeps agora está predefinida para usar ${shlibs:Pre-Depends} para pacotes que são Essential: yes.

    Nota devido à alteração dh_gencontrol acima, qualquer pacote que use dh_gencontrol não terá de fazer nada para esta migração.

  • When running dh_auto_install, debhelper provided build systems. will now ensure all paths in the destdir have minimal user permissions (chmod -R u+rwX) to avoid weird permission denied errors during builds.

    Third-party provided debhelper build systems are recommended to support this as well. This can be done by running

         $this->ensure_minimal_permissions($destdir) if not compat(13);
        

    in the debhelper Buildsystem code from their sub install implementation after the upstream code has been run.

    If you are not using dh_auto_install and you run into weird permission denied errors, you can often solve this by running chmod -R u+rwX DIRECTORY after running the install target from the upstream build system.

    Please take care to check if your package has any special cases for permissions where files or directories for some reason must not have the "user write bit" set. Known cases are *.ali files and /etc/sudoers.d, which dh_fixperms will fix up by default.

    The problem with uncommon permissions have always been present in theory. However, it has become considerable more visible with dh_fixperms being run later in the sequence as of compat 14 and with the move to remove fakeroot by default (which papered over some of these issues). This change is aimed at mitigating the problem.

  • The debhelper configuration files are subject to the following changes:
  • Agora dispara um aviso para usar versões sem-pacote dos ficheiros de configuração do debhelper quando existem 2 ou mais pacotes binário listados em debian/control na maioria dos casos. Ficheiros legados devem ser renomeados para debian/pacote.foo (de debian/foo) onde pacote é o primeiro pacote binário listado em debian/control.

    A principal excepção a esta alteração são ficheiros como debian/changelog, debian/NEWS, e debian/copyright, onde o mesmo é usado para todos os pacotes por predefinição. Estes casos irão continuar inalterados. A ferramenta debhelper que usa os ficheiros irá disparar avisos durante a utilização.

    Em compatibilidade 15 (ou posterior), isto é mudado para um erro.

  • It now triggers a warning to use a packaging file without the package prefix for --name even if the source package only produces one binary package. As example, if you had a debian/bar.service with the following snippet in debian/rules:

     override_dh_installsystemd:
        dh_installsystemd -p foo --name bar
        

    Then you need to rename debian/bar.service to debian/foo.bar.service.

    Em compatibilidade 15 (ou posterior), isto é mudado para um erro.

  • The default look up rules for Dh_Lib based tools now assume that configuration files are no longer named (--name) nor support architecture restrictions by default. If you work with a third-party debhelper-like tool and need support for either of these features, please file a bug against the tool asking it to declare its configuration file with the relevant options in its pkgfile call.

    Note that debhelper itself tweaked its rules for most of its tools as well based on analysis of usage via codesearch.debian.org. Should you be relying on a feature like architecture restrictions for a given config file that is no longer supported, please file a feature request for the use-case and it might be restored.

-
Pacotes que usam o sistema de compilação cmake devem estar conscientes das seguintes alterações:
  • O sistema de compilação cmake agora passa -DCMAKE_BUILD_RPATH_USE_ORIGIN=ON a cmake(1) para evitar alguns problemas de reprodutibilidade.
  • O sistema de compilação cmake agora define a variável de ambiente ASMFLAGS quando não está definida e ASFLAGS está presente. O nome anterior (ASMFLAGS) é o nome que o cmake espera, enquanto o posterior (ASFLAGS) é o nome que o dpkg-buildpackage(1) usa.
  • Os sistemas de compilação cmake agora usam cmake --install em vez de ninja install e na chamada dh_auto_install(1). Qualquer sobreposição de dh_auto_install que passe parâmetros extra ao sistema de compilação do autor deve ser revista.
-
Pacotes que usam o sistema de compilação meson devem estar conscientes das seguintes alterações:
  • O sistema de compilação meson agora passa --auto-features=enabled ao meson.
  • O sistema de compilação meson+ninja agora usa meson install em vez de ninja install na chamada dh_auto_install(1). Qualquer sobreposição de dh_auto_install que passe parâmetros extra ao sistema de compilação do autor deve ser revista.
  • O ficheiro debian/compat não e mais aceite como fonte para especificar o nível de compatibilidade do debhelper. Ponha o nível de compatibilidade no campo X-DH-Compat da estrofe Source do debian/control.

    Nota para evitar quebrar pacotes que já migraram para compatibilidade 14 imediatamente, enquanto era experimental esta alteração era primeiro forçada quando a compatibilidade 14 se tornava estável.

  • A ferramenta dh_installtmpfiles agora corre com --remove na remoção do pacote, e --purge na purga do pacote. É requerido systemd v256 para o posterior.
  • The dh_lintian tool no longer accepts architecture specific overrides files for packages with Multi-Arch: same in debian/control, since these would not be co-installable. Instances affected by this error should migrate to lintian(1) architecture specific overrides.
Este é o modo de operação recomendado.

As alterações a partir de v12 são:

  • O sistema de compilação meson+ninja agora usa meson test em vez de ninja test quando corre a suite de testes. Qualquer sobreposição de dh_auto_test que passe parâmetros extra ao testador original do autor deve ser revista, pois o meson test não é compatível em linha de comandos com o ninja test.
  • Todas as ferramentas tipo debhelper baseadas na biblioteca debhelper oficial (incluindo dh e as ferramentas oficiais dh_*) não aceitam mais parâmetros abreviados de comandos. Ao mesmo tempo, dh agora optimiza as chamadas a ajudantes redundantes dh_* mesmo quando passa opções longas da linha de comandos.
  • As ferramentas debhelper relacionadas com ELF (dh_dwz, dh_strip, dh_makeshlibs, dh_shlibdeps) são agora apenas executadas para os pacotes dependentes de arquitectura por predefinição (isto é, estão excluídas de alvos *-indep e são passadas -a por predefinição). Se você precisar delas para alvos *-indep, você pode adicionar um Build-Depends explícito em dh-sequence-elf-tools.
  • O sistema de compilação de terceiros gradle (do pacote gradle-debian-helper) agora corre a suite de testes disponibilizada pelo autor automaticamente. Para suprimir tal comportamento, sobreponha dh_auto_test.
  • A ferramenta dh_installman agora aborta se vir definições conflituosas de uma manpage. Isto tipicamente acontece se o sistema de compilação do autor está a instalar uma versão comprimida e o pacote lista uma versão descomprimida da manpage em debian/package.manpages. Muitas vezes a correção mais fácil é remover a manpage de debian/package.manpages (assumindo que ambas as versões são idênticas).
  • The dh_auto_* helpers now reset the environment variable HOME and the common XDG_* variables. Please see description of the environment variables in "ENVIRONMENT" in debhelper(1) for how this is handled.

    Esta funcionalidade mudou entre debhelper 13 e debhelper 13.2.

  • O comando dh ir+a agora dar erro se estiver presente um alvo de sobreposição ou hook para um comando obsoleto em debian/rules (ex.override_dh_systemd_enable:).
  • O comando dh_missing irá agora usar por predefinição --fail-missing. Isto pode ser revertido para um aviso não fatal ao passar explicitamente --list-missing como era na compatibilidade 12.

    Se você também não quiser o aviso, por favor omita a chamada ao dh_missing. Se você usar o sequenciador de comandos dh, então pode fazer isto ao inserir um alvo de sobreposição vazio no ficheiro debian/rules do pacote relevante. Como exemplo:

        # Disable dh_missing
        override_dh_missing:
        
  • O sequenciador de comandos dh agora corre dh_installtmpfiles na sequência predefinida. O dh_installtmpfiles assume o manusear dos ficheiros de configuração tmpfiles.d. A funcionalidade relacionada em dh_installsystemd está agora desactivada.

    Note que dh_installtmpfiles responde a debian/package.tmpfiles onde dh_installsystemd usou um nome sem o "s" final.

  • Muitas ferramentas dh_* agora suportam expansão de variáveis limitada via sintaxe ${foo}. Em muitos casos, isto pode ser usado para referenciar caminhos que contêm ou espaços ou valores dpkg-architecture(1). Enquanto isto pode reduzir a necessidade de dh-exec(1) em alguns casos, não é um substituto de dh-exec(1) em geral. Se você precisar de filtrar, renomear, etc... o pacote irá continuar a precisar de dh-exec(1).

    Por favor veja "Substituições em ficheiros de configuração do debhelper" para sintaxe e variáveis de substituição disponíveis. Para os escritores da ferramenta dh_*, a expansão de substituição ocorre como parte das funções filearray e filedoublearray.

  • O sequenciador de comandos dh irá agora saltar todos os alvos hook e de sobreposição para dh_auto_test, dh_dwz e dh_strip quando DEB_BUILD_OPTIONS listar as opções nocheck / nostrip relevantes.

    Qualquer pacote que se apoie nestes alvos para ser sempre corrido deve, em vez disto, mover a lógica relevante para fora destes alvos. Ex, código de empacotamento não relacionado com testes a partir de override_dh_auto_test deverá ser movido para execute_after_dh_auto_build ou execute_before_dh_auto_install.

  • O sistema de compilação cmake agora passa -DCMAKE_SKIP_INSTALL_ALL_DEPENDENCY=ON ao cmake(1) para acelerar o processo de instalação automática. Se por alguma razão você precisar do comportamento anterior, sobreponha a flag:

        dh_auto_configure -- -DCMAKE_SKIP_INSTALL_ALL_DEPENDENCY=OFF ...
        
As alterações a partir de v11 são:
  • A ferramenta dh_makeshlibs agora gera ficheiros shlibs com dependência de versão por predefinição. Isto significa que -VUpstream-Version (a.k.a. -V) é agora a predefinição.

    Se é pedida uma dependência sem versão no ficheiros shlibs, isto pode ser conseguido ao passar -VNone em substituição. No entanto, por favor veja dh_makeshlibs(1) para a problemática das dependências sem versão.

  • A opção -s (--same-arch) foi removida. Por favor use -a (--arch) em vez desta.
  • Invocar dh_clean -k agora causa um erro em vez de um aviso de descontinuação.
  • A opção --no-restart-on-upgrade em dh_installinit foi removida. Por favor use o novo nome --no-stop-on-upgrade
  • Existia um bug nas funções doit (e similares) a partir de Debian::Debhelper::Dh_Lib que fazia aparece uma linha de comandos numa circunstância particular. Este bug foi agora removido e irá fazer com que os ajudantes que contavam com esse bug falhem com um erro de "comando não encontrado".
  • O --list-missing e --fail-missing em dh_install foram removidos. Por favor use dh_missing e as suas opções correspondentes, o qual pode também ver os ficheiros instalados por outros ajudantes.
  • O ajudante dh_installinit já não instala configuração para o sistema de init upstart. Em vez disso, irá abortar a compilação se encontrar um ficheiro de configuração upstart antigo. O erro está lá para lembrar ao maintainer do pacote para assegurar a remoção apropriada dos ficheiros de configuração empacotados em versões anteriores do pacote (caso existam).
  • A ferramenta dh_installdeb irá fazer validação básica de alguns comandos dpkg-maintscript-helper(1) e irá terminar em erro se os comandos parecerem ser inválidos.
  • A ferramenta dh_missing irá agora usar por predefinição --list-missing.
  • A ferramenta dh_makeshlibs irá agora apenas passar bibliotecas para dpkg-gensymbols(1) se o binário ELF tiver um SONAME (contendo ".so").
  • A ferramenta dh_compress não mais comprime exemplos (isto é, nada instalado em </usr/share/doc/pacote/examples>.)
  • A sequência standard em dh agora inclui dh_dwz e dh_installinitramfs por predefinição. Isto tornas as sequências dwz e installinitramfs obsoletas e elas agora irão falhar com um erro. Se desejar saltar estes comandos, por favor insira um alvo de sobreposição vazio para eles em debian/rules (ex. override_dh_dwz:)
  • Os sistemas de compilação meson e autoconf não mais definem explicitamente a variável --libexecdir e assim apoia-se na predefinição do sistema de compilação - O qual deve ser /usr/libexec (por FHS 3.0, adoptado em Debian Policy 4.1.5).

    Se um determinado pacote original do autor não usar a predefinição correcta, o parâmetro pode muitas vezes ser passado manualmente via dh_auto_configure(1). Por exemplo via seguinte exemplo:

        override_dh_auto_configure:
            dh_auto_configure -- --libexecdir=/usr/libexec
        

    Note o -- antes do parâmetro --libexecdir.

  • Retroativamente removido em debhelper/13.5:

    A ferramenta dh_installdeb não iria mais instalar o ficheiro conffiles fornecido pelo responsável pois isso foi considerado desnecessário. No entanto, o remove-on-upgrade do dpkg/1.20 tornou o ficheiro relevante de novo e dh_installdeb agora instala-o nos níveis de compatibilidade 12+.

  • A ferramenta dh_installsystemd não mais se apoia em dh_installinit para lidar com os serviços do systemd que têm uma alternativa de sysvinit. ambas ferramentas devem agora ser usadas em tais casos para assegurar que o serviço é arrancado correctamente sob ambos sysvinit e systemd.

    Se tiver uma sobreposição para dh_installinit (ex. para chama-lo com --no-start) então irá provavelmente precisar agora também de um para dh_installsystemd.

    Esta alteração faz dh_installinit injectar um misc:Pre-Depends para init-system-helpers (>= 1.54~). Por favor assegure que o pacote lista ${misc:Pre-Depends} no seu campo Pre-Depends antes de actualizar para a compatibilidade 12.

  • Esta ferramenta de terceiros dh_golang (do pacote dh-golang) agora por predefinição honra a variável DH_GOLANG_EXCLUDES para instalação fonte em pacotes -dev e não apenas durante o processo de compilação. Por favor defina DH_GOLANG_EXCLUDES_ALL para falso para reverter para o comportamento anterior. Veja Debian::Debhelper::Buildsystem::golang(3pm) para detalhes e exemplos
  • dh_installsystemduser é agora incluído na sequência standard do dh por predefinição.
  • O sistema de compilação python-distutils foi agora removido. Por favor use o sistema de compilação de terceiros pybuild em substituição.
Este modo está desencorajado.

A compatibilidade 11 é desencorajada para novos pacotes pois sofre de interação de características entre dh_installinit e dh_installsystemd o que causa com que os serviços não funcionem correctamente em alguns casos. Por favor considere usar modo de compatibilidade 10 ou 12 em vez deste. Mais detalhes sobre este problema estão disponíveis em Debian#887904 e <https://lists.debian.org/debian-release/2019/04/msg01442.html>.

As alterações a partir de v10 são:

  • dh_installinit já não instala ficheiros service ou tmpfile, nem gera scripts do maintainer para esses ficheiros, Por favor use o novo ajudante dh_installsystemd
  • Os ajudantes dh_systemd_enablee dh_systemd_start foram substituídos pelo novo ajudante dh_installsystemd. Pela mesma razão, a sequência do systemd para dh foi também removida. Se você precisar de desactivar a ferramenta de ajuda dh_installsystemd, por favor use um alvo de sobreposição vazio.

    Por favor note que a ferramenta dh_installsystemd tem um comportamento ligeiramente diferente em alguns casos (ex. quando se usa o parâmetro --name).

  • dh_installdirs já não cria directórios debian/pacote a menos que tal seja explicitamente pedido (ou se tiver de criar um sub-directório nele).

    A grande maioria dos pacotes não serão afectados por esta alteração.

  • O sistema de compilação makefile agora passa INSTALL="install --strip-program=true" para o make(1). Sistemas de compilação derivativos (ex. configure ou cmake) não são afectados por esta alteração.
  • O sistema de compilação autoconf agora passa --runstatedir=/run para ./configure.
  • O sistema de compilação cmake agora passa -DCMAKE_INSTALL_RUNSTATEDIR=/run para cmake(1).
  • dh_installman irá agora preferir detectar a linguagem a partir do nome de caminho em vez de a extensão.
  • dh_auto_install irá agora apenas criar o directório de destino que precisa. Anteriormente, iria criar o directório de compilação de pacote para todos os pacotes. Isto não vai afectar pacotes que apenas compilam com comandos debhelper, mas pode expor bugs em comandos não incluídos no debhelper.
  • Os ajudantes dh_installdocs, dh_installexamples, dh_installinfo, e dh_installman agora dão erro se a sua configuração tiver um padrão que não coincida com nada ou faça referência a um caminho que não exista.

    Excepções conhecidas incluem compilar com o perfil nodoc, onde as ferramentas de cima irão permitir em silêncio correspondências falhadas onde os padrões são usados para especificar documentação.

  • Os ajudantes dh_installdocs, dh_installexamples, dh_installinfo, e dh_installman agora aceitam o parâmetro --sourcedir com o mesmo significado que dh_install. Mais ainda, eles agora também retornam (em fall back) a debian/tmp como dh_install.

    Nota de migração: Um bug no debhelper 11 até ao 11.1.5 faz com que dh_installinfo ignore incorrectamente --sourcedir.

  • Os sistemas de compilação perl-makemaker e perl-build já não passam -I. ao perl. Os pacotes que dependem deste comportamento podem muitas vezes usar a variável de ambiente PERL5LIB como substituto. Ex. ao adicionar export PERL5LIB=. no seu ficheiro debian/rules (ou semelhante).
  • A variável de ambiente PERL_USE_UNSAFE_INC já não é definida pelo dh ou nenhuma das ferramentas dh_auto_*. Ela foi adicionada como um meio de contorno temporário evitar muitos pacotes a falharem a compilação ao mesmo tempo.

    Note que este item irá eventualmente tornar-se obsoleto pois o auto pretende abandonar o suporte para a variável de ambiente PERL_USE_UNSAFE_INC. Quando o perl abandonar o para ala, então esta variável será também removida retroactivamente dos níveis de compatibilidade existentes.

  • O ajudante dh_makeshlibs irá agora terminar em erro se objdump retornar uma saída não-zero a partir da análise de um determinado ficheiro.
  • As ferramentas dh_installdocs e dh_installexamples podem agora instalar a maioria da documentação num caminho diferente para cumprir com a recomendação da política Debian §12.3 (desde versão 3.9.7).

    Note que um dado pacote fonte apenas contém um único pacote binário em debian/control ou nenhum dos pacotes são pacotes -doc, então esta alteração não é relevante para esse pacote fonte e você pode saltar a próxima alteração.

    Por predefinição, estas ferramentas irão agora tentar determinar um "pacote principal para a documentação" (chamado um doc-main-package daqui em diante) para cada pacote -doc. Se encontrarem o tal doc-main-package, irão agora instalar a documentação em /usr/share/doc/doc-main-package no pacote doc fornecido. Isto é, o caminho pode mudar mas a documentação será na mesma enviada no pacote -doc.

    A opção --doc-main-package pode ser usada quando a auto-detecção é insuficiente ou para reiniciar o caminho para o seu valor anterior se existir razão para divergir da recomendação da política Debian.

    Alguma documentação não será afectada por esta alteração. Estas excepções incluem o ficheiro copyright, ficheiros changelog, README.Debian, etc. Estes ficheiros serão na mesma instalados no caminho /usr/share/doc/pacote.

  • As ferramentas dh_strip e dh_shlibdeps já não usam mais padrões de nomes de ficheiros para determinar quais ficheiros processar. Em vez disso, elas abrem o ficheiro e procuram um cabeçalho ELF para determinar se um dado ficheiro é um objecto partilhado ou um executável ELF.

    Esta alteração fazer com que as ferramentas processem mais ficheiros que anteriormente.

As alterações a partir de v9 são:
  • dh_installinit não irá mais instalar um ficheiro chamado debian/pacote como um script de iniciação (init).
  • O dh_installdocs irá dar erro se detectar links criados com --link-doc entre pacotes de arquitectura "all" e não-"all" porque isso faz quebrar binNMUs.
  • O dh_installdeb já não instala um ficheiro debian/pacote.shlibs disponibilizado pelo maintainer. Em vez disso, isto agora é feito pelo dh_makeshlibs.
  • O dh_installwm recusa-se a criar um pacote quebrado se não encontrar nenhuma página de manual (necessário para registo para a alternativa do x-window-manager).
  • Debhelper irá predefinir para --parallel em todos os sistemas de compilação que suportam compilação paralela. Isto pode ser desactivado usando --no-parallel ou passando --max-parallel com o valor de 1.
  • O comando dh não irá aceitar nenhum dos parâmetros de "controle de sequência manua" descontinuados (--before, --after, etc.). Por favor utilize alvos de sobreposição em vez destes.

    Retroactively applied to earlier compat levels: dh já não aceita nenhum destes desde o debhelper/12.4.

  • O comando dh não irá mais usar ficheiros log para seguir quais comandos foram executados. O comando dh ainda mantêm o seguimento se já correu a sequência de "compilação" e salta-a se já o fez.

    Os principais efeitos disto são:

  • Com isto, é agora mais fácil de depurar as sequências install ou/e binary porque agora podem ser trivialmente re-executadas (sem ter que fazer um ciclo de "limpar e recompilar" completo.
  • O principal embargo é que dh_* agora apenas mantêm acompanhamento do que aconteceu num alvo de sobreposição singular. Quanto todas as chamadas a um dado comando dh_cmd acontecem no mesmo alvo de sobreposição tudo irá funcionar como dantes.

    Exemplo de onde pode falhar:

      override_dh_foo:
        dh_foo -pmy-pkg
      override_dh_bar:
        dh_bar
        dh_foo --remaining
        

    Neste caso, a chamada a dh_foo --remaining irá também incluir my-pkg, desde que dh_foo -pmy-pkg tenha corrido num alvo de sobreposição separado. Este problema não está imitado a --remaining, mas também inclui -a, -i, etc.

  • O comando dh_installdeb agora faz "escape de shell" às linhas no ficheiro de configuração de maintscript. Esta foi a intenção original mas não trabalhava correctamente e os pacotes começaram a confiar no "escapar de shell" incompleto (ex. ao mencionar nomes de ficheiros).
  • O comando dh_installinit agora usa por predefinição --restart-after-upgrade. Para pacotes que precisam do comportamento anterior, por favor use --no-restart-after-upgrade.
  • A sequência autoreconf é agora activada por predefinição. Por favor passe --without autoreconf ao dh se isto não for desejável para um determinado pacote
  • A sequência systemd é agora activada por predefinição. Por favor passe --without systemd ao dh se isto não for desejável para um determinado pacote.
  • Retroactively removed dh já não cria o directório de compilação do pacote quando salta a execução de comandos debhelper. Isto não vai afectar pacotes que apenas compilam com comandos debhelper, mas pode expor bugs em comandos não incluídos no debhelper.

    Esta funcionalidade de compatibilidade tinha um bug desde a sua inserção no debhelper/9.20130516 que o fazia falhar ao aplicar em compatibilidade 9 e anteriores. Como não tem havido relatórios de problemas causados por este bug nesses -5 anos, este item foi removido em vez de corrigido.

As alterações a partir de v8 são:
  • Suporte a multi-arquitectura. Em particular, dh_auto_configure passa directórios de multi-arquitectura ao autoconf em --libdir e --libexecdir.
  • O dh tem conhecimento das dependências habituais entre alvos em debian/rules. Por isso, o "dh binary" irá correr quaisquer alvos de build, build-arch, build-indep, install, etc que existam no ficheiro de regras. Não há necessidade de definir um alvo binário explícito com dependências explícitas em outros alvos.
  • dh_strip comprime ficheiros de símbolos de depuração para reduzir o tamanho instalado dos pacotes -dbg.
  • dh_auto_configure não inclui o nome do pacote fonte em --libexecdir quando usa autoconf.
  • dh não tem por predefinição a activação de --with=python-support

    (Obsoleto: Pois a ferramenta dh_pysupport foi removida a partir de Debian stretch. Desde o debhelper/10.3, dh já não se activa esta sequência add-on independentemente do nível de compatibilidade)

  • Todos os programas debhelper dh_auto_* e dh definem variáveis de ambiente listadas por dpkg-buildflags, a menos que elas estejam já definidas.
  • dh_auto_configure passa as dpkg-buildflags CFLAGS, CPPFLAGS, e LDFLAGS para Makefile.PL e Build.PL de perl.
  • dh_strip põe símbolos de depuração separados numa localização baseada no seu build-id.
  • Os ficheiros de configuração executáveis do debhelper são corridos e os seus resultados usados como configuração.

Este modo está descontinuado.

As alterações a partir de v7 são:
  • Os comandos irão falhar em vez de emitirem avisos quando lhes são passadas opções desconhecidas.
  • dh_makeshlibs irá correr dpkg-gensymbols em todas as bibliotecas partilhadas para as quais gera ficheiros shlibs. Portanto o -X pode ser usado para excluir bibliotecas. Também, as bibliotecas em localizações fora do habitual que o dpkg-gensymbols não tenha processado antes serão passadas para ele, uma alteração no comportamento que pode causar que alguns pacotes falhem a compilar.
  • dh requer que a sequência a correr seja especificada como o primeiro parâmetro, e quaisquer switches que venham depois dela. Isto é, use dh $@ --foo", e não "dh --foo $@
  • dh_auto_* prefere usar o Module::Build do Perl em preferência de Makefile.PL.

Este modo está descontinuado.

Este modo está descontinuado.

Este é o nível de compatibilidade mais baixo suportado.

Se você está a actualizar a partir de um nível de compatibilidade anterior, por favor reveja debhelper-obsolete-compat(7).

VEJA TAMBÉM

debhelper-obsolete-compat(7)
A actualizar a partir de um nível de compatibilidade (agora) obsoleto? Este documento a lista de verificação de actualização até ao nível suportado mais recente.
debhelper(7)
Informação geral acerca da estrutura do debhelper. Este documento também cobre como declarar o seu nível de compatibilidade debhelper escolhido.

AUTORES

Niels Thykier <niels@thykier.net>

Joey Hess

TRADUÇÃO

Américo Monteiro

Se encontrar algum erro na tradução deste documento, por favor comunique para Américo Monteiro a_monteiro@gmx.com ou Equipa Debian de Tradução Portuguesa traduz@debianpt.org.

2025-01-03 13.23~bpo12+1