Wyodrębnianie kodu źródłowego z bazy danych MS Access

Mam dostęp do bazy danych, z której chciałbym wyodrębnić kod źródłowy, dzięki czemu mogę umieścić go w kontrolce źródła.

Próbowałem wyodrębnić dane za pomocą Primary Interop Assemblies (PIA), ale otrzymuję problemy, ponieważ nie zbierają wszystkich modułów i formularzy.

W kodzie jest 140 formularzy i modułów (nie pytaj, to jest odziedziczony system, ale kod PIA zbiera tylko 91 z nich).

Oto kod, którego używam.

using System;
using Microsoft.Office.Interop.Access;

namespace GetAccesSourceFiles
{
    class Program
    {
        static void Main(string[] args)
        {
            ApplicationClass appClass = new ApplicationClass();
            try
            {
                appClass.OpenCurrentDatabase("C:\\svn\\projects\\db.mdb",false,"");

                Console.WriteLine(appClass.Version);
                Console.WriteLine(appClass.Modules.Count.ToString());
                Console.WriteLine(appClass.Modules.Parent.ToString());

                int NumOfLines = 0;
                for (int i = 0; i < appClass.Modules.Count; i++)
                {
                    Console.WriteLine(appClass.Modules[i].Name + " : " + appClass.Modules[i].CountOfLines);
                    NumOfLines += appClass.Modules[i].CountOfLines;
                }

                Console.WriteLine("Number of Lines : " + NumOfLines);
                Console.ReadKey();
            }
            catch(Exception ex)
            {
                Console.WriteLine(ex.Message + "\r\n" +ex.StackTrace);
            }
            finally
            {
                appClass.CloseCurrentDatabase();
                appClass.Quit(AcQuitOption.acQuitSaveNone);
            }

        }
    }
}

Jakieś sugestie dotyczące tego, czego może brakować w tym kodzie? lub na produkcie / narzędziu, które to zrobi dla mnie?

Edycja: Powinienem również wspomnieć, że wymaga to skryptu na dysk, integracja z VSS nie jest opcją, ponieważ naszym systemem źródłowym jest SVN. Dzięki.

questionAnswers(4)

yourAnswerToTheQuestion