Showing 12 of 12 total issues

File enjs.js has 897 lines of code (exceeds 250 allowed). Consider refactoring.
Open

(function()
{
  var rsplit, chop, extend;

  EJS = function( options, cb )
Severity: Major
Found in enjs.js - About 2 days to fix

    Function tokenize has 85 lines of code (exceeds 25 allowed). Consider refactoring.
    Open

        tokenize: function(options)
        {
          this.out = '';
          var put_cmd = ";_ABC(this,_T,";
          var insert_cmd = put_cmd;
    Severity: Major
    Found in enjs.js - About 3 hrs to fix

      Function construct has 71 lines of code (exceeds 25 allowed). Consider refactoring.
      Open

          construct : function(options, cb)
          {
            if (typeof options == "string")
              options = {view: options};
            this.set_options(options);
      Severity: Major
      Found in enjs.js - About 2 hrs to fix

        Function report_error has 39 lines of code (exceeds 25 allowed). Consider refactoring.
        Open

            report_error : function(e, args, code)
            {
              if (typeof JSHINT !== 'undefined')
                VALIDATE = JSHINT;
              else if (typeof JSLINT !== 'undefined')
        Severity: Minor
        Found in enjs.js - About 1 hr to fix

          Function Scanner has 38 lines of code (exceeds 25 allowed). Consider refactoring.
          Open

            EJS.Scanner = function(source, left, right)
            {
              extend(
                this,
                {
          Severity: Minor
          Found in enjs.js - About 1 hr to fix

            Function newRequest has 31 lines of code (exceeds 25 allowed). Consider refactoring.
            Open

              EJS.newRequest = function()
              {
                var factories =
                [
                  function()
            Severity: Minor
            Found in enjs.js - About 1 hr to fix

              Function construct has 31 lines of code (exceeds 25 allowed). Consider refactoring.
              Open

                  construct: function(source, left)
                  {
                    this.pre_cmd = [];
                    this.post_cmd = [];
                    this.source = ' ';
              Severity: Minor
              Found in enjs.js - About 1 hr to fix

                Function first has 27 lines of code (exceeds 25 allowed). Consider refactoring.
                Open

                    first : function(cb)
                    {
                      var canvas = this.escape();
                
                      if (canvas.completed)
                Severity: Minor
                Found in enjs.js - About 1 hr to fix

                  Identical blocks of code found in 2 locations. Consider refactoring.
                  Open

                          var endExt = function(path, match)
                          {
                            if(!path)
                              return null;
                  
                  
                  Severity: Major
                  Found in enjs.js and 1 other location - About 1 hr to fix
                  enjs.js on lines 196..205

                  Duplicated Code

                  Duplicated code can lead to software that is hard to understand and difficult to change. The Don't Repeat Yourself (DRY) principle states:

                  Every piece of knowledge must have a single, unambiguous, authoritative representation within a system.

                  When you violate DRY, bugs and maintenance problems are sure to follow. Duplicated code has a tendency to both continue to replicate and also to diverge (leaving bugs as two similar implementations differ in subtle ways).

                  Tuning

                  This issue has a mass of 56.

                  We set useful threshold defaults for the languages we support but you may want to adjust these settings based on your project guidelines.

                  The threshold configuration represents the minimum mass a code block must have to be analyzed for duplication. The lower the threshold, the more fine-grained the comparison.

                  If the engine is too easily reporting duplication, try raising the threshold. If you suspect that the engine isn't catching enough duplication, try lowering the threshold. The best setting tends to differ from language to language.

                  See codeclimate-duplication's documentation for more information about tuning the mass threshold in your .codeclimate.yml.

                  Refactorings

                  Further Reading

                  Identical blocks of code found in 2 locations. Consider refactoring.
                  Open

                    EJS.endExt = function(path, match)
                    {
                      if(!path)
                        return null;
                  
                  
                  Severity: Major
                  Found in enjs.js and 1 other location - About 1 hr to fix
                  enjs.js on lines 111..120

                  Duplicated Code

                  Duplicated code can lead to software that is hard to understand and difficult to change. The Don't Repeat Yourself (DRY) principle states:

                  Every piece of knowledge must have a single, unambiguous, authoritative representation within a system.

                  When you violate DRY, bugs and maintenance problems are sure to follow. Duplicated code has a tendency to both continue to replicate and also to diverge (leaving bugs as two similar implementations differ in subtle ways).

                  Tuning

                  This issue has a mass of 56.

                  We set useful threshold defaults for the languages we support but you may want to adjust these settings based on your project guidelines.

                  The threshold configuration represents the minimum mass a code block must have to be analyzed for duplication. The lower the threshold, the more fine-grained the comparison.

                  If the engine is too easily reporting duplication, try raising the threshold. If you suspect that the engine isn't catching enough duplication, try lowering the threshold. The best setting tends to differ from language to language.

                  See codeclimate-duplication's documentation for more information about tuning the mass threshold in your .codeclimate.yml.

                  Refactorings

                  Further Reading

                  Avoid too many return statements within this function.
                  Open

                        return null;
                  Severity: Major
                  Found in enjs.js - About 30 mins to fix

                    Avoid too many return statements within this function.
                    Open

                        return request.responseText;
                    Severity: Major
                    Found in enjs.js - About 30 mins to fix
                      Severity
                      Category
                      Status
                      Source
                      Language