automatic_namespaces 0.3.1 → 0.5.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/README.md +27 -6
- data/lib/automatic_namespaces/autoloader.rb +20 -17
- data/lib/automatic_namespaces/version.rb +1 -1
- metadata +7 -7
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e7aa390b64ae64d8c78d9b6ac2af5bd2e98d0c63007220eccba244f90ed3c674
|
4
|
+
data.tar.gz: 9acd543871604473d1ac25ca14d64e48873c18c7265ea4c9641def935737ecb4
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 0b2c495a8cd14320988c3ee06a760f913611f1e2f5cf82d14ec0ba01d276b85bd00a8d404b1d6bed6e37a1a0ba454a76a1bfda15327fb445798751d03fef425d
|
7
|
+
data.tar.gz: df329e6def590f4714ef782ab235d82a89daee0fbf2cf3291527e1bd3cf719f24e7bb75981c40d659db98dc31140e3f4732b867eccf888d3daf6a966e06a51e4
|
data/README.md
CHANGED
@@ -11,7 +11,7 @@ app
|
|
11
11
|
│ │ ├── class1.rb # contains Component1::Class1
|
12
12
|
```
|
13
13
|
|
14
|
-
When building a modular monolith using packages ([packwerk](https://github.com/Shopify/packwerk) + [
|
14
|
+
When building a modular monolith using packages ([packwerk](https://github.com/Shopify/packwerk) + [packs-rails](https://github.com/rubyatscale/packs-rails)),
|
15
15
|
this pattern creates a lot of extra noise in the directory structure:
|
16
16
|
|
17
17
|
```
|
@@ -40,7 +40,7 @@ And that's only for a single pack! As your modular monolith grows, you'll likely
|
|
40
40
|
hundreds) of packs. That's a lot of "namespace" directories that aren't adding a lot of value. You already
|
41
41
|
know the namespace of those classes in a strongly namespaced pack -- it's the pack name -- can Zeitwerk know it, too?
|
42
42
|
|
43
|
-
This gem
|
43
|
+
This gem configures the Rails 7 autoloader so that most subdirectories under your strongly namespaced component's `app` directory are
|
44
44
|
automatically associated with the namespace.
|
45
45
|
|
46
46
|
## Installation
|
@@ -57,7 +57,7 @@ If bundler is not being used to manage dependencies, install the gem by executin
|
|
57
57
|
|
58
58
|
Given the `package.yml` of a strongly namespaced pack:
|
59
59
|
|
60
|
-
```
|
60
|
+
```yml
|
61
61
|
enforce_dependencies: true
|
62
62
|
enforce_privacy: true
|
63
63
|
public_path: app/public/
|
@@ -72,7 +72,7 @@ metadata:
|
|
72
72
|
|
73
73
|
modify the metadata to opt into automatic namespacing:
|
74
74
|
|
75
|
-
```
|
75
|
+
```yml
|
76
76
|
metadata:
|
77
77
|
automatic_pack_namespace: true
|
78
78
|
```
|
@@ -85,10 +85,21 @@ generally contain namespaced classes. These are exempted from `automatic_namespa
|
|
85
85
|
* javascript
|
86
86
|
* views
|
87
87
|
|
88
|
+
Additional directories can be excluded by adding them to the `automatic_pack_namespace_exclusions` key in your
|
89
|
+
`package.yml` file. This is useful if you require files in your pack that sit outside of your packs namespace:
|
90
|
+
|
91
|
+
```yml
|
92
|
+
metadata:
|
93
|
+
automatic_pack_namespace: true
|
94
|
+
automatic_pack_namespace_exclusions:
|
95
|
+
- app/policies # Exclude pundit policies
|
96
|
+
- app/admin # Exclude active admin definition files
|
97
|
+
```
|
98
|
+
|
88
99
|
If your package / namespace name requires ActiveSupport inflections, you will probably need to tell `automatic_namespaces`
|
89
100
|
what the correct namespace name should be in that package:
|
90
101
|
|
91
|
-
```
|
102
|
+
```yml
|
92
103
|
# packs/shoes_ui/package.yml
|
93
104
|
metadata:
|
94
105
|
automatic_pack_namespace: true
|
@@ -98,9 +109,19 @@ metadata:
|
|
98
109
|
This is necessary because `automatic_namespaces` works by modifying the autoloader paths, which has to
|
99
110
|
happen during Rails application initialization; but the inflector is not available for use then.
|
100
111
|
|
112
|
+
If you would like to use your own file layout conventions for packs (i.e. not `app/*`) you can specify
|
113
|
+
your own glob by using `autoload_glob` to append the glob to the folder containing package.yml. This defaults
|
114
|
+
to `'/**/app/*'`
|
115
|
+
|
116
|
+
```yml
|
117
|
+
metadata:
|
118
|
+
# Put the folder containing package.yml as the root for the autoloader.
|
119
|
+
autoload_glob: ''
|
120
|
+
```
|
121
|
+
|
101
122
|
## Development
|
102
123
|
|
103
|
-
After checking out the repo, run `bundle
|
124
|
+
After checking out the repo, run `bundle install` to install dependencies. Then, run `rspec` to run the tests.
|
104
125
|
|
105
126
|
To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and the created tag, and push the `.gem` file to [rubygems.org](https://rubygems.org).
|
106
127
|
|
@@ -1,35 +1,42 @@
|
|
1
1
|
require 'yaml'
|
2
2
|
|
3
3
|
class AutomaticNamespaces::Autoloader
|
4
|
+
DEFAULT_EXCLUDED_DIRS = %w[/app/helpers /app/inputs /app/javascript /app/views].freeze
|
5
|
+
PACKAGE_EXCLUDED_DIRS_KEY = "automatic_pack_namespace_exclusions".freeze
|
4
6
|
|
5
7
|
def enable_automatic_namespaces
|
6
8
|
namespaced_packages.each do |pack, metadata|
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
9
|
+
set_namespace_for_pack(pack, metadata)
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
def set_namespace_for_pack(pack, metadata)
|
14
|
+
package_namespace = define_namespace(pack, metadata)
|
15
|
+
pack_directories(pack.path, metadata).each do |pack_dir|
|
16
|
+
set_namespace_for_dir(pack_dir, package_namespace)
|
11
17
|
end
|
12
18
|
end
|
13
19
|
|
14
20
|
private
|
15
21
|
|
16
|
-
def
|
22
|
+
def set_namespace_for_dir(pack_dir, package_namespace)
|
17
23
|
Rails.logger.debug { "Associating #{pack_dir} with namespace #{package_namespace}" }
|
18
24
|
ActiveSupport::Dependencies.autoload_paths.delete(pack_dir)
|
19
25
|
Rails.autoloaders.main.push_dir(pack_dir, namespace: package_namespace)
|
20
26
|
Rails.application.config.watchable_dirs[pack_dir] = [:rb]
|
21
27
|
end
|
22
28
|
|
23
|
-
def pack_directories(pack_root_dir)
|
24
|
-
|
29
|
+
def pack_directories(pack_root_dir, metadata)
|
30
|
+
glob = metadata['autoload_glob'] || "/**/app/*"
|
31
|
+
Dir.glob("#{pack_root_dir}#{glob}").select { |dir| namespaced_directory?(dir, metadata) }
|
32
|
+
end
|
33
|
+
|
34
|
+
def namespaced_directory?(dir, metadata)
|
35
|
+
excluded_directories(metadata).none? { |excluded_dir| dir.include?(excluded_dir) }
|
25
36
|
end
|
26
37
|
|
27
|
-
def
|
28
|
-
|
29
|
-
dir.include?('/app/helpers') || # Rails assumes helpers are global, not namespaced
|
30
|
-
dir.include?('/app/inputs') || # Not sure how to namespace form inputs
|
31
|
-
dir.include?('/app/javascript') ||
|
32
|
-
dir.include?('/app/views')
|
38
|
+
def excluded_directories(metadata)
|
39
|
+
DEFAULT_EXCLUDED_DIRS + metadata.fetch(PACKAGE_EXCLUDED_DIRS_KEY, [])
|
33
40
|
end
|
34
41
|
|
35
42
|
def define_namespace(pack, metadata)
|
@@ -59,7 +66,3 @@ class AutomaticNamespaces::Autoloader
|
|
59
66
|
package_description["metadata"]
|
60
67
|
end
|
61
68
|
end
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: automatic_namespaces
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.5.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Gary Passero
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2025-01-15 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activesupport
|
@@ -94,7 +94,7 @@ dependencies:
|
|
94
94
|
- - ">="
|
95
95
|
- !ruby/object:Gem::Version
|
96
96
|
version: '0'
|
97
|
-
description:
|
97
|
+
description:
|
98
98
|
email:
|
99
99
|
- gpassero@gmail.com
|
100
100
|
executables: []
|
@@ -114,7 +114,7 @@ metadata:
|
|
114
114
|
source_code_uri: https://github.com/gap777/automatic_namespaces
|
115
115
|
changelog_uri: https://github.com/gap777/automatic_namespaces/releases
|
116
116
|
allowed_push_host: https://rubygems.org
|
117
|
-
post_install_message:
|
117
|
+
post_install_message:
|
118
118
|
rdoc_options: []
|
119
119
|
require_paths:
|
120
120
|
- lib
|
@@ -129,8 +129,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
129
129
|
- !ruby/object:Gem::Version
|
130
130
|
version: '0'
|
131
131
|
requirements: []
|
132
|
-
rubygems_version: 3.
|
133
|
-
signing_key:
|
132
|
+
rubygems_version: 3.5.11
|
133
|
+
signing_key:
|
134
134
|
specification_version: 4
|
135
135
|
summary: Modify autoloading to assume all files within a directory belong in a namespace
|
136
136
|
test_files: []
|