-
Notifications
You must be signed in to change notification settings - Fork 22.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
92 changed files
with
2,780 additions
and
100 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,141 @@ | ||
# This file tests more or less everything related to a pull request. All | ||
# in one big job. At the end, if all the testing passes, it proceeds | ||
# to upload all the files that were built to our Dev environment. | ||
# This way, if the tests passed, you'll be able to review the built | ||
# pages on a public URL. | ||
|
||
name: PR Test - new CI | ||
|
||
on: | ||
pull_request: | ||
branches: | ||
- main | ||
|
||
jobs: | ||
tests: | ||
if: github.repository == 'mdn/content' && startsWith(github.event.pull_request.title, '[new-ci]') | ||
runs-on: ubuntu-latest | ||
# Set the permissions to `read-all`, preventing the workflow from | ||
# any accidental write access to the repository. | ||
permissions: read-all | ||
env: | ||
BASE_SHA: ${{ github.event.pull_request.base.sha }} | ||
HEAD_SHA: ${{ github.event.pull_request.head.sha }} | ||
# This is the directory where the built files will be placed. | ||
# It's also hardcoded in the `yarn build` command in package.json. | ||
# If you change it here, you must also make the same change in | ||
# package.json. | ||
BUILD_OUT_ROOT: build | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- name: Get changed files | ||
run: | | ||
# Use the GitHub API to get the list of changed files | ||
# documentation: https://docs.github.com/rest/commits/commits#compare-two-commits | ||
DIFF_DOCUMENTS=$(gh api repos/{owner}/{repo}/compare/${BASE_SHA}...${HEAD_SHA} \ | ||
--jq '.files | .[] | select(.status|IN("added", "modified", "renamed", "copied", "changed")) | .filename') | ||
# filter out files that are not markdown files | ||
GIT_DIFF_CONTENT=$(echo "${DIFF_DOCUMENTS}" | egrep -i "^files/.*\.(md)$" | xargs) | ||
echo "GIT_DIFF_CONTENT=${GIT_DIFF_CONTENT}" >> $GITHUB_ENV | ||
# filter out files that are not attachments | ||
GIT_DIFF_FILES=$(echo "${DIFF_DOCUMENTS}" | egrep -i "^files/.*\.(png|jpeg|jpg|gif|svg|webp)$" | xargs) | ||
echo "GIT_DIFF_FILES=${GIT_DIFF_FILES}" >> $GITHUB_ENV | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
- name: Setup Node.js environment | ||
if: ${{ env.GIT_DIFF_CONTENT }} || ${{ env.GIT_DIFF_FILES }} | ||
uses: actions/setup-node@v4 | ||
with: | ||
node-version-file: ".nvmrc" | ||
cache: yarn | ||
|
||
- name: Install all yarn packages | ||
if: ${{ env.GIT_DIFF_CONTENT }} || ${{ env.GIT_DIFF_FILES }} | ||
run: yarn --frozen-lockfile | ||
env: | ||
# https://github.com/microsoft/vscode-ripgrep#github-api-limit-note | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
- name: Build changed content | ||
id: build-content | ||
if: ${{ env.GIT_DIFF_CONTENT }} | ||
env: | ||
CONTENT_ROOT: ${{ github.workspace }}/files | ||
|
||
# This is so that if there's a single 'unsafe_html' flaw, it | ||
# completely fails the build. | ||
# But all other flaws should be 'warn', so that we can include | ||
# information about the flaws when we analyze the built PR. | ||
BUILD_FLAW_LEVELS: "unsafe_html: error, *:warn" | ||
|
||
# Because we build these pages in a way that you get a toolbar, | ||
# so the flaws can be displayed, but we don't want any of the | ||
# other toolbar features like "Fix fixable flaws" or "Quick-edit" | ||
# we set this to disable that stuff. | ||
REACT_APP_CRUD_MODE_READONLY: true | ||
|
||
BUILD_LIVE_SAMPLES_BASE_URL: https://live.mdnyalp.dev | ||
BUILD_LEGACY_LIVE_SAMPLES_BASE_URL: https://live-samples.mdn.allizom.net | ||
|
||
# In these builds, we never care for or need the ability to sign in. | ||
# This environment variable will disable that functionality entirely. | ||
REACT_APP_DISABLE_AUTH: true | ||
|
||
# TODO: This should be implicit when `CI=true` | ||
BUILD_NO_PROGRESSBAR: true | ||
|
||
# Playground | ||
REACT_APP_PLAYGROUND_BASE_HOST: mdnyalp.dev | ||
|
||
# rari | ||
LIVE_SAMPLES_BASE_URL: https://live.mdnyalp.dev | ||
INTERACTIVE_EXAMPLES_BASE_URL: https://interactive-examples.mdn.allizom.net | ||
|
||
run: | | ||
# The reason this script isn't in `package.json` is because | ||
# you don't need that script as a writer. It's only used in CI | ||
# and it can't use the default CONTENT_ROOT that gets set in | ||
# package.json. | ||
echo Y|yarn rari update | ||
ARGS=$(echo $GIT_DIFF_CONTENT | sed -E -e "s#(^| )files#\1-f $PWD/files#g") | ||
yarn rari build --no-basic --json-issues $ARGS | ||
yarn yari-render-html | ||
echo "Disk usage size of the build" | ||
du -sh $BUILD_OUT_ROOT | ||
# Save the PR number into the build | ||
echo ${{ github.event.number }} > ${BUILD_OUT_ROOT}/NR | ||
# Download the raw diff blob and store that inside the build | ||
# directory. | ||
# The purpose of this is for the PR Review Companion to later | ||
# be able to use this raw diff file for the benefit of analyzing. | ||
wget https://github.com/${{ github.repository }}/compare/${BASE_SHA}...${HEAD_SHA}.diff -O ${BUILD_OUT_ROOT}/DIFF | ||
- name: Merge static assets with built documents | ||
if: ${{ env.GIT_DIFF_CONTENT }} | ||
run: | | ||
# Exclude the .map files, as they're used for debugging JS and CSS. | ||
rsync -a --exclude "*.map" node_modules/@mdn/yari/client/build/ $BUILD_OUT_ROOT | ||
# Show the final disk usage size of the build. | ||
du -sh $BUILD_OUT_ROOT | ||
- uses: actions/upload-artifact@v4 | ||
if: ${{ env.GIT_DIFF_CONTENT }} | ||
with: | ||
name: build | ||
path: ${{ env.BUILD_OUT_ROOT }} | ||
|
||
- name: Check changed files | ||
if: ${{ env.GIT_DIFF_FILES }} | ||
run: | | ||
echo $GIT_DIFF_FILES | ||
export CONTENT_ROOT=$(pwd)/files | ||
yarn filecheck $GIT_DIFF_FILES |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
--- | ||
title: Escape character | ||
slug: Glossary/Escape_character | ||
page-type: glossary-definition | ||
--- | ||
|
||
{{GlossarySidebar}} | ||
|
||
An **escape character** is a {{glossary("character")}} that causes one or more characters that follow it to be interpreted differently. This forms an **escape sequence**, which is often used to represent a character that has an alternative meaning when printed literally, such as the quote character in a string literal. Escape sequences can have other usages too, especially in [regular expressions](/en-US/docs/Web/JavaScript/Reference/Regular_expressions#escape_sequences). | ||
|
||
- In JavaScript [regexes](/en-US/docs/Web/JavaScript/Reference/Regular_expressions/Character_escape), [string literals](/en-US/docs/Web/JavaScript/Reference/Lexical_grammar#string_literals), and [identifiers](/en-US/docs/Web/JavaScript/Reference/Lexical_grammar#identifiers), we can use the backslash (`\`) to escape characters like `\'`, `\"`, `\u0026`, etc. | ||
- In CSS identifiers, we can use the backslash (`\`) to escape characters like `\\`, `\n`, `\26`, etc. See [escape characters](/en-US/docs/Web/CSS/ident#escaping_characters) for more information. | ||
- In HTML text content and attribute values, we can use {{glossary("character reference", "character references")}} like `<`, `<`, or `<`. | ||
- In {{glossary("URL", "URLs")}}, we can use the percent sign (`%`) to escape characters like `%20`, `%3C`, `%3E`, etc. | ||
|
||
## See also | ||
|
||
- Related glossary terms: | ||
- {{glossary("Character")}} | ||
- {{glossary("Character reference")}} | ||
- {{glossary("Code point")}} | ||
- [Escape character](https://en.wikipedia.org/wiki/Escape_character) on Wikipedia | ||
- [Escape sequence](https://en.wikipedia.org/wiki/Escape_sequence) on Wikipedia |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
--- | ||
title: "DOMMatrixReadOnly: flipY() method" | ||
short-title: flipY() | ||
slug: Web/API/DOMMatrixReadOnly/flipY | ||
page-type: web-api-instance-method | ||
browser-compat: api.DOMMatrixReadOnly.flipY | ||
--- | ||
|
||
{{APIRef("Geometry Interfaces")}}{{AvailableInWorkers}} | ||
|
||
The **`flipY()`** method of the {{domxref("DOMMatrixReadOnly")}} interface creates a new matrix being the result of the original matrix flipped about the y-axis. This is equivalent to multiplying the matrix by `DOMMatrix(1, 0, 0, -1, 0, 0)`. The original matrix is not modified. | ||
|
||
## Syntax | ||
|
||
```js-nolint | ||
DOMMatrixReadOnly.flipY() | ||
``` | ||
|
||
### Return value | ||
|
||
A [`DOMMatrix`](/en-US/docs/Web/API/DOMMatrix). | ||
|
||
## Examples | ||
|
||
### Inverting a triangle | ||
|
||
In this example, the SVG contains two identical [paths](/en-US/docs/Web/SVG/Attribute/d) in the shape of a triangle; they are both drawn to have the same size and position. The viewbox has a negative y value showing us content from both sides of the y-axis. This enables the flipped triangle to be withing the viewport after it is transformed. | ||
|
||
#### HTML | ||
|
||
```html | ||
<svg height="200" width="100" viewBox="0 -100 100 200"> | ||
<path fill="red" d="M 0 0 L 100 0 L 50 100 Z" /> | ||
<path fill="blue" d="M 0 0 L 100 0 L 50 100 Z" id="flipped" /> | ||
</svg> | ||
``` | ||
|
||
#### JavaScript | ||
|
||
The JavaScript creates an [identity matrix](/en-US/docs/Web/API/DOMMatrixReadOnly/isIdentity), then uses the `flipY()` method to create a new matrix, which is then applied to the blue triangle, inverting it across the y-axis. The red triangle is left in place. | ||
|
||
```js | ||
const flipped = document.getElementById("flipped"); | ||
const matrix = new DOMMatrix(); | ||
const flippedMatrix = matrix.flipY(); | ||
flipped.setAttribute("transform", flippedMatrix.toString()); | ||
``` | ||
|
||
#### Result | ||
|
||
{{EmbedLiveSample('Inverting a triangle', '', '240')}} | ||
|
||
## Specifications | ||
|
||
{{Specifications}} | ||
|
||
## Browser compatibility | ||
|
||
{{Compat}} | ||
|
||
## See also | ||
|
||
- {{domxref("DOMMatrixReadOnly.flipX()")}} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.