CapicuaGenMelchior 0.0.3 → 0.1.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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 9a1323e8a50a1f0fc170ccd501254b8c3e675856
4
- data.tar.gz: 9904bfd4e8a0cc3eb5bc63357f18d7d450268259
3
+ metadata.gz: 7f76cc4a4517f92d6163e515526d220e891c6e21
4
+ data.tar.gz: def6610d1ea683624bc2f36e93036691d320aa0b
5
5
  SHA512:
6
- metadata.gz: 215fbfc2bee9117768b76368f2b2a047f979e7a8ac5744a0c0b404cc492741fd8c93ca9205c85a2183210975e9908d1c5f5eaab11ef63f6d185d2a7c29449826
7
- data.tar.gz: bd250f7ba61b77b5fa6d439e3d6509ada835e4879e62017ba37bcdd22cefe02ae6621b80125216bda13070897fd27abca8074f9a895ba64ade8770aa12321c70
6
+ metadata.gz: 8f99f3b750badb9fc9a89125f512e6830b70d18c818c41dfe024a699823d21df594276f6c53603eb2441d0d68793774b7af39db8bc9d3b73f870570aecbaf02e
7
+ data.tar.gz: f98138f01eb52cd4f1460aef316141184b984bd7ee9131ecf14793da9d1379c2d313c2222772f38bb25c0d6c88d554a7e78a18d3a1985f7be44138e03ea24a01
data/.gitignore CHANGED
@@ -1,11 +1,11 @@
1
- /.bundle/
2
- /.yardoc
3
- /Gemfile.lock
4
- /_yardoc/
5
- /coverage/
6
- /doc/
7
- /pkg/
8
- /spec/reports/
9
- /tmp/
10
- /.idea
11
- /*.gem
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
10
+ /.idea
11
+ /*.gem
data/.rspec CHANGED
@@ -1,2 +1,2 @@
1
- --format documentation
2
- --color
1
+ --format documentation
2
+ --color
data/.travis.yml CHANGED
@@ -1,4 +1,4 @@
1
- language: ruby
2
- rvm:
3
- - 2.2.3
4
- before_install: gem install bundler -v 1.11.2
1
+ language: ruby
2
+ rvm:
3
+ - 2.2.3
4
+ before_install: gem install bundler -v 1.11.2
data/CODE_OF_CONDUCT.md CHANGED
@@ -1,49 +1,49 @@
1
- # Contributor Code of Conduct
2
-
3
- As contributors and maintainers of this project, and in the interest of
4
- fostering an open and welcoming community, we pledge to respect all people who
5
- contribute through reporting issues, posting feature requests, updating
6
- documentation, submitting pull requests or patches, and other activities.
7
-
8
- We are committed to making participation in this project a harassment-free
9
- experience for everyone, regardless of level of experience, gender, gender
10
- identity and expression, sexual orientation, disability, personal appearance,
11
- body size, race, ethnicity, age, religion, or nationality.
12
-
13
- Examples of unacceptable behavior by participants include:
14
-
15
- * The use of sexualized language or imagery
16
- * Personal attacks
17
- * Trolling or insulting/derogatory comments
18
- * Public or private harassment
19
- * Publishing other's private information, such as physical or electronic
20
- addresses, without explicit permission
21
- * Other unethical or unprofessional conduct
22
-
23
- Project maintainers have the right and responsibility to remove, edit, or
24
- reject comments, commits, code, wiki edits, issues, and other contributions
25
- that are not aligned to this Code of Conduct, or to ban temporarily or
26
- permanently any contributor for other behaviors that they deem inappropriate,
27
- threatening, offensive, or harmful.
28
-
29
- By adopting this Code of Conduct, project maintainers commit themselves to
30
- fairly and consistently applying these principles to every aspect of managing
31
- this project. Project maintainers who do not follow or enforce the Code of
32
- Conduct may be permanently removed from the project team.
33
-
34
- This code of conduct applies both within project spaces and in public spaces
35
- when an individual is representing the project or its community.
36
-
37
- Instances of abusive, harassing, or otherwise unacceptable behavior may be
38
- reported by contacting a project maintainer at jbautista@bansi.com.mx. All
39
- complaints will be reviewed and investigated and will result in a response that
40
- is deemed necessary and appropriate to the circumstances. Maintainers are
41
- obligated to maintain confidentiality with regard to the reporter of an
42
- incident.
43
-
44
- This Code of Conduct is adapted from the [Contributor Covenant][homepage],
45
- version 1.3.0, available at
46
- [http://contributor-covenant.org/version/1/3/0/][version]
47
-
48
- [homepage]: http://contributor-covenant.org
1
+ # Contributor Code of Conduct
2
+
3
+ As contributors and maintainers of this project, and in the interest of
4
+ fostering an open and welcoming community, we pledge to respect all people who
5
+ contribute through reporting issues, posting feature requests, updating
6
+ documentation, submitting pull requests or patches, and other activities.
7
+
8
+ We are committed to making participation in this project a harassment-free
9
+ experience for everyone, regardless of level of experience, gender, gender
10
+ identity and expression, sexual orientation, disability, personal appearance,
11
+ body size, race, ethnicity, age, religion, or nationality.
12
+
13
+ Examples of unacceptable behavior by participants include:
14
+
15
+ * The use of sexualized language or imagery
16
+ * Personal attacks
17
+ * Trolling or insulting/derogatory comments
18
+ * Public or private harassment
19
+ * Publishing other's private information, such as physical or electronic
20
+ addresses, without explicit permission
21
+ * Other unethical or unprofessional conduct
22
+
23
+ Project maintainers have the right and responsibility to remove, edit, or
24
+ reject comments, commits, code, wiki edits, issues, and other contributions
25
+ that are not aligned to this Code of Conduct, or to ban temporarily or
26
+ permanently any contributor for other behaviors that they deem inappropriate,
27
+ threatening, offensive, or harmful.
28
+
29
+ By adopting this Code of Conduct, project maintainers commit themselves to
30
+ fairly and consistently applying these principles to every aspect of managing
31
+ this project. Project maintainers who do not follow or enforce the Code of
32
+ Conduct may be permanently removed from the project team.
33
+
34
+ This code of conduct applies both within project spaces and in public spaces
35
+ when an individual is representing the project or its community.
36
+
37
+ Instances of abusive, harassing, or otherwise unacceptable behavior may be
38
+ reported by contacting a project maintainer at jbautista@bansi.com.mx. All
39
+ complaints will be reviewed and investigated and will result in a response that
40
+ is deemed necessary and appropriate to the circumstances. Maintainers are
41
+ obligated to maintain confidentiality with regard to the reporter of an
42
+ incident.
43
+
44
+ This Code of Conduct is adapted from the [Contributor Covenant][homepage],
45
+ version 1.3.0, available at
46
+ [http://contributor-covenant.org/version/1/3/0/][version]
47
+
48
+ [homepage]: http://contributor-covenant.org
49
49
  [version]: http://contributor-covenant.org/version/1/3/0/
@@ -1,63 +1,66 @@
1
- # coding: utf-8
2
- lib = File.expand_path('../lib', __FILE__)
3
- $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
- require 'CapicuaGenMelchior/version'
5
-
6
- Gem::Specification.new do |spec|
7
- spec.name = "CapicuaGenMelchior"
8
- spec.version = CapicuaGenMelchior::VERSION
9
- spec.authors = ["José Luis Bautista Martín"]
10
- spec.email = ["joseluisbautista@gmail.com"]
11
- spec.date = Date.today.to_s
12
-
13
-
14
- spec.summary = %q{CapicuaGen es un software que ayuda a la creación automática de
15
- sistemas empresariales a través de la definición y ensamblado de
16
- diversos generadores de características. Melchior es un conjunto de
17
- generadores de caracteristicas de ejemplo pertenecientes a CapicuaGen
18
- que se ocupa entre otras cosas de definir las clase para manejar entidades.
19
- =end
20
- }
21
- spec.description = %q{CapicuaGen
22
-
23
- CapicuaGen es un software que ayuda a la creación automática de
24
- sistemas empresariales a través de la definición y ensamblado de
25
- diversos generadores de características.
26
-
27
- Melchior es un conjunto de generadores de caracteristicas de ejemplo pertenecientes a CapicuaGen
28
- que se ocupa entre otras cosas de definir las clase para manejar entidades.
29
-
30
-
31
- El proyecto fue iniciado por José Luis Bautista Martin, el 6 de enero
32
- del 2016.
33
-
34
- Puede modificar y distribuir este software, según le plazca, y usarlo
35
- para cualquier fin ya sea comercial, personal, educativo, o de cualquier
36
- índole, siempre y cuando incluya este mensaje, y se permita acceso el
37
- código fuente.
38
-
39
- Este software es código libre, y se licencia bajo LGPL.
40
-
41
- Para más información consultar http://www.gnu.org/licenses/lgpl.html
42
- }
43
-
44
- spec.homepage = "http://desdelashorasextras.blogspot.mx/"
45
- spec.licenses = ['LGPL']
46
-
47
- # Prevent pushing this gem to RubyGems.org by setting 'allowed_push_host', or
48
- # delete this section to allow pushing this gem to any host.
49
- if spec.respond_to?(:metadata)
50
- spec.metadata['allowed_push_host'] = "https://rubygems.org"
51
- else
52
- raise "RubyGems 2.0 or newer is required to protect against public gem pushes."
53
- end
54
-
55
- spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features|\.idea)/}) }
56
- spec.bindir = "exe"
57
- spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
58
- spec.require_paths = ["lib"]
59
-
60
- spec.add_development_dependency "bundler", "~> 1.11"
61
- spec.add_development_dependency "rake", "~> 10.0"
62
- spec.add_runtime_dependency 'CapicuaGen','>=0.0.1','~> 0.0'
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'CapicuaGenMelchior/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "CapicuaGenMelchior"
8
+ spec.version = CapicuaGenMelchior::VERSION
9
+ spec.authors = ["José Luis Bautista Martín"]
10
+ spec.email = ["joseluisbautista@gmail.com"]
11
+ spec.date = Date.today.to_s
12
+
13
+
14
+ spec.summary = %q{CapicuaGen es un software que ayuda a la creación automática de
15
+ sistemas empresariales a través de la definición y ensamblado de
16
+ diversos generadores de características. Melchior es un conjunto de
17
+ generadores de caracteristicas de ejemplo pertenecientes a CapicuaGen
18
+ que se ocupa entre otras cosas de definir las clase para manejar entidades.
19
+ =end
20
+ }
21
+ spec.description = %q{CapicuaGen
22
+
23
+ CapicuaGen es un software que ayuda a la creación automática de
24
+ sistemas empresariales a través de la definición y ensamblado de
25
+ diversos generadores de características.
26
+
27
+ Melchior es un conjunto de generadores de caracteristicas de ejemplo pertenecientes a CapicuaGen
28
+ que se ocupa entre otras cosas de definir las clase para manejar entidades.
29
+
30
+
31
+ El proyecto fue iniciado por José Luis Bautista Martin, el 6 de enero
32
+ del 2016.
33
+
34
+ Puede modificar y distribuir este software, según le plazca, y usarlo
35
+ para cualquier fin ya sea comercial, personal, educativo, o de cualquier
36
+ índole, siempre y cuando incluya este mensaje, y se permita acceso el
37
+ código fuente.
38
+
39
+ Este software es código libre, y se licencia bajo LGPL.
40
+
41
+ Para más información consultar http://www.gnu.org/licenses/lgpl.html
42
+ }
43
+
44
+ spec.homepage = "http://desdelashorasextras.blogspot.mx/"
45
+ spec.licenses = ['LGPL']
46
+
47
+ # Prevent pushing this gem to RubyGems.org by setting 'allowed_push_host', or
48
+ # delete this section to allow pushing this gem to any host.
49
+ if spec.respond_to?(:metadata)
50
+ spec.metadata['allowed_push_host'] = "https://rubygems.org"
51
+ else
52
+ raise "RubyGems 2.0 or newer is required to protect against public gem pushes."
53
+ end
54
+
55
+ spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features|\.idea)/}) }
56
+ spec.bindir = "exe"
57
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
58
+ spec.require_paths = ["lib"]
59
+
60
+ spec.add_development_dependency "bundler", "~> 1.11"
61
+ spec.add_development_dependency "rake", "~> 10.0"
62
+ spec.add_runtime_dependency 'CapicuaGen','>=0.0.1','~> 0.0'
63
+
64
+
65
+ spec.required_ruby_version = '>= 2.0.0'
63
66
  end
data/Gemfile CHANGED
@@ -1,4 +1,4 @@
1
- source 'https://rubygems.org'
2
-
3
- # Specify your gem's dependencies in CapicuaGenMelchior.gemspec
4
- gemspec
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in CapicuaGenMelchior.gemspec
4
+ gemspec
data/Gemfile.lock CHANGED
@@ -1,30 +1,30 @@
1
- PATH
2
- remote: .
3
- specs:
4
- CapicuaGenMelchior (0.0.2)
5
- CapicuaGen (~> 0.0, >= 0.0.1)
6
-
7
- GEM
8
- remote: https://rubygems.org/
9
- specs:
10
- CapicuaGen (0.0.1)
11
- activesupport (~> 2.3, >= 2.3.18)
12
- nokogiri (~> 1.6, >= 1.6.7)
13
- uuidtools (~> 2.1, >= 2.1.5)
14
- activesupport (2.3.18)
15
- mini_portile2 (2.0.0)
16
- nokogiri (1.6.7.2-x86-mingw32)
17
- mini_portile2 (~> 2.0.0.rc2)
18
- rake (10.4.2)
19
- uuidtools (2.1.5)
20
-
21
- PLATFORMS
22
- x86-mingw32
23
-
24
- DEPENDENCIES
25
- CapicuaGenMelchior!
26
- bundler (~> 1.11)
27
- rake (~> 10.0)
28
-
29
- BUNDLED WITH
30
- 1.11.2
1
+ PATH
2
+ remote: .
3
+ specs:
4
+ CapicuaGenMelchior (0.0.4)
5
+ CapicuaGen (~> 0.0, >= 0.0.1)
6
+
7
+ GEM
8
+ remote: https://rubygems.org/
9
+ specs:
10
+ CapicuaGen (0.0.4)
11
+ activesupport (~> 2.3, >= 2.3.18)
12
+ nokogiri (~> 1.6, >= 1.6.7)
13
+ uuidtools (~> 2.1, >= 2.1.5)
14
+ activesupport (2.3.18)
15
+ mini_portile2 (2.0.0)
16
+ nokogiri (1.6.7.2-x86-mingw32)
17
+ mini_portile2 (~> 2.0.0.rc2)
18
+ rake (10.4.2)
19
+ uuidtools (2.1.5)
20
+
21
+ PLATFORMS
22
+ x86-mingw32
23
+
24
+ DEPENDENCIES
25
+ CapicuaGenMelchior!
26
+ bundler (~> 1.11)
27
+ rake (~> 10.0)
28
+
29
+ BUNDLED WITH
30
+ 1.11.2
data/README.md CHANGED
@@ -1,41 +1,59 @@
1
- # CapicuaGenMelchior
2
-
3
- Welcome to your new gem! In this directory, you'll find the files you need to be able to package up your Ruby library into a gem. Put your Ruby code in the file `lib/CapicuaGenMelchior`. To experiment with that code, run `bin/console` for an interactive prompt.
4
-
5
- TODO: Delete this and the text above, and describe your gem
6
-
7
- ## Installation
8
-
9
- Add this line to your application's Gemfile:
10
-
11
- ```ruby
12
- gem 'CapicuaGenMelchior'
13
- ```
14
-
15
- And then execute:
16
-
17
- $ bundle
18
-
19
- Or install it yourself as:
20
-
21
- $ gem install CapicuaGenMelchior
22
-
23
- ## Usage
24
-
25
- TODO: Write usage instructions here
26
-
27
- ## Development
28
-
29
- After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake spec` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
30
-
31
- 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 tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
32
-
33
- ## Contributing
34
-
35
- Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/CapicuaGenMelchior. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct.
36
-
37
-
38
- ## License
39
-
40
- The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
41
-
1
+ # CapicuaGen
2
+
3
+ CapicuaGen es un software que ayuda a la creación automática de
4
+ sistemas empresariales a través de la definición y ensamblado de
5
+ diversos generadores de características. Melchior es un conjunto de
6
+ generadores de caracteristicas de ejemplo pertenecientes a CapicuaGen
7
+ que se ocupa entre otras cosas de definir las clase para manejar entidades.
8
+
9
+ El proyecto fue iniciado por José Luis Bautista Martin, el 6 de enero
10
+ del 2016.
11
+
12
+ Puede modificar y distribuir este software, según le plazca, y usarlo
13
+ para cualquier fin ya sea comercial, personal, educativo, o de cualquier
14
+ índole, siempre y cuando incluya este mensaje, y se permita acceso el
15
+ código fuente.
16
+
17
+ Este software es código libre, y se licencia bajo LGPL.
18
+
19
+ Para más información consultar http://www.gnu.org/licenses/lgpl.html
20
+
21
+
22
+ ## Instalación
23
+
24
+ Agrege la siguiente linea al archuivo GemFile de tu aplicación
25
+
26
+ ```ruby
27
+ gem 'CapicuaGenMelchior'
28
+ ```
29
+
30
+ y ejecute:
31
+
32
+ $ bundle
33
+
34
+ O instalela manualmente con el siguiente comando
35
+
36
+ $ gem install CapicuaGenMelchior
37
+
38
+ Para obtener un ambiente completamente funcionar de CapicuaGen, puede ejecutar el siguiente comando
39
+
40
+ $ gem install CapicuaGenEssential
41
+
42
+ ## Uso
43
+
44
+ CapicuaGen permite comenzar a trabajar con él desde el mismo momento en que es instalado. Para obtener un ejemplo funcional simplemente ejecutamos el comando CapicuaGen con el parámetro example:
45
+
46
+ $ capicuagen example
47
+
48
+ Se crearan los siguientes archivos:
49
+
50
+ * generator.rb: Ejemplo de un generador de codigo
51
+ * GemFile: Archivo de configuración de depencias para bundler .
52
+ * instnwnd.sql: Ejemplo de base de datos NorthWind, para Microsoft SQL Server
53
+
54
+ Revise el archivo generator.rb para tener una introducción a CapicuaGen.
55
+
56
+ ## Contribuir
57
+
58
+ Reporte de fallos y solicitudes de pull son bien recibidas en https://github.com/jbautistamartin/CapicuaGen
59
+
data/Rakefile CHANGED
@@ -1,6 +1,6 @@
1
- require "bundler/gem_tasks"
2
- require "rspec/core/rake_task"
3
-
4
- RSpec::Core::RakeTask.new(:spec)
5
-
6
- task :default => :spec
1
+ require "bundler/gem_tasks"
2
+ require "rspec/core/rake_task"
3
+
4
+ RSpec::Core::RakeTask.new(:spec)
5
+
6
+ task :default => :spec
data/bin/console CHANGED
@@ -1,14 +1,14 @@
1
- #!/usr/bin/env ruby
2
-
3
- require "bundler/setup"
4
- require "CapicuaGenMelchior/melchior"
5
-
6
- # You can add fixtures and/or initialization code here to make experimenting
7
- # with your gem easier. You can also use a different console, if you like.
8
-
9
- # (If you use this, don't forget to add pry to your Gemfile!)
10
- # require "pry"
11
- # Pry.start
12
-
13
- require "irb"
14
- IRB.start
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "CapicuaGenMelchior/melchior"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start
data/bin/setup CHANGED
@@ -1,8 +1,8 @@
1
- #!/usr/bin/env bash
2
- set -euo pipefail
3
- IFS=$'\n\t'
4
- set -vx
5
-
6
- bundle install
7
-
8
- # Do any other automated setup that you need to do here
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+ set -vx
5
+
6
+ bundle install
7
+
8
+ # Do any other automated setup that you need to do here
@@ -1,70 +1,70 @@
1
- =begin
2
-
3
- CapicuaGen
4
-
5
- CapicuaGen es un software que ayuda a la creación automática de
6
- sistemas empresariales a través de la definición y ensamblado de
7
- diversos generadores de características.
8
-
9
- El proyecto fue iniciado por José Luis Bautista Martin, el 6 de enero
10
- del 2016.
11
-
12
- Puede modificar y distribuir este software, según le plazca, y usarlo
13
- para cualquier fin ya sea comercial, personal, educativo, o de cualquier
14
- índole, siempre y cuando incluya este mensaje, y se permita acceso el
15
- código fuente.
16
-
17
- Este software es código libre, y se licencia bajo LGPL.
18
-
19
- Para más información consultar http://www.gnu.org/licenses/lgpl.html
20
- =end
21
-
22
- require_relative '../../../melchior'
23
- require 'active_support/core_ext/object/blank'
24
-
25
- module CapicuaGen::Melchior
26
-
27
- # Define una campo de una entidad, puede estar ligado a un campo sql
28
- class EntityFieldSchema
29
-
30
- attr_accessor :name, :type, :size, :allow_null, :default_value, :primary_key, :sql_type, :identity, :sql_name
31
-
32
- def initialize (values= {})
33
-
34
- @name = values[:name]
35
- @sql_name = values[:sql_name]
36
- @type = values[:type]
37
- @size = values[:size]
38
- @allow_null = false
39
- @allow_null = values[:allow_null] if values[:allow_null]
40
- @default_value= values[:default_value]
41
- @primary_key = false
42
- @allow_null = values[:allow_null] if values[:allow_null]
43
- @sql_type = values[:sql_type]
44
- @identity = false
45
- @identity = values[:@identity] if values[:identity]
46
-
47
- # Ajusto el tipo
48
- @type = @sql_type unless @type
49
-
50
- # correguir_nombre
51
- fix_name
52
-
53
- end
54
-
55
-
56
- protected
57
- # Ajusta el nombre
58
- def fix_name
59
- return if @name
60
- return unless @sql_name
61
- @name= @sql_name.clone
62
- /\[[^\]]+\]\.\[([^\]]+)\]/.match (@sql_name) { @name= $1 }
63
- @name.gsub!("\"", '')
64
- @name.gsub!("''", '')
65
- @name.gsub!(" ", '')
66
- end
67
-
68
- end
69
-
70
- end
1
+ =begin
2
+
3
+ CapicuaGen
4
+
5
+ CapicuaGen es un software que ayuda a la creación automática de
6
+ sistemas empresariales a través de la definición y ensamblado de
7
+ diversos generadores de características.
8
+
9
+ El proyecto fue iniciado por José Luis Bautista Martin, el 6 de enero
10
+ del 2016.
11
+
12
+ Puede modificar y distribuir este software, según le plazca, y usarlo
13
+ para cualquier fin ya sea comercial, personal, educativo, o de cualquier
14
+ índole, siempre y cuando incluya este mensaje, y se permita acceso el
15
+ código fuente.
16
+
17
+ Este software es código libre, y se licencia bajo LGPL.
18
+
19
+ Para más información consultar http://www.gnu.org/licenses/lgpl.html
20
+ =end
21
+
22
+ require_relative '../../../melchior'
23
+ require 'active_support/core_ext/object/blank'
24
+
25
+ module CapicuaGen::Melchior
26
+
27
+ # Define una campo de una entidad, puede estar ligado a un campo sql
28
+ class EntityFieldSchema
29
+
30
+ attr_accessor :name, :type, :size, :allow_null, :default_value, :primary_key, :sql_type, :identity, :sql_name
31
+
32
+ def initialize (values= {})
33
+
34
+ @name = values[:name]
35
+ @sql_name = values[:sql_name]
36
+ @type = values[:type]
37
+ @size = values[:size]
38
+ @allow_null = false
39
+ @allow_null = values[:allow_null] if values[:allow_null]
40
+ @default_value= values[:default_value]
41
+ @primary_key = false
42
+ @allow_null = values[:allow_null] if values[:allow_null]
43
+ @sql_type = values[:sql_type]
44
+ @identity = false
45
+ @identity = values[:@identity] if values[:identity]
46
+
47
+ # Ajusto el tipo
48
+ @type = @sql_type unless @type
49
+
50
+ # correguir_nombre
51
+ fix_name
52
+
53
+ end
54
+
55
+
56
+ protected
57
+ # Ajusta el nombre
58
+ def fix_name
59
+ return if @name
60
+ return unless @sql_name
61
+ @name= @sql_name.clone
62
+ /\[[^\]]+\]\.\[([^\]]+)\]/.match (@sql_name) { @name= $1 }
63
+ @name.gsub!("\"", '')
64
+ @name.gsub!("''", '')
65
+ @name.gsub!(" ", '')
66
+ end
67
+
68
+ end
69
+
70
+ end
@@ -1,64 +1,64 @@
1
- =begin
2
-
3
- CapicuaGen
4
-
5
- CapicuaGen es un software que ayuda a la creación automática de
6
- sistemas empresariales a través de la definición y ensamblado de
7
- diversos generadores de características.
8
-
9
- El proyecto fue iniciado por José Luis Bautista Martin, el 6 de enero
10
- del 2016.
11
-
12
- Puede modificar y distribuir este software, según le plazca, y usarlo
13
- para cualquier fin ya sea comercial, personal, educativo, o de cualquier
14
- índole, siempre y cuando incluya este mensaje, y se permita acceso el
15
- código fuente.
16
-
17
- Este software es código libre, y se licencia bajo LGPL.
18
-
19
- Para más información consultar http://www.gnu.org/licenses/lgpl.html
20
- =end
21
-
22
- module CapicuaGen::Melchior
23
-
24
-
25
- # Clase para definir la estructura de una entidad, puede tener propiedades a su vez
26
- class EntitySchema
27
-
28
- attr_accessor :name, :fields, :sql_name
29
-
30
- def initialize (values= {})
31
- @name = values[:name]
32
- @fields= values[:fields]
33
- @fields= [] unless @fields
34
-
35
- @sql_name= values[:sql_name]
36
-
37
- # correguir_nombre
38
- fix_name
39
- end
40
-
41
- # Deuelve los campos primarios
42
- def primary_fields
43
- return @fields.select { |field| field.primary_key }
44
- end
45
-
46
- def non_primary_fields
47
- return @fields - primary_fields
48
- end
49
-
50
-
51
- protected
52
- # Ajusta el nombre
53
- def fix_name
54
- return if @name
55
- return unless @sql_name
56
- @name= @sql_name.clone
57
- /\[[^\]]+\]\.\[([^\]]+)\]/.match (@sql_name) { @name= $1 }
58
- @name.gsub!("\"", '')
59
- @name.gsub!("''", '')
60
- @name.gsub!(" ", '')
61
- end
62
-
63
- end
1
+ =begin
2
+
3
+ CapicuaGen
4
+
5
+ CapicuaGen es un software que ayuda a la creación automática de
6
+ sistemas empresariales a través de la definición y ensamblado de
7
+ diversos generadores de características.
8
+
9
+ El proyecto fue iniciado por José Luis Bautista Martin, el 6 de enero
10
+ del 2016.
11
+
12
+ Puede modificar y distribuir este software, según le plazca, y usarlo
13
+ para cualquier fin ya sea comercial, personal, educativo, o de cualquier
14
+ índole, siempre y cuando incluya este mensaje, y se permita acceso el
15
+ código fuente.
16
+
17
+ Este software es código libre, y se licencia bajo LGPL.
18
+
19
+ Para más información consultar http://www.gnu.org/licenses/lgpl.html
20
+ =end
21
+
22
+ module CapicuaGen::Melchior
23
+
24
+
25
+ # Clase para definir la estructura de una entidad, puede tener propiedades a su vez
26
+ class EntitySchema
27
+
28
+ attr_accessor :name, :fields, :sql_name
29
+
30
+ def initialize (values= {})
31
+ @name = values[:name]
32
+ @fields= values[:fields]
33
+ @fields= [] unless @fields
34
+
35
+ @sql_name= values[:sql_name]
36
+
37
+ # correguir_nombre
38
+ fix_name
39
+ end
40
+
41
+ # Deuelve los campos primarios
42
+ def primary_fields
43
+ return @fields.select { |field| field.primary_key }
44
+ end
45
+
46
+ def non_primary_fields
47
+ return @fields - primary_fields
48
+ end
49
+
50
+
51
+ protected
52
+ # Ajusta el nombre
53
+ def fix_name
54
+ return if @name
55
+ return unless @sql_name
56
+ @name= @sql_name.clone
57
+ /\[[^\]]+\]\.\[([^\]]+)\]/.match (@sql_name) { @name= $1 }
58
+ @name.gsub!("\"", '')
59
+ @name.gsub!("''", '')
60
+ @name.gsub!(" ", '')
61
+ end
62
+
63
+ end
64
64
  end
@@ -1,172 +1,172 @@
1
- =begin
2
-
3
- CapicuaGen
4
-
5
- CapicuaGen es un software que ayuda a la creación automática de
6
- sistemas empresariales a través de la definición y ensamblado de
7
- diversos generadores de características.
8
-
9
- El proyecto fue iniciado por José Luis Bautista Martin, el 6 de enero
10
- del 2016.
11
-
12
- Puede modificar y distribuir este software, según le plazca, y usarlo
13
- para cualquier fin ya sea comercial, personal, educativo, o de cualquier
14
- índole, siempre y cuando incluya este mensaje, y se permita acceso el
15
- código fuente.
16
-
17
- Este software es código libre, y se licencia bajo LGPL.
18
-
19
- Para más información consultar http://www.gnu.org/licenses/lgpl.html
20
- =end
21
-
22
- require_relative '../../../melchior'
23
-
24
- module CapicuaGen::Melchior
25
-
26
- # Analizador de tabla SQL segun su archivo de creacio (DLL)
27
- # en este caso se hace a traves de un script exportado directamente de SQL Server
28
- # de momento no es posible parsear un script realizado a mano, solo los exportados por
29
- # MS SQL Server
30
- class SqlTableParse
31
-
32
- public
33
- def initialize
34
-
35
- end
36
-
37
- # Parsea el string y devuelve las tablas encontradas
38
- def parse_string(*sql_strings)
39
-
40
- create_table= /(CREATE\s+TABLE[^\(]+)/mi
41
-
42
- tables= []
43
-
44
- sql_strings.each do |s|
45
-
46
- sql_string= s.clone
47
-
48
- while (sql_string.length>0) do
49
-
50
- # Busco la opcion de crear una tabla
51
- index= sql_string.index(create_table)
52
-
53
- # Salida
54
- break unless index
55
-
56
- # Elimino dentro lo que hay antes del CREATE TABLE
57
- sql_string = sql_string[index..sql_string.length]
58
-
59
- # Obtengo el create table completo
60
- table_found= find_create_table sql_string
61
-
62
- if table_found
63
- table= create_table table_found
64
- tables.push table
65
- end
66
-
67
-
68
- # Obtengo el resto de la cadena
69
- sql_string= sql_string[table_found.length..sql_string.length]
70
- end
71
-
72
- return tables
73
-
74
-
75
- end
76
-
77
- end
78
-
79
- # Parsea s archivos recibidos
80
- def parse_file(*files)
81
-
82
- # Resultado
83
- tables_string= []
84
-
85
- files.each do |f|
86
- sql_string= File.open(f).read
87
- tables_string << sql_string
88
- end
89
-
90
- return parse_string(*tables_string)
91
-
92
- end
93
-
94
-
95
- private
96
-
97
-
98
- def find_create_table sql_string
99
- resultado = ''
100
- numero_parentesis= 1
101
-
102
- indexBajo= sql_string.index("(")+1
103
- resultado= sql_string[0..indexBajo]
104
-
105
- for n in indexBajo+1..sql_string.length-1 do
106
- caracter = sql_string[n]
107
- numero_parentesis= numero_parentesis+1 if caracter=="("
108
- numero_parentesis= numero_parentesis-1 if caracter==")"
109
- resultado = resultado+caracter
110
- break if numero_parentesis==0
111
- end
112
-
113
- return resultado
114
-
115
- end
116
-
117
-
118
- def create_table create_table
119
-
120
-
121
- #obtengo el nombre del campo
122
- expresion_tabla= /CREATE\s+TABLE([^\(]+)/mi
123
- expresion_tabla.match(create_table)
124
- # Nombre en crudo
125
- sql_name= $1
126
- sql_name.strip!.gsub!("\"", '')
127
-
128
- # Creo la tabla
129
- tabla= EntitySchema.new :sql_name => sql_name
130
-
131
- expresion_campo = /\[?(\S+?)\]?\s+\[?(int|n?varchar|n?char|money|real|int|smallint|datetime|bit)\]?\s*(IDENTITY)?\s*(?:\(([^\)]+?)\))?\s*(NOT\s+NULL|NULL)\s*/mi
132
- expresion_contraint_primary= /CONSTRAINT\s+\S+\s+PRIMARY[^\(]+?\(([^\)]+)\)/mi
133
-
134
-
135
- expresion_contraint_primary.match(create_table)
136
- llaves_primarias= $1
137
-
138
-
139
- #obtengo todos los campos
140
- create_table.scan (expresion_campo) do |nombre, tipo, identity, longitud, nulo|
141
-
142
- nombre.gsub!('([', '')
143
-
144
- campo= EntityFieldSchema.new :sql_name => nombre, :sql_type => tipo
145
-
146
- case tipo.upcase
147
- when "VARCHAR", "CHAR", "NVARCHAR", "NCHAR"
148
- campo.size= longitud if longitud
149
- end
150
-
151
- campo.allow_null = true if /NULL/i.match(nulo)
152
- campo.allow_null = false if /NOT/i.match(nulo)
153
-
154
- #reviso a ver si es llave primaria
155
- campo.primary_key= true if llaves_primarias and llaves_primarias.index(campo.name)
156
-
157
- #Agrega información de indentidad.
158
- campo.identity = true if identity
159
-
160
- #agrego el campo
161
- tabla.fields.push campo
162
- end
163
-
164
-
165
- return tabla
166
-
167
- end
168
-
169
-
170
- end
171
-
1
+ =begin
2
+
3
+ CapicuaGen
4
+
5
+ CapicuaGen es un software que ayuda a la creación automática de
6
+ sistemas empresariales a través de la definición y ensamblado de
7
+ diversos generadores de características.
8
+
9
+ El proyecto fue iniciado por José Luis Bautista Martin, el 6 de enero
10
+ del 2016.
11
+
12
+ Puede modificar y distribuir este software, según le plazca, y usarlo
13
+ para cualquier fin ya sea comercial, personal, educativo, o de cualquier
14
+ índole, siempre y cuando incluya este mensaje, y se permita acceso el
15
+ código fuente.
16
+
17
+ Este software es código libre, y se licencia bajo LGPL.
18
+
19
+ Para más información consultar http://www.gnu.org/licenses/lgpl.html
20
+ =end
21
+
22
+ require_relative '../../../melchior'
23
+
24
+ module CapicuaGen::Melchior
25
+
26
+ # Analizador de tabla SQL segun su archivo de creacio (DLL)
27
+ # en este caso se hace a traves de un script exportado directamente de SQL Server
28
+ # de momento no es posible parsear un script realizado a mano, solo los exportados por
29
+ # MS SQL Server
30
+ class SqlTableParse
31
+
32
+ public
33
+ def initialize
34
+
35
+ end
36
+
37
+ # Parsea el string y devuelve las tablas encontradas
38
+ def parse_string(*sql_strings)
39
+
40
+ create_table= /(CREATE\s+TABLE[^\(]+)/mi
41
+
42
+ tables= []
43
+
44
+ sql_strings.each do |s|
45
+
46
+ sql_string= s.clone
47
+
48
+ while (sql_string.length>0) do
49
+
50
+ # Busco la opcion de crear una tabla
51
+ index= sql_string.index(create_table)
52
+
53
+ # Salida
54
+ break unless index
55
+
56
+ # Elimino dentro lo que hay antes del CREATE TABLE
57
+ sql_string = sql_string[index..sql_string.length]
58
+
59
+ # Obtengo el create table completo
60
+ table_found= find_create_table sql_string
61
+
62
+ if table_found
63
+ table= create_table table_found
64
+ tables.push table
65
+ end
66
+
67
+
68
+ # Obtengo el resto de la cadena
69
+ sql_string= sql_string[table_found.length..sql_string.length]
70
+ end
71
+
72
+ return tables
73
+
74
+
75
+ end
76
+
77
+ end
78
+
79
+ # Parsea s archivos recibidos
80
+ def parse_file(*files)
81
+
82
+ # Resultado
83
+ tables_string= []
84
+
85
+ files.each do |f|
86
+ sql_string= File.open(f).read
87
+ tables_string << sql_string
88
+ end
89
+
90
+ return parse_string(*tables_string)
91
+
92
+ end
93
+
94
+
95
+ private
96
+
97
+
98
+ def find_create_table sql_string
99
+ resultado = ''
100
+ numero_parentesis= 1
101
+
102
+ indexBajo= sql_string.index("(")+1
103
+ resultado= sql_string[0..indexBajo]
104
+
105
+ for n in indexBajo+1..sql_string.length-1 do
106
+ caracter = sql_string[n]
107
+ numero_parentesis= numero_parentesis+1 if caracter=="("
108
+ numero_parentesis= numero_parentesis-1 if caracter==")"
109
+ resultado = resultado+caracter
110
+ break if numero_parentesis==0
111
+ end
112
+
113
+ return resultado
114
+
115
+ end
116
+
117
+
118
+ def create_table create_table
119
+
120
+
121
+ #obtengo el nombre del campo
122
+ expresion_tabla= /CREATE\s+TABLE([^\(]+)/mi
123
+ expresion_tabla.match(create_table)
124
+ # Nombre en crudo
125
+ sql_name= $1
126
+ sql_name.strip!.gsub!("\"", '')
127
+
128
+ # Creo la tabla
129
+ tabla= EntitySchema.new :sql_name => sql_name
130
+
131
+ expresion_campo = /\[?(\S+?)\]?\s+\[?(int|n?varchar|n?char|money|real|int|smallint|datetime|bit)\]?\s*(IDENTITY)?\s*(?:\(([^\)]+?)\))?\s*(NOT\s+NULL|NULL)\s*/mi
132
+ expresion_contraint_primary= /CONSTRAINT\s+\S+\s+PRIMARY[^\(]+?\(([^\)]+)\)/mi
133
+
134
+
135
+ expresion_contraint_primary.match(create_table)
136
+ llaves_primarias= $1
137
+
138
+
139
+ #obtengo todos los campos
140
+ create_table.scan (expresion_campo) do |nombre, tipo, identity, longitud, nulo|
141
+
142
+ nombre.gsub!('([', '')
143
+
144
+ campo= EntityFieldSchema.new :sql_name => nombre, :sql_type => tipo
145
+
146
+ case tipo.upcase
147
+ when "VARCHAR", "CHAR", "NVARCHAR", "NCHAR"
148
+ campo.size= longitud if longitud
149
+ end
150
+
151
+ campo.allow_null = true if /NULL/i.match(nulo)
152
+ campo.allow_null = false if /NOT/i.match(nulo)
153
+
154
+ #reviso a ver si es llave primaria
155
+ campo.primary_key= true if llaves_primarias and llaves_primarias.index(campo.name)
156
+
157
+ #Agrega información de indentidad.
158
+ campo.identity = true if identity
159
+
160
+ #agrego el campo
161
+ tabla.fields.push campo
162
+ end
163
+
164
+
165
+ return tabla
166
+
167
+ end
168
+
169
+
170
+ end
171
+
172
172
  end
@@ -1,3 +1,3 @@
1
- module CapicuaGenMelchior
2
- VERSION = "0.0.3"
3
- end
1
+ module CapicuaGenMelchior
2
+ VERSION = "0.1.0"
3
+ end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: CapicuaGenMelchior
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.3
4
+ version: 0.1.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - José Luis Bautista Martín
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2016-04-15 00:00:00.000000000 Z
11
+ date: 2016-05-08 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -118,7 +118,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
118
118
  requirements:
119
119
  - - ">="
120
120
  - !ruby/object:Gem::Version
121
- version: '0'
121
+ version: 2.0.0
122
122
  required_rubygems_version: !ruby/object:Gem::Requirement
123
123
  requirements:
124
124
  - - ">="