ro 4.4.0 → 5.0.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/Gemfile.lock +42 -16
- data/MIGRATION.md +320 -0
- data/README.md +30 -18
- data/a.yml +60 -0
- data/bin/ro +10 -0
- data/lib/ro/_lib.rb +1 -1
- data/lib/ro/asset.rb +46 -5
- data/lib/ro/collection.rb +51 -13
- data/lib/ro/migrator.rb +285 -0
- data/lib/ro/node.rb +53 -13
- data/lib/ro/root.rb +75 -1
- data/lib/ro/script/migrate.rb +204 -0
- data/lib/ro/script/server.rb +1 -1
- data/lib/ro.rb +1 -0
- data/ro.gemspec +207 -16
- data/specs/001-simplify-asset-structure/IMPLEMENTATION_SUMMARY.md +212 -0
- data/specs/001-simplify-asset-structure/checklists/requirements.md +36 -0
- data/specs/001-simplify-asset-structure/contracts/collection_api.md +407 -0
- data/specs/001-simplify-asset-structure/contracts/migrator_api.md +461 -0
- data/specs/001-simplify-asset-structure/contracts/node_api.md +294 -0
- data/specs/001-simplify-asset-structure/data-model.md +381 -0
- data/specs/001-simplify-asset-structure/plan.md +90 -0
- data/specs/001-simplify-asset-structure/quickstart.md +575 -0
- data/specs/001-simplify-asset-structure/research.md +333 -0
- data/specs/001-simplify-asset-structure/spec.md +127 -0
- data/specs/001-simplify-asset-structure/tasks.md +349 -0
- data/test/fixtures/new_structure/mixed/test-json.json +5 -0
- data/test/fixtures/new_structure/mixed/test-yaml.yml +3 -0
- data/test/fixtures/new_structure/posts/metadata-only.yml +7 -0
- data/test/fixtures/new_structure/posts/nested-test/assets/subdirectory/image.png +2 -0
- data/test/fixtures/new_structure/posts/nested-test.yml +7 -0
- data/test/fixtures/new_structure/posts/sample-post/assets/body.md +5 -0
- data/test/fixtures/new_structure/posts/sample-post/assets/image.jpg +2 -0
- data/test/fixtures/new_structure/posts/sample-post.yml +7 -0
- data/test/fixtures/old_structure/posts/assets-only/assets/test.txt +1 -0
- data/test/fixtures/old_structure/posts/sample-post/assets/body.md +5 -0
- data/test/fixtures/old_structure/posts/sample-post/assets/image.jpg +2 -0
- data/test/fixtures/old_structure/posts/sample-post/attributes.yml +2 -0
- data/test/integration/ro_integration_test.rb +165 -0
- data/test/test_helper.rb +149 -0
- data/test/tmp/migration_test_1760746513.backup.20251018001513/migration_test_1760746513/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760746513.backup.20251018001513/migration_test_1760746513/posts/sample-post/attributes.yml +7 -0
- data/test/tmp/migration_test_1760746513.backup.20251018001513/migration_test_1760746513/posts/sample-post/body.md +5 -0
- data/test/tmp/migration_test_1760746513.backup.20251018001513/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760746513.backup.20251018001513/posts/sample-post/attributes.yml +7 -0
- data/test/tmp/migration_test_1760746513.backup.20251018001513/posts/sample-post/body.md +5 -0
- data/test/tmp/migration_test_1760746556.backup.20251018001556/migration_test_1760746556/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760746556.backup.20251018001556/migration_test_1760746556/posts/sample-post/attributes.yml +7 -0
- data/test/tmp/migration_test_1760746556.backup.20251018001556/migration_test_1760746556/posts/sample-post/body.md +5 -0
- data/test/tmp/migration_test_1760746556.backup.20251018001556/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760746556.backup.20251018001556/posts/sample-post/attributes.yml +7 -0
- data/test/tmp/migration_test_1760746556.backup.20251018001556/posts/sample-post/body.md +5 -0
- data/test/tmp/migration_test_1760755248.backup.20251018024048/migration_test_1760755248/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760755248.backup.20251018024048/migration_test_1760755248/posts/sample-post/attributes.yml +7 -0
- data/test/tmp/migration_test_1760755248.backup.20251018024048/migration_test_1760755248/posts/sample-post/body.md +5 -0
- data/test/tmp/migration_test_1760755248.backup.20251018024048/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760755248.backup.20251018024048/posts/sample-post/attributes.yml +7 -0
- data/test/tmp/migration_test_1760755248.backup.20251018024048/posts/sample-post/body.md +5 -0
- data/test/tmp/migration_test_1760758803.backup.20251018034003/migration_test_1760758803/posts/sample-post/body.md +5 -0
- data/test/tmp/migration_test_1760758803.backup.20251018034003/migration_test_1760758803/posts/sample-post/image.jpg +2 -0
- data/test/tmp/migration_test_1760758803.backup.20251018034003/migration_test_1760758803/posts/sample-post.yml +7 -0
- data/test/tmp/migration_test_1760758803.backup.20251018034003/posts/sample-post/body.md +5 -0
- data/test/tmp/migration_test_1760758803.backup.20251018034003/posts/sample-post/image.jpg +2 -0
- data/test/tmp/migration_test_1760758803.backup.20251018034003/posts/sample-post.yml +7 -0
- data/test/tmp/migration_test_1760758869.backup.20251018034109/migration_test_1760758869/posts/sample-post/assets/body.md +5 -0
- data/test/tmp/migration_test_1760758869.backup.20251018034109/migration_test_1760758869/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760758869.backup.20251018034109/migration_test_1760758869/posts/sample-post/attributes.yml +2 -0
- data/test/tmp/migration_test_1760758869.backup.20251018034109/posts/sample-post/assets/body.md +5 -0
- data/test/tmp/migration_test_1760758869.backup.20251018034109/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760758869.backup.20251018034109/posts/sample-post/attributes.yml +2 -0
- data/test/tmp/migration_test_1760758920.backup.20251018034200/migration_test_1760758920/posts/sample-post/assets/body.md +5 -0
- data/test/tmp/migration_test_1760758920.backup.20251018034200/migration_test_1760758920/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760758920.backup.20251018034200/migration_test_1760758920/posts/sample-post/attributes.yml +2 -0
- data/test/tmp/migration_test_1760758920.backup.20251018034200/posts/sample-post/assets/body.md +5 -0
- data/test/tmp/migration_test_1760758920.backup.20251018034200/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760758920.backup.20251018034200/posts/sample-post/attributes.yml +2 -0
- data/test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728/posts/assets-only/assets/test.txt +1 -0
- data/test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728/posts/sample-post/assets/body.md +5 -0
- data/test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728/posts/sample-post/attributes.yml +2 -0
- data/test/tmp/migration_test_1760824728.backup.20251018215848/posts/assets-only/assets/test.txt +1 -0
- data/test/tmp/migration_test_1760824728.backup.20251018215848/posts/sample-post/assets/body.md +5 -0
- data/test/tmp/migration_test_1760824728.backup.20251018215848/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760824728.backup.20251018215848/posts/sample-post/attributes.yml +2 -0
- data/test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153/posts/assets-only/assets/test.txt +1 -0
- data/test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153/posts/sample-post/assets/body.md +5 -0
- data/test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153/posts/sample-post/attributes.yml +2 -0
- data/test/tmp/migration_test_1760844153.backup.20251019032233/posts/assets-only/assets/test.txt +1 -0
- data/test/tmp/migration_test_1760844153.backup.20251019032233/posts/sample-post/assets/body.md +5 -0
- data/test/tmp/migration_test_1760844153.backup.20251019032233/posts/sample-post/assets/image.jpg +2 -0
- data/test/tmp/migration_test_1760844153.backup.20251019032233/posts/sample-post/attributes.yml +2 -0
- data/test/tmp/new_structure_test_1760746452/mixed/test-json.json +5 -0
- data/test/tmp/new_structure_test_1760746452/mixed/test-yaml.yml +3 -0
- data/test/tmp/new_structure_test_1760746452/posts/metadata-only.yml +7 -0
- data/test/tmp/new_structure_test_1760746452/posts/nested-test/subdirectory/image.png +2 -0
- data/test/tmp/new_structure_test_1760746452/posts/nested-test.yml +7 -0
- data/test/tmp/new_structure_test_1760746452/posts/sample-post/body.md +5 -0
- data/test/tmp/new_structure_test_1760746452/posts/sample-post/image.jpg +2 -0
- data/test/tmp/new_structure_test_1760746452/posts/sample-post.yml +7 -0
- data/test/unit/asset_test.rb +90 -0
- data/test/unit/collection_test.rb +127 -0
- data/test/unit/migrator_test.rb +209 -0
- data/test/unit/node_test.rb +138 -0
- metadata +111 -18
- /data/public/ro/nerd/{fastest-possible-embeddings/attributes.yml → fastest-possible-embeddings.yml} +0 -0
- /data/public/ro/nerd/{ima/attributes.yml → ima.yml} +0 -0
- /data/public/ro/nerd/{index/attributes.yml → index.yml} +0 -0
- /data/public/ro/pages/{contact/attributes.yml → contact.yml} +0 -0
- /data/public/ro/pages/{cv/attributes.yml → cv.yml} +0 -0
- /data/public/ro/pages/{disco/attributes.yml → disco.yml} +0 -0
- /data/public/ro/pages/{index/attributes.yml → index.yml} +0 -0
- /data/public/ro/pages/{jess/attributes.yml → jess.yml} +0 -0
- /data/public/ro/pages/{now/attributes.yml → now.yml} +0 -0
- /data/public/ro/posts/{almost-died-in-an-ice-cave/attributes.yml → almost-died-in-an-ice-cave.yml} +0 -0
- /data/public/ro/posts/{facebook-and-global-extremism/attributes.yml → facebook-and-global-extremism.yml} +0 -0
- /data/public/ro/posts/{lemmings-considered-harmful/attributes.yml → lemmings-considered-harmful.yml} +0 -0
- /data/public/ro/posts/{lost-in-the-desert/attributes.yml → lost-in-the-desert.yml} +0 -0
- /data/public/ro/posts/{mission/attributes.yml → mission.yml} +0 -0
- /data/public/ro/posts/{return-your-laptop/attributes.yml → return-your-laptop.yml} +0 -0
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
module Ro
|
|
2
|
+
class Script::Migrate
|
|
3
|
+
def self.run!(script:)
|
|
4
|
+
new(script: script).run!
|
|
5
|
+
end
|
|
6
|
+
|
|
7
|
+
attr_accessor :script
|
|
8
|
+
|
|
9
|
+
def initialize(script:)
|
|
10
|
+
@script = script
|
|
11
|
+
end
|
|
12
|
+
|
|
13
|
+
def run!
|
|
14
|
+
parse_options!
|
|
15
|
+
|
|
16
|
+
root_path = get_root_path
|
|
17
|
+
|
|
18
|
+
show_banner(root_path)
|
|
19
|
+
|
|
20
|
+
migrator = Ro::Migrator.new(root_path, @options)
|
|
21
|
+
|
|
22
|
+
validate_and_report(migrator)
|
|
23
|
+
|
|
24
|
+
return if @options[:dry_run]
|
|
25
|
+
|
|
26
|
+
confirm_unless_forced!
|
|
27
|
+
|
|
28
|
+
execute_migration(migrator)
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
private
|
|
32
|
+
|
|
33
|
+
def parse_options!
|
|
34
|
+
@options = {
|
|
35
|
+
dry_run: false,
|
|
36
|
+
backup: true,
|
|
37
|
+
verbose: false,
|
|
38
|
+
force: false
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
# Use ARGV directly because the Ro.script DSL may have consumed flags
|
|
42
|
+
# We need to find 'migrate' in ARGV and parse everything after it
|
|
43
|
+
argv = []
|
|
44
|
+
found_migrate = false
|
|
45
|
+
ARGV.each do |arg|
|
|
46
|
+
if arg == 'migrate'
|
|
47
|
+
found_migrate = true
|
|
48
|
+
next
|
|
49
|
+
end
|
|
50
|
+
argv << arg if found_migrate
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
while argv.any?
|
|
54
|
+
arg = argv.shift
|
|
55
|
+
case arg
|
|
56
|
+
when '-d', '--dry-run'
|
|
57
|
+
@options[:dry_run] = true
|
|
58
|
+
@options[:verbose] = true
|
|
59
|
+
when '-b', '--backup'
|
|
60
|
+
@options[:backup] = true
|
|
61
|
+
when '--no-backup'
|
|
62
|
+
@options[:backup] = false
|
|
63
|
+
when '-v', '--verbose'
|
|
64
|
+
@options[:verbose] = true
|
|
65
|
+
when '-f', '--force'
|
|
66
|
+
@options[:force] = true
|
|
67
|
+
when '-h', '--help'
|
|
68
|
+
show_help
|
|
69
|
+
exit 0
|
|
70
|
+
else
|
|
71
|
+
argv.unshift(arg)
|
|
72
|
+
break
|
|
73
|
+
end
|
|
74
|
+
end
|
|
75
|
+
|
|
76
|
+
@script.argv.replace(argv)
|
|
77
|
+
end
|
|
78
|
+
|
|
79
|
+
def get_root_path
|
|
80
|
+
if @script.argv.any?
|
|
81
|
+
Pathname.new(@script.argv.first).expand_path
|
|
82
|
+
else
|
|
83
|
+
Ro.config.root.expand
|
|
84
|
+
end
|
|
85
|
+
end
|
|
86
|
+
|
|
87
|
+
def show_banner(root_path)
|
|
88
|
+
puts "Ro Asset Structure Migration Tool"
|
|
89
|
+
puts "=" * 50
|
|
90
|
+
puts "Root: #{root_path}"
|
|
91
|
+
puts "Options: #{@options.inspect}" if @options[:verbose]
|
|
92
|
+
puts ""
|
|
93
|
+
end
|
|
94
|
+
|
|
95
|
+
def validate_and_report(migrator)
|
|
96
|
+
puts "Validating structure..."
|
|
97
|
+
validation = migrator.validate
|
|
98
|
+
|
|
99
|
+
puts "Collections found: #{validation[:collections].size}"
|
|
100
|
+
puts "Old structure nodes: #{validation[:old_nodes].size}"
|
|
101
|
+
puts "New structure nodes: #{validation[:new_nodes].size}"
|
|
102
|
+
puts ""
|
|
103
|
+
|
|
104
|
+
if validation[:old_nodes].empty?
|
|
105
|
+
puts "✓ No old structure nodes found - migration not needed"
|
|
106
|
+
exit 0
|
|
107
|
+
end
|
|
108
|
+
|
|
109
|
+
if validation[:has_new_structure]
|
|
110
|
+
if @options[:force]
|
|
111
|
+
puts "⚠ Warning: Both old and new structures detected!"
|
|
112
|
+
puts "Proceeding with partial migration (--force enabled)..."
|
|
113
|
+
puts ""
|
|
114
|
+
else
|
|
115
|
+
puts "⚠ Warning: Both old and new structures detected!"
|
|
116
|
+
puts "This may indicate a partial migration."
|
|
117
|
+
puts "Use --force to proceed anyway, or check your data first."
|
|
118
|
+
exit 1
|
|
119
|
+
end
|
|
120
|
+
end
|
|
121
|
+
|
|
122
|
+
if @options[:dry_run] || @options[:verbose]
|
|
123
|
+
show_preview(migrator)
|
|
124
|
+
end
|
|
125
|
+
|
|
126
|
+
if @options[:dry_run]
|
|
127
|
+
puts "✓ Dry run complete - no changes made"
|
|
128
|
+
exit 0
|
|
129
|
+
end
|
|
130
|
+
end
|
|
131
|
+
|
|
132
|
+
def show_preview(migrator)
|
|
133
|
+
puts "Migration plan:"
|
|
134
|
+
puts "-" * 50
|
|
135
|
+
plan = migrator.preview
|
|
136
|
+
plan.each_with_index do |step, i|
|
|
137
|
+
puts "\n#{i + 1}. #{step[:collection]}/#{step[:node_id]}"
|
|
138
|
+
step[:actions].each do |action|
|
|
139
|
+
puts " - #{action}"
|
|
140
|
+
end
|
|
141
|
+
end
|
|
142
|
+
puts ""
|
|
143
|
+
end
|
|
144
|
+
|
|
145
|
+
def confirm_unless_forced!
|
|
146
|
+
return if @options[:force]
|
|
147
|
+
|
|
148
|
+
print "Proceed with migration? [y/N] "
|
|
149
|
+
response = STDIN.gets.chomp
|
|
150
|
+
unless response.downcase == 'y'
|
|
151
|
+
puts "Migration cancelled"
|
|
152
|
+
exit 0
|
|
153
|
+
end
|
|
154
|
+
end
|
|
155
|
+
|
|
156
|
+
def execute_migration(migrator)
|
|
157
|
+
puts "\nStarting migration..."
|
|
158
|
+
result = migrator.migrate
|
|
159
|
+
|
|
160
|
+
if result[:success]
|
|
161
|
+
puts "\n✓ Migration complete!"
|
|
162
|
+
puts " Nodes migrated: #{result[:nodes_migrated]}"
|
|
163
|
+
puts " Collections migrated: #{result[:collections_migrated]}"
|
|
164
|
+
|
|
165
|
+
if @options[:backup]
|
|
166
|
+
puts "\n Backup created - rollback available if needed"
|
|
167
|
+
end
|
|
168
|
+
else
|
|
169
|
+
puts "\n✗ Migration failed"
|
|
170
|
+
exit 1
|
|
171
|
+
end
|
|
172
|
+
end
|
|
173
|
+
|
|
174
|
+
def show_help
|
|
175
|
+
puts <<~HELP
|
|
176
|
+
Usage: ro migrate [options] [ROOT_PATH]
|
|
177
|
+
|
|
178
|
+
Migrates Ro assets from old structure to new simplified structure
|
|
179
|
+
|
|
180
|
+
Options:
|
|
181
|
+
-d, --dry-run Preview migration without making changes
|
|
182
|
+
-b, --[no-]backup Create backup before migrating (default: true)
|
|
183
|
+
-v, --verbose Show detailed progress
|
|
184
|
+
-f, --force Force migration even if new structure detected
|
|
185
|
+
-h, --help Show this help message
|
|
186
|
+
|
|
187
|
+
Examples:
|
|
188
|
+
# Preview migration
|
|
189
|
+
ro migrate --dry-run
|
|
190
|
+
|
|
191
|
+
# Migrate with backup (default)
|
|
192
|
+
ro migrate
|
|
193
|
+
|
|
194
|
+
# Migrate without backup
|
|
195
|
+
ro migrate --no-backup
|
|
196
|
+
|
|
197
|
+
# Force migration in mixed structure
|
|
198
|
+
ro migrate --force
|
|
199
|
+
|
|
200
|
+
See MIGRATION.md for more details.
|
|
201
|
+
HELP
|
|
202
|
+
end
|
|
203
|
+
end
|
|
204
|
+
end
|
data/lib/ro/script/server.rb
CHANGED
data/lib/ro.rb
CHANGED
data/ro.gemspec
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
|
|
4
4
|
Gem::Specification::new do |spec|
|
|
5
5
|
spec.name = "ro"
|
|
6
|
-
spec.version = "
|
|
6
|
+
spec.version = "5.0.0"
|
|
7
7
|
spec.required_ruby_version = '>= 3.0'
|
|
8
8
|
spec.platform = Gem::Platform::RUBY
|
|
9
9
|
spec.summary = "all your content in github, as god intended"
|
|
@@ -14,9 +14,11 @@ Gem::Specification::new do |spec|
|
|
|
14
14
|
["Gemfile",
|
|
15
15
|
"Gemfile.lock",
|
|
16
16
|
"LICENSE",
|
|
17
|
+
"MIGRATION.md",
|
|
17
18
|
"README.md",
|
|
18
19
|
"README.md.erb",
|
|
19
20
|
"Rakefile",
|
|
21
|
+
"a.yml",
|
|
20
22
|
"bin",
|
|
21
23
|
"bin/ro",
|
|
22
24
|
"lib",
|
|
@@ -33,6 +35,7 @@ Gem::Specification::new do |spec|
|
|
|
33
35
|
"lib/ro/html_safe.rb",
|
|
34
36
|
"lib/ro/klass.rb",
|
|
35
37
|
"lib/ro/methods.rb",
|
|
38
|
+
"lib/ro/migrator.rb",
|
|
36
39
|
"lib/ro/model.rb",
|
|
37
40
|
"lib/ro/node.rb",
|
|
38
41
|
"lib/ro/pagination.rb",
|
|
@@ -42,6 +45,7 @@ Gem::Specification::new do |spec|
|
|
|
42
45
|
"lib/ro/script.rb",
|
|
43
46
|
"lib/ro/script/builder.rb",
|
|
44
47
|
"lib/ro/script/console.rb",
|
|
48
|
+
"lib/ro/script/migrate.rb",
|
|
45
49
|
"lib/ro/script/server.rb",
|
|
46
50
|
"lib/ro/slug.rb",
|
|
47
51
|
"lib/ro/template",
|
|
@@ -97,6 +101,7 @@ Gem::Specification::new do |spec|
|
|
|
97
101
|
"public/ro",
|
|
98
102
|
"public/ro/nerd",
|
|
99
103
|
"public/ro/nerd/fastest-possible-embeddings",
|
|
104
|
+
"public/ro/nerd/fastest-possible-embeddings.yml",
|
|
100
105
|
"public/ro/nerd/fastest-possible-embeddings/assets",
|
|
101
106
|
"public/ro/nerd/fastest-possible-embeddings/assets/giraffe.jpeg",
|
|
102
107
|
"public/ro/nerd/fastest-possible-embeddings/assets/let-me-in.jpg",
|
|
@@ -104,19 +109,18 @@ Gem::Specification::new do |spec|
|
|
|
104
109
|
"public/ro/nerd/fastest-possible-embeddings/assets/src/fastembed.js",
|
|
105
110
|
"public/ro/nerd/fastest-possible-embeddings/assets/src/fastembed.rs",
|
|
106
111
|
"public/ro/nerd/fastest-possible-embeddings/assets/terminal.jpg",
|
|
107
|
-
"public/ro/nerd/fastest-possible-embeddings/attributes.yml",
|
|
108
112
|
"public/ro/nerd/fastest-possible-embeddings/body.md",
|
|
109
113
|
"public/ro/nerd/ima",
|
|
114
|
+
"public/ro/nerd/ima.yml",
|
|
110
115
|
"public/ro/nerd/ima/assets",
|
|
111
116
|
"public/ro/nerd/ima/assets/og.jpeg",
|
|
112
|
-
"public/ro/nerd/ima/attributes.yml",
|
|
113
117
|
"public/ro/nerd/ima/body.md",
|
|
114
118
|
"public/ro/nerd/index",
|
|
119
|
+
"public/ro/nerd/index.yml",
|
|
115
120
|
"public/ro/nerd/index/assets",
|
|
116
121
|
"public/ro/nerd/index/assets/giraffe.jpeg",
|
|
117
122
|
"public/ro/nerd/index/assets/let-me-in.jpg",
|
|
118
123
|
"public/ro/nerd/index/assets/terminal.jpg",
|
|
119
|
-
"public/ro/nerd/index/attributes.yml",
|
|
120
124
|
"public/ro/nerd/index/body.md",
|
|
121
125
|
"public/ro/pages",
|
|
122
126
|
"public/ro/pages/about",
|
|
@@ -125,16 +129,17 @@ Gem::Specification::new do |spec|
|
|
|
125
129
|
"public/ro/pages/about/assets/speak-english-pulp-fiction.gif",
|
|
126
130
|
"public/ro/pages/about/body.md",
|
|
127
131
|
"public/ro/pages/contact",
|
|
132
|
+
"public/ro/pages/contact.yml",
|
|
128
133
|
"public/ro/pages/contact/assets",
|
|
129
134
|
"public/ro/pages/contact/assets/giraffe.jpeg",
|
|
130
|
-
"public/ro/pages/contact/attributes.yml",
|
|
131
135
|
"public/ro/pages/contact/body.md",
|
|
132
136
|
"public/ro/pages/cv",
|
|
137
|
+
"public/ro/pages/cv.yml",
|
|
133
138
|
"public/ro/pages/cv/assets",
|
|
134
139
|
"public/ro/pages/cv/assets/ara.jpg",
|
|
135
|
-
"public/ro/pages/cv/attributes.yml",
|
|
136
140
|
"public/ro/pages/cv/body.md",
|
|
137
141
|
"public/ro/pages/disco",
|
|
142
|
+
"public/ro/pages/disco.yml",
|
|
138
143
|
"public/ro/pages/disco/assets",
|
|
139
144
|
"public/ro/pages/disco/assets/disco.jpg",
|
|
140
145
|
"public/ro/pages/disco/assets/disco.png",
|
|
@@ -144,7 +149,6 @@ Gem::Specification::new do |spec|
|
|
|
144
149
|
"public/ro/pages/disco/assets/src/fortune-500.md",
|
|
145
150
|
"public/ro/pages/disco/assets/src/greed.md",
|
|
146
151
|
"public/ro/pages/disco/assets/src/up-at-night.md",
|
|
147
|
-
"public/ro/pages/disco/attributes.yml",
|
|
148
152
|
"public/ro/pages/disco/body.md",
|
|
149
153
|
"public/ro/pages/disco/samples",
|
|
150
154
|
"public/ro/pages/disco/samples/environment.md",
|
|
@@ -152,21 +156,22 @@ Gem::Specification::new do |spec|
|
|
|
152
156
|
"public/ro/pages/disco/samples/greed.md",
|
|
153
157
|
"public/ro/pages/disco/samples/up-at-night.md",
|
|
154
158
|
"public/ro/pages/index",
|
|
155
|
-
"public/ro/pages/index
|
|
159
|
+
"public/ro/pages/index.yml",
|
|
156
160
|
"public/ro/pages/index/body.md",
|
|
157
161
|
"public/ro/pages/jess",
|
|
162
|
+
"public/ro/pages/jess.yml",
|
|
158
163
|
"public/ro/pages/jess/assets",
|
|
159
164
|
"public/ro/pages/jess/assets/og.jpg",
|
|
160
165
|
"public/ro/pages/jess/assets/speak-english-pulp-fiction.gif",
|
|
161
|
-
"public/ro/pages/jess/attributes.yml",
|
|
162
166
|
"public/ro/pages/jess/body.md",
|
|
163
167
|
"public/ro/pages/now",
|
|
168
|
+
"public/ro/pages/now.yml",
|
|
164
169
|
"public/ro/pages/now/assets",
|
|
165
170
|
"public/ro/pages/now/assets/speak-english-pulp-fiction.gif",
|
|
166
|
-
"public/ro/pages/now/attributes.yml",
|
|
167
171
|
"public/ro/pages/now/body.md",
|
|
168
172
|
"public/ro/posts",
|
|
169
173
|
"public/ro/posts/almost-died-in-an-ice-cave",
|
|
174
|
+
"public/ro/posts/almost-died-in-an-ice-cave.yml",
|
|
170
175
|
"public/ro/posts/almost-died-in-an-ice-cave/assets",
|
|
171
176
|
"public/ro/posts/almost-died-in-an-ice-cave/assets/image1.png",
|
|
172
177
|
"public/ro/posts/almost-died-in-an-ice-cave/assets/image10.png",
|
|
@@ -187,9 +192,9 @@ Gem::Specification::new do |spec|
|
|
|
187
192
|
"public/ro/posts/almost-died-in-an-ice-cave/assets/levi-rawr.png",
|
|
188
193
|
"public/ro/posts/almost-died-in-an-ice-cave/assets/og.jpg",
|
|
189
194
|
"public/ro/posts/almost-died-in-an-ice-cave/assets/purple-heart.jpg",
|
|
190
|
-
"public/ro/posts/almost-died-in-an-ice-cave/attributes.yml",
|
|
191
195
|
"public/ro/posts/almost-died-in-an-ice-cave/body.md",
|
|
192
196
|
"public/ro/posts/facebook-and-global-extremism",
|
|
197
|
+
"public/ro/posts/facebook-and-global-extremism.yml",
|
|
193
198
|
"public/ro/posts/facebook-and-global-extremism/assets",
|
|
194
199
|
"public/ro/posts/facebook-and-global-extremism/assets/background.html",
|
|
195
200
|
"public/ro/posts/facebook-and-global-extremism/assets/background.md",
|
|
@@ -197,32 +202,218 @@ Gem::Specification::new do |spec|
|
|
|
197
202
|
"public/ro/posts/facebook-and-global-extremism/assets/prompt.txt",
|
|
198
203
|
"public/ro/posts/facebook-and-global-extremism/assets/results.md",
|
|
199
204
|
"public/ro/posts/facebook-and-global-extremism/assets/survey.txt",
|
|
200
|
-
"public/ro/posts/facebook-and-global-extremism/attributes.yml",
|
|
201
205
|
"public/ro/posts/facebook-and-global-extremism/body.md",
|
|
202
206
|
"public/ro/posts/lemmings-considered-harmful",
|
|
207
|
+
"public/ro/posts/lemmings-considered-harmful.yml",
|
|
203
208
|
"public/ro/posts/lemmings-considered-harmful/assets",
|
|
204
209
|
"public/ro/posts/lemmings-considered-harmful/assets/lemming.jpeg",
|
|
205
|
-
"public/ro/posts/lemmings-considered-harmful/attributes.yml",
|
|
206
210
|
"public/ro/posts/lemmings-considered-harmful/body.md",
|
|
207
211
|
"public/ro/posts/lost-in-the-desert",
|
|
212
|
+
"public/ro/posts/lost-in-the-desert.yml",
|
|
208
213
|
"public/ro/posts/lost-in-the-desert/assets",
|
|
209
214
|
"public/ro/posts/lost-in-the-desert/assets/og.jpg",
|
|
210
|
-
"public/ro/posts/lost-in-the-desert/attributes.yml",
|
|
211
215
|
"public/ro/posts/lost-in-the-desert/body.md",
|
|
212
216
|
"public/ro/posts/mission",
|
|
217
|
+
"public/ro/posts/mission.yml",
|
|
213
218
|
"public/ro/posts/mission/assets",
|
|
214
219
|
"public/ro/posts/mission/assets/og.jpg",
|
|
215
|
-
"public/ro/posts/mission/attributes.yml",
|
|
216
220
|
"public/ro/posts/mission/body.md",
|
|
217
221
|
"public/ro/posts/return-your-laptop",
|
|
222
|
+
"public/ro/posts/return-your-laptop.yml",
|
|
218
223
|
"public/ro/posts/return-your-laptop/assets",
|
|
219
224
|
"public/ro/posts/return-your-laptop/assets/og.jpg",
|
|
220
225
|
"public/ro/posts/return-your-laptop/assets/return-your-laptop.png",
|
|
221
|
-
"public/ro/posts/return-your-laptop/attributes.yml",
|
|
222
226
|
"public/ro/posts/return-your-laptop/body.md",
|
|
223
227
|
"ro.gemspec",
|
|
224
228
|
"scripts",
|
|
225
229
|
"scripts/speedtest.rb",
|
|
230
|
+
"specs",
|
|
231
|
+
"specs/001-simplify-asset-structure",
|
|
232
|
+
"specs/001-simplify-asset-structure/IMPLEMENTATION_SUMMARY.md",
|
|
233
|
+
"specs/001-simplify-asset-structure/checklists",
|
|
234
|
+
"specs/001-simplify-asset-structure/checklists/requirements.md",
|
|
235
|
+
"specs/001-simplify-asset-structure/contracts",
|
|
236
|
+
"specs/001-simplify-asset-structure/contracts/collection_api.md",
|
|
237
|
+
"specs/001-simplify-asset-structure/contracts/migrator_api.md",
|
|
238
|
+
"specs/001-simplify-asset-structure/contracts/node_api.md",
|
|
239
|
+
"specs/001-simplify-asset-structure/data-model.md",
|
|
240
|
+
"specs/001-simplify-asset-structure/plan.md",
|
|
241
|
+
"specs/001-simplify-asset-structure/quickstart.md",
|
|
242
|
+
"specs/001-simplify-asset-structure/research.md",
|
|
243
|
+
"specs/001-simplify-asset-structure/spec.md",
|
|
244
|
+
"specs/001-simplify-asset-structure/tasks.md",
|
|
245
|
+
"test",
|
|
246
|
+
"test/fixtures",
|
|
247
|
+
"test/fixtures/new_structure",
|
|
248
|
+
"test/fixtures/new_structure/mixed",
|
|
249
|
+
"test/fixtures/new_structure/mixed/test-json.json",
|
|
250
|
+
"test/fixtures/new_structure/mixed/test-yaml.yml",
|
|
251
|
+
"test/fixtures/new_structure/posts",
|
|
252
|
+
"test/fixtures/new_structure/posts/metadata-only.yml",
|
|
253
|
+
"test/fixtures/new_structure/posts/nested-test",
|
|
254
|
+
"test/fixtures/new_structure/posts/nested-test.yml",
|
|
255
|
+
"test/fixtures/new_structure/posts/nested-test/assets",
|
|
256
|
+
"test/fixtures/new_structure/posts/nested-test/assets/subdirectory",
|
|
257
|
+
"test/fixtures/new_structure/posts/nested-test/assets/subdirectory/image.png",
|
|
258
|
+
"test/fixtures/new_structure/posts/sample-post",
|
|
259
|
+
"test/fixtures/new_structure/posts/sample-post.yml",
|
|
260
|
+
"test/fixtures/new_structure/posts/sample-post/assets",
|
|
261
|
+
"test/fixtures/new_structure/posts/sample-post/assets/body.md",
|
|
262
|
+
"test/fixtures/new_structure/posts/sample-post/assets/image.jpg",
|
|
263
|
+
"test/fixtures/old_structure",
|
|
264
|
+
"test/fixtures/old_structure/posts",
|
|
265
|
+
"test/fixtures/old_structure/posts/assets-only",
|
|
266
|
+
"test/fixtures/old_structure/posts/assets-only/assets",
|
|
267
|
+
"test/fixtures/old_structure/posts/assets-only/assets/test.txt",
|
|
268
|
+
"test/fixtures/old_structure/posts/sample-post",
|
|
269
|
+
"test/fixtures/old_structure/posts/sample-post/assets",
|
|
270
|
+
"test/fixtures/old_structure/posts/sample-post/assets/body.md",
|
|
271
|
+
"test/fixtures/old_structure/posts/sample-post/assets/image.jpg",
|
|
272
|
+
"test/fixtures/old_structure/posts/sample-post/attributes.yml",
|
|
273
|
+
"test/integration",
|
|
274
|
+
"test/integration/ro_integration_test.rb",
|
|
275
|
+
"test/test_helper.rb",
|
|
276
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513",
|
|
277
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513/migration_test_1760746513",
|
|
278
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513/migration_test_1760746513/posts",
|
|
279
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513/migration_test_1760746513/posts/sample-post",
|
|
280
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513/migration_test_1760746513/posts/sample-post/assets",
|
|
281
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513/migration_test_1760746513/posts/sample-post/assets/image.jpg",
|
|
282
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513/migration_test_1760746513/posts/sample-post/attributes.yml",
|
|
283
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513/migration_test_1760746513/posts/sample-post/body.md",
|
|
284
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513/posts",
|
|
285
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513/posts/sample-post",
|
|
286
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513/posts/sample-post/assets",
|
|
287
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513/posts/sample-post/assets/image.jpg",
|
|
288
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513/posts/sample-post/attributes.yml",
|
|
289
|
+
"test/tmp/migration_test_1760746513.backup.20251018001513/posts/sample-post/body.md",
|
|
290
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556",
|
|
291
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556/migration_test_1760746556",
|
|
292
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556/migration_test_1760746556/posts",
|
|
293
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556/migration_test_1760746556/posts/sample-post",
|
|
294
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556/migration_test_1760746556/posts/sample-post/assets",
|
|
295
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556/migration_test_1760746556/posts/sample-post/assets/image.jpg",
|
|
296
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556/migration_test_1760746556/posts/sample-post/attributes.yml",
|
|
297
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556/migration_test_1760746556/posts/sample-post/body.md",
|
|
298
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556/posts",
|
|
299
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556/posts/sample-post",
|
|
300
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556/posts/sample-post/assets",
|
|
301
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556/posts/sample-post/assets/image.jpg",
|
|
302
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556/posts/sample-post/attributes.yml",
|
|
303
|
+
"test/tmp/migration_test_1760746556.backup.20251018001556/posts/sample-post/body.md",
|
|
304
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048",
|
|
305
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048/migration_test_1760755248",
|
|
306
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048/migration_test_1760755248/posts",
|
|
307
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048/migration_test_1760755248/posts/sample-post",
|
|
308
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048/migration_test_1760755248/posts/sample-post/assets",
|
|
309
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048/migration_test_1760755248/posts/sample-post/assets/image.jpg",
|
|
310
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048/migration_test_1760755248/posts/sample-post/attributes.yml",
|
|
311
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048/migration_test_1760755248/posts/sample-post/body.md",
|
|
312
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048/posts",
|
|
313
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048/posts/sample-post",
|
|
314
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048/posts/sample-post/assets",
|
|
315
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048/posts/sample-post/assets/image.jpg",
|
|
316
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048/posts/sample-post/attributes.yml",
|
|
317
|
+
"test/tmp/migration_test_1760755248.backup.20251018024048/posts/sample-post/body.md",
|
|
318
|
+
"test/tmp/migration_test_1760758803.backup.20251018034003",
|
|
319
|
+
"test/tmp/migration_test_1760758803.backup.20251018034003/migration_test_1760758803",
|
|
320
|
+
"test/tmp/migration_test_1760758803.backup.20251018034003/migration_test_1760758803/posts",
|
|
321
|
+
"test/tmp/migration_test_1760758803.backup.20251018034003/migration_test_1760758803/posts/sample-post",
|
|
322
|
+
"test/tmp/migration_test_1760758803.backup.20251018034003/migration_test_1760758803/posts/sample-post.yml",
|
|
323
|
+
"test/tmp/migration_test_1760758803.backup.20251018034003/migration_test_1760758803/posts/sample-post/body.md",
|
|
324
|
+
"test/tmp/migration_test_1760758803.backup.20251018034003/migration_test_1760758803/posts/sample-post/image.jpg",
|
|
325
|
+
"test/tmp/migration_test_1760758803.backup.20251018034003/posts",
|
|
326
|
+
"test/tmp/migration_test_1760758803.backup.20251018034003/posts/sample-post",
|
|
327
|
+
"test/tmp/migration_test_1760758803.backup.20251018034003/posts/sample-post.yml",
|
|
328
|
+
"test/tmp/migration_test_1760758803.backup.20251018034003/posts/sample-post/body.md",
|
|
329
|
+
"test/tmp/migration_test_1760758803.backup.20251018034003/posts/sample-post/image.jpg",
|
|
330
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109",
|
|
331
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109/migration_test_1760758869",
|
|
332
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109/migration_test_1760758869/posts",
|
|
333
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109/migration_test_1760758869/posts/sample-post",
|
|
334
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109/migration_test_1760758869/posts/sample-post/assets",
|
|
335
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109/migration_test_1760758869/posts/sample-post/assets/body.md",
|
|
336
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109/migration_test_1760758869/posts/sample-post/assets/image.jpg",
|
|
337
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109/migration_test_1760758869/posts/sample-post/attributes.yml",
|
|
338
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109/posts",
|
|
339
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109/posts/sample-post",
|
|
340
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109/posts/sample-post/assets",
|
|
341
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109/posts/sample-post/assets/body.md",
|
|
342
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109/posts/sample-post/assets/image.jpg",
|
|
343
|
+
"test/tmp/migration_test_1760758869.backup.20251018034109/posts/sample-post/attributes.yml",
|
|
344
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200",
|
|
345
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200/migration_test_1760758920",
|
|
346
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200/migration_test_1760758920/posts",
|
|
347
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200/migration_test_1760758920/posts/sample-post",
|
|
348
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200/migration_test_1760758920/posts/sample-post/assets",
|
|
349
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200/migration_test_1760758920/posts/sample-post/assets/body.md",
|
|
350
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200/migration_test_1760758920/posts/sample-post/assets/image.jpg",
|
|
351
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200/migration_test_1760758920/posts/sample-post/attributes.yml",
|
|
352
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200/posts",
|
|
353
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200/posts/sample-post",
|
|
354
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200/posts/sample-post/assets",
|
|
355
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200/posts/sample-post/assets/body.md",
|
|
356
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200/posts/sample-post/assets/image.jpg",
|
|
357
|
+
"test/tmp/migration_test_1760758920.backup.20251018034200/posts/sample-post/attributes.yml",
|
|
358
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848",
|
|
359
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728",
|
|
360
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728/posts",
|
|
361
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728/posts/assets-only",
|
|
362
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728/posts/assets-only/assets",
|
|
363
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728/posts/assets-only/assets/test.txt",
|
|
364
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728/posts/sample-post",
|
|
365
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728/posts/sample-post/assets",
|
|
366
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728/posts/sample-post/assets/body.md",
|
|
367
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728/posts/sample-post/assets/image.jpg",
|
|
368
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/migration_test_1760824728/posts/sample-post/attributes.yml",
|
|
369
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/posts",
|
|
370
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/posts/assets-only",
|
|
371
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/posts/assets-only/assets",
|
|
372
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/posts/assets-only/assets/test.txt",
|
|
373
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/posts/sample-post",
|
|
374
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/posts/sample-post/assets",
|
|
375
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/posts/sample-post/assets/body.md",
|
|
376
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/posts/sample-post/assets/image.jpg",
|
|
377
|
+
"test/tmp/migration_test_1760824728.backup.20251018215848/posts/sample-post/attributes.yml",
|
|
378
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233",
|
|
379
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153",
|
|
380
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153/posts",
|
|
381
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153/posts/assets-only",
|
|
382
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153/posts/assets-only/assets",
|
|
383
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153/posts/assets-only/assets/test.txt",
|
|
384
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153/posts/sample-post",
|
|
385
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153/posts/sample-post/assets",
|
|
386
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153/posts/sample-post/assets/body.md",
|
|
387
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153/posts/sample-post/assets/image.jpg",
|
|
388
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/migration_test_1760844153/posts/sample-post/attributes.yml",
|
|
389
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/posts",
|
|
390
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/posts/assets-only",
|
|
391
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/posts/assets-only/assets",
|
|
392
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/posts/assets-only/assets/test.txt",
|
|
393
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/posts/sample-post",
|
|
394
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/posts/sample-post/assets",
|
|
395
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/posts/sample-post/assets/body.md",
|
|
396
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/posts/sample-post/assets/image.jpg",
|
|
397
|
+
"test/tmp/migration_test_1760844153.backup.20251019032233/posts/sample-post/attributes.yml",
|
|
398
|
+
"test/tmp/new_structure_test_1760746452",
|
|
399
|
+
"test/tmp/new_structure_test_1760746452/mixed",
|
|
400
|
+
"test/tmp/new_structure_test_1760746452/mixed/test-json.json",
|
|
401
|
+
"test/tmp/new_structure_test_1760746452/mixed/test-yaml.yml",
|
|
402
|
+
"test/tmp/new_structure_test_1760746452/posts",
|
|
403
|
+
"test/tmp/new_structure_test_1760746452/posts/metadata-only.yml",
|
|
404
|
+
"test/tmp/new_structure_test_1760746452/posts/nested-test",
|
|
405
|
+
"test/tmp/new_structure_test_1760746452/posts/nested-test.yml",
|
|
406
|
+
"test/tmp/new_structure_test_1760746452/posts/nested-test/subdirectory",
|
|
407
|
+
"test/tmp/new_structure_test_1760746452/posts/nested-test/subdirectory/image.png",
|
|
408
|
+
"test/tmp/new_structure_test_1760746452/posts/sample-post",
|
|
409
|
+
"test/tmp/new_structure_test_1760746452/posts/sample-post.yml",
|
|
410
|
+
"test/tmp/new_structure_test_1760746452/posts/sample-post/body.md",
|
|
411
|
+
"test/tmp/new_structure_test_1760746452/posts/sample-post/image.jpg",
|
|
412
|
+
"test/unit",
|
|
413
|
+
"test/unit/asset_test.rb",
|
|
414
|
+
"test/unit/collection_test.rb",
|
|
415
|
+
"test/unit/migrator_test.rb",
|
|
416
|
+
"test/unit/node_test.rb",
|
|
226
417
|
"tmp/gem-details.oe"]
|
|
227
418
|
|
|
228
419
|
spec.executables = ["ro"]
|