import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.Reader;
import java.io.Writer;
import java.net.URI;
import java.net.URISyntaxException;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.ServiceLoader;
import java.util.Set;
import javax.lang.model.element.Modifier;
import javax.lang.model.element.NestingKind;
import javax.tools.FileObject;
import javax.tools.JavaCompiler;
import javax.tools.JavaFileManager;
import javax.tools.JavaFileObject;
import javax.tools.JavaFileObject.Kind;
import javax.tools.ToolProvider;
class Ideone {
String src
="public class Test {\r\n" + " public static void main(String[] args) {\r\n" +
" System.out.println(\"Hello \"+args[0]+\"!\");\r\n" +
" }\r\n" +
"}";
List
<JFO
> sources
=Arrays.
asList(new JFO
(name,src
)); Map
<String,JFO
> files
=new HashMap
<>(); JavaCompiler jc=ToolProvider.getSystemJavaCompiler();
JavaCompiler.CompilationTask ct=jc.getTask(null, new JFM(jc.getStandardFileManager(null, null, null),files), null, null, null, sources);
System.
out.
println(ct.
call()); Class<?> clazz=new CL().defineClass(name, files.get(name).baos.toByteArray());
clazz.
getDeclaredMethod("main",
String[].
class).
invoke(null,
(Object)new String[] {"StackOverflow"}); }
static class JFO implements JavaFileObject {
this.name=name;
this.src=src;
}
@Override
public URI toUri() {
URI uri=null;
try {
uri=new URI(name);
}catch(URISyntaxException use) {use.printStackTrace();};
System.
out.
println("toUri "+uri
); return uri;
}
@Override
System.
out.
println("getName "+name
); return name;
}
@Override
}
@Override
System.
out.
println("openOutputStream"); if(baos
!=null)throw new Error(); return baos;
}
@Override
}
@Override
public CharSequence getCharContent
(boolean ignoreEncodingErrors
) throws IOException { System.
out.
println("getCharContent"); return src;
}
@Override
}
@Override
public long getLastModified() {
}
@Override
public boolean delete() {
}
@Override
public Kind getKind() {
System.
out.
println("getKind"); return Kind.SOURCE;
}
@Override
public boolean isNameCompatible
(String simpleName, Kind kind
) { System.
out.
println("isNameCompatible "+name
+" ? "+simpleName
); return name.equals(simpleName);
}
@Override
public NestingKind getNestingKind() {
}
@Override
}
}
static class JFM implements JavaFileManager {
final JavaFileManager jfm;
JFM
(JavaFileManager jfm, Map
<String, JFO
> files
){ this.jfm=jfm;
this.files=files;
}
@Override
public int isSupportedOption
(String option
) { int iso=jfm.isSupportedOption(option);
System.
out.
println("isSupportedOption "+option
+" "+iso
); return iso;
}
@Override
System.
out.
println("getClassLoader "+location
+" "+cl
); return cl;
}
@Override
public Iterable
<JavaFileObject
> list
(Location location,
String packageName, Set
<Kind
> kinds,
boolean recurse
) System.
out.
println("list "+location
+" "+packageName
+" ... "+recurse
); return jfm.list(location, packageName, kinds, recurse);
}
@Override
public String inferBinaryName
(Location location, JavaFileObject file
) { String ibm
=jfm.
inferBinaryName(location, file
); // System.out.println("inferBinaryName "+location+" "+file+" "+ibm);
return ibm;
}
@Override
public boolean isSameFile(FileObject a, FileObject b) {
}
@Override
public boolean handleOption
(String current, Iterator
<String
> remaining
) { boolean ho=jfm.handleOption(current, remaining);
System.
out.
println("handleOption "+current
+" ..."); return ho;
}
@Override
public boolean hasLocation(Location location) {
boolean hl=jfm.hasLocation(location);
// System.out.println("hasLocation "+location+" "+hl);
return hl;
}
@Override
public JavaFileObject getJavaFileForInput
(Location location,
String className, Kind kind
) throws IOException { // System.out.println("getJavaFileForInput "+location+" "+className+" "+kind.name());
return jfm.getJavaFileForInput(location, className, kind);
}
@Override
public JavaFileObject getJavaFileForOutput
(Location location,
String className, Kind kind, FileObject sibling
) System.
out.
println("getJavaFileForOutput "+location
+" "+className
+" "+kind.
name()+" "+sibling
); if(files.containsKey(className))
JFO jfo=new JFO(className,null);
files.put(className, jfo);
return jfo;
}
@Override
public FileObject getFileForInput
(Location location,
String packageName,
String relativeName
) }
@Override
public FileObject getFileForOutput
(Location location,
String packageName,
String relativeName,
}
@Override
}
@Override
}
public Location getLocationForModule
(Location location,
String moduleName
) throws IOException { }
public Location getLocationForModule
(Location location, JavaFileObject fo
) throws IOException { }
public <S
> ServiceLoader
<S
> getServiceLoader
(Location location, Class
<S
> service
) throws IOException { }
String imm
=jfm.
inferModuleName(location
); // System.out.println("inferModuleName "+location+" "+imm);
return imm;
}
public Iterable
<Set
<Location
>> listLocationsForModules
(Location location
) throws IOException { Iterable<Set<Location>> llfm=jfm.listLocationsForModules(location);
System.
out.
println("listLocationsForModules "+location
+" ..."); return llfm;
}
public boolean contains
(Location location, FileObject fo
) throws IOException { }
}
public Class
<?> defineClass
(String name,
byte array
[]) { return defineClass(name, array, 0, array.length);
}
}
}
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.Reader;
import java.io.Writer;
import java.net.URI;
import java.net.URISyntaxException;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.ServiceLoader;
import java.util.Set;

