com.nflabs.zeppelin.zengine.stmt.AnnotationStatement Maven / Gradle / Ivy
package com.nflabs.zeppelin.zengine.stmt;
import java.io.InputStream;
import java.net.URI;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import com.nflabs.zeppelin.driver.ZeppelinConnection;
import com.nflabs.zeppelin.driver.ZeppelinDriver;
import com.nflabs.zeppelin.util.Util;
import com.nflabs.zeppelin.zengine.ParamInfo;
import com.nflabs.zeppelin.zengine.ZException;
import com.nflabs.zeppelin.zengine.Zengine;
/**
* AnnotationStatement consumes string statement like
*
* @[Annotation] [Command] [Argument]
*
* for example, statement like '@driver set hive'
* getAnnotation() returns 'driver'
* getCommand() returns 'set'
* getArgument retuns 'hive'
*
* @author moon
*
*/
public class AnnotationStatement extends Q {
transient static Pattern annotationPattern = Pattern.compile("@([^ ]*)\\s([^ ]*)(\\s(.*))?");
private ANNOTATION annotation;
private COMMAND command;
private String arg;
public static enum ANNOTATION {
DRIVER
};
public static enum COMMAND{
SET
};
public AnnotationStatement(String stmt) throws ZException{
super(stmt);
Matcher matcher = annotationPattern.matcher(query);
if (matcher.find()) {
String annotation = matcher.group(1);
String cmd = matcher.group(2);
String arg = matcher.group(4);
if (ANNOTATION.DRIVER.name().compareToIgnoreCase(annotation)==0) {
this.annotation = ANNOTATION.DRIVER;
if (COMMAND.SET.name().compareToIgnoreCase(cmd)==0) {
this.command = COMMAND.SET;
} else {
throw new ZException("Unsupported command "+cmd);
}
} else {
throw new ZException("Invalid annotation "+annotation);
}
this.arg = arg;
} else {
throw new ZException("Invalid annotation syntax "+query);
}
}
public ANNOTATION getAnnotation(){
return annotation;
}
public COMMAND getCommand(){
return command;
}
public String getArgument(){
return arg;
}
@Override
public String getQuery() throws ZException {
return super.getQuery();
}
@Override
public List getResources() throws ZException {
return new LinkedList();
}
@Override
public String getReleaseQuery() throws ZException {
return null;
}
@Override
public InputStream readWebResource(String path) throws ZException {
return null;
}
@Override
public boolean isWebEnabled() {
return false;
}
@Override
protected void initialize() throws ZException {
}
@Override
protected Map extractParams() throws ZException {
return null;
}
public Z execute(ZeppelinConnection connection) throws ZException {
if(executed) { return this; }
initialize();
if (this.hasPrev()){
prev().execute(connection);
}
executed = true;
return this;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy