2011-05-29 19:20:24 +02:00
|
|
|
@title Remarkup Reference
|
|
|
|
@group userguide
|
|
|
|
|
2011-07-04 22:04:22 +02:00
|
|
|
Explains how to make bold text; this makes your words louder so you can win
|
2011-06-23 22:04:52 +02:00
|
|
|
arguments.
|
2011-05-29 19:20:24 +02:00
|
|
|
|
|
|
|
= Overview =
|
|
|
|
|
|
|
|
Phabricator uses a lightweight markup language called "Remarkup", similar to
|
|
|
|
other lightweight markup langauges like Markdown and Wiki markup.
|
|
|
|
|
|
|
|
This document describes how to format text using Remarkup.
|
|
|
|
|
Provide a "reference-with-full-name" syntax for Remarkup
Summary:
Provide a {T123} syntax which pulls in the entire name of an object, not just a
link to it. A major use for this is organizing projects using wiki pages. Since
handle links show object status now, this lets you organize stuff in an ad-hoc
way and get a reasonable overview of it. We can make handles richer in the
future, too.
The performance on this isn't perfect (it adds some potential single gets) but I
think it's okay for now and I don't want to make remarkup engine even more
complex until the preprocess/postprocess stuff has had a chance to settle and
I'm more confident it works.
In Differential and Maniphest we'll also incorrectly cache the object
state/name, but that'll fix itself once I move the cache code to use
preprocess/postprocess correctly.
Test Plan:
- See https://secure.phabricator.com/file/view/PHID-FILE-5f9ca32407bec20899b9/
for an example.
- Generated and looked over the documentation.
Reviewed By: jungejason
Reviewers: jungejason, tuomaspelkonen, aran, hunterbridges
CC: skrul, aran, jungejason, epriestley
Differential Revision: 784
2011-08-05 17:50:26 +02:00
|
|
|
= Quick Reference =
|
|
|
|
|
|
|
|
All the syntax is explained in more detail below, but this is a quick guide to
|
2012-01-16 20:45:43 +01:00
|
|
|
formatting text in Remarkup.
|
|
|
|
|
|
|
|
These are inline styles, and can be applied to most text:
|
Provide a "reference-with-full-name" syntax for Remarkup
Summary:
Provide a {T123} syntax which pulls in the entire name of an object, not just a
link to it. A major use for this is organizing projects using wiki pages. Since
handle links show object status now, this lets you organize stuff in an ad-hoc
way and get a reasonable overview of it. We can make handles richer in the
future, too.
The performance on this isn't perfect (it adds some potential single gets) but I
think it's okay for now and I don't want to make remarkup engine even more
complex until the preprocess/postprocess stuff has had a chance to settle and
I'm more confident it works.
In Differential and Maniphest we'll also incorrectly cache the object
state/name, but that'll fix itself once I move the cache code to use
preprocess/postprocess correctly.
Test Plan:
- See https://secure.phabricator.com/file/view/PHID-FILE-5f9ca32407bec20899b9/
for an example.
- Generated and looked over the documentation.
Reviewed By: jungejason
Reviewers: jungejason, tuomaspelkonen, aran, hunterbridges
CC: skrul, aran, jungejason, epriestley
Differential Revision: 784
2011-08-05 17:50:26 +02:00
|
|
|
|
|
|
|
**bold** //italic// ##monospaced##
|
2012-02-18 04:39:13 +01:00
|
|
|
D123 T123 rX123 # Link to Objects
|
|
|
|
{D123} {T123} # Link to Objects (Full Name)
|
|
|
|
{F123} # Embed Images
|
|
|
|
@username # Mention a user
|
|
|
|
[[wiki page]] # Link to Phriction
|
|
|
|
[[wiki page | name]] # Named link to Phriction
|
|
|
|
http://xyz/ # Link to web
|
|
|
|
[[http://xyz/ | name]] # Named link to web
|
|
|
|
|
2012-01-16 20:45:43 +01:00
|
|
|
|
|
|
|
These are block styles, and must be separated from surrounding text by
|
|
|
|
empty lines:
|
|
|
|
|
2012-02-18 04:39:13 +01:00
|
|
|
= Large Header =
|
2012-01-16 20:45:43 +01:00
|
|
|
== Smaller Header ==
|
|
|
|
> Quoted Text
|
2012-02-19 18:06:47 +01:00
|
|
|
Use "- " or "* " for bulleted lists, and "# " for numbered lists.
|
2011-12-01 18:48:27 +01:00
|
|
|
Use ``` or indent two spaces for code.
|
2012-01-04 03:08:58 +01:00
|
|
|
Use %%% for a literal block.
|
Provide a "reference-with-full-name" syntax for Remarkup
Summary:
Provide a {T123} syntax which pulls in the entire name of an object, not just a
link to it. A major use for this is organizing projects using wiki pages. Since
handle links show object status now, this lets you organize stuff in an ad-hoc
way and get a reasonable overview of it. We can make handles richer in the
future, too.
The performance on this isn't perfect (it adds some potential single gets) but I
think it's okay for now and I don't want to make remarkup engine even more
complex until the preprocess/postprocess stuff has had a chance to settle and
I'm more confident it works.
In Differential and Maniphest we'll also incorrectly cache the object
state/name, but that'll fix itself once I move the cache code to use
preprocess/postprocess correctly.
Test Plan:
- See https://secure.phabricator.com/file/view/PHID-FILE-5f9ca32407bec20899b9/
for an example.
- Generated and looked over the documentation.
Reviewed By: jungejason
Reviewers: jungejason, tuomaspelkonen, aran, hunterbridges
CC: skrul, aran, jungejason, epriestley
Differential Revision: 784
2011-08-05 17:50:26 +02:00
|
|
|
|
2011-05-29 19:20:24 +02:00
|
|
|
= Basic Styling =
|
|
|
|
|
|
|
|
Format **basic text styles** like this:
|
|
|
|
|
|
|
|
**bold text**
|
|
|
|
//italic text//
|
|
|
|
##monospaced text##
|
|
|
|
|
|
|
|
Those produce **bold text**, //italic text// and ##monospaced text##,
|
|
|
|
respectively.
|
|
|
|
|
|
|
|
= Layout =
|
|
|
|
|
|
|
|
Make **headers** like this:
|
|
|
|
|
|
|
|
= Large Header =
|
2012-01-16 20:45:43 +01:00
|
|
|
|
2011-05-29 19:20:24 +02:00
|
|
|
== Smaller Header ==
|
2012-01-16 20:45:43 +01:00
|
|
|
|
2011-05-29 19:20:24 +02:00
|
|
|
===== Very Small Header =====
|
|
|
|
|
2012-02-18 04:39:13 +01:00
|
|
|
You can optionally omit the trailing "=" signs -- that is, these are the same:
|
|
|
|
|
|
|
|
== Smaller Header ==
|
|
|
|
|
|
|
|
== Smaller Header
|
|
|
|
|
2012-01-16 20:45:43 +01:00
|
|
|
This produces headers like the ones in this document. Make sure you have an
|
|
|
|
empty line before and after the header.
|
2011-05-29 19:20:24 +02:00
|
|
|
|
2011-12-01 18:48:27 +01:00
|
|
|
Make **lists** by beginning each item with a "-" or a "*":
|
2011-05-29 19:20:24 +02:00
|
|
|
|
2011-08-03 17:17:53 +02:00
|
|
|
lang=text
|
2011-05-29 19:20:24 +02:00
|
|
|
- milk
|
|
|
|
- eggs
|
|
|
|
- bread
|
|
|
|
|
2011-12-01 18:48:27 +01:00
|
|
|
* duck
|
|
|
|
* duck
|
|
|
|
* goose
|
|
|
|
|
2011-05-29 19:20:24 +02:00
|
|
|
This produces a list like this:
|
|
|
|
|
|
|
|
- milk
|
|
|
|
- eggs
|
|
|
|
- bread
|
|
|
|
|
2011-12-01 18:48:27 +01:00
|
|
|
(Note that you need to put a space after the "-" or "*".)
|
|
|
|
|
2012-02-19 18:06:47 +01:00
|
|
|
You can make numbered lists with a "#" instead of "-" or "*":
|
|
|
|
|
|
|
|
# Articuno
|
|
|
|
# Zapdos
|
|
|
|
# Moltres
|
|
|
|
|
|
|
|
You can also nest lists:
|
|
|
|
|
|
|
|
- Body
|
|
|
|
- Head
|
|
|
|
- Arm
|
|
|
|
- Elbow
|
|
|
|
- Hand
|
|
|
|
# Thumb
|
|
|
|
# Index
|
|
|
|
# Middle
|
|
|
|
# Ring
|
|
|
|
# Pinkie
|
|
|
|
- Leg
|
|
|
|
- Knee
|
|
|
|
- Foot
|
|
|
|
|
2011-05-29 19:20:24 +02:00
|
|
|
Make **code blocks** by indenting two spaces:
|
|
|
|
|
|
|
|
f(x, y);
|
|
|
|
|
2011-12-01 18:48:27 +01:00
|
|
|
You can also use three backticks to enclose the code block:
|
|
|
|
|
|
|
|
```f(x, y);
|
|
|
|
g(f);```
|
|
|
|
|
2011-05-29 19:20:24 +02:00
|
|
|
You can specify a language for syntax highlighting with "lang=xxx":
|
|
|
|
|
2011-08-03 17:17:53 +02:00
|
|
|
lang=text
|
2011-05-29 19:20:24 +02:00
|
|
|
lang=html
|
|
|
|
<a href="#">...</a>
|
|
|
|
|
|
|
|
This will highlight the block using a highlighter for that language, if one is
|
|
|
|
available (in most cases, this means you need to configure Pygments):
|
|
|
|
|
|
|
|
lang=html
|
|
|
|
<a href="#">...</a>
|
|
|
|
|
|
|
|
You can also use a "COUNTEREXAMPLE" header to show that a block of code is
|
|
|
|
bad and shouldn't be copied:
|
|
|
|
|
2011-08-03 17:17:53 +02:00
|
|
|
lang=text
|
2011-05-29 19:20:24 +02:00
|
|
|
COUNTEREXAMPLE
|
|
|
|
function f() {
|
|
|
|
global $$variable_variable;
|
|
|
|
}
|
|
|
|
|
|
|
|
This produces a block like this:
|
|
|
|
|
|
|
|
COUNTEREXAMPLE
|
|
|
|
function f() {
|
|
|
|
global $$variable_variable;
|
|
|
|
}
|
|
|
|
|
2012-01-16 19:07:21 +01:00
|
|
|
You can use ##lines=N## to limit the vertical size of a chunk of code, and
|
|
|
|
##name=some_name.ext## to give it a name. For example, this:
|
|
|
|
|
|
|
|
lang=text
|
|
|
|
lang=html, name=example.html, lines=12, counterexample
|
|
|
|
...
|
|
|
|
|
|
|
|
...produces this:
|
|
|
|
|
|
|
|
lang=html, name=example.html, lines=12, counterexample
|
|
|
|
<p>Apple</p>
|
|
|
|
<p>Apricot</p>
|
|
|
|
<p>Avocado</p>
|
|
|
|
<p>Banana</p>
|
|
|
|
<p>Bilberry</p>
|
|
|
|
<p>Blackberry</p>
|
|
|
|
<p>Blackcurrant</p>
|
|
|
|
<p>Blueberry</p>
|
|
|
|
<p>Currant</p>
|
|
|
|
<p>Cherry</p>
|
|
|
|
<p>Cherimoya</p>
|
|
|
|
<p>Clementine</p>
|
|
|
|
<p>Date</p>
|
|
|
|
<p>Damson</p>
|
|
|
|
<p>Durian</p>
|
|
|
|
<p>Eggplant</p>
|
|
|
|
<p>Elderberry</p>
|
|
|
|
<p>Feijoa</p>
|
|
|
|
<p>Gooseberry</p>
|
|
|
|
<p>Grape</p>
|
|
|
|
<p>Grapefruit</p>
|
|
|
|
<p>Guava</p>
|
|
|
|
<p>Huckleberry</p>
|
|
|
|
<p>Jackfruit</p>
|
|
|
|
<p>Jambul</p>
|
|
|
|
<p>Kiwi fruit</p>
|
|
|
|
<p>Kumquat</p>
|
|
|
|
<p>Legume</p>
|
|
|
|
<p>Lemon</p>
|
|
|
|
<p>Lime</p>
|
|
|
|
<p>Lychee</p>
|
|
|
|
<p>Mandarine</p>
|
|
|
|
<p>Mango</p>
|
|
|
|
<p>Mangostine</p>
|
|
|
|
<p>Melon</p>
|
|
|
|
|
2011-12-01 18:48:27 +01:00
|
|
|
You can also use "NOTE:" to call out an important idea.
|
|
|
|
|
|
|
|
NOTE: Don't cross the streams!
|
|
|
|
|
2011-05-29 19:20:24 +02:00
|
|
|
= Linking URIs =
|
|
|
|
|
|
|
|
URIs are automatically linked: http://phabricator.org/
|
|
|
|
|
|
|
|
If you have a URI with problematic characters in it, like
|
|
|
|
"##http://comma.org/,##", you can surround it with angle brackets:
|
|
|
|
|
|
|
|
<http://comma.org/,>
|
|
|
|
|
|
|
|
This will force the parser to consume the whole URI: <http://comma.org/,>
|
|
|
|
|
2012-02-18 04:39:13 +01:00
|
|
|
You can also use create named links, where you choose the displayed text. These
|
|
|
|
work within Phabricator or on the internet at large:
|
|
|
|
|
|
|
|
[[/herald/transcript/ | Herald Transcripts]]
|
|
|
|
[[http://www.boring-legal-documents.com/ | exciting legal documents]]
|
|
|
|
|
2011-05-29 19:20:24 +02:00
|
|
|
= Linking to Objects =
|
|
|
|
|
|
|
|
You can link to Differential revisions, Diffusion commits and Maniphest tasks
|
|
|
|
by mentioning the name of an object:
|
|
|
|
|
|
|
|
D123 # Link to Differential revision D123
|
|
|
|
rX123 # Link to SVN commit 123 from the "X" repository
|
|
|
|
rXaf3192cd5 # Link to Git commit "af3192cd5..." from the "X" repository.
|
|
|
|
# You must specify at least 7 characters of the hash.
|
|
|
|
T123 # Link to Maniphest task T123
|
|
|
|
|
2011-05-31 19:23:31 +02:00
|
|
|
You can also link directly to a comment in Maniphest and Differential:
|
|
|
|
|
|
|
|
T123#4 # Link to comment #4 of T123
|
|
|
|
|
Provide a "reference-with-full-name" syntax for Remarkup
Summary:
Provide a {T123} syntax which pulls in the entire name of an object, not just a
link to it. A major use for this is organizing projects using wiki pages. Since
handle links show object status now, this lets you organize stuff in an ad-hoc
way and get a reasonable overview of it. We can make handles richer in the
future, too.
The performance on this isn't perfect (it adds some potential single gets) but I
think it's okay for now and I don't want to make remarkup engine even more
complex until the preprocess/postprocess stuff has had a chance to settle and
I'm more confident it works.
In Differential and Maniphest we'll also incorrectly cache the object
state/name, but that'll fix itself once I move the cache code to use
preprocess/postprocess correctly.
Test Plan:
- See https://secure.phabricator.com/file/view/PHID-FILE-5f9ca32407bec20899b9/
for an example.
- Generated and looked over the documentation.
Reviewed By: jungejason
Reviewers: jungejason, tuomaspelkonen, aran, hunterbridges
CC: skrul, aran, jungejason, epriestley
Differential Revision: 784
2011-08-05 17:50:26 +02:00
|
|
|
You can also generate full-name references to some objects by using braces:
|
|
|
|
|
|
|
|
{D123} # Link to Differential revision D123 with the full name
|
|
|
|
{T123} # Link to Maniphest task T123 with the full name
|
|
|
|
|
|
|
|
These references will also show when an object changes state (for instance, a
|
|
|
|
task is closed or a revision is committed).
|
|
|
|
|
2011-05-29 19:20:24 +02:00
|
|
|
= Quoting Text =
|
|
|
|
|
|
|
|
To quote text, preface it with an ">":
|
|
|
|
|
|
|
|
> This is quoted text.
|
|
|
|
|
|
|
|
This appears like this:
|
|
|
|
|
|
|
|
> This is quoted text.
|
|
|
|
|
Provide a "reference-with-full-name" syntax for Remarkup
Summary:
Provide a {T123} syntax which pulls in the entire name of an object, not just a
link to it. A major use for this is organizing projects using wiki pages. Since
handle links show object status now, this lets you organize stuff in an ad-hoc
way and get a reasonable overview of it. We can make handles richer in the
future, too.
The performance on this isn't perfect (it adds some potential single gets) but I
think it's okay for now and I don't want to make remarkup engine even more
complex until the preprocess/postprocess stuff has had a chance to settle and
I'm more confident it works.
In Differential and Maniphest we'll also incorrectly cache the object
state/name, but that'll fix itself once I move the cache code to use
preprocess/postprocess correctly.
Test Plan:
- See https://secure.phabricator.com/file/view/PHID-FILE-5f9ca32407bec20899b9/
for an example.
- Generated and looked over the documentation.
Reviewed By: jungejason
Reviewers: jungejason, tuomaspelkonen, aran, hunterbridges
CC: skrul, aran, jungejason, epriestley
Differential Revision: 784
2011-08-05 17:50:26 +02:00
|
|
|
= Embedding Images =
|
|
|
|
|
|
|
|
You can embed an image by using braces to refer to it:
|
|
|
|
|
2012-01-16 19:07:21 +01:00
|
|
|
{F123} # Embed the image file F123
|
Provide a "reference-with-full-name" syntax for Remarkup
Summary:
Provide a {T123} syntax which pulls in the entire name of an object, not just a
link to it. A major use for this is organizing projects using wiki pages. Since
handle links show object status now, this lets you organize stuff in an ad-hoc
way and get a reasonable overview of it. We can make handles richer in the
future, too.
The performance on this isn't perfect (it adds some potential single gets) but I
think it's okay for now and I don't want to make remarkup engine even more
complex until the preprocess/postprocess stuff has had a chance to settle and
I'm more confident it works.
In Differential and Maniphest we'll also incorrectly cache the object
state/name, but that'll fix itself once I move the cache code to use
preprocess/postprocess correctly.
Test Plan:
- See https://secure.phabricator.com/file/view/PHID-FILE-5f9ca32407bec20899b9/
for an example.
- Generated and looked over the documentation.
Reviewed By: jungejason
Reviewers: jungejason, tuomaspelkonen, aran, hunterbridges
CC: skrul, aran, jungejason, epriestley
Differential Revision: 784
2011-08-05 17:50:26 +02:00
|
|
|
|
|
|
|
In most interfaces, you can drag-and-drop an image from your computer into the
|
|
|
|
text area to upload and reference it.
|
|
|
|
|
2012-01-16 19:07:21 +01:00
|
|
|
You can set file display options like this:
|
|
|
|
|
|
|
|
{F123, layout=left, float, size=full}
|
|
|
|
|
|
|
|
Valid options are:
|
|
|
|
|
|
|
|
- **layout** left (default), center, right, inline
|
|
|
|
- **float** If layout is set to left or right, the image will be floated so
|
|
|
|
text wraps around it.
|
|
|
|
- **size** thumb (default), full
|
|
|
|
|
2011-05-29 19:20:24 +02:00
|
|
|
= Embedding Media =
|
|
|
|
|
|
|
|
If you set configuration flags, you can embed media directly in text:
|
|
|
|
|
|
|
|
- **files.enable-proxy**: allows you to paste in image URLs and have them
|
|
|
|
render inline.
|
|
|
|
- **remarkup.enable-embedded-youtube**: allows you to paste in YouTube videos
|
|
|
|
and have them render inline.
|
|
|
|
|
|
|
|
These options are disabled by default because they have security and/or
|
|
|
|
silliness implications, read their descriptions in ##default.conf.php## before
|
2011-06-12 01:23:57 +02:00
|
|
|
enabling them.
|
|
|
|
|
|
|
|
= Image Macros =
|
|
|
|
|
|
|
|
You can upload image macros (Files -> Image Macros) which will replace text
|
|
|
|
strings with the image you specify. For instance, you could upload an image of a
|
|
|
|
dancing banana to create a macro named "peanutbutterjellytime", and then any
|
|
|
|
time you type that string it will be replaced with the image of a dancing
|
2011-06-24 21:01:19 +02:00
|
|
|
banana.
|
|
|
|
|
|
|
|
= Mentioning Users =
|
|
|
|
|
|
|
|
In Differential and Maniphest, you can mention another user by writing:
|
|
|
|
|
|
|
|
@username
|
|
|
|
|
|
|
|
When you submit your comment, this will add them as a CC on the revision or task
|
2011-07-12 17:28:07 +02:00
|
|
|
if they aren't already CC'd.
|
|
|
|
|
|
|
|
= Phriction Documents =
|
|
|
|
|
|
|
|
You can link to Phriction documents with a name or path:
|
|
|
|
|
Require double brackets for Phriction links
Summary:
Single brackets are getting some troublesome false positives in Facebook's
install. Particularly, there's a weird convention at Facebook of tagging diffs
by putting stuff like "[perf]" or "[chat]" in the title, although this isn't
turned into structured data at any stage. When commits appear in Diffusion, we
currently link such ad-hoc tags to Phriction.
Wikipedia uses double-bracket sytnax, as do many other wikis, so this seems like
a reasonable burden to place on the lightweightness of the markup. The
alternative is selectively disabling Phriction markup in some interfaces, but
I'd rather allow integration in commit messages and just guard the syntax more
closely.
(I'm not providing any sort of migration plan since this landed less than a week
ago and I'm pretty confident no one has built a huge wiki yet, but I added a
CHANGELOG note.)
Test Plan: Edited a wiki document and added some links. Verified single brackets
were unlinked and double brackets were linked.
Reviewed By: jungejason
Reviewers: hsb, aran, jungejason, tuomaspelkonen
CC: aran, jungejason, epriestley
Differential Revision: 689
2011-07-18 17:52:40 +02:00
|
|
|
Make sure you sign and date your [[legal/Letter of Marque and Reprisal]]!
|
2011-07-12 17:28:07 +02:00
|
|
|
|
|
|
|
With a pipe (##|##), you can retitle the link. Use this to mislead your
|
|
|
|
opponents:
|
|
|
|
|
Require double brackets for Phriction links
Summary:
Single brackets are getting some troublesome false positives in Facebook's
install. Particularly, there's a weird convention at Facebook of tagging diffs
by putting stuff like "[perf]" or "[chat]" in the title, although this isn't
turned into structured data at any stage. When commits appear in Diffusion, we
currently link such ad-hoc tags to Phriction.
Wikipedia uses double-bracket sytnax, as do many other wikis, so this seems like
a reasonable burden to place on the lightweightness of the markup. The
alternative is selectively disabling Phriction markup in some interfaces, but
I'd rather allow integration in commit messages and just guard the syntax more
closely.
(I'm not providing any sort of migration plan since this landed less than a week
ago and I'm pretty confident no one has built a huge wiki yet, but I added a
CHANGELOG note.)
Test Plan: Edited a wiki document and added some links. Verified single brackets
were unlinked and double brackets were linked.
Reviewed By: jungejason
Reviewers: hsb, aran, jungejason, tuomaspelkonen
CC: aran, jungejason, epriestley
Differential Revision: 689
2011-07-18 17:52:40 +02:00
|
|
|
Check out these [[legal/boring_documents/ | exciting legal documents]]!
|
2011-08-31 22:42:52 +02:00
|
|
|
|
2012-01-04 03:08:58 +01:00
|
|
|
= Literal Blocks =
|
|
|
|
|
|
|
|
To place text in a literal block use "%%%":
|
|
|
|
|
|
|
|
%%%Text that won't be processed by remarkup
|
|
|
|
[[http://www.example.com | example]]
|
|
|
|
%%%
|
|
|
|
|
|
|
|
Remarkup will not process the text inside of literal blocks (other than to
|
|
|
|
escape HTML, linkify URLs, and preserve line breaks).
|