diff options
author | luke <luke@980ebf18-57e1-0310-9a29-db15c13687c0> | 2006-02-27 23:22:09 +0000 |
---|---|---|
committer | luke <luke@980ebf18-57e1-0310-9a29-db15c13687c0> | 2006-02-27 23:22:09 +0000 |
commit | eda9d955b3fb2bbe5d7ca2cc3f7802d5fb9395ef (patch) | |
tree | b078cd5c83f969c1eab0c017b750e8b5c25b460d | |
parent | 56116c2aa64ccbbc6740d30b5901b2700bcae036 (diff) | |
download | puppet-eda9d955b3fb2bbe5d7ca2cc3f7802d5fb9395ef.tar.gz puppet-eda9d955b3fb2bbe5d7ca2cc3f7802d5fb9395ef.tar.xz puppet-eda9d955b3fb2bbe5d7ca2cc3f7802d5fb9395ef.zip |
Fixing #64; multiple class definitions in the same scope is now an error, although using the same class name in different scopes is not an error.
git-svn-id: https://reductivelabs.com/svn/puppet/trunk@956 980ebf18-57e1-0310-9a29-db15c13687c0
-rw-r--r-- | lib/puppet/parser/scope.rb | 8 | ||||
-rwxr-xr-x | test/language/scope.rb | 20 |
2 files changed, 26 insertions, 2 deletions
diff --git a/lib/puppet/parser/scope.rb b/lib/puppet/parser/scope.rb index e81664219..b441fd4bc 100644 --- a/lib/puppet/parser/scope.rb +++ b/lib/puppet/parser/scope.rb @@ -639,7 +639,13 @@ module Puppet # Define our type. def settype(name,ltype) - @typetable[name] = ltype + # Don't let them redefine the class in this scope. + if @typetable.include?(name) + raise Puppet::ParseError, + "%s is already defined" % name + else + @typetable[name] = ltype + end end # Return an interpolated string. diff --git a/test/language/scope.rb b/test/language/scope.rb index b4a546267..ee896ab32 100755 --- a/test/language/scope.rb +++ b/test/language/scope.rb @@ -411,7 +411,25 @@ class TestScope < Test::Unit::TestCase assert_equal("bin", file["owner"], "Value did not override correctly") } end + + def test_multipletypes + scope = Puppet::Parser::Scope.new() + children = [] - def test_classscopes + # create the parent class + children << classobj("aclass") + children << classobj("aclass") + top = nil + assert_nothing_raised("Could not create top object") { + top = AST::ASTArray.new( + :children => children + ) + } + + scope = nil + assert_raise(Puppet::ParseError) { + scope = Puppet::Parser::Scope.new() + objects = top.evaluate(:scope => scope) + } end end |