aa
com.cliffc.aa.HM.HM6.Ident Class Reference
Inheritance diagram for com.cliffc.aa.HM.HM6.Ident:
[legend]
Collaboration diagram for com.cliffc.aa.HM.HM6.Ident:
[legend]

Public Member Functions

String p ()
 
final String toString ()
 

Package Functions

 Ident (String name)
 
void add_kids (Worklist work)
 
void add_occurs (Worklist work)
 
T2 debug_find ()
 
T2 find ()
 
boolean hm (Worklist work)
 
T2 lookup (String name)
 
boolean more_work (Worklist work)
 
final boolean more_work_impl (Worklist work)
 
final SB p0 (SB sb, VBitSet dups)
 
SB p1 (SB sb)
 
SB p2 (SB sb, VBitSet dups)
 
void prep_lookup_deps (Ident id)
 
int prep_tree (Syntax par, VStack nongen, Worklist work)
 
final void prep_tree_impl (Syntax par, VStack nongen, Worklist work, T2 t)
 
SB str (SB sb)
 

Package Attributes

final String _name
 
VStack _nongen
 
Syntax _par
 
T2 _t
 

Detailed Description

Definition at line 269 of file HM6.java.

Constructor & Destructor Documentation

◆ Ident()

com.cliffc.aa.HM.HM6.Ident.Ident ( String  name)
package

Definition at line 271 of file HM6.java.

271 { _name=name; }

References com.cliffc.aa.HM.HM6.Ident._name.

Member Function Documentation

◆ add_kids()

void com.cliffc.aa.HM.HM6.Ident.add_kids ( Worklist  work)
package

Reimplemented from com.cliffc.aa.HM.HM6.Syntax.

Definition at line 288 of file HM6.java.

288 { }

◆ add_occurs()

void com.cliffc.aa.HM.HM6.Ident.add_occurs ( Worklist  work)
package

Reimplemented from com.cliffc.aa.HM.HM6.Syntax.

Definition at line 289 of file HM6.java.

289  {
290  T2 t = _par==null ? null : _par.lookup(_name); // Lookup in current env
291  if( t==null ) t = PRIMS.get(_name); // Lookup in prims
292  if( t.occurs_in(_par) ) // Got captured in some parent?
293  t.add_deps_work(work); // Need to revisit dependent ids
294  }

References com.cliffc.aa.HM.HM6.Ident._name, com.cliffc.aa.HM.HM6.Syntax._par, com.cliffc.aa.HM.HM6.T2.add_deps_work(), com.cliffc.aa.HM.HM6.Syntax.lookup(), com.cliffc.aa.HM.HM6.T2.occurs_in(), and com.cliffc.aa.HM.HM6.PRIMS.

Here is the call graph for this function:

◆ debug_find()

T2 com.cliffc.aa.HM.HM6.Syntax.debug_find ( )
packageinherited

Definition at line 218 of file HM6.java.

218 { return _t.find(); } // Find, without the roll-up

References com.cliffc.aa.HM.HM6.Syntax._t, and com.cliffc.aa.HM.HM6.T2.find().

Referenced by com.cliffc.aa.HM.HM6.hm().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ find()

T2 com.cliffc.aa.HM.HM6.Syntax.find ( )
packageinherited

Definition at line 214 of file HM6.java.

214  { // U-F find
215  T2 t = _t.find();
216  return t==_t ? t : (_t=t);
217  }

References com.cliffc.aa.HM.HM6.Syntax._t, and com.cliffc.aa.HM.HM6.T2.find().

Referenced by com.cliffc.aa.HM.HM6.T2._occurs_in(), com.cliffc.aa.HM.HM6.Lambda.add_occurs(), com.cliffc.aa.HM.HM6.Lambda2.add_occurs(), com.cliffc.aa.HM.HM6.Let.add_occurs(), com.cliffc.aa.HM.HM6.Con.hm(), com.cliffc.aa.HM.HM6.Ident.hm(), com.cliffc.aa.HM.HM6.Lambda.hm(), com.cliffc.aa.HM.HM6.Lambda2.hm(), com.cliffc.aa.HM.HM6.Let.hm(), and com.cliffc.aa.HM.HM6.Apply.hm().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ hm()

boolean com.cliffc.aa.HM.HM6.Ident.hm ( Worklist  work)
package

Reimplemented from com.cliffc.aa.HM.HM6.Syntax.

Definition at line 275 of file HM6.java.

275  {
276  // A boolean if name is from a Let._body (or PRIM) vs Let._def (or
277  // Lambda). Not helpful, as its only useful at the top-layer.
278  // Structural unification requires the 'occurs check' at each internal
279  // layer, which can differ from the top-layer.
280  //boolean occurs_fresh = _par==null /*from prims*/ || _par.is_fresh(_name,this);
281  T2 t = _par==null ? null : _par.lookup(_name); // Lookup in current env
282  if( t==null ) t = PRIMS.get(_name); // Lookup in prims
283  if( t==null )
284  throw new RuntimeException("Parse error, "+_name+" is undefined");
285  return t.fresh_unify(find(),_nongen,work);
286  }

