Skip to content

Commit

Permalink
Closes #346. Merge options for language namespace, fallbacks, _default
Browse files Browse the repository at this point in the history
  • Loading branch information
Glavin001 committed May 19, 2015
1 parent 5fd07cf commit 573a949
Show file tree
Hide file tree
Showing 8 changed files with 73 additions and 50 deletions.
7 changes: 4 additions & 3 deletions examples/nested-jsbeautifyrc/.jsbeautifyrc
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
brace_style: "collapse"
indent_char: " "
indent_scripts: "normal"
indent_size: 6
indent_size: 2
max_preserve_newlines: 1
preserve_newlines: true
unformatted:
Expand All @@ -16,7 +16,8 @@
wrap_line_length: 0
css:
indent_char: " "
indent_size: 4
indent_size: 2
preserve_newlines: true
js:
indent_size: 2
indent_char: " "
Expand All @@ -31,7 +32,7 @@
indent_level: 0
indent_with_tabs: false
python:
indent_size: 4
indent_size: 2
#max_line_length: 79
#ignore:
# - "E24"
Expand Down
4 changes: 3 additions & 1 deletion spec/beautify-languages-spec.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@ describe "BeautifyLanguages", ->
# Force activate package
pack = atom.packages.getLoadedPackage("atom-beautify")
pack.activateNow()
# Change logger level
# atom.config.set('atom-beautify._loggerLevel', 'verbose')
# Return promise
return activationPromise

Expand Down Expand Up @@ -134,7 +136,7 @@ describe "BeautifyLanguages", ->

beautifyCompleted = false
completionFun = (text) ->
# console.log(expectedTestPath, text) if ext is ".swig"
# logger.verbose(expectedTestPath, text) if ext is ".less"
expect(text instanceof Error).not.toEqual(true, text)
# if text instanceof Error
# return beautifyCompleted = text # text == Error
Expand Down
108 changes: 64 additions & 44 deletions src/beautifiers/index.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -288,9 +288,9 @@ module.exports = class Beautifiers


