<para>Este capítulo descreve como personalizar o &quantaplus; de acordo com as suas necessidades particulares e como pode ajudar o &quantaplus; a tornar-se melhor. </para>
<para>Os Pacotes de Edição do Tipo de Documentos (&DTEP;s) são usados no &quantaplus; para adicionar o suporte para as linguagens de formatação e de 'scripting', bem como para o &CSS;. Estas permitem ao &quantaplus; oferecer as funcionalidades como a auto-completação e as árvores de nós. A sua simplicidade e flexibilidade são o que tornam o &quantaplus; um &IDE; rápido e amigável para os programadores Web. São também o que fazem do &quantaplus; um ambiente produtivo e simples de utilizar. </para>
<para>Os &DTEP;s vêm em dois formatos: a Família 1, que corresponde às linguagens de formatação e a Família 2, que corresponde ao 'scripting' e ao &CSS;. Os &DTEP;s são compostos por duas partes, a Pasta de Marcas e as Barras de Ferramentas. As Pastas de Marcas são compostas por dois tipos de ficheiros, o &descriptionrc; e os ficheiros de TagXML, os quais contêm a extensão '.tag'. As barras de ferramentas são as páginas de botões úteis e orientados por ícones (por cima da janela de edição) que colocam o texto num documento de forma mais rápida do que o utilizador consegue escrever. </para>
<para>Os &DTEP;s podem ser criados manualmente (veja em baixo), <link linkend="download-resources">obtidos da Internet</link> ou criados automaticamente a partir de uma DTD existente. Veja em <xref linkend="converting-dtd"/> os detalhes da conversão. </para>
<para>Este documento descreve como é possível criar ficheiros TagXML, o &descriptionrc; e as barras de ferramentas. Em resumo, como criar um &DTEP;. </para>
<para>Os ficheiros TagXML (.tag) definem tanto os atributos específicos para uma marca como a disposição e o conteúdo da janela de propriedades que o &quantaplus; irá mostrar para a marca. O ficheiro &descriptionrc; contém as regras e a informação para o próprio &DTEP;. As barras de ferramentas oferecem uma forma rápida de adicionar marcas num documento, sem haver a preocupação com erros de escrita e outros erros do género. </para>
<para>As Pastas de Marcas são isso mesmo - pastas. Estas são compostas apenas pelos ficheiros &descriptionrc; e TagXML. As Pastas de Marcas contêm o nome da linguagem de formatação e a versão, se tal se aplicar. (Por exemplo, html-4.01-strict) </para>
<para>A tabela em baixo enumera os elementos que são definidos no TagXML e refere se estes são obrigatórios ou não. Embora nem todos sejam necessários, recomenda-se que você use tantos quantos possíveis para que os outros utilizadores possam ter uma melhor experiência e mais informação com que lidar. </para>
<para>As secções seguintes irão descrever, em detalhe, cada elemento. Tudo desde onde eles poderão estar até o que poderão conter é descrito aqui de uma forma simples de seguir. </para>
<para>Este é o elemento de raiz (topo) de um documento de TagXML. Só poderá aparecer num documento uma única vez. Poderá conter a definição de várias marcas. Este é um elemento do tipo apenas para elementos. </para>
<entry></entry><entry>O tipo da marca é uma função de programação. Quando é usado, os elementos <attr> tornam-se os argumentos da função (apenas na Família 2).</entry>
<entry>opcional</entry><entry>Se for igual a "yes", a marca corresponde a um grupo de atributos comum e os atributos desta marca poderão ser anexados a qualquer outra marca. (Apenas na Família 1.)</entry>
<para>Define um atributo da marca. Este elemento ocorre uma vez para cada atributo. Define o nome e o tipo do atributo. Também contém as marcas adicionais que indicam como o atributo deverá ser mostrado, etc. Este é um elemento do tipo apenas para elementos. </para>
<entry>opcional</entry><entry>Necessita do 'source="dcop"' e do nome de uma interface. O nome do método de DCOP a partir do qual o &quantaplus; irá buscar os dados de origem.</entry>
<entry>opcional</entry><entry>Necessita do 'source="dcop"', de uma interface e de um nome de um método. Os argumentos que são passados ao método. Poderá estar em branco ou aceitar o "%tagname%", que corresponde ao nome actual da marca.</entry>
<para>Uma marca que apenas agrupa os itens de uma lista. Só pode aparecer uma vez por cada descrição de um atributo. Este é um elemento do tipo apenas para elementos. </para>
<para>Indica a posição do atributo de uma marca dentro de uma janela. Esta marca só poderá ocorrer uma vez por cada atributo da janela (&ie; um por cada marca <attr>). Este elemento fica vazio. </para>
<para>Indica a posição e o tamanho de um campo na janela. Esta marca só deverá aparecer uma vez por cada campo da janela (&ie; um por cada marca de <attr> e <label>). Este elemento fica vazio. </para>
<para>Todos os ficheiros de TagXML deverão começar pela declaração de &XML;: <?xml version="1.0" encoding="UTF-8"?> e deverão estar devidamente aninhados e fechados. </para>
<para>Os espaços não afectam de facto em nada, mas tenha em atenção os caracteres & e <. Estes deverão ser substituídos provavelmente por &amp; e por &lt;, respectivamente, nos elementos como o <tooltip>, o <whatsthis> e o <text>. Se não o fizer não irá estoirar o programa, mas poderá fazer com que certos pedaços do seu trabalho desapareçam, nesse caso. </para>
<para>Para validar os seus ficheiros TagXML, basta carregar na janela das <quote>Ferramentas</quote> no topo do &quantaplus; e seleccionar <quote>Validar o TagXML.</quote> Irá então aparecer uma janela na qual você terá apenas de seguir as indicações simples. </para>
<para>Esta funcionalidade de momento não está presente. Actualmente a validação ocorre quando os ficheiros TagXML são carregados no &quantaplus;. </para>
<para>O seguinte irá mostrar um ficheiro de TagXML da Família 1 válido. Este ficheiro descreve também o elemento <schema> do &XML; Schema da &W3C;. O nome do ficheiro para este ficheiro TagXML seria então schema.tag. Simples, não é? </para>
<para>O seguinte irá mostrar-lhe um ficheiro TagXML da Família 2 válido. Este ficheiro descreve a função 'overload' do &PHP;. O nome do ficheiro TagXML seria overload.tag. </para>
<para>O ficheiro &descriptionrc; também é bastante simples e existe um editor para ele, acessível através da opção <menuchoice><guimenu>DTD</guimenu><guimenuitem>Editar a Configuração da DTD</guimenuitem></menuchoice>. Isto irá editar o &descriptionrc; de um &DTEP; que você poderá seleccionar numa lista. Para editar o &descriptionrc; para um &DTEP; acabado de criar, deverá criar um único &descriptionrc; com os seguintes itens: </para>
<para>Logo que o tenha criado e colocado junto com os ficheiros de marcas, carregue o &DTEP; acabado de criar com a opção <menuchoice><guimenu>DTD</guimenu><guimenuitem>Carregar o Pacote de DTD (DTEP)</guimenuitem></menuchoice> e, depois de carregado, você poderá prosseguir com a edição da configuração do &DTEP;. Verifique as dicas e o texto 'o que é isto' na janela do editor para compreender o significado de cada item. Em alternativa, poderá ler o ficheiro <filename>quanta/data/dtep/dtd-description.txt</filename> do pacote de código, que contém uma descrição do formato. </para>
<para>As acções são muito comuns em todas as aplicações. Você necessita delas com frequência quando usa qualquer aplicação. Se carregar num ícone da barra de ferramentas, seleccionar um item do menu ou usar um atalho de teclado irá normalmente executar uma acção. No &quantaplus;, as acções são levadas a um outro nível. Em vez de ter as acções implementadas de forma estanque (criadas pelo programador da aplicação ao nível do código-fonte), é possível para um utilizador normal criar e modificar acções e, deste modo, adicionar novas funcionalidades ao &quantaplus;. Estas são as acções definidas pelo utilizador; muitas das acções normais do &quantaplus; são definidas pelo utilizador (e modificáveis pelo mesmo). </para>
<para>Existem três tipos de acções definidas pelo utilizador: <itemizedlist>
<listitem><para><link linkend="text-actions">Acções de texto</link></para></listitem>
<listitem><para><link linkend="tag-actions">Acções de marcas</link></para></listitem>
<listitem><para><link linkend="script-actions">Acções de programas</link></para></listitem>
<para>Poderá criar uma acção se for a <menuchoice> <guimenu>Configuração</guimenu> <guimenuitem>Configurar as Acções</guimenuitem> </menuchoice>. Carregue em <guibutton>Nova Acção</guibutton> para que lhe apareça uma janela semelhante: <mediaobject> <imageobject>
<listitem><para>Define o tipo da acção (<link linkend="text-actions">Texto</link>, <link linkend="tag-actions">Marca</link>, <link linkend="script-actions">Programa</link>).</para>
<listitem><para>O atalho atribuído a esta acção. Carregue em <guilabel>Personalizado</guilabel> ou no botão perto de <guilabel>Personalizado</guilabel> para atribuir um atalho; carregue em <guilabel>Nenhum</guilabel> para remover o atalho atribuído de momento.</para>
<term><guilabel>Barras de Ferramentas de Contentores</guilabel></term>
<listitem><para>As barras de ferramentas definidas pelo utilizador onde esta acção irá aparecer. Veja em <xref linkend="creating-toolbars-3-2"/>.</para>
</imageobject></mediaobject> As acções mais simples. Poderá indicar algum texto na <guilabel>Configuração Detalhada</guilabel> e, sempre que a acção for executada, este texto será inserido no seu documento, na posição actual do cursor. Veja o exemplo em baixo. </para>
<para>É útil para introduzir marcas de XML, mas claro que as poderá usar para outros fins. <mediaobject><imageobject> <imagedata fileref="tag-actions.png" format="PNG"/> </imageobject></mediaobject> <variablelist> <varlistentry> <term><guilabel><marca></guilabel></term> <listitem><para>O nome da marca.</para></listitem> </varlistentry> <varlistentry> <term><guilabel></marca></guilabel></term> <listitem><para>Se estiver assinalado, quando a acção for executada, este texto será inserido como uma marca de fecho. Se existir alguma área seleccionada no documento, antes de você executar a acção, a <marca> será inserida antes da área seleccionada e a </marca> a seguir.</para></listitem> </varlistentry> <varlistentry> <term><guilabel>Correr o "Editar a marca" se disponível</guilabel></term> <listitem><para>Se estiver assinalada e existir um ficheiro tagXML para esta marca, irá aparecer uma janela de edição da marca antes de a introduzir dentro do documento, para que possa definir os atributos da mesma.</para></listitem> </varlistentry> </variablelist> A <marca> e a </marca> serão introduzidas tal e qual as indicou aí. O <, o > ou o sinal de / não serão adicionados automaticamente. </para>
</imageobject></mediaobject> O tipo de acção mais poderoso. Com a ajuda desta acção, poderá executar aplicações externas (normalmente programas, embora não esteja limitado a estes), que poderão alterar o seu documento ou usá-lo (ou parte deste) como dados de entrada. Os exemplos do próprio &quantaplus; são a janela de <guibutton>Introdução</guibutton> e as várias acções de <guilabel>Ver Em...</guilabel> dos DTEPs de (X)HTML. </para>
<para>Primeiro, terá de introduzir o nome do seu programa, acompanhado do interpretador. Exemplo: <command>sh /home/aMinhaArea/oMeuPrograma.sh</command>. </para>
<para>Ainda que possa usar localizações completas, a forma recomendada será usar a variável <command>%scriptdir</command> na linha de comandos, como por exemplo <command>sh %scriptdir/oMeuPrograma.sh</command>. Desta forma, o &quantaplus; irá tentar localizar o seu programa nos seguintes locais: <itemizedlist> <listitem><para>pasta de programas globais: <filename><envar>$TDEDIR</envar>/share/apps/quanta/scripts</filename></para></listitem> <listitem><para>pasta de programas locais: <filename><envar>$TDEHOME</envar>/share/apps/quanta/scripts</filename></para></listitem> <listitem><para>a sua 'path': <envar>$PATH</envar></para></listitem> </itemizedlist> Existem outras variáveis especiais que poderá usar na linha de comandos: <itemizedlist>
<listitem><para><command>%f</command>: será substituída pelo URL do documento actual. No caso dos documentos locais, o 'file:/' será retirado do documento.</para></listitem>
<listitem><para><command>%input</command>: será substituído pela entrada seleccionada. Veja em baixo.</para></listitem>
<listitem><para><command>%projectbase</command>: será substituído pelo URL do projecto actual. Estará em branco se não estiver nenhum projecto carregado.</para></listitem>
<listitem><para><command>%pid</command>: será substituído pelo PID do processo do &quantaplus; em execução. Se o &quantaplus; estiver a correr em modo único, o texto "único " será colocado antes do número do PID. É útil quando você usa o DCOP para controlar o &quantaplus; a partir do programa externo.</para></listitem>
<listitem><para><command>%userarguments</command>: é útil no caso dos eventos. Este item será substituído pelas propriedades do evento na seguinte ordem: <variablelist>
<para>Para além dos métodos normais, o programa poderá receber dados à entrada do &quantaplus; no 'standard input'. Na lista <guilabel>Entrada</guilabel>, poderá seleccionar o que é enviado para o 'standard input'. As opções são: <itemizedlist>
<listitem><para><guilabel>Nenhum</guilabel>: não é enviado nada para o programa.</para></listitem>
<listitem><para><guilabel>Documento actual</guilabel>: é enviado o documento inteiro para o programa.</para></listitem>
<listitem><para><guilabel>Texto seleccionado</guilabel>: a área seleccionada do documento é enviada para o programa. A utilização da variável <command>%input</command> faz normalmente sentido só quando se usa esta opção.</para></listitem>
<para>De forma semelhante à <guilabel>Entrada</guilabel>, você poderá capturar o resultado da aplicação executada. Existem dois tipos de saídas: <itemizedlist> <listitem><para>a saída normal, que é impressa no 'standard output';</para> </listitem> <listitem><para>as mensagens de erro, que são impressas no 'standard error'.</para> </listitem> </itemizedlist> Poderá indicar o que deverá acontecer ao texto impresso para o 'standard output'. Isto pode ser feito se modificar o valor da lista da <guilabel>Saída</guilabel>: <itemizedlist>
<listitem><para><guilabel>Nenhum</guilabel>: o resultado da aplicação é ignorado.</para></listitem>
<listitem><para><guilabel>Inserir na posição do cursor</guilabel>: o resultado será inserido no documento actual, mais concretamente na posição do cursor.</para></listitem>
<listitem><para><guilabel>Substituir a selecção</guilabel>: a área seleccionada no documento será substituída pelo resultado.</para></listitem>
<listitem><para><guilabel>Substituir a selecção</guilabel>: a área seleccionada no documento será substituída pelo resultado.</para></listitem>
<listitem><para><guilabel>Criar um novo documento</guilabel>: será criado um novo documento que irá conter o resultado do programa.</para></listitem>
<listitem><para><guilabel>Substituir o documento actual</guilabel>: o documento inteiro será substituído pelo resultado.</para></listitem>
<listitem><para><guilabel>Janela de mensagem</guilabel>: o resultado irá aparecer na área de <guilabel>Mensagens</guilabel>.</para></listitem>
<para>O seguinte irá mostrar como criar barras de ferramentas para um &DTEP;. As barras de ferramentas são elementos gráficos que se encontram associados a acções. As acções no &quantaplus; são a base para praticamente todas as extensões que o &quanta; tem e que irá adquirir no futuro. O mesmo mecanismo que define uma acção no &quanta; activa a auto-completação e as janelas de 'tags'. Com as acções, o limite do que poderá fazer é virtualmente nulo. Para poder ver um exemplo, iremos usar o <ulink url="http://tidy.sf.net">&HTML; tidy</ulink> nas nossas páginas Web. </para>
<para>Para começar, você irá precisar de criar uma barra de ferramentas do utilizador. Seleccione a opção <menuchoice> <guimenu>Barras de Ferramentas</guimenu> <guimenuitem>Adicionar uma Barra de Ferramentas do Utilizador</guimenuitem> </menuchoice>. </para>
<para>Se existirem várias marcas para a linguagem de formatação, recomenda-se que você divida as marcas em grupos lógicos. Irá precisar de criar uma nova barra de ferramentas do utilizador para cada grupo. Neste caso, não existem muitas, por isso vamos criar apenas uma barra de ferramentas e dar-lhe o nome da formatação. </para>
<para>Logo que todas as suas barras de ferramentas forem criadas, você precisa adicionar e configurar as acções. Para o fazer, seleccione <menuchoice> <guimenu>Configuração</guimenu> <guimenuitem>Configurar as Acções</guimenuitem> </menuchoice> <emphasis> </emphasis>. </para>
<para>As componentes desta janela são relativamente intuitivas. Carregue no botão <guibutton>Nova acção</guibutton> no fundo da janela para entrar no modo de edição. </para>
<para>Preencha todos os campos necessários e adicione a marca à(s) barra(s) de ferramentas apropriada(s). </para>
<para>Complete o resto e, se a marca tiver atributos e planeia usá-los sempre, assinale a opção <guilabel>Correr a janela "Editar a marca" se disponível </guilabel> de modo a que não tenha de ser avisado de cada vez que a acção é usada. </para>
<para>Agora você deverá ter algo muito semelhante ao seguinte. </para>
<para>Ui! Este é um ícone horrível. Como é que você próprio e os outros irão recordar que aquele ícone corresponde a aquela acção? Vamos substitui-lo antes que haja problemas. </para>
<para>Para criar um ícone que descreva de forma mais adequada essa acção, nós iremos usar o &kiconedit;. Seleccione-o no &kmenu;, <menuchoice> <guisubmenu>Gráficos</guisubmenu> <guisubmenu>Mais Programas</guisubmenu> </menuchoice> (ou onde quer qe a sua distribuição o tenha posto). </para>
<para>O &kiconedit; usa por omissão o tamanho de 32x32 pixels, mas nós precisamos do tamanho 22x22. Para o alterar, seleccione <menuchoice> <guimenu>Editar</guimenu> <guimenuitem>Redimensionar</guimenuitem> </menuchoice>. </para>
<para>Lembre-se que você está a criar um ícone que o irá ajudar não só a si a lembrar o objectivo daquela acção, mas também aos outros utilizadores do &DTEP;. </para>
<para>Dado que a marca para a qual estou a criar o ícone se chama <quote>iniciar,</quote> decidi criar um ícone de <quote>sinal de Iniciar.</quote> Ao usar a cor verde (o verde é normalmente interpretado como <quote>seguir,</quote> <quote>iniciar,</quote> ou <quote>prosseguir</quote>) irá, ou pelo menos é suposto, fornecer ao utilizador uma mensagem de que, se carregar nesta acção, irá colocar a marca de <inicio> no documento actual. </para>
<para>Agora que terminei a criação do ícone, vou então gravá-lo. </para>
<para>Logo que tenha acabado de criar o ícone ou ícones, você precisa associar o ícone à acção. Para o fazer, abra a <menuchoice> <guimenu>Configuração</guimenu> <guimenuitem>Configurar as Acções</guimenuitem> </menuchoice> de novo (no &quantaplus;) e seleccione a acção para a qual criou o ícone. Para além do campo de <guilabel>Texto</guilabel>, você irá ver um botão; neste momento, carregue no mesmo. </para>
<para>Seleccione <guilabel>Outros Ícones</guilabel> e carregue então no botão <guibutton>Escolher</guibutton>. </para>
<para>Vá para a pasta na qual gravou o ícone, seleccione o mesmo e carregue em <guibutton>OK</guibutton>. </para>
<para>Carregue no botão <guibutton>Aplicar</guibutton> e poderá então continuar a fazer o mesmo com as outras marcas, se existirem, ou poderá então carregar em <guibutton>OK</guibutton> para terminar. </para>
<para>Digamos que você desejaria adicionar mais algumas funções comuns do &quantaplus; à sua barra de ferramentas ou então acharia que a barra de ferramentas ficaria melhor se ficasse arrumada com alguns separadores para agrupar as acções. Abra a janela de <guilabel>Configurar as Barras de Ferramentas</guilabel> indo à opção <menuchoice> <guimenu>Configuração</guimenu> <guimenuitem>Configurar as Barras de Ferramentas</guimenuitem> </menuchoice>. Certifique-se que a sua barra de ferramentas está seleccionada. </para>
<para>Irei então escolher o separador (em cima na coluna da esquerda) para a minha barra de ferramentas. Logo que você tenha seleccionado o item que deseja adicionar à sua barra de ferramentas, carregue no botão com a seta para a direita. Isto irá adicioná-lo à sua barra de ferramentas. </para>
<para>Penso que gostaria de uma forma mais rápida de aceder à <guilabel>Antevisão no Konqueror</guilabel>. Irei então seleccioná-la e adicioná-la à barra de ferramentas. </para>
<para>Repare como o separador ajuda a agrupar. Alguém que não conhecesse bem a minha barra de ferramentas poderia ter pensado que o botão do &konqueror; seria semelhante ou o oposto do botão de início. </para>
<para>Agora, para gravar a barra de ferramentas, iremos seleccionar a opção <menuchoice> <guimenu>Barras de Ferramentas</guimenu> <guisubmenu>Gravar as Barras de Ferramentas</guisubmenu> <guimenuitem>Gravar como Barra de Ferramentas Local</guimenuitem> </menuchoice>. </para>
<para>Grave-a na pasta correcta. Dado que a NeXML não existe, irei tê-la apenas na pasta de topo, mas as suas barras de ferramentas deverão ser gravadas na pasta correcta. Certifique-se que ajusta o seu &descriptionrc; para que este carregue as mesmas barras de cada vez que um ficheiro desse tipo é criado. </para>
<para>Provavelmente as adições mais notáveis ao &quantaplus; para o utilizador geral serão a inclusão de documentação para a linguagem de formatação ou de 'scripting' que gostar mais. Para tal, este capítulo irá explicar como é que eu crio a árvore de documentação de &PHP; para o meu uso pessoal. </para>
<para>Antes de começar a criar a sua própria documentação, poderá querer ver o <ulink url="http://quanta.sf.net/main1.php?contfile=resource">repositório do &quantaplus;</ulink> para ver se alguém já a criou. </para>
<para>Existem duas partes neste processo. Primeiro, deverá obter a documentação existente para a linguagem em questão que está à procura. Em segundo lugar, terá de criar o ficheiro <filename>docrc</filename>. O primeiro é segundo o seu critério, enquanto o último passo será debatido aqui. </para>
<para>A secção Tree define o aspecto da apresentação da documentação na página respectiva. Por exemplo, poderá ver na documentação de &PHP; que tem algo do género do seguinte: </para>
<para> Repare no <literal>#</literal> antes da <quote>Introdução</quote> e <quote>Referência da Linguagem</quote>. Isto indica que estes são sub-títulos na árvore e que tem conteúdo próprio. Não creio que haja um limite para a profundidade do conjunto (excepto a que é definida pela sanidade) - use segundo o seu critério. </para>
<para>Para o Índice, irá reparar que este referencia directamente um ficheiro (e, como consequência, irá aparecer no fundo da árvore — com as pastas primeiro!). </para>
<para>Os espaços não afectam de facto em nada, mas tenha em atenção os caracteres & e <. Estes deverão ser substituídos provavelmente por &amp; e por &lt;, respectivamente, em todos os ficheiros de recursos de &XML; do &quantaplus;. </para>
<para>A secção Context é a secção do ficheiro 'docrc' que é usada para facilitar a ajuda dependente do contexto. Por exemplo, você está a fazer um programa em &PHP; e deseja ver a documentação para a função <function>mysql_fetch_array</function>. Basta você seleccionar a função e carregar então em <keycombo action="simul">&Ctrl;<keycap>H</keycap> </keycombo> para obter a ajuda de contexto. A documentação do <function>mysql_fetch_array</function> irá aparecer imediatamente. Existem apenas dois tipos de itens aqui: o ContextList e as linhas de associações de ficheiros. </para>
<para>Muito simplesmente, isto é apenas uma lista separada por vírgulas dos itens de contexto que você deseja ter disponíveis (para o &PHP;, estas serão as funções de &PHP;). </para>
<para>Agora poderá gravar o seu ficheiro <filename>docrc</filename>, colocá-lo na pasta <filename class="directory"> $<envar>HOME</envar>/.trinity/share/apps/quanta/doc</filename> ou em <filename class="directory"> $<envar>TDEDIR</envar>/share/apps/quanta/doc</filename> para o uso local ou global, respectivamente. Crie então uma pasta (a especificada no seu ficheiro 'docrc') na mesma pasta que no seu ficheiro 'docrc' e copie as suas páginas de documentação em &HTML; para lá. </para>
<para>Terá de reiniciar o &quantaplus; para poder então ver a sua documentação. </para>
<para>Logo que tenha a certeza que eles ficaram bem e que vale a pena serem partilhados, envie o ficheiro <filename>docrc</filename> em conjunto com uma descrição com todas as informações pertinentes da documentação que usou no <ulink url="http://quanta.sf.net/main1.php?contfile=resource">repositório do &quantaplus;</ulink> para ser usado pela comunidade do &quanta;. Não irá ficar rico, mas ficará satisfeito de certeza em saber que contribuiu para a melhor plataforma de programação Web existente. </para>
<para>Com o &quantaplus;, você não está sozinho. É possível partilhar os vários recursos (pacotes DTEP, barras de ferramentas com acções, programas, modelos) com outras pessoas. Existem duas formas de o fazer: </para>
<listitem><para>Os recursos poderão ser enviados por e-mail para os seus amigos, colegas ou para quem você quiser. Irá ver os itens de menu <guilabel>Enviar por E-mail</guilabel> em vários sítios, como o <menuchoice><guimenu>DTD</guimenu><guimenuitem>Enviar o Pacote de DTD (DTEP) por E-mail</guimenuitem></menuchoice>, <menuchoice><guimenu>Barras de Ferramentas</guimenu><guimenuitem>Enviar a Barra de Ferramentas por E-mail</guimenuitem></menuchoice>, no menu de contexto dos ficheiros e pastas dos e na árvore de <guilabel>Modelos</guilabel> e <guilabel>'Scripts'</guilabel>. </para></listitem>
<listitem><para>Os recursos podem ser remetidos para o nosso repositório principal, a partir do qual todos os outros utilizadores do &quantaplus; os poderão obter. Os envios são revistos e disponibilizados, se a nossa equipa considerar que estão correctos e são úteis. Para fazer um envio válido, sugere-se que assine os recursos, pelo que irá necessitar de uma chave de GPG/PGP. Esta informação é usada para verificar a origem dos recursos, tanto pela nossa equipa como por quem irá obter os recursos.</para>
<para>Para saber como obter os recursos do servidor principal, veja em <xref linkend="download-resources"/>.</para>
<para>Ao enviar, ser-lhe-á pedido para indicar a senha da sua chave privada de GPG (a senha não será gravada) ou, no caso de ter mais chaves privadas, poderá escolher a que deseja usar. Na janela para <guilabel>Partilhar Coisas Novas</guilabel>, preencha os campos de entrada (o <guilabel>URL de Antevisão</guilabel> poderá ficar em branco) e inicie o envio, carregando para tal em <guilabel>OK</guilabel>.</para>
<para>O envio poderá ser iniciado em <menuchoice><guimenu>DTD</guimenu><guimenuitem>Enviar o Pacote do DTD (DTEP)</guimenuitem></menuchoice>, <menuchoice><guimenu>Barras de Ferramentas</guimenu><guimenuitem>Enviar a Barra de Ferramentas</guimenuitem></menuchoice>, no menu de contexto dos ficheiros e pastas na árvore de <guilabel>Modelos</guilabel> e <guilabel>'Scripts'</guilabel>. </para>
<para>É possível actualizar o seu &quantaplus; sem obter uma versão nova, obtendo os recursos novos como os pacotes DTEP, as barras de ferramentas com acções, modelos, 'scripts' e documentação. Uma possibilidade será que você obteve os recursos por e-mail ou a partir de um servidor Web; nesses casos, você terá de os instalar manualmente. Se teve sorte, você também obteve um programa de instalação no local de onde transferiu os recursos. Contudo, o &quantaplus; tem um servidor dedicado que mantém os recursos que não foram instalados na distribuição principal, devido aos seus tamanhos ou a utilizações pouco frequentes ou que foram contribuídos posteriormente pelos utilizadores, sendo estes recursos instalados automaticamente. Para obter esses recursos, use os vários itens de menu para <guilabel>Obter</guilabel>. Você poderá encontrá-los em <menuchoice><guimenu>DTD</guimenu><guimenuitem>Obter o Pacote de DTD (DTEP)</guimenuitem></menuchoice>, <menuchoice><guimenu>Barras de Ferramenta</guimenu><guimenuitem>Obter Barra de Ferramentas</guimenuitem></menuchoice>, no menu de contexto ou numa área vazia ou num item de topo nas árvores de <guilabel>Modelos</guilabel>, <guilabel>'Scripts'</guilabel> e <guilabel>Documentação</guilabel>. </para>
<para>Depois de obter um recurso, mas antes de o instalar, o &quantaplus; verifica se o recurso é válido, verificando a integridade e a assinatura. No caso de ocorrerem problemas, ele avisá-lo-á e você poderá decidir se deseja continuar ou não. Por favor reveja as janelas de avisos com cuidado. No caso de a integridade ser correcta e o recurso estar devidamente assinado, você irá obter à mesma uma janela de informação, para que possa ver quem criou o recurso. </para>
<caution><para>Certifique-se que instala os recursos, principalmente as barras de ferramentas e os 'scripts', apenas a partir de fontes de confiança!</para></caution>
<para>É possível trabalhar em linguagens de XML que não sejam suportadas de momento pelo &quantaplus; se criar um pacote DTEP. Contudo, a criação poderá levar bastante tempo, dado que poderá ter de indicar centenas de ficheiros de marcas no formato <link linkend="tagxml-3-2">tagXML</link>. Obviamente, existe uma forma melhor de o fazer, convertendo a DTD automaticamente para um pacote DTEP. </para>
<para>A conversão poderá ser iniciada a partir da opção do menu <menuchoice><guimenu>DTD</guimenu><guimenuitem>Carregar e Converter a DTD</guimenuitem></menuchoice>. Seleccione o ficheiro <filename>.dtd</filename> que define a DTD que deseja usar, onde irá ver a janela seguinte: <mediaobject> <imageobject>
<listitem><para><guilabel>Nome da pasta-alvo:</guilabel>o &DTEP; acabado de criar irá parar, com este nome, à pasta <filename><envar>$TDEHOME</envar>/share/apps/quanta/dtep</filename>. </para>
<listitem><para><guilabel>Nome:</guilabel>: o nome (texto de definição) da DTD</para></listitem>
<listitem><para><guilabel>Nome alternativo:</guilabel>: o nome visível para o utilizador do &DTEP;</para></listitem>
<listitem><para><guilabel>Linha de definição do !DOCTYPE:</guilabel> o texto que deverá aparecer na marca !DOCTYPE, como por exemplo HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"</para></listitem>
<listitem><para><guilabel>URL da DTD</guilabel>: o URL que aponta para o ficheiro da DTD</para></listitem>
<listitem><para><guilabel>Extensão por omissão:</guilabel> a extensão que será usada normalmente para os ficheiros que foram escritos nesta DTD</para></listitem>
<listitem><para><guilabel>Marcas e atributos com distinção de maiúsculas:</guilabel> esta opção costuma estar assinalada para o caso das variantes da linguagem XML</para></listitem>
<listitem><para><guilabel>Afinar o DTEP após a conversão:</guilabel> se estiver assinalado, após a conversão, o &quantaplus; irá invocar o editor do &descriptionrc;, de modo a que você possa afinar alguns detalhes do &DTEP; acabado de criar. Recomenda-se que deixe esta opção assinalada.</para></listitem>