/*
* This file is part of the Haven & Hearth game client.
* Copyright (C) 2009 Fredrik Tolf <fredrik@dolda2000.com>, and
* Björn Johannessen <johannessen.bjorn@gmail.com>
*
* Redistribution and/or modification of this file is subject to the
* terms of the GNU Lesser General Public License, version 3, as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* Other parts of this source tree adhere to other copying
* rights. Please see the file `COPYING' in the root directory of the
* source tree for details.
*
* A copy the GNU Lesser General Public License is distributed along
* with the source tree of which this file is a part in the file
* `doc/LPGL-3'. If it is missing for any reason, please see the Free
* Software Foundation's website at <http://www.fsf.org/>, or write
* to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
* Boston, MA 02111-1307 USA
*/
package haven.glsl;
public abstract class Variable {
public final Type type;
public final Symbol name;
public Variable(Type type, Symbol name) {
this.type = type;
this.name = name;
}
public class Ref extends LValue {
public Ref process(Context ctx) {
return(this);
}
public void output(Output out) {
out.write(name);
}
}
public Ref ref() {
return(new Ref());
}
public static class Implicit extends Variable {
public Implicit(Type type, Symbol name) {
super(type, name);
}
}
public static class Global extends Variable {
public Global(Type type, Symbol name) {
super(type, name);
}
public Global(Type type) {
super(type, new Symbol.Gen());
}
public class Ref extends Variable.Ref {
public Ref process(Context ctx) {
use(ctx);
return(this);
}
}
public Ref ref() {
return(new Ref());
}
public boolean defined(Context ctx) {
for(Toplevel tl : ctx.vardefs) {
if((tl instanceof Definition) && (((Definition)tl).var() == this))
return(true);
}
return(false);
}
public void use(Context ctx) {
if(!defined(ctx))
ctx.vardefs.add(new Definition());
}
public class Definition extends Toplevel {
public Definition process(Context ctx) {
return(this);
}
public void output(Output out) {
out.write(type.name(out.ctx));
out.write(" ");
out.write(name);
out.write(";\n");
}
private Global var() {
return(Global.this);
}
}
}
}