beautify : (text, allOptions, grammar, filePath, {onSave} = {}) ->
return new Promise((resolve, reject)=>
return new Promise((resolve, reject) =>
logger.info('beautify', text, allOptions, grammar, filePath)
console.log(allOptions)
logger.verbose(allOptions)

# Get language
fileExtension = path.extname(filePath)
Expand Down Expand Up @@ -339,29 +339,21 @@ module.exports = class Beautifiers
return resolve( null )

# Options for Language
options = @getOptions(language.namespace, allOptions) or {}

console.log(options)

# Support fallback for options
if language.fallback?
for fallback in language.fallback

# Merge current options on top of fallback options
options = _.merge( @getOptions(fallback, allOptions) or {}, options)
options = @getOptions([language.namespace].concat(language.fallback or []), allOptions) or {}

# Get Beautifier
logger.verbose(grammar, language)
beautifiers = @getBeautifiers(language.name, options)

console.log(options)
# logger.verbose('beautifiers', beautifiers)
#
logger.verbose('options', options)
logger.verbose('beautifiers', beautifiers)

logger.verbose(language.name, filePath, options, allOptions)

# Check if unsupported language
if beautifiers.length < 1
unsupportedGrammar = true
else

# Select beautifier from language config preferences
beautifier = _.find(beautifiers, (beautifier) ->
beautifier.name is preferredBeautifierName
Expand Down Expand Up @@ -420,7 +412,6 @@ module.exports = class Beautifiers
# Apply language-specific option transformations
options = transformOptions(beautifier, language.name, options)


# Beautify text with language options
beautifier.beautify(text, language.name, options)
.then(resolve)
Expand Down Expand Up @@ -546,7 +537,7 @@ module.exports = class Beautifiers
envs = @getUserHome()
home = path.normalize(path.join(envs, config))
proj = @findFile(config, dir, upwards)
console.log(dir, proj, home)
logger.verbose(dir, proj, home)
return proj if proj
return home if @verifyExists(home)
null
Expand Down Expand Up @@ -650,6 +641,7 @@ module.exports = class Beautifiers
editorconfig ?= require('editorconfig')
editorConfigOptions = editorconfig.parse(editedFilePath)

logger.verbose('editorConfigOptions', editorConfigOptions)

# Transform EditorConfig to Atom Beautify's config structure and naming
if editorConfigOptions.indent_style is 'space'
Expand All @@ -675,11 +667,15 @@ module.exports = class Beautifiers
pf = path.join(p, "FAKEFILENAME")
pc = @getConfig(pf, false)

isNested = @isNestedOptions(pc)
unless isNested
pc = {
_default: pc
}

# Add config for p to project's config options
projectOptions.push(pc)


# logger.verbose p, pc
# Move upwards
p = path.resolve(p, "../")
Expand All @@ -689,48 +685,72 @@ module.exports = class Beautifiers

# Combine all options together
allOptions = [
editorOptions
configOptions
homeOptions
{
_default:
editorOptions
},
configOptions,
{
_default:
homeOptions
},
editorConfigOptions
]
# Reverse and add projectOptions to all options
projectOptions.reverse()
allOptions = allOptions.concat(projectOptions)


# logger.verbose(allOptions)
return allOptions
getOptions : (selection, allOptions) ->

isNestedOptions : (currOptions) ->
containsNested = false
key = undefined

# Check if already nested under _default
if currOptions._default
return true

# Check to see if config file uses nested object format to split up js/css/html options
for key of currOptions

# Check if is supported language
if _.indexOf(@languages.namespaces, key) >= 0 and typeof currOptions[key] is "object" # Check if nested object (more options in value)
containsNested = true
break # Found, break out of loop, no need to continue

return containsNested

getOptions : (selections, allOptions) =>
self = this
_ ?= require("lodash")
extend ?= require("extend")

logger.verbose(selections, allOptions)

# logger.verbose(selection, allOptions);
# Reduce all options into correctly merged options.
options = _.reduce(allOptions, (result, currOptions) ->
containsNested = false
collectedConfig = {}
key = undefined


# Check to see if config file uses nested object format to split up js/css/html options
for key of currOptions

# Check if is supported language
if _.indexOf(self.languages.namespaces, key) >= 0 and typeof currOptions[key] is "object" # Check if nested object (more options in value)
containsNested = true
break # Found, break out of loop, no need to continue

options = _.reduce(allOptions, (result, currOptions) =>
collectedConfig = currOptions._default or {}
containsNested = @isNestedOptions(currOptions)
logger.verbose(containsNested, currOptions)
# logger.verbose(containsNested, currOptions);

# Create a flat object of config options if nested format was used
unless containsNested
_.merge collectedConfig, currOptions
else

# Merge with selected options
# where `selection` could be `html`, `js`, 'css', etc
# logger.verbose(selection, currOptions[selection]);
# _.merge collectedConfig, currOptions
currOptions = {
_default: currOptions
}

# Merge with selected options
# where `selection` could be `html`, `js`, 'css', etc
for selection in selections
# Merge current options on top of fallback options
logger.verbose('options', selection, currOptions[selection]);
_.merge collectedConfig, currOptions[selection]
logger.verbose('options', selection, collectedConfig);

extend result, collectedConfig
, {})

Expand Down
3 changes: 2 additions & 1 deletion src/beautifiers/prettydiff.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ module.exports = class PrettyDiff extends Beautifier

beautify: (text, language, options) ->

return new @Promise((resolve, reject) ->
return new @Promise((resolve, reject) =>
prettydiff = require("prettydiff")
_ = require('lodash')

Expand Down Expand Up @@ -71,6 +71,7 @@ module.exports = class PrettyDiff extends Beautifier
_.merge(options, args)

# Beautify
@verbose('prettydiff', options)
output = prettydiff.api(options)
result = output[0]

Expand Down
1 change: 0 additions & 1 deletion src/beautify.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,6 @@ setCursors = (editor, posArray) ->
editor.addCursorAtBufferPosition bufferPosition
return
beautify = ({onSave}) ->
console.log('beautify!!!')
# Deprecation warning for beautify on save
if atom.config.get("atom-beautify.beautifyOnSave") is true
detail = """See issue https://github.com/Glavin001/atom-beautify/issues/308
Expand Down

0 comments on commit 573a949

Please sign in to comment.