References com.cliffc.aa.HM.HM6.Ident._name, com.cliffc.aa.HM.HM6.Syntax._nongen, com.cliffc.aa.HM.HM6.Syntax._par, com.cliffc.aa.HM.HM6.Syntax.find(), com.cliffc.aa.HM.HM6.T2.fresh_unify(), com.cliffc.aa.HM.HM6.Syntax.lookup(), and com.cliffc.aa.HM.HM6.PRIMS.

Here is the call graph for this function:

◆ lookup()

T2 com.cliffc.aa.HM.HM6.Ident.lookup ( String  name)
package

Reimplemented from com.cliffc.aa.HM.HM6.Syntax.

Definition at line 287 of file HM6.java.

287 { throw unimpl("should not reach here"); }

◆ more_work()

boolean com.cliffc.aa.HM.HM6.Ident.more_work ( Worklist  work)
package

Reimplemented from com.cliffc.aa.HM.HM6.Syntax.

Definition at line 302 of file HM6.java.

302 { return more_work_impl(work); }

References com.cliffc.aa.HM.HM6.Syntax.more_work_impl().

Here is the call graph for this function:

◆ more_work_impl()

final boolean com.cliffc.aa.HM.HM6.Syntax.more_work_impl ( Worklist  work)
packageinherited

Definition at line 238 of file HM6.java.

238  {
239  return work.has(this) || !hm(null); // Either on worklist, or no-progress
240  }

References com.cliffc.aa.HM.HM6.Worklist.has(), and com.cliffc.aa.HM.HM6.Syntax.hm().

Referenced by com.cliffc.aa.HM.HM6.Con.more_work(), com.cliffc.aa.HM.HM6.Ident.more_work(), com.cliffc.aa.HM.HM6.Lambda.more_work(), com.cliffc.aa.HM.HM6.Lambda2.more_work(), com.cliffc.aa.HM.HM6.Let.more_work(), and com.cliffc.aa.HM.HM6.Apply.more_work().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ p()

String com.cliffc.aa.HM.HM6.Syntax.p ( )
inherited

Definition at line 245 of file HM6.java.

245 { return p0(new SB(), new VBitSet()).toString(); }

References com.cliffc.aa.HM.HM6.Syntax.p0(), and com.cliffc.aa.util.SB.toString().

Here is the call graph for this function:

◆ p0()

final SB com.cliffc.aa.HM.HM6.Syntax.p0 ( SB  sb,
VBitSet  dups 
)
packageinherited

Definition at line 246 of file HM6.java.

246  {
247  _t.get_dups(dups);
248  _t.str(p1(sb.i()).p(" "), new VBitSet(),dups).nl();
249  return p2(sb.ii(1),dups).di(1);
250  }

References com.cliffc.aa.HM.HM6.Syntax._t, com.cliffc.aa.util.SB.di(), com.cliffc.aa.HM.HM6.T2.get_dups(), com.cliffc.aa.util.SB.i(), com.cliffc.aa.util.SB.ii(), com.cliffc.aa.util.SB.nl(), com.cliffc.aa.util.SB.p(), com.cliffc.aa.HM.HM6.Syntax.p1(), com.cliffc.aa.HM.HM6.Syntax.p2(), and com.cliffc.aa.HM.HM6.T2.str().

Referenced by com.cliffc.aa.HM.HM6.Syntax.p(), com.cliffc.aa.HM.HM6.Lambda.p2(), com.cliffc.aa.HM.HM6.Lambda2.p2(), com.cliffc.aa.HM.HM6.Let.p2(), and com.cliffc.aa.HM.HM6.Apply.p2().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ p1()

SB com.cliffc.aa.HM.HM6.Ident.p1 ( SB  sb)
package

Reimplemented from com.cliffc.aa.HM.HM6.Syntax.

Definition at line 273 of file HM6.java.

273 { return sb.p(_name); }

References com.cliffc.aa.HM.HM6.Ident._name, and com.cliffc.aa.util.SB.p().

Referenced by com.cliffc.aa.HM.HM6.Ident.str().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ p2()

SB com.cliffc.aa.HM.HM6.Ident.p2 ( SB  sb,
VBitSet  dups 
)
package

Reimplemented from com.cliffc.aa.HM.HM6.Syntax.

Definition at line 274 of file HM6.java.

274 { return sb; }

◆ prep_lookup_deps()

void com.cliffc.aa.HM.HM6.Ident.prep_lookup_deps ( Ident  id)
package

Reimplemented from com.cliffc.aa.HM.HM6.Syntax.

Definition at line 301 of file HM6.java.

301 { throw unimpl("should not reach here"); }

◆ prep_tree()

int com.cliffc.aa.HM.HM6.Ident.prep_tree ( Syntax  par,
VStack  nongen,
Worklist  work 
)
package

Reimplemented from com.cliffc.aa.HM.HM6.Syntax.

Definition at line 295 of file HM6.java.

295  {
296  prep_tree_impl(par,nongen,work,T2.make_leaf());
297  for( Syntax syn = _par; syn!=null; syn = syn._par )
298  syn.prep_lookup_deps(this);
299  return 1;
300  }

