Я пытаюсь найти Jar репозитории затмения для JSDT - PullRequest
0 голосов
/ 16 сентября 2018

Для работы над проектом я пытаюсь найти надежный репозиторий, в котором доступен файл ядра jsdt.

Хотя 'org.eclipse.jdt: org.eclipse.jdt.core: 3.14.0' было очень легко найти, я не похож на jsdt для моей сборки Gradle. И мне нужны некоторые веб-инструменты.

Когда я загружаю затмение, я могу найти банку внутри и найти группы и идентификаторы артефактов. Но не хранилище для объявления зависимости.

Я нашел Jabylon и Alfresco, но они с 2013 года, я также нашел одно под другим именем с 2007 года. Но я пытаюсь найти, где они на самом деле помещают эти банки, чтобы иметь возможность выбирать среди текущих версий.

Это комплект, который я ищу: Bundle-SymbolicName: org.eclipse.wst.jsdt.core Похоже, его группа org.eclipse.webtools.jsdt.bundles

есть идеи?

Ответы [ 2 ]

0 голосов
/ 17 сентября 2018

Для дальнейшего использования я создал быстрый скрипт для сортировки файлов затмений в структуру хранилища, чтобы можно было развернуть их, если они могут, и иметь сервер.

import java.io.IOException;
import java.net.URI;
import java.nio.charset.StandardCharsets;
import java.nio.file.*;
import java.util.*;
import java.util.regex.*;

public final class DirToRepoStructure {

    private static final Pattern jarNamePattern = Pattern.compile( "(.*)_(\\d+\\.\\d+\\.\\d+)\\.v?(\\d+)\\.jar" );

    public static void main( String[] args ) throws IOException {

        Path root = Paths.get( args[ 0 ] );
        int rootNameCount = root.getNameCount( );

        String rootName = root.getFileName( )
                              .toString( );

        Path tempDir = Files.createTempDirectory( Paths.get( "." ), rootName );
        System.out.println( "using temporary directory: " + tempDir );

        Path achievePath = tempDir.getParent( )
                                  .resolve( rootName + ".zip" );
        System.out.println( "Archiving at: " + achievePath );

        DirectoryStream< Path > stream = Files.newDirectoryStream( root, "*.jar" );

        stream.forEach( jar -> {
            String fullName = jar.getFileName( )
                                 .toString( );

            System.out.println( fullName );
            Matcher matcher = jarNamePattern.matcher( fullName );

            if ( matcher.matches( ) ) {

                String jarName = matcher.group( 1 );

                String version = matcher.group( 2 );

                String snap = matcher.group( 3 );

                System.out.println( "reading: " + jarName + ", " + version );

                createJarStructure( tempDir, jar, jarName, version, snap );

            }
            else {
                throw new IllegalArgumentException( "file name does not match regex" );
            }

        } );

        try ( FileSystem zipFs = getZipFs( achievePath ) ) {

            Files.walk( tempDir )
                 .skip( rootNameCount )
                 .forEach( source -> copyIntoZip( zipFs, source, rootNameCount ) );
        }
    }

    private static void copyIntoZip( FileSystem zipFs, Path source, int rootNameCount ) {

        try {
            Path zipRoot = zipFs.getPath( "/" );

            int tempRootNameCount = rootNameCount + 1;
            int sourceNameCount = source.getNameCount( );

            String newPathName = source.subpath( tempRootNameCount, sourceNameCount )
                                       .toString( );

            Path pathInZipFile = zipRoot.resolve( newPathName );
            Files.copy( source, pathInZipFile, StandardCopyOption.REPLACE_EXISTING );
        }
        catch ( IOException e ) {
            throw new RuntimeException( e );
        }
    }

    private static void createJarStructure( Path tempDir, Path jar, String jarName, String version, String snap ) {

        try {

            Path jarRoot = jar.getParent( )
                              .resolve( jarName )
                              .resolve( version + "-SNAPSHOT" );

            Path jarDirectory = Files.createDirectories( tempDir.resolve( jarRoot ) );

            String shortSnap = snap.substring( 0,8 );
            Path jarTarget = jarDirectory.resolve( jarName + "-" + version + "-"+ shortSnap + ".jar" ); Files.copy( jar, jarTarget );

        }
        catch ( IOException e ) {
            throw new RuntimeException( e );
        }
    }

    private static FileSystem getZipFs( Path archivePath ) throws IOException {

        Map< String, String > env = new HashMap<>( );
        env.put( "create", "true" );
        env.put( "encoding", StandardCharsets.UTF_8.toString( ) );

        System.out.println( archivePath );
        URI uri = URI.create( "jar:file:" + archivePath.toAbsolutePath( ) );
        return FileSystems.newFileSystem( uri, env );

    }
}
0 голосов
/ 17 сентября 2018

Только некоторые JAR-модули Eclipse, предназначенные для использования также вне Eclipse в простых (не OSGi) приложениях, публикуются самими проектами Eclipse в репозитории Maven или Gradle (например, Eclipse JGit ).

В мире Eclipse p2 репозитории или простые папки, содержащие JAR-пакеты OSGi, используются для так называемых целевых платформ для создания и запуска приложения Java OSGi .

Требуемые артефакты находятся, например, на последнем сайте одновременного выпуска обновлений , но не могут бытьдоступ из Maven или Gradle.

Обратите внимание, что некоторые JAR-модули Eclipse работают только в приложении OSGi (например, когда используется класс активатора пакета) или в приложении на основе Eclipse (например, когда точки расширения Eclipseиспользуются).

...