blob: e2c091fe18f05f62e5991bf358e13b4e1fa8e284 (
plain)
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
|
/**
* Copyright (c) Rich Hickey. All rights reserved.
* The use and distribution terms for this software are covered by the
* Common Public License 1.0 (http://opensource.org/licenses/cpl.php)
* which can be found in the file CPL.TXT at the root of this distribution.
* By using this software in any fashion, you are agreeing to be bound by
* the terms of this license.
* You must not remove this notice, or any other, from this software.
**/
/* rich Mar 27, 2006 1:29:39 PM */
using System;
using System.Collections.Specialized;
namespace clojure.lang
{
public class Module
{
/**
* String->Module
*/
static public HybridDictionary table = new HybridDictionary();
/**
* Symbol->Var
*/
public HybridDictionary vars = new HybridDictionary();
public String name;
Module(String name)
{
this.name = name;
table.Add(name, this);
}
static public Module find(String name)
{
return (Module) table[name];
}
static public Module findOrCreate(String name)
{
lock(table)
{
Module ns = find(name);
if(ns == null)
table.Add(name,ns = new Module(name));
return ns;
}
}
static public Var intern(String ns, String name)
{
return findOrCreate(ns).intern(Symbol.intern(name));
}
public Var intern(Symbol sym)
{
lock(vars)
{
Var var = (Var) vars[sym];
if(var == null)
vars.Add(sym,var = new Var(sym, this));
return var;
}
}
}
}
|