References com.cliffc.aa.HM.HM6.Syntax._par, com.cliffc.aa.HM.HM6.T2.make_leaf(), and com.cliffc.aa.HM.HM6.Syntax.prep_tree_impl().

Here is the call graph for this function:

◆ prep_tree_impl()

final void com.cliffc.aa.HM.HM6.Syntax.prep_tree_impl ( Syntax  par,
VStack  nongen,
Worklist  work,
T2  t 
)
packageinherited

Definition at line 228 of file HM6.java.

228 { _par=par; _t=t; _nongen = nongen; work.push(this); }

References com.cliffc.aa.HM.HM6.Syntax._nongen, com.cliffc.aa.HM.HM6.Syntax._par, com.cliffc.aa.HM.HM6.Syntax._t, and com.cliffc.aa.HM.HM6.Worklist.push().

Referenced by com.cliffc.aa.HM.HM6.Con.prep_tree(), com.cliffc.aa.HM.HM6.Ident.prep_tree(), com.cliffc.aa.HM.HM6.Lambda.prep_tree(), com.cliffc.aa.HM.HM6.Lambda2.prep_tree(), com.cliffc.aa.HM.HM6.Let.prep_tree(), and com.cliffc.aa.HM.HM6.Apply.prep_tree().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ str()

SB com.cliffc.aa.HM.HM6.Ident.str ( SB  sb)
package

Reimplemented from com.cliffc.aa.HM.HM6.Syntax.

Definition at line 272 of file HM6.java.

272 { return p1(sb); }

References com.cliffc.aa.HM.HM6.Ident.p1().

Here is the call graph for this function:

◆ toString()

final String com.cliffc.aa.HM.HM6.Syntax.toString ( )
inherited

Definition at line 242 of file HM6.java.

242 { return str(new SB()).toString(); }

References com.cliffc.aa.HM.HM6.Syntax.str(), and com.cliffc.aa.util.SB.toString().

Here is the call graph for this function:

Member Data Documentation

◆ _name

final String com.cliffc.aa.HM.HM6.Ident._name
package

◆ _nongen

VStack com.cliffc.aa.HM.HM6.Syntax._nongen
packageinherited

◆ _par

◆ _t


The documentation for this class was generated from the following file:
com.cliffc.aa.HM.HM6.Syntax.lookup
abstract T2 lookup(String name)
com.cliffc.aa.HM.HM6.Syntax._t
T2 _t
Definition: HM6.java:213
com.cliffc.aa.HM.HM6.T2.str
SB str(SB sb, VBitSet visit, VBitSet dups)
Definition: HM6.java:836
com.cliffc.aa.util.SB.ii
SB ii(int i)
Definition: SB.java:44
com.cliffc.aa.util.SB.di
SB di(int i)
Definition: SB.java:46
com.cliffc.aa.HM.HM6.T2.get_dups
VBitSet get_dups(VBitSet dups)
Definition: HM6.java:823
com.cliffc.aa.HM.HM6.Ident._name
final String _name
Definition: HM6.java:270
com.cliffc.aa.HM.HM6.Syntax.prep_tree_impl
final void prep_tree_impl(Syntax par, VStack nongen, Worklist work, T2 t)
Definition: HM6.java:228
com.cliffc.aa.HM.HM6.Syntax.p2
abstract SB p2(SB sb, VBitSet dups)
com.cliffc.aa.HM.HM6.Syntax._nongen
VStack _nongen
Definition: HM6.java:212
com.cliffc.aa.HM.HM6.T2.find
T2 find()
Definition: HM6.java:543
com.cliffc.aa.HM.HM6.Syntax._par
Syntax _par
Definition: HM6.java:211
com.cliffc.aa.HM.HM6.Syntax.p1
abstract SB p1(SB sb)
com.cliffc.aa.HM.HM6.Syntax.str
abstract SB str(SB sb)
com.cliffc.aa.HM.HM6.Ident.p1
SB p1(SB sb)
Definition: HM6.java:273
com.cliffc.aa.HM.HM6.Syntax.find
T2 find()
Definition: HM6.java:214
com.cliffc.aa.util.VBitSet
Definition: VBitSet.java:5
com.cliffc.aa.util.SB
Tight/tiny StringBuilder wrapper.
Definition: SB.java:8
com.cliffc.aa.HM.HM6.PRIMS
static final HashMap< String, T2 > PRIMS
Definition: HM6.java:24
com.cliffc.aa.util.SB.nl
SB nl()
Definition: SB.java:48
com.cliffc.aa.util.SB.p
SB p(String s)
Definition: SB.java:13
com.cliffc.aa.util.SB.i
SB i(int d)
Definition: SB.java:38
com.cliffc.aa.HM.HM6.Syntax.hm
abstract boolean hm(Worklist work)
com.cliffc.aa.util.SB.toString
String toString()
Definition: SB.java:62
com.cliffc.aa.HM.HM6.Syntax.more_work_impl
final boolean more_work_impl(Worklist work)
Definition: HM6.java:238
com.cliffc.aa.HM.HM6.Syntax.p0
final SB p0(SB sb, VBitSet dups)
Definition: HM6.java:246