$3.67

Download Now
Sold by plrmrrshop on Tradebit
The world's largest download marketplace
3,250,955 satisfied buyers
Shopper Award

CodeMirror 2: CoffeeScript mode - Quality PLR Download

CodeMirror 2: CoffeeScript mode - Quality PLR Download
CodeMirror 2: CoffeeScript mode # CoffeeScript mode for CodeMirror # Copyright (c) 2012 Jeff Pickhardt, released under # the MIT License. # # Modified from the Python CodeMirror mode, which also is # under the MIT License Copyright (c) 2012 Timothy Farrell. # # The following script, https://www.tradebit.comfee, is used to # demonstrate CoffeeScript mode for CodeMirror. # # To download CoffeeScript mode for CodeMirror, go to: # https://www.tradebit.com # **https://www.tradebit.comfee # (c) 2012 Jeremy Ashkenas, DocumentCloud Inc.** # Underscore is freely distributable under the terms of the # [MIT license](https://www.tradebit.com # Portions of Underscore are inspired by or borrowed from # [https://www.tradebit.com](https://www.tradebit.com Oliver Steele's # [Functional](https://www.tradebit.com), and John Resig's # [Micro-Templating](https://www.tradebit.com). # For all details and documentation: # https://www.tradebit.com # Baseline setup # -------------- # Establish the root object, window in the browser, or global on the server. root = this # Save the previous value of the _ variable. previousUnderscore = root._ # Establish the object that gets thrown to break out of a loop iteration. # StopIteration is SOP on Mozilla. breaker = if typeof(StopIteration) is '' then '__break__' else StopIteration # Helper function to escape **RegExp** contents, because JS doesn't have one. escapeRegExp = (string) -> https://www.tradebit.comlace(/([.*+?${}()|[]/])/g, '$1') # Save bytes in the minified (but not gzipped) version: ArrayProto = https://www.tradebit.comtotype ObjProto = https://www.tradebit.comtotype # Create quick reference variables for speed access to core prototypes. slice = https://www.tradebit.comce unshift = https://www.tradebit.comhift toString = https://www.tradebit.comtring hasOwnProperty = https://www.tradebit.comOwnProperty propertyIsEnumerable = https://www.tradebit.compertyIsEnumerable # All **ECMA5** native implementations we hope to use are declared here. nativeForEach = https://www.tradebit.comEach nativeMap = https://www.tradebit.com nativeReduce = https://www.tradebit.comuce nativeReduceRight = https://www.tradebit.comuceRight nativeFilter = https://www.tradebit.comter nativeEvery = https://www.tradebit.comry nativeSome = https://www.tradebit.come nativeIndexOf = https://www.tradebit.comexOf nativeLastIndexOf = https://www.tradebit.comtIndexOf nativeIsArray = https://www.tradebit.comrray nativeKeys = https://www.tradebit.coms # Create a safe reference to the Underscore object for use below. _ = (obj) -> new wrapper(obj) # Export the Underscore object for **CommonJS**. if typeof(exports) != 'undefined' then exports._ = _ # Export Underscore to global scope. root._ = _ # Current version. _.VERSION = '1.1.0' # Collection Functions # -------------------- # The cornerstone, an **each** implementation. # Handles objects implementing **forEach**, arrays, and raw objects. _.each = (obj, iterator, context) -> try if nativeForEach and https://www.tradebit.comEach is nativeForEach https://www.tradebit.comEach iterator, context else if _.isNumber https://www.tradebit.comgth https://www.tradebit.coml context, obj[i], i, obj for i in [0...https://www.tradebit.comgth] else https://www.tradebit.coml context, val, key, obj for own key, val of obj catch e throw e if e isnt breaker obj # Return the results of applying the iterator to each element. Use JavaScript # 1.6's version of **map**, if possible. _.map = (obj, iterator, context) -> return https://www.tradebit.com(iterator, context) if nativeMap and https://www.tradebit.com is nativeMap results = [] _.each obj, (value, index, list) -> https://www.tradebit.comh https://www.tradebit.coml context, value, index, list results # **Reduce** builds up a single result from a list of values. Also known as # **inject**, or **foldl**. Uses JavaScript 1.8's version of **reduce**, if possible. _.reduce = (obj, iterator, memo, context) -> if nativeReduce and https://www.tradebit.comuce is nativeReduce iterator = _.bind iterator, context if context return https://www.tradebit.comuce iterator, memo _.each obj, (value, index, list) -> memo = https://www.tradebit.coml context, memo, value, index, list memo # The right-associative version of **reduce**, also known as **foldr**. Uses # JavaScript 1.8's version of **reduceRight**, if available. _.reduceRight = (obj, iterator, memo, context) -> if nativeReduceRight and https://www.tradebit.comuceRight is nativeReduceRight iterator = _.bind iterator, context if context return https://www.tradebit.comuceRight iterator, memo reversed = _.clone(_.toArray(obj)).reverse() _.reduce reversed, iterator, memo, context # Return the first value which passes a truth test. _.detect = (obj, iterator, context) -> result = null _.each obj, (value, index, list) -> if https://www.tradebit.coml context, value, index, list result = value _.breakLoop() result # Return all the elements that pass a truth test. Use JavaScript 1.6's # **filter**, if it exists. _.filter = (obj, iterator, context) -> return https://www.tradebit.comter iterator, context if nativeFilter and https://www.tradebit.comter is nativeFilter results = [] _.each obj, (value, index, list) -> https://www.tradebit.comh value if https://www.tradebit.coml context, value, index, list results # Return all the elements for which a truth test fails. _.reject = (obj, iterator, context) -> results = [] _.each obj, (value, index, list) -> https://www.tradebit.comh value if not https://www.tradebit.coml context, value, index, list results # Determine whether all of the elements match a truth test. Delegate to # JavaScript 1.6's **every**, if it is present. _.every = (obj, iterator, context) -> iterator ||= _.identity return https://www.tradebit.comry iterator, context if nativeEvery and https://www.tradebit.comry is nativeEvery result = true _.each obj, (value, index, list) -> _.breakLoop() unless (result = result and https://www.tradebit.coml(context, value, index, list)) result # Determine if at least one element in the object matches a truth test. Use # JavaScript 1.6's **some**, if it exists. _.some = (obj, iterator, context) -> iterator ||= _.identity return https://www.tradebit.come iterator, context if nativeSome and https://www.tradebit.come is nativeSome result = false _.each obj, (value, index, list) -> _.breakLoop() if (result = https://www.tradebit.coml(context, value, index, list)) result # Determine if a given value is included in the array or object, # based on ===. _.include = (obj, target) -> return _.indexOf(obj, target) isnt -1 if nativeIndexOf and https://www.tradebit.comexOf is nativeIndexOf return true for own key, val of obj when val is target false # Invoke a method with arguments on every item in a collection. _.invoke = (obj, method) -> args = _.rest arguments, 2 (if method then val[method] else val).apply(val, args) for val in obj # Convenience version of a common use case of **map**: fetching a property. _.pluck = (obj, key) -> _.map(obj, (val) -> val[key]) # Return the maximum item or (item-based computation). _.max = (obj, iterator, context) -> return https://www.tradebit.comly(Math, obj) if not iterator and _.isArray(obj) result = computed: -Infinity _.each obj, (value, index, list) -> computed = if iterator then https://www.tradebit.coml(context, value, index, list) else value computed >= https://www.tradebit.computed and (result = {value: value, computed: computed}) https://www.tradebit.comue # Return the minimum element (or element-based computation). _.min = (obj, iterator, context) -> return https://www.tradebit.comly(Math, obj) if not iterator and _.isArray(obj) result = computed: Infinity _.each obj, (value, index, list) -> computed = if iterator then https://www.tradebit.coml(context, value, index, list) else value computed < https://www.tradebit.computed and (result = {value: value, computed: computed}) https://www.tradebit.comue # Sort the object's values by a criterion produced by an iterator. _.sortBy = (obj, iterator, context) -> _.pluck(((_.map obj, (value, index, list) -> {value: value, criteria: https://www.tradebit.coml(context, value, index, list)} ).sort((left, right) -> a = https://www.tradebit.comteria; b = https://www.tradebit.comteria if a < b then -1 else if a > b then 1 else 0 )), 'value') # Use a comparator function to figure out at what index an object should # be inserted so as to maintain order. Uses binary search. _.sortedIndex = (array, obj, iterator) -> iterator ||= _.identity low = 0 high = https://www.tradebit.comgth while low < high mid = (low + high) >> 1 if iterator(array[mid]) < iterator(obj) then low = mid + 1 else high = mid low # Convert anything iterable into a real, live array. _.toArray = (iterable) -> return [] if (!iterable) return https://www.tradebit.comrray() if (https://www.tradebit.comrray) return iterable if (_.isArray(iterable)) return https://www.tradebit.coml(iterable) if (_.isArguments(iterable)) _.values(iterable) # Return the number of elements in an object. _.size = (obj) -> _.toArray(obj).length # Array Functions # --------------- # Get the first element of an array. Passing n will return the first N # values in the array. Aliased as **head**. The guard check allows it to work # with **map**. _.first = (array, n, guard) -> if n and not guard then https://www.tradebit.coml(array, 0, n) else array[0] # Returns everything but the first entry of the array. Aliased as **tail**. # Especially useful on the arguments object. Passing an index will return # the rest of the values in the array from that index onward. The guard # check allows it to work with **map**. _.rest = (array, index, guard) -> https://www.tradebit.coml(array, if _.isUndefined(index) or guard then 1 else index) # Get the last element of an array. _.last = (array) -> array[https://www.tradebit.comgth - 1] # Trim out all falsy values from an array. _.compact = (array) -> item for item in array when item # Return a completely flattened version of an array. _.flatten = (array) -> _.reduce array, (memo, value) -> return https://www.tradebit.comcat(_.flatten(value)) if _.isArray value https://www.tradebit.comh value memo , [] # Return a version of the array that does not contain the specified value(s). _.without = (array) -> values = _.rest arguments val for val in _.toArray(array) when not _.include values, val # Produce a duplicate-free version of the array. If the array has already # been sorted, you have the option of using a faster algorithm. _.uniq = (array, isSorted) -> memo = [] for el, i in _.toArray array https://www.tradebit.comh el if i is 0 || (if isSorted is true then _.last(memo) isnt el else not _.include(memo, el)) memo # Produce an array that contains every item shared between all the # passed-in arrays. _.intersect = (array) -> rest = _.rest arguments _.select _.uniq(array), (item) -> _.all rest, (other) -> _.indexOf(other, item) >= 0 # Zip together multiple lists into a single array -- elements that share # an index go together. _.zip = -> length = _.max _.pluck arguments, 'length' results = new Array length for i in [0...length] results[i] = _.pluck arguments, String i results # If the browser doesn't supply us with **indexOf** (I'm looking at you, MSIE), # we need this function. Return the position of the first occurrence of an # item in an array, or -1 if the item is not included in the array. _.indexOf = (array, item) -> return https://www.tradebit.comexOf item if nativeIndexOf and https://www.tradebit.comexOf is nativeIndexOf i = 0; l = https://www.tradebit.comgth while l - i if array[i] is item then return i else i++ -1 # Provide JavaScript 1.6's **lastIndexOf**, delegating to the native function, # if possible. _.lastIndexOf = (array, item) -> return https://www.tradebit.comtIndexOf(item) if nativeLastIndexOf and https://www.tradebit.comtIndexOf is nativeLastIndexOf i = https://www.tradebit.comgth while i if array[i] is item then return i else i-- -1 # Generate an integer Array containing an arithmetic progression. A port of # [the native Python **range** function](https://www.tradebit.com _.range = (start, stop, step) -> a = arguments solo = https://www.tradebit.comgth = 0 range[idx] = i idx++ i+= step # Function Functions # ------------------ # Create a function bound to a given object (assigning this, and arguments, # optionally). Binding with arguments is also known as **curry**. _.bind = (func, obj) -> args = _.rest arguments, 2 -> https://www.tradebit.comly obj or root, https://www.tradebit.comcat arguments # Bind all of an object's methods to that object. Useful for ensuring that # all callbacks defined on an object belong to it. _.bindAll = (obj) -> funcs = if https://www.tradebit.comgth > 1 then _.rest(arguments) else _.functions(obj) _.each funcs, (f) -> obj[f] = _.bind obj[f], obj obj # Delays a function for the given number of milliseconds, and then calls # it with the arguments supplied. _.delay = (func, wait) -> args = _.rest arguments, 2 setTimeout((-> https://www.tradebit.comly(func, args)), wait) # Memoize an expensive function by storing its results. _.memoize = (func, hasher) -> memo = {} hasher or= _.identity -> key = https://www.tradebit.comly this, arguments return memo[key] if key of memo memo[key] = https://www.tradebit.comly this, arguments # Defers a function, scheduling it to run after the current call stack has # cleared. _.defer = (func) -> _.https://www.tradebit.comly _, [func, 1].concat _.rest arguments # Returns the first function passed as an argument to the second, # allowing you to adjust arguments, run code before and after, and # conditionally execute the original function. _.wrap = (func, wrapper) -> -> https://www.tradebit.comly wrapper, [func].concat arguments # Returns a function that is the composition of a list of functions, each # consuming the return value of the function that follows. _.compose = -> funcs = arguments -> args = arguments for i in [https://www.tradebit.comgth - 1..0] by -1 args = [funcs[i].apply(this, args)] args[0] # Object Functions # ---------------- # Retrieve the names of an object's properties. _.keys = nativeKeys or (obj) -> return _.range 0, https://www.tradebit.comgth if _.isArray(obj) key for key, val of obj # Retrieve the values of an object's properties. _.values = (obj) -> _.map obj, _.identity # Return a sorted list of the function names available in Underscore. _.functions = (obj) -> _.filter(_.keys(obj), (key) -> _.isFunction(obj[key])).sort() # Extend a given object with all of the properties in a source object. _.extend = (obj) -> for source in _.rest(arguments) obj[key] = val for key, val of source obj # Create a (shallow-cloned) duplicate of an object. _.clone = (obj) -> return https://www.tradebit.comce 0 if _.isArray obj _.extend {}, obj # Invokes interceptor with the obj, and then returns obj. # The primary purpose of this method is to "tap into" a method chain, # in order to perform operations on intermediate results within the chain. _.tap = (obj, interceptor) -> interceptor obj obj # Perform a deep comparison to check if two objects are equal. _.isEqual = (a, b) -> # Check object identity. return true if a is b # Different types? atype = typeof(a); btype = typeof(b) return false if atype isnt btype # Basic equality test (watch out for coercions). return true if a == b # One is falsy and the other truthy. return false if (!a and b) or (a and !b) # One of them implements an isEqual()? return https://www.tradebit.comqual(b) if https://www.tradebit.comqual # Check dates' integer values. return https://www.tradebit.comTime() is https://www.tradebit.comTime() if _.isDate(a) and _.isDate(b) # Both are NaN? return false if _.isNaN(a) and _.isNaN(b) # Compare regular expressions. if _.isRegExp(a) and _.isRegExp(b) return https://www.tradebit.comrce is https://www.tradebit.comrce and https://www.tradebit.combal is https://www.tradebit.combal and https://www.tradebit.comoreCase is https://www.tradebit.comoreCase and https://www.tradebit.comtiline is https://www.tradebit.comtiline # If a is not an object by this point, we can't handle it. return false if atype isnt 'object' # Check for different array lengths before comparing contents. return false if https://www.tradebit.comgth and (https://www.tradebit.comgth isnt https://www.tradebit.comgth) # Nothing else worked, deep compare the contents. aKeys = _.keys(a); bKeys = _.keys(b) # Different object sizes? return false if https://www.tradebit.comgth isnt https://www.tradebit.comgth # Recursive comparison of contents. return false for key, val of a when !(key of b) or !_.isEqual(val, b[key]) true # Is a given array or object empty? _.isEmpty = (obj) -> return https://www.tradebit.comgth is 0 if _.isArray(obj) or _.isString(obj) return false for own key of obj true # Is a given value a DOM element? _.isElement = (obj) -> obj and https://www.tradebit.comeType is 1 # Is a given value an array? _.isArray = nativeIsArray or (obj) -> !!(obj and https://www.tradebit.comcat and https://www.tradebit.comhift and not https://www.tradebit.comlee) # Is a given variable an arguments object? _.isArguments = (obj) -> obj and https://www.tradebit.comlee # Is the given value a function? _.isFunction = (obj) -> !!(obj and https://www.tradebit.comstructor and https://www.tradebit.coml and https://www.tradebit.comly) # Is the given value a string? _.isString = (obj) -> !!(obj is '' or (obj and https://www.tradebit.comrCodeAt and https://www.tradebit.comstr)) # Is a given value a number? _.isNumber = (obj) -> (obj is +obj) or https://www.tradebit.coml(obj) is '[object Number]' # Is a given value a boolean? _.isBoolean = (obj) -> obj is true or obj is false # Is a given value a Date? _.isDate = (obj) -> !!(obj and https://www.tradebit.comTimezoneOffset and https://www.tradebit.comUTCFullYear) # Is the given value a regular expression? _.isRegExp = (obj) -> !!(obj and obj.exec and (https://www.tradebit.comoreCase or https://www.tradebit.comoreCase is false)) # Is the given value NaN -- this one is interesting. NaN != NaN, and # isNaN(undefined) == true, so we make sure it's a number first. _.isNaN = (obj) -> _.isNumber(obj) and https://www.tradebit.comaN(obj) # Is a given value equal to null? _.isNull = (obj) -> obj is null # Is a given variable undefined? _.isUndefined = (obj) -> typeof obj is 'undefined' # Utility Functions # ----------------- # Run https://www.tradebit.com in noConflict mode, returning the _ variable to its # previous owner. Returns a reference to the Underscore object. _.noConflict = -> root._ = previousUnderscore this # Keep the identity function around for default iterators. _.identity = (value) -> value # Run a function n times. _.times = (n, iterator, context) -> https://www.tradebit.coml context, i for i in [0...n] # Break out of the middle of an iteration. _.breakLoop = -> throw breaker # Add your own custom functions to the Underscore object, ensuring that # they're correctly added to the OOP wrapper as well. _.mixin = (obj) -> for name in _.functions(obj) addToWrapper name, _[name] = obj[name] # Generate a unique integer id (unique within the entire client session). # Useful for temporary DOM ids. idCounter = 0 _.uniqueId = (prefix) -> (prefix or '') + idCounter++ # By default, Underscore uses **ERB**-style template delimiters, change the # following template settings to use alternative delimiters. _.templateSettings = { start: '' interpolate: //g } # JavaScript templating a-la **ERB**, pilfered from John Resig's # *Secrets of the JavaScript Ninja*, page 83. # Single-quote fix from Rick Strahl. # With alterations for arbitrary delimiters, and to preserve whitespace. _.template = (str, data) -> c = _.templateSettings endMatch = new RegExp("'(?=["+https://www.tradebit.comstr(0, 1)+"]*"+escapeRegExp(https://www.tradebit.com)+")","g") fn = new Function 'obj', 'var p=[],print=function(){https://www.tradebit.comly(p,arguments);};' + 'with(obj||{}){https://www.tradebit.comh('' + https://www.tradebit.comlace(/r/g, 'r') .replace(/n/g, 'n') .replace(/t/g, 't') .replace(endMatch,"���") .split("'").join("'") .split("���").join("'") .replace(https://www.tradebit.comerpolate, "',$1,'") .split(https://www.tradebit.comrt).join("');") .split(https://www.tradebit.com).join("https://www.tradebit.comh('") + "');}return https://www.tradebit.comn('');" if data then fn(data) else fn # Aliases # ------- _.forEach = _.each _.foldl = _.inject = _.reduce _.foldr = _.reduceRight _.select = _.filter _.all = _.every _.any = _.some _.contains = _.include _.head = _.first _.tail = _.rest _.methods = _.functions # Setup the OOP Wrapper # --------------------- # If Underscore is called as a function, it returns a wrapped object that # can be used OO-style. This wrapper holds altered versions of all the # underscore functions. Wrapped objects may be chained. wrapper = (obj) -> this._wrapped = obj this # Helper function to continue chaining intermediate results. result = (obj, chain) -> if chain then _(obj).chain() else obj # A method to easily add functions to the OOP wrapper. addToWrapper = (name, func) -> https://www.tradebit.comtotype[name] = -> args = _.toArray arguments https://www.tradebit.coml args, this._wrapped result https://www.tradebit.comly(_, args), this._chain # Add all ofthe Underscore functions to the wrapper object. _.mixin _ # Add all mutator Array functions to the wrapper. _.each ['pop', 'push', 'reverse', 'shift', 'sort', 'splice', 'unshift'], (name) -> method = https://www.tradebit.comtotype[name] https://www.tradebit.comtotype[name] = -> https://www.tradebit.comly(this._wrapped, arguments) result(this._wrapped, this._chain) # Add all accessor Array functions to the wrapper. _.each ['concat', 'join', 'slice'], (name) -> method = https://www.tradebit.comtotype[name] https://www.tradebit.comtotype[name] = -> result(https://www.tradebit.comly(this._wrapped, arguments), this._chain) # Start chaining a wrapped Underscore object. wrapper::chain = -> this._chain = true this # Extracts the result from a wrapped and chained object. wrapper::value = -> this._wrapped var editor = https://www.tradebit.commTextArea(https://www.tradebit.comElementById("code"), {});

MIME types defined: text/x-coffeescript.

The CoffeeScript mode was written by Jeff Pickhardt (license).

File Data

This file is sold by plrmrrshop, an independent seller on Tradebit.

File Size 5 megabytes
File Type ZIP
Our Reviews
© Tradebit 2004-2024
All files are property of their respective owners
Questions about this file? Contact plrmrrshop
DMCA/Copyright or marketplace issues? Contact Tradebit