Skip to content

Commit 95301e4

Browse files
committed
Merge remote-tracking branch 'upstream/develop' into fix/remark-plugin
2 parents 131ea6e + 6264042 commit 95301e4

File tree

3 files changed

+223
-3
lines changed

3 files changed

+223
-3
lines changed
Lines changed: 84 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,84 @@
1+
#/
2+
# @license Apache-2.0
3+
#
4+
# Copyright (c) 2025 The Stdlib Authors.
5+
#
6+
# Licensed under the Apache License, Version 2.0 (the "License");
7+
# you may not use this file except in compliance with the License.
8+
# You may obtain a copy of the License at
9+
#
10+
# http://www.apache.org/licenses/LICENSE-2.0
11+
#
12+
# Unless required by applicable law or agreed to in writing, software
13+
# distributed under the License is distributed on an "AS IS" BASIS,
14+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15+
# See the License for the specific language governing permissions and
16+
# limitations under the License.
17+
#/
18+
19+
# Workflow name:
20+
name: label_good_first_prs
21+
22+
# Workflow triggers:
23+
on:
24+
pull_request_target:
25+
types:
26+
- opened
27+
- closed
28+
- synchronize
29+
- reopened
30+
- edited
31+
32+
# Workflow jobs:
33+
jobs:
34+
35+
# Define a job which automatically labels pull requests based on whether they reference good first issues
36+
labeler:
37+
38+
# Define job name:
39+
name: 'Label PRs for issues with label "Good First Issue" as "Good First PR"s'
40+
41+
# Only run this job if the pull request did not have label `automated-pr`:
42+
if: contains(github.event.pull_request.labels.*.name, 'automated-pr') == false
43+
44+
# Define job permissions:
45+
permissions:
46+
contents: read
47+
pull-requests: write
48+
49+
# Define the type of virtual host machine:
50+
runs-on: ubuntu-latest
51+
52+
# Define the sequence of job steps:
53+
steps:
54+
# Check whether any of the referenced issues is a "Good First Issue":
55+
- name: 'Check whether any of the referenced issues is a "Good First Issue"'
56+
id: 'check-pr'
57+
env:
58+
PR_NUMBER: ${{ github.event.pull_request.number }}
59+
run: |
60+
bool=$(. "$GITHUB_WORKSPACE/.github/workflows/scripts/references_good_first_issue $PR_NUMBER)
61+
echo "good-first-pr=$bool" >> $GITHUB_OUTPUT
62+
63+
# Add "Good First PR" label if PR references a "Good First Issue"
64+
- name: 'Add "Good First PR" label if PR references a "Good First Issue"'
65+
if: ${{ steps.check-pr.outputs.good-first-pr == 'true' }}
66+
# Pin action to full-length commit SHA
67+
uses: actions/github-script@60a0d83039c74a4aee543508d2ffcb1c3799cdea # v7.0.1
68+
with:
69+
github-token: ${{ secrets.STDLIB_BOT_PAT_REPO_WRITE }}
70+
script: |
71+
const { data: pr } = await github.rest.pulls.get({
72+
'owner': context.repo.owner,
73+
'repo': context.repo.repo,
74+
'pull_number': context.payload.pull_request.number
75+
});
76+
const labels = context.payload.pull_request.labels.map( label => label.name );
77+
if ( !labels.includes( 'Good First PR' ) ) {
78+
await github.rest.issues.addLabels({
79+
'owner': context.repo.owner,
80+
'repo': context.repo.repo,
81+
'issue_number': context.payload.pull_request.number,
82+
'labels': [ 'Good First PR' ]
83+
});
84+
}
Lines changed: 139 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,139 @@
1+
#!/usr/bin/env bash
2+
#
3+
# @license Apache-2.0
4+
#
5+
# Copyright (c) 2025 The Stdlib Authors.
6+
#
7+
# Licensed under the Apache License, Version 2.0 (the "License");
8+
# you may not use this file except in compliance with the License.
9+
# You may obtain a copy of the License at
10+
#
11+
# http://www.apache.org/licenses/LICENSE-2.0
12+
#
13+
# Unless required by applicable law or agreed to in writing, software
14+
# distributed under the License is distributed on an "AS IS" BASIS,
15+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16+
# See the License for the specific language governing permissions and
17+
# limitations under the License.
18+
19+
# Script to check whether a PR references an issue with label "Good First Issue".
20+
#
21+
# Usage: references_good_first_issue <pr_number>
22+
#
23+
# Arguments:
24+
#
25+
# pr_number Pull request number.
26+
#
27+
# Environment variables:
28+
#
29+
# GITHUB_TOKEN GitHub token for authentication.
30+
31+
# Ensure that the exit status of pipelines is non-zero in the event that at least one of the commands in a pipeline fails:
32+
set -o pipefail
33+
34+
35+
# VARIABLES #
36+
37+
# Resolve the pull request number:
38+
pr_number="$1"
39+
40+
# GitHub API base URL:
41+
github_api_url="https://api.github.com"
42+
43+
# Repository owner and name:
44+
repo_owner="stdlib-js"
45+
repo_name="stdlib"
46+
47+
48+
# FUNCTIONS #
49+
50+
# Error handler.
51+
#
52+
# $1 - error status
53+
on_error() {
54+
echo 'ERROR: An error was encountered during execution.' >&2
55+
exit "$1"
56+
}
57+
58+
# Performs a GitHub API request.
59+
#
60+
# $1 - HTTP method (GET or POST)
61+
# $2 - API endpoint
62+
# $3 - data for POST requests
63+
github_api() {
64+
local method="$1"
65+
local endpoint="$2"
66+
local data="$3"
67+
68+
# Initialize an array to hold curl headers:
69+
local headers=()
70+
71+
# If GITHUB_TOKEN is set, add the Authorization header:
72+
if [ -n "${GITHUB_TOKEN}" ]; then
73+
headers+=("-H" "Authorization: token ${GITHUB_TOKEN}")
74+
fi
75+
76+
# Determine the HTTP method and construct the curl command accordingly...
77+
case "${method}" in
78+
GET)
79+
curl -s "${headers[@]}" "${github_api_url}${endpoint}"
80+
;;
81+
POST)
82+
# For POST requests, always set the Content-Type header:
83+
headers+=("-H" "Content-Type: application/json")
84+
85+
# If data is provided, include it in the request:
86+
if [ -n "${data}" ]; then
87+
curl -s -X POST "${headers[@]}" -d "${data}" "${github_api_url}${endpoint}"
88+
else
89+
# Handle cases where POST data is required but not provided:
90+
echo "ERROR: POST request requires data."
91+
on_error 1
92+
fi
93+
;;
94+
*)
95+
echo "ERROR: Invalid HTTP method: ${method}."
96+
on_error 1
97+
;;
98+
esac
99+
}
100+
101+
# Main execution sequence.
102+
main() {
103+
local issue_numbers
104+
local issue_details
105+
local pr_details
106+
local pr_body
107+
local issue
108+
local bool
109+
110+
if [ -z "${pr_number}" ]; then
111+
echo "ERROR: Pull request number is required." >&2
112+
on_error 1
113+
fi
114+
115+
# Fetch pull request details:
116+
pr_details=$(github_api "GET" "/repos/${repo_owner}/${repo_name}/pulls/${pr_number}")
117+
pr_body=$(echo "${pr_details}" | jq -r '.body')
118+
119+
issue_numbers=$(echo "${pr_body}" | grep -Ei '#[0-9]+' | grep -oEi '[0-9]+' | sort | uniq)
120+
if [ -z "${issue_numbers}" ]; then
121+
echo 'false'
122+
exit 0
123+
fi
124+
125+
for issue in ${issue_numbers}; do
126+
issue_details=$(github_api "GET" "/repos/${repo_owner}/${repo_name}/issues/${issue}")
127+
128+
bool=$(echo "${issue_details}" | jq '.labels | any(.name == "Good First Issue")')
129+
if [ "${bool}" == 'true' ]; then
130+
echo 'true'
131+
exit 0
132+
fi
133+
done
134+
135+
echo 'false'
136+
exit 0
137+
}
138+
139+
main

