1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
---
title: chrome.manifest
slug: chrome.manifest
tags:
- Extensões
- Toolkit API
translation_of: Archive/Mozilla/Creating_a_Skin_for_SeaMonkey_2.x/chrome.manifest
---
<p> </p>
<h3 id="O_que_.C3.A9_Chrome.3F" name="O_que_.C3.A9_Chrome.3F">O que é Chrome?</h3>
<p><a href="/en/Chrome">Chrome</a> é o conjunto de elementos da interface de usuário na janela do aplicativo localizado fora da área da janela de conteúdo. Barras de ferramentas, barras de menu, barras de progresso e barras do título da janela são todos os exemplos de elementos que normalmente fazem parte do chrome.</p>
<h3 id="Fornecedores_Chrome" name="Fornecedores_Chrome">Fornecedores Chrome</h3>
<p>Um fornecedor de chrome para um determinado tipo de janela (e.g., para a janela do navegador) é chamado de fornecedor chrome. Os fornecedores trabalham juntos para fornecer um kit completo de chrome para uma janela particular, das imagens dos botões na barra de ferramentas aos arquivos que descrevem o texto, conteúdo e aparência da própria janela.</p>
<p>Existem três tipos básicos de fornecedores chrome:</p>
<h4 id="Content_.28conte.C3.BAdo.29" name="Content_.28conte.C3.BAdo.29">Content (conteúdo)</h4>
<p>O arquivo fonte principal para a descrição de uma janela vem do forneceder content (conteúdo), e ele pode ser qualquer tipo de arquivo visível com o Mozilla. Normalmente será um arquivo XUL, desde que o XUL seja desenhado para descrever os conteúdos das janelas e diálogos. Os arquivos javascript que definem a interface de usuário são também contidas com o pacote content (conteúdo), assim como a maioria dos arquivos XBL binding.</p>
<h4 id="Locale_.28local.29" name="Locale_.28local.29">Locale (local)</h4>
<p>Aplicativos localizáveis mantêm toda a informação localizada em fornecedores locale (local). Isto permite a tradutores ligá-lo em um diferente pacote chrome para traduzir um aplicativo sem alterar o resto do código fonte. Os dois tipos principais de arquivos localizáveis são arquivos DTD e arquivos de propriedade java-style.</p>
<h4 id="Skin_.28pele.29" name="Skin_.28pele.29">Skin (pele)</h4>
<p>Um fornecedor skin (pele) é responsável por proporcionar um kit completo de arquivos que descrevem a aparência visual do chrome. Normalmente um fornecedor skin (pele) proporcionará arquivos CSS e imagens.</p>
<h3 id="O_registro_Chrome" name="O_registro_Chrome">O registro Chrome</h3>
<p>O gecko runtime mantém um serviço sabido como o registro chrome que proporciona mapeamentos de nomes de pacotes chrome à localização física do pacote chrome no disco.</p>
<p>Este registro chorme é configurável e persistente, e assim um usuário pode instalar diferentes fornecedores chrome, e selecionar um preferido skin (pele) e locale (local). Isto é realizado através do xpinstall e do gerenciador de extensões.</p>
<p>Em ordem para informar o registro chrome do chrome disponível, um manifesto texto é usado: este manifesto é "chrome.manifest" na raiz de uma extensão, ou tema, e chrome/*manifest em um aplicativo XULRunner.</p>
<p>O texto simples do manifesto chrome tem um formato simples baseado em linhas. Cada linha é analizada gramaticalmente e individualmente; se a linha estiver correta o registro chrome pega a ação identificada por aquela linha; caso contrário o registro chrome ignora aquela linha (e imprime uma mensagem de aviso no console de runtime error).</p>
<pre class="eval">locale packagename localename path/to/files
skin packagename skinname path/to/files
</pre>
<h3 id="Instru.C3.A7.C3.B5es_do_Manifesto" name="Instru.C3.A7.C3.B5es_do_Manifesto">Instruções do Manifesto</h3>
<h4 id="Coment.C3.A1rios" name="Coment.C3.A1rios">Comentários</h4>
<p>Uma linha é um comentário se ela iniciar com o caractere '#'; qualquer outro caractere na linha é ignorado.</p>
<pre class="eval"># esta linha é um comentário — você pode colocar o que quiser aqui
</pre>
<h4 id="content_.28conte.C3.BAdo.29" name="content_.28conte.C3.BAdo.29">content (conteúdo)</h4>
<p>Um pacote content (conteúdo) é registrado com a linha:</p>
<pre class="eval">content <em>packagename</em> <em>uri/to/files/</em> <em>[flags]</em>
</pre>
<p>Isto irá registrar a localização para usar quando for resolvida a URL <code>chrome://<em>packagename</em>/content/...</code>. A URL pode ser absoluta ou relativa à localização do arquivo de manifesto. Note que é necessário acabar com uma '/'.</p>
<h4 id="locale_.28local.29" name="locale_.28local.29">locale (local)</h4>
<p>Um pacote locale (local) é registrado com a linha</p>
<pre class="eval">locale <em>packagename</em> <em>localename</em> <em>uri/to/files/</em> <em>[flags]</em>
</pre>
<p>Isto irá registrar o pacote locale (local) quando for resolvida a URL chrome://<em>packagename</em>/locale/... . O <em>localename</em> (nome local) é normalmente um simples idenficador de língua "en" ou um identificador língua-país "en-US". Se mais de um local for registrado para um pacote, o registro chrome irá selecionar o melhor local usando as preferências do usuário.</p>
<h4 id="skin_.28pele.29" name="skin_.28pele.29">skin (pele)</h4>
<p>Um pacote skin (pele) é registrado com a linha</p>
<pre class="eval">skin <em>packagename</em> <em>skinname</em> <em>uri/to/files/</em> <em>[flags]</em>
</pre>
<p>Isto irá registrar um pacote skin (pele) quando for resolvida a URL <a class="external" rel="freelink">chrome://packagename/skin/</a>... . O <em>skinname</em> (nome da pele) é uma sring opaca identificando uma skin (pele) instalada. Se mais de uma pele for registrada para um pacote, o registro chrome irá selecionar a melhor pele usando as preferências do usuário.</p>
<h4 id="overlay_.28sobreposi.C3.A7.C3.A3o.29" name="overlay_.28sobreposi.C3.A7.C3.A3o.29">overlay (sobreposição)</h4>
<p>XUL overlays (sobreposições XUL) são registradas com a seguinte sintaxe:</p>
<pre class="eval">overlay chrome://<em>URI-to-be-overlayed</em> chrome://<em>overlay-URI</em> <em>[flags]</em>
</pre>
<h4 id="style_.28estilo.29" name="style_.28estilo.29">style (estilo)</h4>
<p>Style overlays (sobreposições de estilo) (CSS customizado que será aplicado à página chrome) é registrado com a seguinte sintaxe:</p>
<pre class="eval">style chrome://<em>URI-to-style</em> chrome://<em>stylesheet-URI</em> <em>[flags]</em>
</pre>
<h4 id="override_.28substitui.C3.A7.C3.A3o.29" name="override_.28substitui.C3.A7.C3.A3o.29">override (substituição)</h4>
<p>Em alguns casos uma extensão ou encaixe pode desejar substituir um arquivo chrome providenciado pela aplicação ou XULRunner. A fim de permitir isto, o manifesto de registro chrome permite instruções para "substituição":</p>
<pre class="eval">override chrome://<em>package</em>/<em>type</em>/<em>original-uri.whatever</em> <em>new-resolved-URI</em> <em>[flags]</em>
</pre>
<h3 id="Marcadores_do_Manifesto" name="Marcadores_do_Manifesto">Marcadores do Manifesto</h3>
<p>Linhas do manifesto podem ter múltiplos espaços delimitados por marcadores adicionados no final da linha de registro. Estes marcadores marcam atributos especiais do chrome no pacote, ou limitam as condições sob qual linha é usada.</p>
<h4 id="application_.28aplicativo.29" name="application_.28aplicativo.29">application (aplicativo)</h4>
<p>Extensões podem instalar múltiplos aplicativos. Existem algumas linhas com registro chrome que somente se aplicam a um aplicativo particular. O marcador</p>
<pre class="eval">application=<em>app-ID</em>
</pre>
<p>indica que a instrução deve ser aplicada somente se a extensão instalada no aplicativo identificado por <em>app-ID</em> estiver rodando. Múltiplos marcadores de aplicativos podem ser incluídos em uma única linha, neste caso a linha é aplicada se qualquer um dos marcadores rodar.</p>
<h4 id="appversion_.28vers.C3.A3o_do_aplicativo.29" name="appversion_.28vers.C3.A3o_do_aplicativo.29">appversion (versão do aplicativo)</h4>
<p>Extensões podem instalar em múltiplas versões de um aplicativo. Existem algumas extensões que podem instalar múltiplas versões de um aplicativo. O marcador</p>
<pre class="eval">appversion=<em>version</em>
appversion<<em>version</em>
appversion<=<em>version</em>
appversion><em>version</em>
appversion>=<em>version</em>
</pre>
<p>indica que a instrução deve somente ser aplicada se a extensão instalada no aplicativo tiver versão identificada. Múltiplos marcadores <code>appversion</code> podem ser incluídos em uma única linha. neste caso a linha é aplicada se qualquer um dos marcadores rodar. A versão da string precisa estar conforme o <a href="/pt/Toolkit_version_format" title="pt/Toolkit_version_format">Toolkit version format</a>.</p>
<h4 id="platform_.28plataforma.29.28Pacotes_espec.C3.ADficos_da_plataforma.29" name="platform_.28plataforma.29.28Pacotes_espec.C3.ADficos_da_plataforma.29">platform (plataforma)(Pacotes específicos da plataforma)</h4>
<p>Alguns pacotes são marcados com um marcador especial indicando que ele tem uma plataforma específica. Algumas partes do content (conteúdo), skin (pele), locales (locais) podem ser diferentemente baseados para a plataforma que rodam. Estes pacotes contém três diferentes grupos de arquivos, para windows/os2, macintosh, e plataformas como o unix. Por exemplo, a ordem dos botões "OK" e "cancelar" em um diálogo é diferente, assim como o nome de alguns itens.</p>
<p>O modificador de "plataforma" é somente analizado gramaticamente para o registro de conteúdo, não é reconhecido pelo registro de local e pele. Entretanto isto se aplica às partes conteúdo, local, e pele do pacote, quando especificado.</p>
<p>Para indicar se um pacote tem plataforma específica, adicione o modificador "plataform" à linha do "content" após o trajeto, por exemplo:</p>
<pre class="eval">content global-platform jar:toolkit.jar!/toolkit/content/global-platform/ platform
</pre>
<p>Uma vez especificado isto em seu manifesto você assegura-se então que abaixo do diretório da plataforma global existem sub-diretórios <code>win</code> (Windows/OS2), <code>mac</code> (OS9/OSX), ou <code>unix</code> (Todos os outros). Alguma coisa residindo do lado de fora destes sub-diretórios será ignorado.</p>
<h4 id="xpcnativewrappers" name="xpcnativewrappers">xpcnativewrappers</h4>
<p>Pacotes chrome podem decidir se para usar o mecanismo de segurança xpcnativewrappers para proteger seu código contra conteúdos maliciosos que possam ter acesso. Veja <a href="/en/Safely_accessing_content_DOM_from_chrome">en:Safely accessing content DOM from chrome</a> para detalhes.</p>
<p>Com o Firefox 1.5 lançamento alpha (Deer Park alphas), este marcador está *desligado* por padrão, e precisa ser explicitamente ativado especificando-se xpcnavitewrappers=yes.</p>
<p>Com o Firefox 1.5 lançamento beta, este marcador será ativado por padrão, e extensões que tiverem um acesso inseguro aos objetos de conteúdo serão requeridas para especificar xpcnavitewrappers=no.</p>
<p>O marcador xpcnativewrappers aplica somente ao pacote content (conteúdo): ele não é reconhecido pelo registro locale (local) ou skin (pele).</p>
<h3 id="Exemplo_de_Manifesto_Chrome" name="Exemplo_de_Manifesto_Chrome">Exemplo de Manifesto Chrome</h3>
<pre class="eval">content necko jar:comm.jar!/content/necko/ xpcnativewrappers=yes
locale necko en-US jar:en-US.jar!/locale/en-US/necko/
content xbl-marquee jar:comm.jar!/content/xbl-marquee/
content pipnss jar:pipnss.jar!/content/pipnss/
locale pipnss en-US jar:en-US.jar!/locale/en-US/pipnss/
# Firefox-only
overlay <a class="external" rel="freelink">chrome://browser/content/pageInfo.xul</a> <a class="external" rel="freelink">chrome://pippki/content/PageInfoOverlay.xul</a> application={ec8030f7-c20a-464f-9b0e-13a3a9e97384}
overlay <a class="external" rel="freelink">chrome://communicator/content/pref/preftree.xul</a> <a class="external" rel="freelink">chrome://pippki/content/PrefOverlay.xul</a>
overlay <a class="external" rel="freelink">chrome://navigator/content/pageInfo.xul</a> <a class="external" rel="freelink">chrome://pippki/content/PageInfoOverlay.xul</a> <a class="link-mailto" href="mailto:application=seamonkey@applications.mozilla.org" rel="freelink">application=seamonkey@applications.mozilla.org</a>
content pippki jar:pippki.jar!/content/pippki/ xpcnativewrappers=yes
locale pippki en-US jar:en-US.jar!/locale/en-US/pippki/
content global-platform jar:toolkit.jar!/content/global-platform/ platform
skin global classic/1.0 jar:classic.jar!/skin/classic/global/
override <a class="external" rel="freelink">chrome://global/content/netError.xhtml</a> jar:embedder.jar!/global/content/netError.xhtml
content inspector jar:inspector.jar!/content/inspector/ xpcnativewrappers=no
</pre>
<h3 id="Manifestos_contents.rdf_com_estilo_antigo" name="Manifestos_contents.rdf_com_estilo_antigo">Manifestos contents.rdf com estilo antigo</h3>
<p>Antes do manifesto de texto simples foram introduzidos (os quais funcionam no Firefox 1.5, Toolkit 1.8), manifestos RDF chamados "contents.rdf" que foram usados para registrar o chrome. Este formato é desaprovado; todavia, a Suíte Mozilla (SeaMonkey) não suporta o formato do manifesto de texto simples ainda, então o manifesto contents.rdf é requerido para extensões que desejam deixar para trás o mantimento da compatibilidade com o Firefox 1.0 ou à suíte.</p>
|