- features https://github.com/features/
- changelog https://github.blog/changelog
- public roadmap https://github.com/orgs/github/projects/4247
Main site
- https://github.com/dashboard-feed old feed
Repository specific
# PAT ::= "commits" | "tree"
https://github.com/OWNER/REPO/PAT/REF_OR_COMMIT/path/to/dir
# PAT ::= "blob" | "blame" | "commits" | "edit" | "raw"
https://github.com/OWNER/REPO/PAT/REF_OR_COMMIT/path/to/file
# "commit"
https://github.com/OWNER/REPO/commit/SHA (shortened SHA works too)
https://github.com/OWNER/REPO/commit/SHA.diff
https://github.com/OWNER/REPO/commit/SHA.patch
# "labels"
https://github.com/OWNER/REPO/labels
https::/github.com/OWNER/REPO/labels/LABEL_NAME
# "issues"
https://github.com/OWNER/REPO/issues
https://github.com/OWNER/REPO/issues/AUTHOR # aka "is:open is:issue author:AUTHOR"
# special author "@me" supported
https://github.com/OWNER/REPO/issues/created_by/AUTHOR
https://github.com/OWNER/REPO/issues/ISSUE_NUMBER
https://github.com/OWNER/REPO/issues/new # blank issue
https://github.com/OWNER/REPO/issues/new/choose # choose an issue template
https://github.com/pgf-tikz/pgf/issues/new?assignees=&labels=&projects=&template=ISSUE_TEMPLATE.{md,yml}
# create an issue from a URL query
# https://docs.github.com/en/issues/tracking-your-work-with-issues/creating-an-issue#creating-an-issue-from-a-url-query
# "pulls" and "pull"
https://github.com/OWNER/REPO/pulls
https://github.com/OWNER/REPO/pulls/AUTHOR # aka "is:open is:pr author:AUTHOR"
https://github.com/OWNER/REPO/pull/PR_NUMBER
# "compare"
# see https://docs.github.com/en/pull-requests/committing-changes-to-your-project/viewing-and-comparing-commits
https://github.com/OWNER/REPO/compare/SHA_BASE..SHA_HEAD
https://github.com/OWNER/REPO/compare/BASE_BRANCH...REPO_B:HEAD_BRANCH
https://github.com/OWNER/REPO/compare/BASE_BRANCH...REPO_B:HEAD_BRANCH?expand=1 # open a pr
where
REF_OR_COMMIT ::= REFERENCE | COMMIT
REFERENCE ::= BRANCH | TAG
# top-level misc
https://github.com/OWNER/REPO#readme-ov-file # readme
https://github.com/OWNER/REPO/contribute
https://github.com/OWNER/REPO/stargazers
https://github.com/OWNER/REPO/watchers
https://github.com/OWNER/REPO/forks
raw
pattern first saw in CTeX-org/ctex-kit#686 (comment)contribute
page first saw in https://docs.github.com/en/issues/using-labels-and-milestones-to-track-work/managing-labels#about-default-labels
- general Markdown notes
- spec https://github.github.com/gfm/
- related Github docs https://docs.github.com/en/get-started/writing-on-github
Links
<!-- full-reference-link -->
[my text][my-label] <!-- link-text == "my text", link-label == "my-label" -->
<!-- shortcut-reference-link -->
[my-label] <!-- link-text == link-label == "my-label" -->
<!-- link reference definition -->
[my-label]: /my-url
-
GFM Spec
- link-reference-definition
[link-label]: link-destination "link-title"
https://github.github.com/gfm/#link-reference-definitions- the concept
link-text
,link-label
, andlink-title
defined in GFM Spec contain the corresponding delimiters like[...]
or"..."
- the concept
- link
https://github.github.com/gfm/#links
- components: link-text, link-destination, and link-title
https://github.github.com/gfm/#link-text
https://github.github.com/gfm/#link-destination
https://github.github.com/gfm/#link-title
- link-title is optional
- classification
tip: link-text is always taken from the first
[...]
- inline-link
[link-text](link-destination "link-title")
- link-title can alternatively be delimited by
'...'
and(...)
https://github.github.com/gfm/#inline-link
- link-title can alternatively be delimited by
- reference-link
https://github.github.com/gfm/#reference-link
- full-reference-link
[link-text][link-label]
https://github.github.com/gfm/#full-reference-link - collapsed-reference-link
[link-label][]
, equivalent to full-reference-link[link-label][link-label]
https://github.github.com/gfm/#collapsed-reference-link - shortcut-reference-link
[link-label]
, equivalent to collapsed-reference-link[link-label][]
https://github.github.com/gfm/#shortcut-reference-link
- full-reference-link
- inline-link
- components: link-text, link-destination, and link-title
https://github.github.com/gfm/#link-text
https://github.github.com/gfm/#link-destination
https://github.github.com/gfm/#link-title
- link-reference-definition
-
Confusing description in 0.29-gfm
- phrase "first link label" in definitions of concepts "collapsed reference link" and "shortcut reference link"
-
A collapsed reference link consists of a link label that matches a link reference definition elsewhere in the document, followed by the string
[]
. The contents of the first link label are parsed as inlines, which are used as the link’s text. https://github.github.com/gfm/#collapsed-reference-link -
A shortcut reference link consists of a link label that matches a link reference definition elsewhere in the document and is not followed by
[]
or a link label. The contents of the first link label are parsed as inlines, which are used as the link’s text. https://github.github.com/gfm/#shortcut-reference-link - Q: What does "first link label" here mean?
- Can be traced back to commonmark spec. commonmark/commonmark-spec#746
- On 2023-10-18, CommonMark has removed the two occurrences of word "first". Waiting for GFM to catch up.
-
- phrase "first link label" in definitions of concepts "collapsed reference link" and "shortcut reference link"
Special Usages
-
Using
<span>
tag to disable auto-linking https://gist.github.com/alexpeattie/4729247 -
Using
<details>
and<summary>
tags to create collapsed sections- shortcut: typing
/details
, a GitHub slash commandhttps://github.blog/changelog/2023-03-15-introducing-the-github-markdown-helpers-public-beta/ https://docs.github.com/en/issues/tracking-your-work-with-issues/about-slash-commands<details><summary>Details</summary> <p> |cursor position </p> </details>
- example
https://docs.github.com/en/get-started/writing-on-github/working-with-advanced-formatting/organizing-information-with-collapsed-sections
<details> <summary>Details about <code>\x</code></summary> markdown content normally parsed </details>
- notes
<details>
starts a three-line html block which is treated as raw html, and can only be ended by a blank line. Thus the content of<summary>
element is not parsed as markdown. https://github.github.com/gfm/#html-blocks- To enable parsing,
<summary>
open tag must be followed by a blank line. But this will make the<summary>
content a block element (surrounded by<p>
). It will look like▸<newline>Details about ...
. https://github.github.com/gfm/#paragraphs - A CSS solution is to set
details summary > * { display: inline; }
, but it seems GitHub blocks user-specified re-styling. Not only<style>
element, butstyle
attribute like<summary style="color: red;">
are blocked. https://css-tricks.com/two-issues-styling-the-details-element-and-how-to-solve-them/#aa-inline-all-the-things https://github.github.com/gfm/#disallowed-raw-html-extension-
- MDN docs https://developer.mozilla.org/en-US/docs/Web/HTML/Element/details https://developer.mozilla.org/en-US/docs/Web/HTML/Element/summary
- shortcut: typing
-
no-backlink references Replace
github.com
withredirect.github.com
. Shortage: no link shortening is applied any more. github/docs#35987 https://github.com/orgs/community/discussions/23123#discussioncomment-11891227 Linking to an issue without creating a reference- https://docs.github.com/en/get-started/writing-on-github/working-with-advanced-formatting/autolinked-references-and-urls Autolinked references and URLs
Filter issues and pull requests https://docs.github.com/en/search-github/searching-on-github/searching-issues-and-pull-requests
author:@me
mentions:USERNAME # note the third person singular "s"
commenter:USERNAME
head:HEAD_BRANCH
All my subscriptions
- special git refs
head commit
refs/pull/PR_NUMBER/head
merge branchrefs/pull/PR_NUMBER/merge
(only for open PRs)git ls-remote REMOTE <pattern>...
- see also https://fluffyandflakey.blog/2022/12/21/what-is-a-github-pull-request-merge-branch/
Check out a PR locally
# fetch and create a local branch
git fetch origin pull/PR_NUMBER/head:BRANCH && git switch BRANCH
# fetch only
# https://stackoverflow.com/a/45967995
git fetch origin pull/PR_NUMBER/head && git switch --detach FETCH_HEAD
# update
# --force is needed for divergent branches
git fetch --force --update-head-ok origin pull/PR_NUMBER/head:BRANCH
- via the GitHub CLI
gh pr checkout <pr_number>
This fails with non-globremote.<name>.fetch
git config (usually resulted from a shallow clone), see cli/cli#4287
- labels in a repo
https://github.com/OWNER/REPO/labels
or
gh label list --repo OWNER/REPO
https://cli.github.com/manual/gh_label_list
Abstractions
- workflow run "pages build and deployment"
demo in https://github.com/actions/jekyll-build-pages
- job "build"
- uses action image
ghcr.io/actions/jekyll-build-pages:vx.y.z
packed by https://github.com/actions/jekyll-build-pages depends ongem "github-pages", "= VERSION"
https://github.com/actions/jekyll-build-pages/blob/main/Gemfile- gem package
github-pages
https://github.com/github/pages-gem depends on"jekyll" => "x.y.z",
https://github.com/github/pages-gem/blob/master/lib/github-pages/dependencies.rb
- gem package
- uses action image
- job "report-build-status" which needs "build"
- job "deploy" which need "build"
- job "build"
Dependency versions
- https://pages.github.com/versions/
- Till 2023-11-23, Jekyll 3.9.3, rather than 4.x is used.
"jekyll" => "3.9.3",
https://github.com/github/pages-gem/blob/v228/lib/github-pages/dependencies.rb
Build site locally
# install prerequisitions
gem install bundler
# create "Gemfile", if it doesn't exist
echo "gem 'github-pages', group: :jekyll_plugins" > Gemfile
# to use the same version as GitHub Pages
# echo "gem 'github-pages', \"~> VERSION\", group: :jekyll_plugins" > Gemfile
# workaround for "webrick"
bundle add webrick
# install (ruby packages), build, and serve
bundle install
bundle exec jekyll serve
Docs and useful links
- Building your site locally - GitHub Docs (outdated, Jan 20 2021)
- Dependency gem versions
About the webrick
workaround
jekyll
depends onwebrick
, but the latter one is no longer a bundled gem in Ruby 3.0.- Once
jekyll
releases a new version (most likely v4.3) including the PR resolving this, and gemgihub-pages
uses that newerjekyll
, then the workaround is not needed.
-
meta
- general https://github.com/features/#features-automation https://github.com/features/actions
- docs https://docs.github.com/actions
- marketplace of actions https://github.com/marketplace?type=actions
- changelog https://github.blog/changelog/label/actions/
- repos
https://github.com/actions/runner
https://github.com/actions/runner-images
- GitHub-hosted runners, their YAML labels and included softwares
-
workflow a
.github/workflows/filename.(yml|yaml)
file- structure
- each workflow contains one or more jobs
- each job either contains one or more steps (
jobs.<job_id>.steps
) or uses another (reusable) workflow (jobs.<job_id>.uses
) see github/vscode-github-actions#291 - each step either uses an action (
jobs.<job_id>.steps[*].uses
) or runs some code (jobs.<job_id>.steps[*].run
)
- actions used by steps
uses: actions/checkout@main
- such actions are one of "Docker container action", "JavaScript action", and "composite action"
- reusable workflows used by jobs
jobs.<job_id>.uses: {owner}/{repo}/.github/workflows/{filename}@{ref}
- reusable workflows must have the
on.workflow_call
event https://docs.github.com/en/actions/sharing-automations/reusing-workflows
- composite actions vs reusable workflows https://docs.github.com/en/actions/sharing-automations/avoiding-duplication#comparison-of-reusable-workflows-and-composite-actions
- structure
-
workflow syntax https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions
- glob pattern
*
doesn't match/
, use**
instead https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#filter-pattern-cheat-sheet- misuse: using
on.push.branches: ["*"]
to accept all branches, but actually branches containing/
are filtered out latex3/latex3#1293
- misuse: using
on.(push|pull_request).(paths|paths_ignore)
should match a (relative) path to file, sopaths: dir/**
works butpaths: dir
doesn't https://github.com/muzimuzhi/hello-github-actions/commit/c84ebdc31cc0af60d02ed74ceffb3a069ee772e1
- glob pattern
-
variables
- default environment variables
https://docs.github.com/en/actions/learn-github-actions/variables#default-environment-variables
Because default environment variables are set by GitHub and not defined in a workflow, they are not accessible through the
env
context.- run | echo 'github.workspace === ${{ github.workspace }}' # ok echo "GITHUB_WORKSPACE === $GITHUB_WORKSPACE" # ok echo 'env.GITHUB_WORKSPACE === ${{ env.GITHUB_WORKSPACE }}' # wrong
- use env var as boolean
if: fromJSON(env.MY_VAR) # all truthy values are accepted if: env.MY_VAR == 'true' # suppose MY_VAR is either 'true' or 'false'
- Background: using env var used in conditionals along
- if non-existent or empty -> falsy value
""
(string) ->false
(boolean) - otherwise -> truthy value (string) ->
true
(boolean) - So with
env.MY_ENV_VAR: false
,if: $MY_ENV_VAR
evaluates to true
- if non-existent or empty -> falsy value
- Background: using env var used in conditionals along
- default environment variables
https://docs.github.com/en/actions/learn-github-actions/variables#default-environment-variables
-
expressions
- if-else (ternary operator) in expressions
${{ x && 'ifTrue' || 'ifFalse' }}
the first value after the
&&
must be truthy https://docs.github.com/en/actions/writing-workflows/choosing-what-your-workflow-does/evaluate-expressions-in-workflows-and-actions#operators
- if-else (ternary operator) in expressions
-
run logs
working-directory
is never logged, even when debug logging is enabled https://docs.github.com/actions/monitoring-and-troubleshooting-workflows/enabling-debug-logging- can be set by one or more of
defaults.run.working-directory
,jobs.<job_id>.defaults.run.working-directory
, andjobs.<job_id>.steps[*].working-directory
- only
shell
andenv
are always logged for all steps. Quite some other step properties are similarly hidden in logs - Sep 15, 2024: feedback submitted https://github.com/orgs/community/discussions/138657
- can be set by one or more of
-
frequently used actions
actions/checkout
https://github.com/actions/checkout- name: Checkout uses: actions/checkout@v<n> with: # when possible, default values are listed repository: ${{ github.repository }} ref: "${{ github.ref }} or the HEAD of default branch" path: . # relative path under ${{ github.workspace }} fetch-depth: 1 # 0 indicates "all history for all branches and tags" fetch-tags: false lfs: false submodules: false # more sophisticated inputs filter: '' # see `git clone --filter=<filter-spec>` # https://git-scm.com/docs/git-clone#Documentation/git-clone.txt-code--filtercodeemltfilter-specgtem sparse-checkout: null # see `git sparse-checkout` # https://git-scm.com/docs/git-sparse-checkout
- by default checks out
${{ github.repository }}
to${{ github.workspace }}
- configurable via
repository
andpath
(relative path, sub-dir only) inputs
- configurable via
- in most cases the
path
directory is erased before checkout- for example, when
path
doesn't contain a pre-existing.git
dir actions/checkout#561 - job log
Deleting the contents of '/home/runner/work/REPO/REPO'
- for example, when
- default setting
set-safe-directory: true
doesn't work for containers- workaround:
git config set --global safe.directory "*"
(too loose?) - actions/runner#2033 "git config safe.directory inside docker containers" actions/checkout#766 "fatal: unsafe repository (REPO is owned by someone else) in other workflow steps after running checkout" actions/checkout#1169 "/github/home/.gitconfig does not exist for container runs"
- workaround:
- by default checks out
-
tools
- vscode extensions (not actively maintained)
- https://github.com/github/vscode-github-actions
https://marketplace.visualstudio.com/items?itemName=GitHub.vscode-github-actions "GitHub Actions"
it's linter is not as comprehensive and updated as others'
- important dependency https://github.com/actions/languageservices
- https://github.com/redhat-developer/vscode-yaml https://marketplace.visualstudio.com/items?itemName=redhat.vscode-yaml "YAML" uses JSON schemas for workflow and action files from https://www.schemastore.org/json/
- https://github.com/github/vscode-github-actions
https://marketplace.visualstudio.com/items?itemName=GitHub.vscode-github-actions "GitHub Actions"
it's linter is not as comprehensive and updated as others'
- linter
- vscode extensions (not actively maintained)