sorbet-struct-comparable 1.1.0 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.github/workflows/ci.yml +47 -52
- data/.gitignore +3 -0
- data/CHANGELOG.md +4 -0
- data/Gemfile +3 -8
- data/lib/sorbet-struct-comparable/version.rb +1 -1
- data/lib/t/struct/acts_as_comparable.rb +5 -0
- data/nix/sources.json +14 -0
- data/nix/sources.nix +174 -0
- data/run_ci.sh +6 -0
- data/shell.nix +20 -0
- data/sorbet/config +2 -0
- data/sorbet/rbi/gems/ast@2.4.2.rbi +54 -0
- data/sorbet/rbi/gems/byebug@11.1.3.rbi +1568 -0
- data/sorbet/rbi/gems/coderay@1.1.3.rbi +1005 -0
- data/sorbet/rbi/gems/diff-lcs@1.4.4.rbi +8 -0
- data/sorbet/rbi/gems/docile@1.4.0.rbi +54 -0
- data/sorbet/rbi/gems/method_source@1.0.0.rbi +72 -0
- data/sorbet/rbi/gems/parser@3.0.2.0.rbi +1188 -0
- data/sorbet/rbi/gems/pry-byebug@3.9.0.rbi +461 -0
- data/sorbet/rbi/gems/{pry.rbi → pry@0.13.1.rbi} +2308 -1706
- data/sorbet/rbi/{sorbet-typed/lib/rake/all/rake.rbi → gems/rake@13.0.6.rbi} +580 -430
- data/sorbet/rbi/gems/rbi@0.0.6.rbi +1405 -0
- data/sorbet/rbi/gems/{rspec-core.rbi → rspec-core@3.10.1.rbi} +2303 -1735
- data/sorbet/rbi/gems/{rspec-expectations.rbi → rspec-expectations@3.10.1.rbi} +1133 -707
- data/sorbet/rbi/gems/{rspec-mocks.rbi → rspec-mocks@3.10.2.rbi} +1299 -937
- data/sorbet/rbi/gems/rspec-support@3.10.2.rbi +509 -0
- data/sorbet/rbi/gems/rspec@3.10.0.rbi +38 -0
- data/sorbet/rbi/gems/simplecov-html@0.12.3.rbi +89 -0
- data/sorbet/rbi/gems/{simplecov.rbi → simplecov@0.21.2.rbi} +451 -293
- data/sorbet/rbi/gems/simplecov_json_formatter@0.1.3.rbi +8 -0
- data/sorbet/rbi/gems/spoom@1.1.5.rbi +1241 -0
- data/sorbet/rbi/gems/tapioca@0.5.2.rbi +949 -0
- data/sorbet/rbi/gems/thor@1.1.0.rbi +839 -0
- data/sorbet/rbi/gems/unparser@0.6.0.rbi +8 -0
- metadata +34 -29
- data/.ruby-version +0 -1
- data/sorbet/rbi/gems/byebug.rbi +0 -1041
- data/sorbet/rbi/gems/coderay.rbi +0 -92
- data/sorbet/rbi/gems/docile.rbi +0 -36
- data/sorbet/rbi/gems/listen.rbi +0 -301
- data/sorbet/rbi/gems/method_source.rbi +0 -64
- data/sorbet/rbi/gems/pry-byebug.rbi +0 -155
- data/sorbet/rbi/gems/rake.rbi +0 -642
- data/sorbet/rbi/gems/rspec-support.rbi +0 -280
- data/sorbet/rbi/gems/rspec.rbi +0 -15
- data/sorbet/rbi/gems/simplecov-html.rbi +0 -35
- data/sorbet/rbi/gems/simplecov_json_formatter.rbi +0 -45
- data/sorbet/rbi/hidden-definitions/errors.txt +0 -2742
- data/sorbet/rbi/hidden-definitions/hidden.rbi +0 -6540
- data/sorbet/rbi/sorbet-typed/lib/rspec-core/all/rspec-core.rbi +0 -1891
- data/sorbet/rbi/todo.rbi +0 -6
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: d75584d06f03e99a4b6d99e85532a200df25cd1e394dacc2ee40618f906728d6
|
4
|
+
data.tar.gz: 3f958d5649ede2d8e7448799860c01646ce718039031f9017dc995211cecca78
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 10b0597ced15739b32d12ed3758ccfd2d61075e24e374abfcdc6a3f74ecd89db5e919bb3e9f52ae31f5b4cc5a41b8a5b9550e1e928a7de1af25850355b8ebea1
|
7
|
+
data.tar.gz: f32f196a0dd234bc76f1512cc62f783e114c3e614a377d5426d0974eabd81487adac7ba20be9ec68f4cf91828fe029c70a93c2e767571d9b9b464adb8380895d
|
data/.github/workflows/ci.yml
CHANGED
@@ -1,53 +1,48 @@
|
|
1
1
|
---
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
FAILURE*\", \"attachments\": [{ \"fallback\": \"Failure summary\", \"color\":
|
50
|
-
\"#ff0000\", \"fields\": [{\"title\": \"Branch\", \"value\":\"${{ steps.extract_branch.outputs.branch
|
51
|
-
}}\"}, {\"title\": \"Who broke it\", \"value\":\"${{ github.actor }}\"},
|
52
|
-
{ \"title\": \"Build output\", \"value\": \"https://github.com/${{ github.repository
|
53
|
-
}}/commit/${{ github.sha }}/checks\", \"short\": false }]}]}'
|
2
|
+
name: Continuous Integration
|
3
|
+
on:
|
4
|
+
push:
|
5
|
+
branches-ignore:
|
6
|
+
- refs/tags/*_staging
|
7
|
+
- refs/tags/*_production
|
8
|
+
jobs:
|
9
|
+
build:
|
10
|
+
runs-on: ubuntu-18.04
|
11
|
+
steps:
|
12
|
+
- name: Checkout branch
|
13
|
+
uses: actions/checkout@v2
|
14
|
+
- name: Extract branch name
|
15
|
+
shell: bash
|
16
|
+
run: echo "##[set-output name=branch;]$(echo ${GITHUB_REF#refs/heads/})"
|
17
|
+
id: extract_branch
|
18
|
+
- name: Cache gems
|
19
|
+
uses: actions/cache@v2
|
20
|
+
with:
|
21
|
+
path: vendor/bundle
|
22
|
+
key: "${{ runner.OS }}-gem-cache-${{ hashFiles('**/*.gemspec')
|
23
|
+
}}"
|
24
|
+
restore-keys: "${{ runner.OS }}-gem-cache-\n"
|
25
|
+
- uses: "cachix/install-nix-action@8d6d5e949675fbadb765c6b1a975047fa5f09b27"
|
26
|
+
with:
|
27
|
+
extra_nix_config: |
|
28
|
+
post-build-hook = /etc/nix/upload-to-cache.sh
|
29
|
+
substituters = https://cache.nixos.org/
|
30
|
+
trusted-public-keys = cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY=
|
31
|
+
nix_path: nixpkgs=channel:nixos-21.05
|
32
|
+
- name: Run CI through nix-shell
|
33
|
+
env:
|
34
|
+
GEMFURY_DEPLOY_TOKEN: ${{ secrets.GEMFURY_DEPLOY_TOKEN }}
|
35
|
+
run: nix-shell --run "chmod 755 ./run_ci.sh && ./run_ci.sh"
|
36
|
+
- name: Post to Slack if build fails
|
37
|
+
if: failure() && (github.ref == 'refs/heads/master' || github.ref == 'refs/heads/main'
|
38
|
+
|| github.ref == 'refs/heads/stable')
|
39
|
+
uses: pullreminders/slack-action@a5a262c896a1cc80dcbae59ba95513e2dfb21439
|
40
|
+
env:
|
41
|
+
SLACK_BOT_TOKEN: "${{ secrets.SLACK_BOT_TOKEN }}"
|
42
|
+
with:
|
43
|
+
args: '{\"channel\":\"C33574SJJ\",\"text\":\"* ${{ github.repository }} BUILD
|
44
|
+
FAILURE*\", \"attachments\": [{ \"fallback\": \"Failure summary\", \"color\":
|
45
|
+
\"#ff0000\", \"fields\": [{\"title\": \"Branch\", \"value\":\"${{ steps.extract_branch.outputs.branch
|
46
|
+
}}\"}, {\"title\": \"Who broke it\", \"value\":\"${{ github.actor }}\"},
|
47
|
+
{ \"title\": \"Build output\", \"value\": \"https://github.com/${{ github.repository
|
48
|
+
}}/commit/${{ github.sha }}/checks\", \"short\": false }]}]}'
|
data/.gitignore
CHANGED
data/CHANGELOG.md
CHANGED
data/Gemfile
CHANGED
@@ -4,19 +4,14 @@ source 'https://rubygems.org'
|
|
4
4
|
gemspec
|
5
5
|
|
6
6
|
group :development, :test do
|
7
|
-
gem 'rake'
|
8
|
-
gem 'rspec'
|
7
|
+
gem 'rake'
|
8
|
+
gem 'rspec'
|
9
9
|
gem 'pry-byebug'
|
10
10
|
gem 'sorbet'
|
11
11
|
gem 'sorbet-runtime'
|
12
|
-
|
13
|
-
|
14
|
-
group :development do
|
15
|
-
gem 'spring'
|
16
|
-
gem 'spring-watcher-listen'
|
12
|
+
gem 'tapioca'
|
17
13
|
end
|
18
14
|
|
19
15
|
group :test do
|
20
16
|
gem 'simplecov'
|
21
|
-
gem 'spring-commands-rspec'
|
22
17
|
end
|
data/nix/sources.json
ADDED
@@ -0,0 +1,14 @@
|
|
1
|
+
{
|
2
|
+
"nixpkgs": {
|
3
|
+
"branch": "nixos-21.05",
|
4
|
+
"description": "Nix packages collection",
|
5
|
+
"homepage": "https://github.com/NixOS/nixpkgs",
|
6
|
+
"owner": "NixOS",
|
7
|
+
"repo": "nixpkgs",
|
8
|
+
"rev": "e85f0175e3effe9ba191d66c09e8f1b7d6362d5e",
|
9
|
+
"sha256": "1qr2hmymbzwj8jrz6smcgc04scgwp2v5070x22k4fvh261g1n4zw",
|
10
|
+
"type": "tarball",
|
11
|
+
"url": "https://github.com/NixOS/nixpkgs/archive/e85f0175e3effe9ba191d66c09e8f1b7d6362d5e.tar.gz",
|
12
|
+
"url_template": "https://github.com/<owner>/<repo>/archive/<rev>.tar.gz"
|
13
|
+
}
|
14
|
+
}
|
data/nix/sources.nix
ADDED
@@ -0,0 +1,174 @@
|
|
1
|
+
# This file has been generated by Niv.
|
2
|
+
|
3
|
+
let
|
4
|
+
|
5
|
+
#
|
6
|
+
# The fetchers. fetch_<type> fetches specs of type <type>.
|
7
|
+
#
|
8
|
+
|
9
|
+
fetch_file = pkgs: name: spec:
|
10
|
+
let
|
11
|
+
name' = sanitizeName name + "-src";
|
12
|
+
in
|
13
|
+
if spec.builtin or true then
|
14
|
+
builtins_fetchurl { inherit (spec) url sha256; name = name'; }
|
15
|
+
else
|
16
|
+
pkgs.fetchurl { inherit (spec) url sha256; name = name'; };
|
17
|
+
|
18
|
+
fetch_tarball = pkgs: name: spec:
|
19
|
+
let
|
20
|
+
name' = sanitizeName name + "-src";
|
21
|
+
in
|
22
|
+
if spec.builtin or true then
|
23
|
+
builtins_fetchTarball { name = name'; inherit (spec) url sha256; }
|
24
|
+
else
|
25
|
+
pkgs.fetchzip { name = name'; inherit (spec) url sha256; };
|
26
|
+
|
27
|
+
fetch_git = name: spec:
|
28
|
+
let
|
29
|
+
ref =
|
30
|
+
if spec ? ref then spec.ref else
|
31
|
+
if spec ? branch then "refs/heads/${spec.branch}" else
|
32
|
+
if spec ? tag then "refs/tags/${spec.tag}" else
|
33
|
+
abort "In git source '${name}': Please specify `ref`, `tag` or `branch`!";
|
34
|
+
in
|
35
|
+
builtins.fetchGit { url = spec.repo; inherit (spec) rev; inherit ref; };
|
36
|
+
|
37
|
+
fetch_local = spec: spec.path;
|
38
|
+
|
39
|
+
fetch_builtin-tarball = name: throw
|
40
|
+
''[${name}] The niv type "builtin-tarball" is deprecated. You should instead use `builtin = true`.
|
41
|
+
$ niv modify ${name} -a type=tarball -a builtin=true'';
|
42
|
+
|
43
|
+
fetch_builtin-url = name: throw
|
44
|
+
''[${name}] The niv type "builtin-url" will soon be deprecated. You should instead use `builtin = true`.
|
45
|
+
$ niv modify ${name} -a type=file -a builtin=true'';
|
46
|
+
|
47
|
+
#
|
48
|
+
# Various helpers
|
49
|
+
#
|
50
|
+
|
51
|
+
# https://github.com/NixOS/nixpkgs/pull/83241/files#diff-c6f540a4f3bfa4b0e8b6bafd4cd54e8bR695
|
52
|
+
sanitizeName = name:
|
53
|
+
(
|
54
|
+
concatMapStrings (s: if builtins.isList s then "-" else s)
|
55
|
+
(
|
56
|
+
builtins.split "[^[:alnum:]+._?=-]+"
|
57
|
+
((x: builtins.elemAt (builtins.match "\\.*(.*)" x) 0) name)
|
58
|
+
)
|
59
|
+
);
|
60
|
+
|
61
|
+
# The set of packages used when specs are fetched using non-builtins.
|
62
|
+
mkPkgs = sources: system:
|
63
|
+
let
|
64
|
+
sourcesNixpkgs =
|
65
|
+
import (builtins_fetchTarball { inherit (sources.nixpkgs) url sha256; }) { inherit system; };
|
66
|
+
hasNixpkgsPath = builtins.any (x: x.prefix == "nixpkgs") builtins.nixPath;
|
67
|
+
hasThisAsNixpkgsPath = <nixpkgs> == ./.;
|
68
|
+
in
|
69
|
+
if builtins.hasAttr "nixpkgs" sources
|
70
|
+
then sourcesNixpkgs
|
71
|
+
else if hasNixpkgsPath && ! hasThisAsNixpkgsPath then
|
72
|
+
import <nixpkgs> {}
|
73
|
+
else
|
74
|
+
abort
|
75
|
+
''
|
76
|
+
Please specify either <nixpkgs> (through -I or NIX_PATH=nixpkgs=...) or
|
77
|
+
add a package called "nixpkgs" to your sources.json.
|
78
|
+
'';
|
79
|
+
|
80
|
+
# The actual fetching function.
|
81
|
+
fetch = pkgs: name: spec:
|
82
|
+
|
83
|
+
if ! builtins.hasAttr "type" spec then
|
84
|
+
abort "ERROR: niv spec ${name} does not have a 'type' attribute"
|
85
|
+
else if spec.type == "file" then fetch_file pkgs name spec
|
86
|
+
else if spec.type == "tarball" then fetch_tarball pkgs name spec
|
87
|
+
else if spec.type == "git" then fetch_git name spec
|
88
|
+
else if spec.type == "local" then fetch_local spec
|
89
|
+
else if spec.type == "builtin-tarball" then fetch_builtin-tarball name
|
90
|
+
else if spec.type == "builtin-url" then fetch_builtin-url name
|
91
|
+
else
|
92
|
+
abort "ERROR: niv spec ${name} has unknown type ${builtins.toJSON spec.type}";
|
93
|
+
|
94
|
+
# If the environment variable NIV_OVERRIDE_${name} is set, then use
|
95
|
+
# the path directly as opposed to the fetched source.
|
96
|
+
replace = name: drv:
|
97
|
+
let
|
98
|
+
saneName = stringAsChars (c: if isNull (builtins.match "[a-zA-Z0-9]" c) then "_" else c) name;
|
99
|
+
ersatz = builtins.getEnv "NIV_OVERRIDE_${saneName}";
|
100
|
+
in
|
101
|
+
if ersatz == "" then drv else
|
102
|
+
# this turns the string into an actual Nix path (for both absolute and
|
103
|
+
# relative paths)
|
104
|
+
if builtins.substring 0 1 ersatz == "/" then /. + ersatz else /. + builtins.getEnv "PWD" + "/${ersatz}";
|
105
|
+
|
106
|
+
# Ports of functions for older nix versions
|
107
|
+
|
108
|
+
# a Nix version of mapAttrs if the built-in doesn't exist
|
109
|
+
mapAttrs = builtins.mapAttrs or (
|
110
|
+
f: set: with builtins;
|
111
|
+
listToAttrs (map (attr: { name = attr; value = f attr set.${attr}; }) (attrNames set))
|
112
|
+
);
|
113
|
+
|
114
|
+
# https://github.com/NixOS/nixpkgs/blob/0258808f5744ca980b9a1f24fe0b1e6f0fecee9c/lib/lists.nix#L295
|
115
|
+
range = first: last: if first > last then [] else builtins.genList (n: first + n) (last - first + 1);
|
116
|
+
|
117
|
+
# https://github.com/NixOS/nixpkgs/blob/0258808f5744ca980b9a1f24fe0b1e6f0fecee9c/lib/strings.nix#L257
|
118
|
+
stringToCharacters = s: map (p: builtins.substring p 1 s) (range 0 (builtins.stringLength s - 1));
|
119
|
+
|
120
|
+
# https://github.com/NixOS/nixpkgs/blob/0258808f5744ca980b9a1f24fe0b1e6f0fecee9c/lib/strings.nix#L269
|
121
|
+
stringAsChars = f: s: concatStrings (map f (stringToCharacters s));
|
122
|
+
concatMapStrings = f: list: concatStrings (map f list);
|
123
|
+
concatStrings = builtins.concatStringsSep "";
|
124
|
+
|
125
|
+
# https://github.com/NixOS/nixpkgs/blob/8a9f58a375c401b96da862d969f66429def1d118/lib/attrsets.nix#L331
|
126
|
+
optionalAttrs = cond: as: if cond then as else {};
|
127
|
+
|
128
|
+
# fetchTarball version that is compatible between all the versions of Nix
|
129
|
+
builtins_fetchTarball = { url, name ? null, sha256 }@attrs:
|
130
|
+
let
|
131
|
+
inherit (builtins) lessThan nixVersion fetchTarball;
|
132
|
+
in
|
133
|
+
if lessThan nixVersion "1.12" then
|
134
|
+
fetchTarball ({ inherit url; } // (optionalAttrs (!isNull name) { inherit name; }))
|
135
|
+
else
|
136
|
+
fetchTarball attrs;
|
137
|
+
|
138
|
+
# fetchurl version that is compatible between all the versions of Nix
|
139
|
+
builtins_fetchurl = { url, name ? null, sha256 }@attrs:
|
140
|
+
let
|
141
|
+
inherit (builtins) lessThan nixVersion fetchurl;
|
142
|
+
in
|
143
|
+
if lessThan nixVersion "1.12" then
|
144
|
+
fetchurl ({ inherit url; } // (optionalAttrs (!isNull name) { inherit name; }))
|
145
|
+
else
|
146
|
+
fetchurl attrs;
|
147
|
+
|
148
|
+
# Create the final "sources" from the config
|
149
|
+
mkSources = config:
|
150
|
+
mapAttrs (
|
151
|
+
name: spec:
|
152
|
+
if builtins.hasAttr "outPath" spec
|
153
|
+
then abort
|
154
|
+
"The values in sources.json should not have an 'outPath' attribute"
|
155
|
+
else
|
156
|
+
spec // { outPath = replace name (fetch config.pkgs name spec); }
|
157
|
+
) config.sources;
|
158
|
+
|
159
|
+
# The "config" used by the fetchers
|
160
|
+
mkConfig =
|
161
|
+
{ sourcesFile ? if builtins.pathExists ./sources.json then ./sources.json else null
|
162
|
+
, sources ? if isNull sourcesFile then {} else builtins.fromJSON (builtins.readFile sourcesFile)
|
163
|
+
, system ? builtins.currentSystem
|
164
|
+
, pkgs ? mkPkgs sources system
|
165
|
+
}: rec {
|
166
|
+
# The sources, i.e. the attribute set of spec name to spec
|
167
|
+
inherit sources;
|
168
|
+
|
169
|
+
# The "pkgs" (evaluated nixpkgs) to use for e.g. non-builtin fetchers
|
170
|
+
inherit pkgs;
|
171
|
+
};
|
172
|
+
|
173
|
+
in
|
174
|
+
mkSources (mkConfig {}) // { __functor = _: settings: mkSources (mkConfig settings); }
|
data/run_ci.sh
ADDED
data/shell.nix
ADDED
@@ -0,0 +1,20 @@
|
|
1
|
+
{ sources ? import ./nix/sources.nix }:
|
2
|
+
let
|
3
|
+
nixpkgs = import sources.nixpkgs { };
|
4
|
+
in
|
5
|
+
nixpkgs.mkShell {
|
6
|
+
name = "bellroy-gem-env";
|
7
|
+
buildInputs = with nixpkgs; [
|
8
|
+
bundler
|
9
|
+
libnotify
|
10
|
+
niv
|
11
|
+
pkg-config
|
12
|
+
readline
|
13
|
+
ruby_2_7
|
14
|
+
zlib
|
15
|
+
]
|
16
|
+
++ (if stdenv.hostPlatform.isDarwin then [ libiconv darwin.apple_sdk.frameworks.CoreServices ] else [ ]);
|
17
|
+
shellHook = ''
|
18
|
+
bundle config --local path "$PWD/vendor/bundle"
|
19
|
+
'';
|
20
|
+
}
|
data/sorbet/config
CHANGED
@@ -0,0 +1,54 @@
|
|
1
|
+
# DO NOT EDIT MANUALLY
|
2
|
+
# This is an autogenerated file for types exported from the `ast` gem.
|
3
|
+
# Please instead update this file by running `bin/tapioca gem ast`.
|
4
|
+
|
5
|
+
# typed: true
|
6
|
+
|
7
|
+
module AST; end
|
8
|
+
|
9
|
+
class AST::Node
|
10
|
+
def initialize(type, children = T.unsafe(nil), properties = T.unsafe(nil)); end
|
11
|
+
|
12
|
+
def +(array); end
|
13
|
+
def <<(element); end
|
14
|
+
def ==(other); end
|
15
|
+
def append(element); end
|
16
|
+
def children; end
|
17
|
+
def clone; end
|
18
|
+
def concat(array); end
|
19
|
+
def deconstruct; end
|
20
|
+
def dup; end
|
21
|
+
def eql?(other); end
|
22
|
+
def hash; end
|
23
|
+
def inspect(indent = T.unsafe(nil)); end
|
24
|
+
def to_a; end
|
25
|
+
def to_ast; end
|
26
|
+
def to_s(indent = T.unsafe(nil)); end
|
27
|
+
def to_sexp(indent = T.unsafe(nil)); end
|
28
|
+
def to_sexp_array; end
|
29
|
+
def type; end
|
30
|
+
def updated(type = T.unsafe(nil), children = T.unsafe(nil), properties = T.unsafe(nil)); end
|
31
|
+
|
32
|
+
protected
|
33
|
+
|
34
|
+
def assign_properties(properties); end
|
35
|
+
def fancy_type; end
|
36
|
+
|
37
|
+
private
|
38
|
+
|
39
|
+
def original_dup; end
|
40
|
+
end
|
41
|
+
|
42
|
+
class AST::Processor
|
43
|
+
include ::AST::Processor::Mixin
|
44
|
+
end
|
45
|
+
|
46
|
+
module AST::Processor::Mixin
|
47
|
+
def handler_missing(node); end
|
48
|
+
def process(node); end
|
49
|
+
def process_all(nodes); end
|
50
|
+
end
|
51
|
+
|
52
|
+
module AST::Sexp
|
53
|
+
def s(type, *children); end
|
54
|
+
end
|