/* $RCSfile$
 * $Author: hansonr $
 * $Date: 2012-08-09 08:31:30 -0500 (Thu, 09 Aug 2012) $
 * $Revision: 17434 $
 *
 * Copyright (C) 2003-2005  Miguel, Jmol Development, www.jmol.org
 *
 * Contact: jmol-developers@lists.sf.net
 *
 *  This library is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Lesser General Public
 *  License as published by the Free Software Foundation; either
 *  version 2.1 of the License, or (at your option) any later version.
 *
 *  This library 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
 *  Lesser General Public License for more details.
 *
 *  You should have received a copy of the GNU Lesser General Public
 *  License along with this library; if not, write to the Free Software
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 */

package org.jmol.adapter.smarter;

import org.jmol.api.JmolAdapter;
import org.jmol.api.JmolAdapterAtomIterator;
import javajs.util.BS;
import org.jmol.script.T;

import javajs.util.Lst;
import javajs.util.P3;
import javajs.util.V3;


/* **************************************************************
 * the frame iterators
 * **************************************************************/
class AtomIterator implements JmolAdapterAtomIterator {
	private int iatom;
	private Atom atom;
	private int ac;
	private Atom[] atoms;
	private BS bsAtoms;

	AtomIterator(AtomSetCollection asc) {
		ac = asc.ac;
		atoms = asc.atoms;		
		bsAtoms = asc.bsAtoms;
		iatom = 0;
	}

	@Override
  public boolean hasNext() {
		if (iatom == ac)
			return false;
		while ((atom = atoms[iatom++]) == null
				|| (bsAtoms != null && !bsAtoms.get(atom.index)))
			if (iatom == ac)
				return false;
		atoms[iatom - 1] = null; // single pass
		return true;
	}

	@Override
  public int getAtomSetIndex() {
		return atom.atomSetIndex;
	}

	
	@Override
  public BS getSymmetry() {
		return atom.bsSymmetry;
	}

	
	@Override
  public int getAtomSite() {
		return atom.atomSite + 1;
	}

	
	@Override
  public Object getUniqueID() {
		return Integer.valueOf(atom.index);
	}

	
	@Override
  public int getElementNumber() {
		return (atom.elementNumber > 0 ? atom.elementNumber : JmolAdapter
				.getElementNumber(atom.getElementSymbol()));
	}

	
	@Override
  public String getAtomName() {
		return atom.atomName;
	}

	
	@Override
  public int getFormalCharge() {
    return (atom.formalCharge == Integer.MIN_VALUE ? 0 : atom.formalCharge);
  }
	
	@Override
  public float getPartialCharge() {
		return atom.partialCharge;
	}

	
	@Override
  public Lst<Object> getTensors() {
		return atom.tensors;
	}

	
	@Override
  public float getRadius() {
		return atom.radius;
	}
	
  @Override
  public float getBondRadius() {
    return atom.bondingRadius;
  }
  
	/**
	 * Note that atom.vib also serves to deliver specific 
	 * data items.
	 */
	@Override
  public V3 getVib() {
	  return (atom.vib == null || Float.isNaN(atom.vib.z) ? null : 
	    atom.vib);
	}

  @Override
  public int getSeqID() {
    return (atom.vib == null || !Float.isNaN(atom.vib.y) || atom.vib.z != T.seqid ? 0 : 
      (int) atom.vib.x);
  }

	
	@Override
  public float getBfactor() {
		return atom.bfactor;
	}

	
	@Override
  public float getOccupancy() {
		return atom.foccupancy * 100;
	}

	
	@Override
  public boolean getIsHetero() {
		return atom.isHetero;
	}

	
	@Override
  public int getSerial() {
		return atom.atomSerial;
	}

	
	@Override
  public int getChainID() {
		return atom.chainID;
	}

	
	@Override
  public char getAltLoc() {
		return JmolAdapter.canonizeAlternateLocationID(atom.altLoc);
	}

	
	@Override
  public String getGroup3() {
		return atom.group3;
	}

	
	@Override
  public int getSequenceNumber() {
		return atom.sequenceNumber;
	}

	
	@Override
  public char getInsertionCode() {
		return JmolAdapter.canonizeInsertionCode(atom.insertionCode);
	}

	
	@Override
  public P3 getXYZ() {
		return atom;
	}

	 @Override
	  public int getElement() {  
	    return getElementNumber() & 0x7F;
	  }

	  @Override
	  public int getIsotope() {
	    return getElementNumber() >> 7;
	  }


}
