-
Notifications
You must be signed in to change notification settings - Fork 0
/
frankorm-gen.rb
99 lines (85 loc) · 3.21 KB
/
frankorm-gen.rb
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
require "#{File.dirname(__FILE__)}/base-gen"
class FrankObject < BaseGeneratorObject
attr_accessor :name, :fields, :class_references, :enums, :belongs_tos, :class_includes, :has_manies
def initialize(name)
super()
@name = name.to_s.camelize
@fields = []
@class_references = []
@class_includes = []
@belongs_tos = []
@has_manies = []
@enums = []
end
[:string, :number].each do |field_type|
define_method field_type do |field_name|
@fields << { :type => ObjC.type_for(field_type), :name => field_name.to_s.camelize(:lower) }
end
end
def enum(field_name, options={})
raise "Needs values!" unless options.has_key? :values
name = options[:name] ? options[:name].to_s.camelize : "#{@name}#{field_name.to_s.camelize}"
@fields << { :type => "#{name} ", :name => field_name.to_s.camelize(:lower) }
@enums << { name => options[:values].uniq.map{|x|x.to_s.camelize} }
end
def belongs_to(object, options={})
@class_references << object.to_s.camelize unless @class_references.include?(object.to_s.camelize)
@class_includes << object.to_s.camelize unless @class_includes.include?(object.to_s.camelize)
name = options[:name] || object
fk = options[:fk] || "#{object}_pk"
@fields << { :type => "NSNumber *", :name => fk.to_s.camelize(:lower), :fk => fk }
@belongs_tos << { :type => "#{name.to_s.camelize} *", :name => name.to_s.camelize(:lower), :fk => fk.to_s.camelize(:lower) }
end
def has_many(objects, options={})
@class_includes << objects.to_s.singularize.camelize unless @class_includes.include?(objects.to_s.singularize.camelize)
name = options[:name] || objects
fk = options[:fk] || "#{@name.underscore}_pk"
@has_manies << { :type => "#{objects.to_s.camelize} *", :name => name.to_s.camelize(:lower), :fk => fk }
end
def field_names
@fields.map { |field| field[:name] }
end
def table_name
self.name.underscore.pluralize
end
def self.fmdb_column_value(type, name)
case type
when "NSNumber *"
%{[NSNumber numberWithInt:[rs intForColumn:@"#{name}"]]}
when "NSString *"
%{[rs stringForColumn:@"#{name}"]}
end
end
end
class FrankORMGenerator < BaseGenerator
def self.frank_object(object_name)
object = FrankObject.new object_name
yield(object)
generate_files(object)
# @objects ||= []
# @objects << object
end
def self.generate_files(object)
template_files = `ls #{File.dirname(__FILE__)}/frankorm-templates`.split(/\n/)
template_files.each do |template_file|
file = File.new "#{File.dirname(__FILE__)}/frankorm-templates/#{template_file}", 'r'
template = ERB.new file.read, nil, "-"
file.close
suffix = template_file.split('.').pop
file = File.new File.join(@directory, "#{object.name}.#{suffix}"), 'w'
file << template.result(binding)
file.close
end
end
# def self.generate_schema
# file = File.new "#{File.dirname(__FILE__)}/frankorm-templates/schema.sql", 'r'
# template = ERB.new file.read, nil, "-"
# file.close
#
# puts "hi!"
# puts @objects
# file = File.new File.join(@directory, "schema.sql"), 'w'
# file << template.result(binding)
# file.close
# end
end