CLR package guidelines (Português)
Este documento define o padrão para a empacotamento de projetos Common Language Runtime (.NET) sob Arch Linux. Atualmente, apenas o Mono é capaz de fornecer um runtime CLR usável e eficiente para vários sistemas e esse padrão refletirá seu uso. Esteja ciente de que muitos programas CLR foram desenvolvidos com o Microsoft .NET em mente e, como tal, podem ou não ser executados em Mono por causa de fatores exclusivos do .NET, como chamadas P/Invoke e APIs de Gestão Digital de Direitos (DRM) da Microsoft e, portanto, não produzirá um pacote utilizável para o Arch Linux. No entanto, se combinado com Wine a partir da versão 1.5.6 (?), seu pacote pode ter a chance de executar sob ele. Consulte as diretrizes de pacotes Wine para obter mais informações, se tal for o caso.
Pegadinhas de empacotamento
- Sempre adicione mono a
depends
- Sempre defina
arch
comoany
. Mono não oferece suporte a compilar (executar?) montagens de 64 bits. - Sempre adicione
!strip
aoptions
- Se o pacote é uma biblioteca (DLL), considere instalá-lo ao Global Assembly Cache (GAC) do Mono, se ele for usado como uma dependência.
- Se a montagem é pré-compilada e vem com um arquivo de banco de dados para depuração de programas (Foo.dll.pdb), considere convertê-la como tal:
pdb2mdb Foo.dll
- Se o pacote destina-se a ser um executável (EXE), certifique-se de instalar em
/usr/bin
um shell script para executá-lo, similar a esse:
#!/bin/sh mono foo.exe $@
Montagens assinadas
Se o pacote for instalado no GAC, certifique-se de ter um arquivo de chave assinado. Caso contrário, você pode gerar um como este: sn -k 1024 Foo.snk
. Em seguida, a forma mais fácil de embutir o arquivo chave na montagem para ser desmontada assim: . Após, remonte-o assim:
Exemplos de PKGBUILD
Os exemplos a seguir vão tentar cobrir algumas das convenções mais comuns e sistemas de compilação.