download process

CodeMirror 2: CoffeeScript mode - Quality PLR Download














Problems with checkout?
Try your download again
Instant Download
Price:
3.67
USD


Tradebit buyer protection fee included.

Instant Download from plrmrrshop, digital version

Pay for CodeMirror 2: CoffeeScript mode - Quality PLR Download
4.937 MB ZIP File - Platform: Indy

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).



(ID 190062402)

File Data:

Contact Seller:
plrmrrshop, IN, Member since 09/11/2012

URL:

Embed:
Create JavaScript Mobile Tag Widgets for your homepage

Resell product:


Tradebit Reviews

Tradebit is the worlds largest marketplace for digital files, with over 2.5 million satisfied customers and millions of digital products. Online for over 12 years, Tradebit is the best place to find files like music, video tutorials, repair manuals, and more. If you're curious about how much our users love Tradebit, read reviews from real buyers!