import javax.lang.model.element.Modifier;
import javax.lang.model.element.NestingKind;
import javax.tools.FileObject;
import javax.tools.JavaCompiler;
import javax.tools.JavaFileManager;
import javax.tools.JavaFileObject;
import javax.tools.JavaFileObject.Kind;
import javax.tools.ToolProvider;

class Ideone {
	public static void main(String[] args) throws Exception {
		String name="Test";
		String src="public class Test {\r\n" + 
				"  public static void main(String[] args) {\r\n" + 
				"    System.out.println(\"Hello \"+args[0]+\"!\");\r\n" + 
				"  }\r\n" + 
				"}";
		System.out.println(src);
		List<JFO> sources=Arrays.asList(new JFO(name,src));
		Map<String,JFO> files=new HashMap<>();
		JavaCompiler jc=ToolProvider.getSystemJavaCompiler();
		JavaCompiler.CompilationTask ct=jc.getTask(null, new JFM(jc.getStandardFileManager(null, null, null),files), null, null, null, sources);
		System.out.println(ct.call());
		Class<?> clazz=new CL().defineClass(name, files.get(name).baos.toByteArray());
		clazz.getDeclaredMethod("main", String[].class).invoke(null, (Object)new String[] {"StackOverflow"});
	}
	
	static class JFO implements JavaFileObject {
		final String name;
		final String src;
		JFO(String name,String src){
			this.name=name;
			this.src=src;
		}
		@Override
		public URI toUri() {
			URI uri=null;
			try {
				uri=new URI(name);
			}catch(URISyntaxException use) {use.printStackTrace();};
			System.out.println("toUri "+uri);
			return uri;
		}

		@Override
		public String getName() {
			System.out.println("getName "+name);
			return name;
		}

		@Override
		public InputStream openInputStream() throws IOException {
			throw new Error();
		}

		ByteArrayOutputStream baos;
		@Override
		public OutputStream openOutputStream() throws IOException {
			System.out.println("openOutputStream");
			if(baos!=null)throw new Error();
			baos=new ByteArrayOutputStream();
			return baos;
		}

		@Override
		public Reader openReader(boolean ignoreEncodingErrors) throws IOException {
			throw new Error();
		}

		@Override
		public CharSequence getCharContent(boolean ignoreEncodingErrors) throws IOException {
			System.out.println("getCharContent");
			return src;
		}

		@Override
		public Writer openWriter() throws IOException {
			throw new Error();
		}

		@Override
		public long getLastModified() {
			throw new Error();
		}

		@Override
		public boolean delete() {
			throw new Error();
		}

		@Override
		public Kind getKind() {
			System.out.println("getKind");
			return Kind.SOURCE;
		}

