summaryrefslogtreecommitdiffstats
path: root/lib/puppet/parser
diff options
context:
space:
mode:
authorluke <luke@980ebf18-57e1-0310-9a29-db15c13687c0>2006-02-27 23:22:09 +0000
committerluke <luke@980ebf18-57e1-0310-9a29-db15c13687c0>2006-02-27 23:22:09 +0000
commiteda9d955b3fb2bbe5d7ca2cc3f7802d5fb9395ef (patch)
treeb078cd5c83f969c1eab0c017b750e8b5c25b460d /lib/puppet/parser
parent56116c2aa64ccbbc6740d30b5901b2700bcae036 (diff)
downloadpuppet-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
Diffstat (limited to 'lib/puppet/parser')
-rw-r--r--lib/puppet/parser/scope.rb8
1 files changed, 7 insertions, 1 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.