What does Gradle compile files, and coppile fileTree works












0















This is working gradle build script code:



dependencies {
compile files("dir/libs", "dir/libs2")
compile fileTree(dir: "libs", include: "*.jar")
}


As far as I understand it,



dependencies is a method that takes a closure, sets it's delegate property to DependencyHandler object and execute it.



compile is a Configuration object belonging to project



But what are files and fileTree?










share|improve this question


















  • 1





    docs.gradle.org/current/javadoc/org/gradle/api/…, docs.gradle.org/current/javadoc/org/gradle/api/…

    – JB Nizet
    Nov 20 '18 at 22:52











  • additional link: see Gradle Project DSL documentation here : docs.gradle.org/current/dsl/org.gradle.api.Project.html .

    – M.Ricciuti
    Nov 20 '18 at 23:00











  • Buy how is the collection -- (ConfigurableFileCollection) --, that is returned by files, applied to compile object? It does't look like an assignment nor method call.

    – Jerry Lundegaard
    Nov 21 '18 at 8:35
















0















This is working gradle build script code:



dependencies {
compile files("dir/libs", "dir/libs2")
compile fileTree(dir: "libs", include: "*.jar")
}


As far as I understand it,



dependencies is a method that takes a closure, sets it's delegate property to DependencyHandler object and execute it.



compile is a Configuration object belonging to project



But what are files and fileTree?










share|improve this question


















  • 1





    docs.gradle.org/current/javadoc/org/gradle/api/…, docs.gradle.org/current/javadoc/org/gradle/api/…

    – JB Nizet
    Nov 20 '18 at 22:52











  • additional link: see Gradle Project DSL documentation here : docs.gradle.org/current/dsl/org.gradle.api.Project.html .

    – M.Ricciuti
    Nov 20 '18 at 23:00











  • Buy how is the collection -- (ConfigurableFileCollection) --, that is returned by files, applied to compile object? It does't look like an assignment nor method call.

    – Jerry Lundegaard
    Nov 21 '18 at 8:35














0












0








0








This is working gradle build script code:



dependencies {
compile files("dir/libs", "dir/libs2")
compile fileTree(dir: "libs", include: "*.jar")
}


As far as I understand it,



dependencies is a method that takes a closure, sets it's delegate property to DependencyHandler object and execute it.



compile is a Configuration object belonging to project



But what are files and fileTree?










share|improve this question














This is working gradle build script code:



dependencies {
compile files("dir/libs", "dir/libs2")
compile fileTree(dir: "libs", include: "*.jar")
}


As far as I understand it,



dependencies is a method that takes a closure, sets it's delegate property to DependencyHandler object and execute it.



compile is a Configuration object belonging to project



But what are files and fileTree?







gradle groovy






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 20 '18 at 22:38









Jerry LundegaardJerry Lundegaard

286




286








  • 1





    docs.gradle.org/current/javadoc/org/gradle/api/…, docs.gradle.org/current/javadoc/org/gradle/api/…

    – JB Nizet
    Nov 20 '18 at 22:52











  • additional link: see Gradle Project DSL documentation here : docs.gradle.org/current/dsl/org.gradle.api.Project.html .

    – M.Ricciuti
    Nov 20 '18 at 23:00











  • Buy how is the collection -- (ConfigurableFileCollection) --, that is returned by files, applied to compile object? It does't look like an assignment nor method call.

    – Jerry Lundegaard
    Nov 21 '18 at 8:35














  • 1





    docs.gradle.org/current/javadoc/org/gradle/api/…, docs.gradle.org/current/javadoc/org/gradle/api/…

    – JB Nizet
    Nov 20 '18 at 22:52











  • additional link: see Gradle Project DSL documentation here : docs.gradle.org/current/dsl/org.gradle.api.Project.html .

    – M.Ricciuti
    Nov 20 '18 at 23:00











  • Buy how is the collection -- (ConfigurableFileCollection) --, that is returned by files, applied to compile object? It does't look like an assignment nor method call.

    – Jerry Lundegaard
    Nov 21 '18 at 8:35








1




1





docs.gradle.org/current/javadoc/org/gradle/api/…, docs.gradle.org/current/javadoc/org/gradle/api/…

– JB Nizet
Nov 20 '18 at 22:52





docs.gradle.org/current/javadoc/org/gradle/api/…, docs.gradle.org/current/javadoc/org/gradle/api/…

– JB Nizet
Nov 20 '18 at 22:52













additional link: see Gradle Project DSL documentation here : docs.gradle.org/current/dsl/org.gradle.api.Project.html .

– M.Ricciuti
Nov 20 '18 at 23:00





additional link: see Gradle Project DSL documentation here : docs.gradle.org/current/dsl/org.gradle.api.Project.html .

– M.Ricciuti
Nov 20 '18 at 23:00













Buy how is the collection -- (ConfigurableFileCollection) --, that is returned by files, applied to compile object? It does't look like an assignment nor method call.

– Jerry Lundegaard
Nov 21 '18 at 8:35





Buy how is the collection -- (ConfigurableFileCollection) --, that is returned by files, applied to compile object? It does't look like an assignment nor method call.

– Jerry Lundegaard
Nov 21 '18 at 8:35












1 Answer
1






active

oldest

votes


















1














The first thing to know is that Gradle uses AST for the dependecies closure syntax this answer here does a good job of explaining what AST is.



I'll talk about the above code snippet, you are right about the block of code being delegated to the DependencyHandler, the line
is defined here as




To declare a specific dependency for a configuration you can use the following syntax:



dependencies {
configurationName dependencyNotation1, dependencyNotation2, ...
}



The important thing to note here is the above code is syntax provided by Gradle to make code clean and terse. You could as well use the method DependencyHandler.add(String,Object)
For example