		@Override
		public boolean isNameCompatible(String simpleName, Kind kind) {
			System.out.println("isNameCompatible "+name+" ? "+simpleName);
			return name.equals(simpleName);
		}

		@Override
		public NestingKind getNestingKind() {
			throw new Error();
		}

		@Override
		public Modifier getAccessLevel() {
			throw new Error();
		}
		
	}
	
	static class JFM implements JavaFileManager {
		final JavaFileManager jfm;
		final Map<String, JFO> files;
		JFM(JavaFileManager jfm, Map<String, JFO> files){
			this.jfm=jfm;
			this.files=files;
		}

		@Override
		public int isSupportedOption(String option) {
			int iso=jfm.isSupportedOption(option);
			System.out.println("isSupportedOption "+option+" "+iso);
			return iso;
		}

		@Override
		public ClassLoader getClassLoader(Location location) {
			ClassLoader cl=jfm.getClassLoader(location);
			System.out.println("getClassLoader "+location+" "+cl);
			return cl;
		}

		@Override
		public Iterable<JavaFileObject> list(Location location, String packageName, Set<Kind> kinds, boolean recurse)
				throws IOException {
			System.out.println("list "+location+" "+packageName+" ... "+recurse);
			return jfm.list(location, packageName, kinds, recurse);
		}

		@Override
		public String inferBinaryName(Location location, JavaFileObject file) {
			String ibm=jfm.inferBinaryName(location, file);
//			System.out.println("inferBinaryName "+location+" "+file+" "+ibm);
			return ibm;
		}

		@Override
		public boolean isSameFile(FileObject a, FileObject b) {
			throw new Error();
		}

		@Override
		public boolean handleOption(String current, Iterator<String> remaining) {
			boolean ho=jfm.handleOption(current, remaining);
			System.out.println("handleOption "+current+" ...");
			return ho;
		}

		@Override
		public boolean hasLocation(Location location) {
			boolean hl=jfm.hasLocation(location);
//			System.out.println("hasLocation "+location+" "+hl);
			return hl;
		}

		@Override
		public JavaFileObject getJavaFileForInput(Location location, String className, Kind kind) throws IOException {
//			System.out.println("getJavaFileForInput "+location+" "+className+" "+kind.name());
			return jfm.getJavaFileForInput(location, className, kind);
		}

		@Override
		public JavaFileObject getJavaFileForOutput(Location location, String className, Kind kind, FileObject sibling)
				throws IOException {
			System.out.println("getJavaFileForOutput "+location+" "+className+" "+kind.name()+" "+sibling);
			if(files.containsKey(className))
				throw new Error();
			JFO jfo=new JFO(className,null);
			files.put(className, jfo);
			return jfo;
		}

		@Override
		public FileObject getFileForInput(Location location, String packageName, String relativeName)
				throws IOException {
			throw new Error();
		}

		@Override
		public FileObject getFileForOutput(Location location, String packageName, String relativeName,
				FileObject sibling) throws IOException {
			throw new Error();
		}

		@Override
		public void flush() throws IOException {
			System.out.println("flush");
		}

		@Override
		public void close() throws IOException {
			throw new Error();
		}
		
	    public Location getLocationForModule(Location location, String moduleName) throws IOException {
	        throw new UnsupportedOperationException();
	    }

	    public Location getLocationForModule(Location location, JavaFileObject fo) throws IOException {
	        throw new UnsupportedOperationException();
	    }

	    public <S> ServiceLoader<S> getServiceLoader(Location location, Class<S> service) throws  IOException {
	        throw new UnsupportedOperationException();
	    }

	    public String inferModuleName(Location location) throws IOException {
	    	String imm=jfm.inferModuleName(location);
//	    	System.out.println("inferModuleName "+location+" "+imm);
	    	return imm;
	    }

	    public Iterable<Set<Location>> listLocationsForModules(Location location) throws IOException {
	    	Iterable<Set<Location>> llfm=jfm.listLocationsForModules(location);
	    	System.out.println("listLocationsForModules "+location+" ...");
	    	return llfm;
	    }

	    public boolean contains(Location location, FileObject fo) throws IOException {
	        throw new UnsupportedOperationException();
	    }
	}
	
	static class CL extends ClassLoader {
		public Class<?> defineClass(String name,byte array[]) {
			return defineClass(name, array, 0, array.length);
		}
	}
}
