@ -46,6 +46,8 @@ import java.io.File;
import java.io.IOException ;
import java.io.IOException ;
import java.text.MessageFormat ;
import java.text.MessageFormat ;
import java.util.Locale ;
import java.util.Locale ;
import java.util.HashMap ;
import java.util.Map ;
import org.eclipse.jgit.dircache.DirCache ;
import org.eclipse.jgit.dircache.DirCache ;
import org.eclipse.jgit.dircache.DirCacheIterator ;
import org.eclipse.jgit.dircache.DirCacheIterator ;
@ -330,6 +332,8 @@ public class SubmoduleWalk implements AutoCloseable {
private String path ;
private String path ;
private Map < String , String > pathToName ;
/ * *
/ * *
* Create submodule generator
* Create submodule generator
*
*
@ -355,6 +359,7 @@ public class SubmoduleWalk implements AutoCloseable {
* /
* /
public SubmoduleWalk setModulesConfig ( final Config config ) {
public SubmoduleWalk setModulesConfig ( final Config config ) {
modulesConfig = config ;
modulesConfig = config ;
loadPathNames ( ) ;
return this ;
return this ;
}
}
@ -374,6 +379,7 @@ public class SubmoduleWalk implements AutoCloseable {
public SubmoduleWalk setRootTree ( final AbstractTreeIterator tree ) {
public SubmoduleWalk setRootTree ( final AbstractTreeIterator tree ) {
rootTree = tree ;
rootTree = tree ;
modulesConfig = null ;
modulesConfig = null ;
pathToName = null ;
return this ;
return this ;
}
}
@ -396,6 +402,7 @@ public class SubmoduleWalk implements AutoCloseable {
p . reset ( walk . getObjectReader ( ) , id ) ;
p . reset ( walk . getObjectReader ( ) , id ) ;
rootTree = p ;
rootTree = p ;
modulesConfig = null ;
modulesConfig = null ;
pathToName = null ;
return this ;
return this ;
}
}
@ -419,6 +426,7 @@ public class SubmoduleWalk implements AutoCloseable {
repository . getFS ( ) ) ;
repository . getFS ( ) ) ;
config . load ( ) ;
config . load ( ) ;
modulesConfig = config ;
modulesConfig = config ;
loadPathNames ( ) ;
} else {
} else {
try ( TreeWalk configWalk = new TreeWalk ( repository ) ) {
try ( TreeWalk configWalk = new TreeWalk ( repository ) ) {
configWalk . addTree ( rootTree ) ;
configWalk . addTree ( rootTree ) ;
@ -438,10 +446,12 @@ public class SubmoduleWalk implements AutoCloseable {
if ( filter . isDone ( configWalk ) ) {
if ( filter . isDone ( configWalk ) ) {
modulesConfig = new BlobBasedConfig ( null , repository ,
modulesConfig = new BlobBasedConfig ( null , repository ,
configWalk . getObjectId ( 0 ) ) ;
configWalk . getObjectId ( 0 ) ) ;
loadPathNames ( ) ;
return this ;
return this ;
}
}
}
}
modulesConfig = new Config ( ) ;
modulesConfig = new Config ( ) ;
pathToName = null ;
} finally {
} finally {
if ( idx > 0 )
if ( idx > 0 )
rootTree . next ( idx ) ;
rootTree . next ( idx ) ;
@ -451,6 +461,20 @@ public class SubmoduleWalk implements AutoCloseable {
return this ;
return this ;
}
}
private void loadPathNames ( ) {
pathToName = null ;
if ( modulesConfig ! = null ) {
HashMap < String , String > pathNames = new HashMap < > ( ) ;
for ( String name : modulesConfig
. getSubsections ( ConfigConstants . CONFIG_SUBMODULE_SECTION ) ) {
pathNames . put ( modulesConfig . getString (
ConfigConstants . CONFIG_SUBMODULE_SECTION , name ,
ConfigConstants . CONFIG_KEY_PATH ) , name ) ;
}
pathToName = pathNames ;
}
}
/ * *
/ * *
* Checks whether the working tree contains a . gitmodules file . That ' s a
* Checks whether the working tree contains a . gitmodules file . That ' s a
* hint that the repo contains submodules .
* hint that the repo contains submodules .
@ -475,9 +499,15 @@ public class SubmoduleWalk implements AutoCloseable {
}
}
private void lazyLoadModulesConfig ( ) throws IOException , ConfigInvalidException {
private void lazyLoadModulesConfig ( ) throws IOException , ConfigInvalidException {
if ( modulesConfig = = null )
if ( modulesConfig = = null ) {
loadModulesConfig ( ) ;
loadModulesConfig ( ) ;
}
}
}
private String getModuleName ( String modulePath ) {
String name = pathToName ! = null ? pathToName . get ( modulePath ) : null ;
return name ! = null ? name : modulePath ;
}
/ * *
/ * *
* Set tree filter
* Set tree filter
@ -525,6 +555,7 @@ public class SubmoduleWalk implements AutoCloseable {
public SubmoduleWalk reset ( ) {
public SubmoduleWalk reset ( ) {
repoConfig = repository . getConfig ( ) ;
repoConfig = repository . getConfig ( ) ;
modulesConfig = null ;
modulesConfig = null ;
pathToName = null ;
walk . reset ( ) ;
walk . reset ( ) ;
return this ;
return this ;
}
}
@ -586,9 +617,8 @@ public class SubmoduleWalk implements AutoCloseable {
* /
* /
public String getModulesPath ( ) throws IOException , ConfigInvalidException {
public String getModulesPath ( ) throws IOException , ConfigInvalidException {
lazyLoadModulesConfig ( ) ;
lazyLoadModulesConfig ( ) ;
return modulesConfig . getString (
return modulesConfig . getString ( ConfigConstants . CONFIG_SUBMODULE_SECTION ,
ConfigConstants . CONFIG_SUBMODULE_SECTION , path ,
getModuleName ( path ) , ConfigConstants . CONFIG_KEY_PATH ) ;
ConfigConstants . CONFIG_KEY_PATH ) ;
}
}
/ * *
/ * *
@ -600,6 +630,10 @@ public class SubmoduleWalk implements AutoCloseable {
* @throws IOException
* @throws IOException
* /
* /
public String getConfigUrl ( ) throws IOException , ConfigInvalidException {
public String getConfigUrl ( ) throws IOException , ConfigInvalidException {
// SubmoduleInitCommand copies the submodules.*.url and
// submodules.*.update values from .gitmodules to the config, and
// does so using the path defined in .gitmodules as the subsection
// name. So no path-to-name translation is necessary here.
return repoConfig . getString ( ConfigConstants . CONFIG_SUBMODULE_SECTION ,
return repoConfig . getString ( ConfigConstants . CONFIG_SUBMODULE_SECTION ,
path , ConfigConstants . CONFIG_KEY_URL ) ;
path , ConfigConstants . CONFIG_KEY_URL ) ;
}
}
@ -614,9 +648,8 @@ public class SubmoduleWalk implements AutoCloseable {
* /
* /
public String getModulesUrl ( ) throws IOException , ConfigInvalidException {
public String getModulesUrl ( ) throws IOException , ConfigInvalidException {
lazyLoadModulesConfig ( ) ;
lazyLoadModulesConfig ( ) ;
return modulesConfig . getString (
return modulesConfig . getString ( ConfigConstants . CONFIG_SUBMODULE_SECTION ,
ConfigConstants . CONFIG_SUBMODULE_SECTION , path ,
getModuleName ( path ) , ConfigConstants . CONFIG_KEY_URL ) ;
ConfigConstants . CONFIG_KEY_URL ) ;
}
}
/ * *
/ * *
@ -642,9 +675,8 @@ public class SubmoduleWalk implements AutoCloseable {
* /
* /
public String getModulesUpdate ( ) throws IOException , ConfigInvalidException {
public String getModulesUpdate ( ) throws IOException , ConfigInvalidException {
lazyLoadModulesConfig ( ) ;
lazyLoadModulesConfig ( ) ;
return modulesConfig . getString (
return modulesConfig . getString ( ConfigConstants . CONFIG_SUBMODULE_SECTION ,
ConfigConstants . CONFIG_SUBMODULE_SECTION , path ,
getModuleName ( path ) , ConfigConstants . CONFIG_KEY_UPDATE ) ;
ConfigConstants . CONFIG_KEY_UPDATE ) ;
}
}
/ * *
/ * *
@ -660,7 +692,7 @@ public class SubmoduleWalk implements AutoCloseable {
ConfigInvalidException {
ConfigInvalidException {
lazyLoadModulesConfig ( ) ;
lazyLoadModulesConfig ( ) ;
String name = modulesConfig . getString (
String name = modulesConfig . getString (
ConfigConstants . CONFIG_SUBMODULE_SECTION , path ,
ConfigConstants . CONFIG_SUBMODULE_SECTION , getModuleName ( path ) ,
ConfigConstants . CONFIG_KEY_IGNORE ) ;
ConfigConstants . CONFIG_KEY_IGNORE ) ;
if ( name = = null )
if ( name = = null )
return null ;
return null ;