lib/node_modules/@stdlib/utils/README.md

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -318,7 +318,6 @@ The namespace has the following sub-namespaces:
318318
- <span class="signature">[`safeintmax( dtype )`][@stdlib/utils/safe-int-max]</span><span class="delimiter">: </span><span class="description">return the maximum safe integer capable of being represented by a numeric real type.</span>
319319
- <span class="signature">[`safeintmin( dtype )`][@stdlib/utils/safe-int-min]</span><span class="delimiter">: </span><span class="description">return the minimum safe integer capable of being represented by a numeric real type.</span>
320320
- <span class="signature">[`sizeOf( dtype )`][@stdlib/utils/size-of]</span><span class="delimiter">: </span><span class="description">return the size (in bytes) of the canonical binary representation of a specified numeric type.</span>
321-
- <span class="signature">[`thunk( fcn[, ...args] )`][@stdlib/utils/thunk]</span><span class="delimiter">: </span><span class="description">generate a thunk.</span>
322321
- <span class="signature">[`timeit( code, [options,] clbk )`][@stdlib/utils/timeit]</span><span class="delimiter">: </span><span class="description">time a snippet.</span>
323322
- <span class="signature">[`typemax( dtype )`][@stdlib/utils/type-max]</span><span class="delimiter">: </span><span class="description">return the maximum value of a specified numeric type.</span>
324323
- <span class="signature">[`typemin( dtype )`][@stdlib/utils/type-min]</span><span class="delimiter">: </span><span class="description">return the minimum value of a specified numeric type.</span>
@@ -439,8 +438,6 @@ console.log( objectKeys( utils ) );
439438

440439
[@stdlib/utils/size-of]: https://github.com/stdlib-js/stdlib/tree/develop/lib/node_modules/%40stdlib/utils/size-of
441440

442-
[@stdlib/utils/thunk]: https://github.com/stdlib-js/stdlib/tree/develop/lib/node_modules/%40stdlib/utils/thunk
443-
444441
[@stdlib/utils/timeit]: https://github.com/stdlib-js/stdlib/tree/develop/lib/node_modules/%40stdlib/utils/timeit
445442

446443
[@stdlib/utils/type-max]: https://github.com/stdlib-js/stdlib/tree/develop/lib/node_modules/%40stdlib/utils/type-max

0 commit comments

Comments
 (0)