dependencies {
add('compile', fileTree(dir: "libs", include: "*.jar"))
}


As compared to the above syntax, the top syntax allows you to add multiple dependencies in a single statement and is a lot more cleaner.



fileTree(), files() etc are methods defined in Project. From DependencyHandler.add(String,Object), the second argument is of type Object, as such the method as well as the dependency syntax can accept a number of type of dependencies like ProjectDependency, other Configurations and FileCollection and its sub types as you mentioned the ConfigurableFileCollection.






share|improve this answer

























    Your Answer






    StackExchange.ifUsing("editor", function () {
    StackExchange.using("externalEditor", function () {
    StackExchange.using("snippets", function () {
    StackExchange.snippets.init();
    });
    });
    }, "code-snippets");

    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "1"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














    draft saved

    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53402649%2fwhat-does-gradle-compile-files-and-coppile-filetree-works%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    1














    The first thing to know is that Gradle uses AST for the dependecies closure syntax this answer here does a good job of explaining what AST is.



    I'll talk about the above code snippet, you are right about the block of code being delegated to the DependencyHandler, the line
    is defined here as




    To declare a specific dependency for a configuration you can use the following syntax:



    dependencies {
    configurationName dependencyNotation1, dependencyNotation2, ...
    }



    The important thing to note here is the above code is syntax provided by Gradle to make code clean and terse. You could as well use the method DependencyHandler.add(String,Object)
    For example



    dependencies {
    add('compile', fileTree(dir: "libs", include: "*.jar"))
    }


    As compared to the above syntax, the top syntax allows you to add multiple dependencies in a single statement and is a lot more cleaner.



    fileTree(), files() etc are methods defined in Project. From DependencyHandler.add(String,Object), the second argument is of type Object, as such the method as well as the dependency syntax can accept a number of type of dependencies like ProjectDependency, other Configurations and FileCollection and its sub types as you mentioned the ConfigurableFileCollection.






    share|improve this answer






























      1














      The first thing to know is that Gradle uses AST for the dependecies closure syntax this answer here does a good job of explaining what AST is.



      I'll talk about the above code snippet, you are right about the block of code being delegated to the DependencyHandler, the line
      is defined here as




      To declare a specific dependency for a configuration you can use the following syntax:



      dependencies {
      configurationName dependencyNotation1, dependencyNotation2, ...
      }



      The important thing to note here is the above code is syntax provided by Gradle to make code clean and terse. You could as well use the method DependencyHandler.add(String,Object)
      For example



      dependencies {
      add('compile', fileTree(dir: "libs", include: "*.jar"))
      }


      As compared to the above syntax, the top syntax allows you to add multiple dependencies in a single statement and is a lot more cleaner.



      fileTree(), files() etc are methods defined in Project. From DependencyHandler.add(String,Object), the second argument is of type Object, as such the method as well as the dependency syntax can accept a number of type of dependencies like ProjectDependency, other Configurations and FileCollection and its sub types as you mentioned the ConfigurableFileCollection.






      share|improve this answer




























        1












        1








        1







        The first thing to know is that Gradle uses AST for the dependecies closure syntax this answer here does a good job of explaining what AST is.



        I'll talk about the above code snippet, you are right about the block of code being delegated to the DependencyHandler, the line
        is defined here as




        To declare a specific dependency for a configuration you can use the following syntax:



        dependencies {
        configurationName dependencyNotation1, dependencyNotation2, ...
        }



        The important thing to note here is the above code is syntax provided by Gradle to make code clean and terse. You could as well use the method DependencyHandler.add(String,Object)
        For example



        dependencies {
        add('compile', fileTree(dir: "libs", include: "*.jar"))
        }


        As compared to the above syntax, the top syntax allows you to add multiple dependencies in a single statement and is a lot more cleaner.



        fileTree(), files() etc are methods defined in Project. From DependencyHandler.add(String,Object), the second argument is of type Object, as such the method as well as the dependency syntax can accept a number of type of dependencies like ProjectDependency, other Configurations and FileCollection and its sub types as you mentioned the ConfigurableFileCollection.






        share|improve this answer















        The first thing to know is that Gradle uses AST for the dependecies closure syntax this answer here does a good job of explaining what AST is.



        I'll talk about the above code snippet, you are right about the block of code being delegated to the DependencyHandler, the line
        is defined here as




        To declare a specific dependency for a configuration you can use the following syntax:



        dependencies {
        configurationName dependencyNotation1, dependencyNotation2, ...
        }



        The important thing to note here is the above code is syntax provided by Gradle to make code clean and terse. You could as well use the method DependencyHandler.add(String,Object)
        For example



        dependencies {
        add('compile', fileTree(dir: "libs", include: "*.jar"))
        }


        As compared to the above syntax, the top syntax allows you to add multiple dependencies in a single statement and is a lot more cleaner.



        fileTree(), files() etc are methods defined in Project. From DependencyHandler.add(String,Object), the second argument is of type Object, as such the method as well as the dependency syntax can accept a number of type of dependencies like ProjectDependency, other Configurations and FileCollection and its sub types as you mentioned the ConfigurableFileCollection.







        share|improve this answer














        share|improve this answer



        share|improve this answer








        edited Nov 21 '18 at 14:00

























        answered Nov 21 '18 at 13:51









        RyotsuRyotsu

        565313




        565313






























            draft saved

            draft discarded




















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53402649%2fwhat-does-gradle-compile-files-and-coppile-filetree-works%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            MongoDB - Not Authorized To Execute Command

            Npm cannot find a required file even through it is in the searched directory

            in spring boot 2.1 many test slices are not allowed anymore due to multiple @BootstrapWith