Index: src/java/org/apache/lucene/store/FileSwitchDirectory.java
===================================================================
--- src/java/org/apache/lucene/store/FileSwitchDirectory.java	(revision 0)
+++ src/java/org/apache/lucene/store/FileSwitchDirectory.java	(revision 0)
@@ -0,0 +1,97 @@
+package org.apache.lucene.store;
+
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Set;
+
+/**
+ * Files with the given extensions are placed in the fsDirectory;
+ */
+public class FileSwitchDirectory extends Directory {
+  private RAMDirectory ramDirectory;
+  private Directory fsDirectory;
+  private Set fileExtensions;
+  private boolean doClose;
+
+  public FileSwitchDirectory(Set fileExtensions, Directory fsDirectory, RAMDirectory ramDirectory, boolean doClose) {
+    this.fileExtensions = fileExtensions;
+    this.fsDirectory = fsDirectory;
+    this.ramDirectory = ramDirectory;
+    this.doClose = doClose;
+    this.lockFactory = fsDirectory.getLockFactory();
+  }
+  
+  public void close() throws IOException {
+    if (doClose) {
+      ramDirectory.close();
+      fsDirectory.close();
+    }
+  }
+  
+  public String[] list() throws IOException {
+    List list = new ArrayList();
+    String[] ramFiles = ramDirectory.list();
+    for (int x = 0; x < ramFiles.length; x++) {
+      list.add(ramFiles[x]);
+    }
+    String[] fsFiles = fsDirectory.list();
+    for (int x = 0; x < fsFiles.length; x++) {
+      list.add(fsFiles[x]);
+    }
+    return (String[]) list.toArray(new String[0]);
+  }
+
+  public static String getExtension(String name) {
+    int i = name.lastIndexOf('.');
+    if (i == -1) {
+      return "";
+    }
+    return name.substring(i+1, name.length());
+  }
+
+  private Directory getDirectory(String name) {
+    String ext = getExtension(name);
+    if (fileExtensions.contains(ext)) {
+      return fsDirectory;
+    } else {
+      return ramDirectory;
+    }
+  }
+
+  public boolean fileExists(String name) throws IOException {
+    return getDirectory(name).fileExists(name);
+  }
+
+  public long fileModified(String name) throws IOException {
+    return getDirectory(name).fileModified(name);
+  }
+
+  public void touchFile(String name) throws IOException {
+    getDirectory(name).touchFile(name);
+  }
+
+  public void deleteFile(String name) throws IOException {
+    getDirectory(name).deleteFile(name);
+  }
+
+  public void renameFile(String from, String to) throws IOException {
+    getDirectory(from).renameFile(from, to);
+  }
+
+  public long fileLength(String name) throws IOException {
+    return getDirectory(name).fileLength(name);
+  }
+
+  public IndexOutput createOutput(String name) throws IOException {
+    return getDirectory(name).createOutput(name);
+  }
+
+  public void sync(String name) throws IOException {
+    getDirectory(name).sync(name);
+  }
+
+  public IndexInput openInput(String name) throws IOException {
+    return getDirectory(name).openInput(name);
+  }
+}
Index: src/test/org/apache/lucene/index/TestIndexWriterReader.java
===================================================================
--- src/test/org/apache/lucene/index/TestIndexWriterReader.java	(revision 769601)
+++ src/test/org/apache/lucene/index/TestIndexWriterReader.java	(working copy)
@@ -537,7 +537,7 @@
 
   public static void createIndexNoClose(boolean multiSegment, String indexName,
       IndexWriter w) throws IOException {
-    w.setMergePolicy(new LogDocMergePolicy());
+    //w.setMergePolicy(new LogDocMergePolicy());
     for (int i = 0; i < 100; i++) {
       w.addDocument(createDocument(i, indexName, 4));
     }
Index: src/test/org/apache/lucene/store/TestFileSwitchDirectory.java
===================================================================
--- src/test/org/apache/lucene/store/TestFileSwitchDirectory.java	(revision 0)
+++ src/test/org/apache/lucene/store/TestFileSwitchDirectory.java	(revision 0)
@@ -0,0 +1,51 @@
+package org.apache.lucene.store;
+
+import java.io.IOException;
+import java.util.HashSet;
+import java.util.Set;
+
+import org.apache.lucene.analysis.WhitespaceAnalyzer;
+import org.apache.lucene.index.IndexReader;
+import org.apache.lucene.index.IndexWriter;
+import org.apache.lucene.index.TestIndexWriterReader;
+import org.apache.lucene.util.LuceneTestCase;
+
+public class TestFileSwitchDirectory extends LuceneTestCase {
+  /**
+   * Test if writing doc stores to disk and everything else to ram works.
+   * @throws IOException
+   */
+  public void testBasic() throws IOException {
+    Set fileExtensions = new HashSet();
+    fileExtensions.add("fdt");
+    fileExtensions.add("fdx");
+    
+    Directory fsDirectory = new MockRAMDirectory();
+    RAMDirectory ramDirectory = new MockRAMDirectory();
+    
+    FileSwitchDirectory fsd = new FileSwitchDirectory(fileExtensions, fsDirectory, ramDirectory, true);
+    IndexWriter writer = new IndexWriter(fsd, new WhitespaceAnalyzer(),
+        IndexWriter.MaxFieldLength.LIMITED);
+    writer.setUseCompoundFile(false);
+    TestIndexWriterReader.createIndexNoClose(true, "ram", writer);
+    IndexReader reader = writer.getReader();
+    assertEquals(100, reader.maxDoc());
+    writer.commit();
+    // we should see fdx,fdt files here
+    String[] fsFiles = fsDirectory.listAll();
+    assertTrue(fsFiles.length > 0);
+    for (int x=0; x < fsFiles.length; x++) {
+      String ext = FileSwitchDirectory.getExtension(fsFiles[x]);
+      assertTrue(fileExtensions.contains(ext));
+    }
+    //String[] ramFiles = ramDirectory.listAll();
+    //for (int x=0; x < ramFiles.length; x++) {
+    //  System.out.println("ramFiles:"+ramFiles[x]);
+    //}
+    reader.close();
+    writer.close();
+    
+    fsDirectory.close();
+    ramDirectory.close();
+  }
+}
