diff --git a/util/gh-pages/index.html b/util/gh-pages/index.html
index e11f2eeba3b3..428708136cb6 100644
--- a/util/gh-pages/index.html
+++ b/util/gh-pages/index.html
@@ -89,7 +89,7 @@
ALL the Clippy Lints
+ ng-repeat="lint in data | filter:byLevels | filter:byGroups | filter:bySearch | orderBy:'id' track by lint.id">
@@ -215,6 +215,46 @@
return $scope.groups[lint.group];
};
+ $scope.bySearch = function (lint, index, array) {
+ let search_str = $scope.search;
+ // It can be `null` I haven't missed this value
+ if (search_str == null || search_str.length == 0) {
+ return true;
+ }
+ search_str = search_str.toLowerCase();
+
+ // Search by id
+ let id_search = search_str.trim().replace(/(\-| )/g, "_");
+ if (lint.id.includes(id_search)) {
+ return true;
+ }
+
+ // Search the description
+ // The use of `for`-loops instead of `foreach` enables us to return early
+ let search_lint = (lint, therm) => {
+ for (const field in lint.docs) {
+ // Continue if it's not a property
+ if (!lint.docs.hasOwnProperty(field)) {
+ continue;
+ }
+
+ // Return if not found
+ if (lint.docs[field].toLowerCase().includes(therm)) {
+ return true;
+ }
+ }
+ return false;
+ };
+ let therms = search_str.split(" ");
+ for (index = 0; index < therms.length; index++) {
+ if (!search_lint(lint, therms[index])) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
// Get data
$scope.open = {};
$scope.loading = true;