mirror of
				https://github.com/KevinMidboe/linguist.git
				synced 2025-10-29 17:50:22 +00:00 
			
		
		
		
	Compare commits
	
		
			135 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 62b1816297 | ||
|  | 2d1e1d4747 | ||
|  | f785aa0ae2 | ||
|  | cc476e212e | ||
|  | bca9716fc6 | ||
|  | fae6dbfebd | ||
|  | a7a0800b46 | ||
|  | 305293d3e5 | ||
|  | 17d4eb7a5e | ||
|  | f97e103b6d | ||
|  | dafca264b2 | ||
|  | be970e9e3d | ||
|  | e76837fa20 | ||
|  | e1b3403dc8 | ||
|  | 79da17c5c8 | ||
|  | e9623d542d | ||
|  | bc999f4067 | ||
|  | 474e536ae8 | ||
|  | 79647c5bb4 | ||
|  | 5409c39e35 | ||
|  | 5d4a24dd4f | ||
|  | c97abe7ef5 | ||
|  | edaea7bede | ||
|  | 909bce8ed9 | ||
|  | 4090c492e8 | ||
|  | a24afb0e12 | ||
|  | bc01f8b25f | ||
|  | 077c4141d6 | ||
|  | e5f20314e9 | ||
|  | 8a61bcb6b5 | ||
|  | 61b301b380 | ||
|  | be86f28be1 | ||
|  | a443380869 | ||
|  | 3d1d431cda | ||
|  | 9559ece8af | ||
|  | 8f56a1096d | ||
|  | 0ec85f902a | ||
|  | a47dde2166 | ||
|  | abdd6bfbd2 | ||
|  | d64104f472 | ||
|  | 1cd5ae2d57 | ||
|  | e27bf1627d | ||
|  | 0689d64efd | ||
|  | 3ba47aec38 | ||
|  | b90253981b | ||
|  | 513f678b6c | ||
|  | 478b9cf189 | ||
|  | 6675baff13 | ||
|  | a6efeebd21 | ||
|  | 6e2bb25b6e | ||
|  | a54edf71d1 | ||
|  | 8ff7eaf893 | ||
|  | a8d3872002 | ||
|  | dea03b7a46 | ||
|  | f5723dcccf | ||
|  | d772d1f162 | ||
|  | 46cfd16ae7 | ||
|  | 315243350b | ||
|  | 886d8a7293 | ||
|  | 54318f4001 | ||
|  | b3aee8abab | ||
|  | 1bdbadc1b3 | ||
|  | e0997b311b | ||
|  | 3c2ca312b9 | ||
|  | 315df1339a | ||
|  | e03b3e5ec4 | ||
|  | 43923976c2 | ||
|  | 6b8ee2f3f7 | ||
|  | b8e570bb3d | ||
|  | 69ff3c79b4 | ||
|  | eff4da20f8 | ||
|  | 473688b109 | ||
|  | 7bfb6ed5d7 | ||
|  | 276080aeec | ||
|  | 41c880afc7 | ||
|  | 3d242c3a3a | ||
|  | 9325b07d68 | ||
|  | ddeeb5d416 | ||
|  | c8bc0a5c79 | ||
|  | f58522d5a9 | ||
|  | 27a621531b | ||
|  | 0235433b7e | ||
|  | 6b5d1fe25b | ||
|  | f811ab1b28 | ||
|  | fc73f51855 | ||
|  | dd181421a7 | ||
|  | f6e2189739 | ||
|  | d61f31d3ed | ||
|  | 4e83a6ad23 | ||
|  | 7fc39dc8d1 | ||
|  | f10154a782 | ||
|  | 8761dc4e17 | ||
|  | 5a044b1c07 | ||
|  | 0100b76412 | ||
|  | c8754292f4 | ||
|  | 61faea0298 | ||
|  | b9ecf61dcb | ||
|  | 437f81c4a0 | ||
|  | 26dad7dada | ||
|  | b1e5d6f8f8 | ||
|  | 8c7b54d6e3 | ||
|  | fea0d8963c | ||
|  | 7aca52c68c | ||
|  | 529d3faaf8 | ||
|  | 9f0f4657a2 | ||
|  | 90ff1b5896 | ||
|  | feb82e34d6 | ||
|  | 4d7a34c177 | ||
|  | 5c3385ecd8 | ||
|  | a1af3a509c | ||
|  | 2913a87cc4 | ||
|  | 69cc86c572 | ||
|  | 60144c907e | ||
|  | 1828cf6fc7 | ||
|  | ad4d273241 | ||
|  | 0d03a94cde | ||
|  | 6af5adaac1 | ||
|  | 17a28f2e91 | ||
|  | baaa7a5c13 | ||
|  | cfeb2a833c | ||
|  | e6fd58b3aa | ||
|  | 2ef905ef1e | ||
|  | db80aa84dc | ||
|  | f404cc16a1 | ||
|  | 8b4acf7023 | ||
|  | bb7d6ab429 | ||
|  | c5acce0604 | ||
|  | a6ccce7b76 | ||
|  | 2f4ea20fdd | ||
|  | 81fcb4452e | ||
|  | 4f1a5cd456 | ||
|  | ae2d3d7e61 | ||
|  | 58ae0908e3 | ||
|  | e91caeaade | ||
|  | bd694c60e1 | 
| @@ -4,6 +4,7 @@ | ||||
| #     usage: linguist <path> [<--breakdown>] | ||||
|  | ||||
| require 'linguist/file_blob' | ||||
| require 'linguist/language' | ||||
| require 'linguist/repository' | ||||
| require 'rugged' | ||||
|  | ||||
| @@ -30,7 +31,7 @@ if File.directory?(path) | ||||
|     puts | ||||
|     file_breakdown = repo.breakdown_by_file | ||||
|     file_breakdown.each do |lang, files| | ||||
|       puts "#{lang}:"  | ||||
|       puts "#{lang}:" | ||||
|       files.each do |file| | ||||
|         puts file | ||||
|       end | ||||
|   | ||||
| @@ -1,6 +1,4 @@ | ||||
| require 'linguist/generated' | ||||
| require 'linguist/language' | ||||
|  | ||||
| require 'charlock_holmes' | ||||
| require 'escape_utils' | ||||
| require 'mime/types' | ||||
|   | ||||
| @@ -52,5 +52,20 @@ module Linguist | ||||
|     def size | ||||
|       File.size(@path) | ||||
|     end | ||||
|  | ||||
|     # Public: Get file extension. | ||||
|     # | ||||
|     # Returns a String. | ||||
|     def extension | ||||
|       # File.extname returns nil if the filename is an extension. | ||||
|       extension = File.extname(name) | ||||
|       basename = File.basename(name) | ||||
|       # Checks if the filename is an extension. | ||||
|       if extension.empty? && basename[0] == "." | ||||
|         basename | ||||
|       else | ||||
|         extension | ||||
|       end | ||||
|     end | ||||
|   end | ||||
| end | ||||
|   | ||||
| @@ -54,7 +54,7 @@ module Linguist | ||||
|       name == 'Gemfile.lock' || | ||||
|         minified_files? || | ||||
|         compiled_coffeescript? || | ||||
|         xcode_project_file? || | ||||
|         xcode_file? || | ||||
|         generated_parser? || | ||||
|         generated_net_docfile? || | ||||
|         generated_net_designer_file? || | ||||
| @@ -67,14 +67,14 @@ module Linguist | ||||
|         generated_by_zephir? | ||||
|     end | ||||
|  | ||||
|     # Internal: Is the blob an XCode project file? | ||||
|     # Internal: Is the blob an Xcode file? | ||||
|     # | ||||
|     # Generated if the file extension is an XCode project | ||||
|     # Generated if the file extension is an Xcode  | ||||
|     # file extension. | ||||
|     # | ||||
|     # Returns true of false. | ||||
|     def xcode_project_file? | ||||
|       ['.xib', '.nib', '.storyboard', '.pbxproj', '.xcworkspacedata', '.xcuserstate'].include?(extname) | ||||
|     def xcode_file? | ||||
|       ['.nib', '.xcworkspacedata', '.xcuserstate'].include?(extname) | ||||
|     end | ||||
|  | ||||
|     # Internal: Is the blob minified files? | ||||
| @@ -235,7 +235,7 @@ module Linguist | ||||
|     # | ||||
|     # Returns true or false. | ||||
|     def composer_lock? | ||||
|       !!name.match(/composer.lock/) | ||||
|       !!name.match(/composer\.lock/) | ||||
|     end | ||||
|  | ||||
|     # Internal: Is the blob a generated by Zephir | ||||
| @@ -256,3 +256,4 @@ module Linguist | ||||
|     end | ||||
|   end | ||||
| end | ||||
|  | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| module Linguist | ||||
|   # A collection of simple heuristics that can be used to better analyze languages. | ||||
|   class Heuristics | ||||
|     ACTIVE = false | ||||
|     ACTIVE = true | ||||
|  | ||||
|     # Public: Given an array of String language names, | ||||
|     # apply heuristics against the given data and return an array | ||||
| @@ -13,24 +13,13 @@ module Linguist | ||||
|     # Returns an array of Languages or [] | ||||
|     def self.find_by_heuristics(data, languages) | ||||
|       if active? | ||||
|         if languages.all? { |l| ["Objective-C", "C++"].include?(l) } | ||||
|           disambiguate_c(data, languages) | ||||
|         end | ||||
|         if languages.all? { |l| ["Perl", "Prolog"].include?(l) } | ||||
|           disambiguate_pl(data, languages) | ||||
|           result = disambiguate_pl(data, languages) | ||||
|         end | ||||
|         if languages.all? { |l| ["ECL", "Prolog"].include?(l) } | ||||
|           disambiguate_ecl(data, languages) | ||||
|         end | ||||
|         if languages.all? { |l| ["TypeScript", "XML"].include?(l) } | ||||
|           disambiguate_ts(data, languages) | ||||
|         end | ||||
|         if languages.all? { |l| ["Common Lisp", "OpenCL"].include?(l) } | ||||
|           disambiguate_cl(data, languages) | ||||
|         end | ||||
|         if languages.all? { |l| ["Rebol", "R"].include?(l) } | ||||
|           disambiguate_r(data, languages) | ||||
|           result = disambiguate_ecl(data, languages) | ||||
|         end | ||||
|         return result | ||||
|       end | ||||
|     end | ||||
|  | ||||
|   | ||||
| @@ -9,6 +9,8 @@ end | ||||
| require 'linguist/classifier' | ||||
| require 'linguist/heuristics' | ||||
| require 'linguist/samples' | ||||
| require 'linguist/file_blob' | ||||
| require 'linguist/blob_helper' | ||||
|  | ||||
| module Linguist | ||||
|   # Language names that are recognizable by GitHub. Defined languages | ||||
| @@ -109,7 +111,8 @@ module Linguist | ||||
|       # A bit of an elegant hack. If the file is executable but extensionless, | ||||
|       # append a "magic" extension so it can be classified with other | ||||
|       # languages that have shebang scripts. | ||||
|       if File.extname(name).empty? && blob.mode && (blob.mode.to_i(8) & 05) == 05 | ||||
|       extension = FileBlob.new(name).extension | ||||
|       if extension.empty? && blob.mode && (blob.mode.to_i(8) & 05) == 05 | ||||
|         name += ".script!" | ||||
|       end | ||||
|  | ||||
| @@ -133,7 +136,7 @@ module Linguist | ||||
|         elsif (determined = Heuristics.find_by_heuristics(data, possible_language_names)) && !determined.empty? | ||||
|           determined.first | ||||
|         # Lastly, fall back to the probablistic classifier. | ||||
|         elsif classified = Classifier.classify(Samples::DATA, data, possible_language_names ).first | ||||
|         elsif classified = Classifier.classify(Samples::DATA, data, possible_language_names).first | ||||
|           # Return the actual Language object based of the string language name (i.e., first element of `#classify`) | ||||
|           Language[classified[0]] | ||||
|         end | ||||
| @@ -189,7 +192,8 @@ module Linguist | ||||
|     # | ||||
|     # Returns all matching Languages or [] if none were found. | ||||
|     def self.find_by_filename(filename) | ||||
|       basename, extname = File.basename(filename), File.extname(filename) | ||||
|       basename = File.basename(filename) | ||||
|       extname = FileBlob.new(filename).extension | ||||
|       langs = @filename_index[basename] + | ||||
|               @extension_index[extname] | ||||
|       langs.compact.uniq | ||||
| @@ -528,6 +532,7 @@ module Linguist | ||||
|     if extnames = extensions[name] | ||||
|       extnames.each do |extname| | ||||
|         if !options['extensions'].include?(extname) | ||||
|           warn "#{name} has a sample with extension (#{extname}) that isn't explicitly defined in languages.yml" unless extname == '.script!' | ||||
|           options['extensions'] << extname | ||||
|         end | ||||
|       end | ||||
|   | ||||
| @@ -28,6 +28,16 @@ ABAP: | ||||
|   extensions: | ||||
|   - .abap | ||||
|  | ||||
| AGS Script: | ||||
|   type: programming | ||||
|   lexer: C++ | ||||
|   color: "#B9D9FF" | ||||
|   aliases: | ||||
|   - ags | ||||
|   extensions: | ||||
|   - .asc | ||||
|   - .ash | ||||
|  | ||||
| ANTLR: | ||||
|   type: programming | ||||
|   color: "#9DC3FF" | ||||
| @@ -35,6 +45,12 @@ ANTLR: | ||||
|   extensions: | ||||
|   - .g4 | ||||
|  | ||||
| APL: | ||||
|   type: programming | ||||
|   color: "#8a0707" | ||||
|   extensions: | ||||
|   - .apl | ||||
|  | ||||
| ASP: | ||||
|   type: programming | ||||
|   color: "#6a40fd" | ||||
| @@ -260,6 +276,7 @@ C: | ||||
|   extensions: | ||||
|   - .c | ||||
|   - .cats | ||||
|   - .h | ||||
|   - .w | ||||
|  | ||||
| C#: | ||||
| @@ -288,6 +305,7 @@ C++: | ||||
|   - .cc | ||||
|   - .cxx | ||||
|   - .H | ||||
|   - .h | ||||
|   - .h++ | ||||
|   - .hh | ||||
|   - .hpp | ||||
| @@ -321,7 +339,7 @@ CLIPS: | ||||
| CMake: | ||||
|   extensions: | ||||
|   - .cmake | ||||
|   - .cmake.in | ||||
|   - .in | ||||
|   filenames: | ||||
|   - CMakeLists.txt | ||||
|  | ||||
| @@ -346,6 +364,14 @@ Ceylon: | ||||
|   extensions: | ||||
|   - .ceylon | ||||
|  | ||||
| Chapel: | ||||
|   type: programming | ||||
|   color: "#8dc63f" | ||||
|   aliases: | ||||
|   - chpl | ||||
|   extensions: | ||||
|   - .chpl | ||||
|  | ||||
| ChucK: | ||||
|   lexer: Java | ||||
|   extensions: | ||||
| @@ -354,9 +380,8 @@ ChucK: | ||||
| Cirru: | ||||
|   type: programming | ||||
|   color: "#aaaaff" | ||||
|   # ace_mode: cirru | ||||
|   # lexer: Cirru | ||||
|   lexer: Text only | ||||
|   ace_mode: cirru | ||||
|   lexer: Cirru | ||||
|   extensions: | ||||
|   - .cirru | ||||
|  | ||||
| @@ -380,7 +405,7 @@ Clojure: | ||||
|   - .cljscm | ||||
|   - .cljx | ||||
|   - .hic | ||||
|   - .cljs.hl | ||||
|   - .hl | ||||
|   filenames: | ||||
|   - riemann.config | ||||
|  | ||||
| @@ -403,14 +428,27 @@ CoffeeScript: | ||||
|  | ||||
| ColdFusion: | ||||
|   type: programming | ||||
|   group: ColdFusion | ||||
|   lexer: Coldfusion HTML | ||||
|   ace_mode: coldfusion | ||||
|   color: "#ed2cd6" | ||||
|   search_term: cfm | ||||
|   aliases: | ||||
|   - cfm | ||||
|   - cfml | ||||
|   extensions: | ||||
|   - .cfm | ||||
|  | ||||
| ColdFusion CFC: | ||||
|   type: programming | ||||
|   group: ColdFusion | ||||
|   lexer: Coldfusion CFC | ||||
|   ace_mode: coldfusion | ||||
|   color: "#ed2cd6" | ||||
|   search_term: cfc | ||||
|   aliases: | ||||
|   - cfc | ||||
|   extensions: | ||||
|   - .cfc | ||||
|  | ||||
| Common Lisp: | ||||
| @@ -444,6 +482,7 @@ Coq: | ||||
|   type: programming | ||||
|   extensions: | ||||
|   - .coq | ||||
|   - .v | ||||
|  | ||||
| Cpp-ObjDump: | ||||
|   type: data | ||||
| @@ -479,6 +518,12 @@ Cuda: | ||||
|   - .cu | ||||
|   - .cuh | ||||
|  | ||||
| Cycript: | ||||
|   type: programming | ||||
|   lexer: JavaScript | ||||
|   extensions: | ||||
|   - .cy | ||||
|  | ||||
| Cython: | ||||
|   type: programming | ||||
|   group: Python | ||||
| @@ -533,6 +578,7 @@ Dart: | ||||
| Diff: | ||||
|   extensions: | ||||
|   - .diff | ||||
|   - .patch | ||||
|  | ||||
| Dogescript: | ||||
|   type: programming | ||||
| @@ -581,7 +627,7 @@ Eagle: | ||||
|  | ||||
| Eiffel: | ||||
|   type: programming | ||||
|   lexer: Text only | ||||
|   lexer: Eiffel | ||||
|   color: "#946d57" | ||||
|   extensions: | ||||
|   - .e | ||||
| @@ -601,7 +647,7 @@ Elm: | ||||
|  | ||||
| Emacs Lisp: | ||||
|   type: programming | ||||
|   lexer: Scheme | ||||
|   lexer: Common Lisp | ||||
|   color: "#c065db" | ||||
|   aliases: | ||||
|   - elisp | ||||
| @@ -612,11 +658,20 @@ Emacs Lisp: | ||||
|   - .el | ||||
|   - .emacs | ||||
|  | ||||
| EmberScript: | ||||
|   type: programming | ||||
|   color: "#f64e3e" | ||||
|   lexer: CoffeeScript | ||||
|   extensions: | ||||
|   - .em | ||||
|   - .emberscript | ||||
|  | ||||
| Erlang: | ||||
|   type: programming | ||||
|   color: "#0faf8d" | ||||
|   extensions: | ||||
|   - .erl | ||||
|   - .escript | ||||
|   - .hrl | ||||
|  | ||||
| F#: | ||||
| @@ -692,6 +747,7 @@ Forth: | ||||
|   extensions: | ||||
|   - .fth | ||||
|   - .4th | ||||
|   - .forth | ||||
|  | ||||
| Frege: | ||||
|   type: programming | ||||
| @@ -800,6 +856,9 @@ Gosu: | ||||
|   color: "#82937f" | ||||
|   extensions: | ||||
|   - .gs | ||||
|   - .gst | ||||
|   - .gsx | ||||
|   - .vark | ||||
|  | ||||
| Grace: | ||||
|   type: programming | ||||
| @@ -835,6 +894,7 @@ Groovy: | ||||
|   color: "#e69f56" | ||||
|   extensions: | ||||
|   - .groovy | ||||
|   - .gradle | ||||
|   - .grt | ||||
|   - .gtpl | ||||
|   - .gvy | ||||
| @@ -857,7 +917,6 @@ HTML: | ||||
|   extensions: | ||||
|   - .html | ||||
|   - .htm | ||||
|   - .html.hl | ||||
|   - .st | ||||
|   - .xhtml | ||||
|  | ||||
| @@ -877,9 +936,7 @@ HTML+ERB: | ||||
|   - erb | ||||
|   extensions: | ||||
|   - .erb | ||||
|   - .erb.deface | ||||
|   - .html.erb | ||||
|   - .html.erb.deface | ||||
|   - .deface | ||||
|  | ||||
| HTML+PHP: | ||||
|   type: markup | ||||
| @@ -897,17 +954,14 @@ Haml: | ||||
|   type: markup | ||||
|   extensions: | ||||
|   - .haml | ||||
|   - .haml.deface | ||||
|   - .html.haml.deface | ||||
|   - .deface | ||||
|  | ||||
| Handlebars: | ||||
|   type: markup | ||||
|   lexer: Text only | ||||
|   lexer: Handlebars | ||||
|   extensions: | ||||
|   - .handlebars | ||||
|   - .hbs | ||||
|   - .html.handlebars | ||||
|   - .html.hbs | ||||
|  | ||||
| Harbour: | ||||
|   type: programming | ||||
| @@ -933,7 +987,7 @@ Haxe: | ||||
|  | ||||
| Hy: | ||||
|   type: programming | ||||
|   lexer: Clojure | ||||
|   lexer: Hy | ||||
|   ace_mode: clojure | ||||
|   color: "#7891b1" | ||||
|   extensions: | ||||
| @@ -945,6 +999,13 @@ IDL: | ||||
|   color: "#e3592c" | ||||
|   extensions: | ||||
|   - .pro | ||||
|   - .dlm | ||||
|  | ||||
| IGOR Pro: | ||||
|   type: programming | ||||
|   lexer: Igor | ||||
|   extensions: | ||||
|   - .ipf | ||||
|  | ||||
| INI: | ||||
|   type: data | ||||
| @@ -967,7 +1028,7 @@ Idris: | ||||
|  | ||||
| Inform 7: | ||||
|   type: programming | ||||
|   lexer: Text only | ||||
|   lexer: Inform 7 | ||||
|   wrap: true | ||||
|   extensions: | ||||
|   - .ni | ||||
| @@ -1019,6 +1080,7 @@ JSON: | ||||
|   searchable: false | ||||
|   extensions: | ||||
|   - .json | ||||
|   - .lock | ||||
|   - .sublime-keymap | ||||
|   - .sublime-mousemap | ||||
|   - .sublime-project | ||||
| @@ -1141,12 +1203,31 @@ LLVM: | ||||
|   extensions: | ||||
|   - .ll | ||||
|  | ||||
| LSL: | ||||
|   type: programming | ||||
|   lexer: LSL | ||||
|   ace_mode: lsl | ||||
|   extensions: | ||||
|   - .lsl | ||||
|   interpreters: | ||||
|   - lsl | ||||
|   color: '#3d9970' | ||||
|  | ||||
| LabVIEW: | ||||
|   type: programming | ||||
|   lexer: Text only | ||||
|   extensions: | ||||
|   - .lvproj | ||||
|  | ||||
| Lasso: | ||||
|   type: programming | ||||
|   lexer: Lasso | ||||
|   color: "#2584c3" | ||||
|   extensions: | ||||
|   - .lasso | ||||
|   - .las | ||||
|   - .lasso9 | ||||
|   - .ldml | ||||
|  | ||||
| Latte: | ||||
|   type: markup | ||||
| @@ -1225,6 +1306,14 @@ Logtalk: | ||||
|   - .lgt | ||||
|   - .logtalk | ||||
|  | ||||
| LookML: | ||||
|   type: programming | ||||
|   lexer: YAML | ||||
|   ace_mode: yaml | ||||
|   color: "#652B81" | ||||
|   extensions: | ||||
|   - .lookml | ||||
|  | ||||
| Lua: | ||||
|   type: programming | ||||
|   ace_mode: lua | ||||
| @@ -1232,6 +1321,7 @@ Lua: | ||||
|   extensions: | ||||
|   - .lua | ||||
|   - .nse | ||||
|   - .pd_lua | ||||
|   - .rbxs | ||||
|   interpreters: | ||||
|   - lua | ||||
| @@ -1297,7 +1387,7 @@ Mathematica: | ||||
|   - .mathematica | ||||
|   - .m | ||||
|   - .nb | ||||
|   lexer: Text only | ||||
|   lexer: Mathematica | ||||
|  | ||||
| Matlab: | ||||
|   type: programming | ||||
| @@ -1345,7 +1435,7 @@ MiniD: # Legacy | ||||
| Mirah: | ||||
|   type: programming | ||||
|   lexer: Ruby | ||||
|   search_term: ruby | ||||
|   search_term: mirah | ||||
|   color: "#c7a938" | ||||
|   extensions: | ||||
|   - .druby | ||||
| @@ -1377,6 +1467,7 @@ Myghty: | ||||
| NSIS: | ||||
|   extensions: | ||||
|   - .nsi | ||||
|   - .nsh | ||||
|  | ||||
| Nemerle: | ||||
|   type: programming | ||||
| @@ -1441,6 +1532,7 @@ OCaml: | ||||
|   color: "#3be133" | ||||
|   extensions: | ||||
|   - .ml | ||||
|   - .eliom | ||||
|   - .eliomi | ||||
|   - .ml4 | ||||
|   - .mli | ||||
| @@ -1461,6 +1553,7 @@ Objective-C: | ||||
|   - objc | ||||
|   extensions: | ||||
|   - .m | ||||
|   - .h | ||||
|  | ||||
| Objective-C++: | ||||
|   type: programming | ||||
| @@ -1492,6 +1585,13 @@ Opa: | ||||
|   extensions: | ||||
|   - .opa | ||||
|  | ||||
| Opal: | ||||
|   type: programming | ||||
|   color: "#f7ede0" | ||||
|   lexer: Text only | ||||
|   extensions: | ||||
|   - .opal | ||||
|  | ||||
| OpenCL: | ||||
|   type: programming | ||||
|   group: C | ||||
| @@ -1508,6 +1608,13 @@ OpenEdge ABL: | ||||
|   - abl | ||||
|   extensions: | ||||
|   - .p | ||||
|   - .cls | ||||
|  | ||||
| OpenSCAD: | ||||
|   type: programming | ||||
|   lexer: Text only | ||||
|   extensions: | ||||
|   - .scad | ||||
|  | ||||
| Org: | ||||
|   type: prose | ||||
| @@ -1546,6 +1653,7 @@ PHP: | ||||
|   - .php | ||||
|   - .aw | ||||
|   - .ctp | ||||
|   - .module | ||||
|   - .php3 | ||||
|   - .php4 | ||||
|   - .php5 | ||||
| @@ -1557,7 +1665,7 @@ PHP: | ||||
|  | ||||
| Pan: | ||||
|   type: programming | ||||
|   lexer: Text only | ||||
|   lexer: Pan | ||||
|   color: '#cc0000' | ||||
|   extensions: | ||||
|   - .pan | ||||
| @@ -1594,6 +1702,7 @@ Pascal: | ||||
|   extensions: | ||||
|   - .pas | ||||
|   - .dfm | ||||
|   - .dpr | ||||
|   - .lpr | ||||
|  | ||||
| Perl: | ||||
| @@ -1603,12 +1712,15 @@ Perl: | ||||
|   extensions: | ||||
|   - .pl | ||||
|   - .PL | ||||
|   - .cgi | ||||
|   - .fcgi | ||||
|   - .perl | ||||
|   - .ph | ||||
|   - .plx | ||||
|   - .pm | ||||
|   - .pod | ||||
|   - .psgi | ||||
|   - .t | ||||
|   interpreters: | ||||
|   - perl | ||||
|  | ||||
| @@ -1625,6 +1737,13 @@ Perl6: | ||||
|   - .pl6 | ||||
|   - .pm6 | ||||
|  | ||||
| PigLatin: | ||||
|   type: programming | ||||
|   color: "#fcd7de" | ||||
|   lexer: Text only | ||||
|   extensions: | ||||
|   - .pig | ||||
|  | ||||
| Pike: | ||||
|   type: programming | ||||
|   color: "#066ab2" | ||||
| @@ -1675,9 +1794,9 @@ Prolog: | ||||
|   type: programming | ||||
|   color: "#74283c" | ||||
|   extensions: | ||||
|   - .prolog | ||||
|   - .ecl | ||||
|   - .pl | ||||
|   - .ecl | ||||
|   - .prolog | ||||
|  | ||||
| Propeller Spin: | ||||
|   type: programming | ||||
| @@ -1777,7 +1896,7 @@ R: | ||||
|  | ||||
| RDoc: | ||||
|   type: prose | ||||
|   lexer: Text only | ||||
|   lexer: Rd | ||||
|   ace_mode: rdoc | ||||
|   wrap: true | ||||
|   extensions: | ||||
| @@ -1817,6 +1936,7 @@ Racket: | ||||
|   - .rkt | ||||
|   - .rktd | ||||
|   - .rktl | ||||
|   - .scrbl | ||||
|  | ||||
| Ragel in Ruby Host: | ||||
|   type: programming | ||||
| @@ -1886,7 +2006,10 @@ Ruby: | ||||
|   - .god | ||||
|   - .irbrc | ||||
|   - .mspec | ||||
|   - .pluginspec | ||||
|   - .podspec | ||||
|   - .rabl | ||||
|   - .rake | ||||
|   - .rbuild | ||||
|   - .rbw | ||||
|   - .rbx | ||||
| @@ -1931,6 +2054,14 @@ SCSS: | ||||
|   extensions: | ||||
|   - .scss | ||||
|  | ||||
| SQF: | ||||
|   type: programming | ||||
|   color: "#FFCB1F" | ||||
|   lexer: C++ | ||||
|   extensions: | ||||
|   - .sqf | ||||
|   - .hqf | ||||
|  | ||||
| SQL: | ||||
|   type: data | ||||
|   ace_mode: sql | ||||
| @@ -1960,6 +2091,7 @@ Sass: | ||||
|   group: CSS | ||||
|   extensions: | ||||
|   - .sass | ||||
|   - .scss | ||||
|  | ||||
| Scala: | ||||
|   type: programming | ||||
| @@ -1967,6 +2099,7 @@ Scala: | ||||
|   color: "#7dd3b0" | ||||
|   extensions: | ||||
|   - .scala | ||||
|   - .sbt | ||||
|   - .sc | ||||
|  | ||||
| Scaml: | ||||
| @@ -1982,6 +2115,7 @@ Scheme: | ||||
|   - .scm | ||||
|   - .sld | ||||
|   - .sls | ||||
|   - .sps | ||||
|   - .ss | ||||
|   interpreters: | ||||
|   - guile | ||||
| @@ -1993,6 +2127,8 @@ Scilab: | ||||
|   type: programming | ||||
|   extensions: | ||||
|   - .sci | ||||
|   - .sce | ||||
|   - .tst | ||||
|  | ||||
| Self: | ||||
|   type: programming | ||||
| @@ -2012,8 +2148,10 @@ Shell: | ||||
|   - zsh | ||||
|   extensions: | ||||
|   - .sh | ||||
|   - .bash | ||||
|   - .bats | ||||
|   - .tmux | ||||
|   - .zsh | ||||
|   interpreters: | ||||
|   - bash | ||||
|   - sh | ||||
| @@ -2080,6 +2218,7 @@ Standard ML: | ||||
|   extensions: | ||||
|   - .ML | ||||
|   - .fun | ||||
|   - .sig | ||||
|   - .sml | ||||
|  | ||||
| Stata: | ||||
| @@ -2160,10 +2299,13 @@ TeX: | ||||
|   extensions: | ||||
|   - .tex | ||||
|   - .aux | ||||
|   - .bbx | ||||
|   - .bib | ||||
|   - .cbx | ||||
|   - .cls | ||||
|   - .dtx | ||||
|   - .ins | ||||
|   - .lbx | ||||
|   - .ltx | ||||
|   - .mkii | ||||
|   - .mkiv | ||||
| @@ -2280,6 +2422,7 @@ Visual Basic: | ||||
|   extensions: | ||||
|   - .vb | ||||
|   - .bas | ||||
|   - .cls | ||||
|   - .frm | ||||
|   - .frx | ||||
|   - .vba | ||||
| @@ -2308,6 +2451,7 @@ XML: | ||||
|   - wsdl | ||||
|   extensions: | ||||
|   - .xml | ||||
|   - .ant | ||||
|   - .axml | ||||
|   - .ccxml | ||||
|   - .clixml | ||||
| @@ -2321,6 +2465,7 @@ XML: | ||||
|   - .fsproj | ||||
|   - .glade | ||||
|   - .grxml | ||||
|   - .ivy | ||||
|   - .jelly | ||||
|   - .kml | ||||
|   - .launch | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -36,6 +36,10 @@ | ||||
| # Bootstrap minified css and js | ||||
| - (^|/)bootstrap([^.]*)(\.min)?\.(js|css)$ | ||||
|  | ||||
| # Font Awesome | ||||
| - font-awesome.min.css | ||||
| - font-awesome.css | ||||
|  | ||||
| # Foundation css | ||||
| - foundation.min.css | ||||
| - foundation.css | ||||
| @@ -43,8 +47,17 @@ | ||||
| # Normalize.css | ||||
| - normalize.css | ||||
|  | ||||
| # Bourbon SCSS | ||||
| - (^|/)[Bb]ourbon/.*\.css$ | ||||
| - (^|/)[Bb]ourbon/.*\.scss$ | ||||
|  | ||||
| # Animate.css | ||||
| - animate.css | ||||
| - animate.min.css | ||||
|  | ||||
| # Vendored dependencies | ||||
| - thirdparty/ | ||||
| - third[-_]?party/ | ||||
| - 3rd[-_]?party/ | ||||
| - vendors?/ | ||||
| - extern(al)?/ | ||||
|  | ||||
| @@ -112,6 +125,10 @@ | ||||
| - (^|/)modernizr\-\d\.\d+(\.\d+)?(\.min)?\.js$ | ||||
| - (^|/)modernizr\.custom\.\d+\.js$ | ||||
|  | ||||
| # Knockout | ||||
| - (^|/)knockout-(\d+\.){3}(debug\.)?js$ | ||||
| - knockout-min.js | ||||
|  | ||||
| ## Python ## | ||||
|  | ||||
| # django | ||||
| @@ -198,6 +215,9 @@ | ||||
| - (^|/)cordova([^.]*)(\.min)?\.js$ | ||||
| - (^|/)cordova\-\d\.\d(\.\d)?(\.min)?\.js$ | ||||
|  | ||||
| # Foundation js | ||||
| - foundation(\..*)?\.js$ | ||||
|  | ||||
| # Vagrant | ||||
| - ^Vagrantfile$ | ||||
|  | ||||
|   | ||||
| @@ -1,3 +1,3 @@ | ||||
| module Linguist | ||||
|   VERSION = "3.0.3" | ||||
|   VERSION = "3.1.4" | ||||
| end | ||||
|   | ||||
							
								
								
									
										521
									
								
								samples/AGS Script/GlobalScript.asc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										521
									
								
								samples/AGS Script/GlobalScript.asc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,521 @@ | ||||
| // main global script file | ||||
|  | ||||
| // A function that initializes a bunch of stuff. | ||||
| function initialize_control_panel() {  | ||||
|   // Centre the control panel | ||||
|   gPanel.Centre();  | ||||
|   // Centre the Restart dialog as well | ||||
|   gRestartYN.Centre();  | ||||
|   if (!IsSpeechVoxAvailable()) {  | ||||
|     // If there is no speech-vox file, and therefore no speech, | ||||
|     // disable all the controls related with speech. | ||||
|     lblVoice.Visible = false;   | ||||
|     btnVoice.Visible = false;   | ||||
|     sldVoice.Visible = false; | ||||
|   } | ||||
|   else { | ||||
|     // If there *is*, then set it to voice and text. It's best to use | ||||
|     // both whenever possible, for the player's sake. | ||||
|     SetVoiceMode(eSpeechVoiceAndText);  | ||||
|     // And reflect this in the control panel. | ||||
|     btnVoice.Text = "Voice and Text";  | ||||
|   } | ||||
|   if (!System.SupportsGammaControl) { | ||||
|     // If we can't change the gamma settings, disable the relevant options. | ||||
|     sldGamma.Visible = false;  | ||||
|     lblGamma.Visible = false; | ||||
|   }  | ||||
|    | ||||
|   //And now, set all the defaults | ||||
|   System.Volume = 100; | ||||
|   sldAudio.Value = System.Volume; | ||||
|   SetGameSpeed(40); | ||||
|   sldSpeed.Value = 40; | ||||
|   if (IsSpeechVoxAvailable()) { | ||||
|      SetVoiceMode(eSpeechVoiceAndText); | ||||
|      btnVoice.Text = "Voice and Text"; | ||||
|      sldVoice.Value = 255; | ||||
|      SetSpeechVolume(255); | ||||
|   } | ||||
|   if (System.SupportsGammaControl) { | ||||
|     System.Gamma = 100; | ||||
|     sldGamma.Value = 100; | ||||
|   } | ||||
| } | ||||
|  | ||||
| // Called when the game starts, before the first room is loaded | ||||
| function game_start() {    | ||||
|   // Put the code all in a function and then just call the function.  | ||||
|   // It saves cluttering up places like game_start. | ||||
|   initialize_control_panel();  | ||||
|   // Use the KeyboardMovement module to, per default, replicate the standard | ||||
|   // keyboard movement of most Sierra games. See KeyboardMovement.txt for more info | ||||
|   KeyboardMovement.SetMode(eKeyboardMovement_Tapping);  | ||||
| } | ||||
|  | ||||
| function repeatedly_execute() { | ||||
|    | ||||
|   // Put here anything you want to happen every game cycle, even when | ||||
|   // the game is paused. This will not run when the game is blocked | ||||
|   // inside a command like a blocking Walk() | ||||
|    | ||||
|   if (IsGamePaused() == 1) return; | ||||
|  | ||||
|   // Put here anything you want to happen every game cycle, but not | ||||
|   // when the game is paused. | ||||
| } | ||||
|  | ||||
| function repeatedly_execute_always() { | ||||
|    | ||||
|   // Put anything you want to happen every game cycle, even | ||||
|   // when the game is blocked inside a command like a | ||||
|   // blocking Walk(). | ||||
|   // You cannot run blocking commands from this function. | ||||
|    | ||||
| } | ||||
|  | ||||
| function show_inventory_window ()  | ||||
| { | ||||
|   gInventory.Visible = true; | ||||
|   // switch to the Use cursor (to select items with) | ||||
|   mouse.Mode = eModeInteract; | ||||
|   // But, override the appearance to look like the arrow | ||||
|   mouse.UseModeGraphic(eModePointer); | ||||
| } | ||||
|  | ||||
| function show_save_game_dialog() | ||||
| { | ||||
|   gSaveGame.Visible = true; | ||||
|   // Get the list of save games | ||||
|   lstSaveGamesList.FillSaveGameList(); | ||||
|   if (lstSaveGamesList.ItemCount > 0) | ||||
|   { | ||||
|     // If there is at least one, set the default text | ||||
|     // to be the first game's name | ||||
|     txtNewSaveName.Text = lstSaveGamesList.Items[0]; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     // No save games yet, default empty text. | ||||
|     txtNewSaveName.Text = ""; | ||||
|   } | ||||
|   mouse.UseModeGraphic(eModePointer); | ||||
|   gIconbar.Visible = false; | ||||
| } | ||||
|  | ||||
| function show_restore_game_dialog() | ||||
| { | ||||
|   gRestoreGame.Visible = true; | ||||
|   lstRestoreGamesList.FillSaveGameList(); | ||||
|   mouse.UseModeGraphic(eModePointer); | ||||
|   gIconbar.Visible = false; | ||||
| } | ||||
|  | ||||
| function close_save_game_dialog() | ||||
| { | ||||
|   gSaveGame.Visible = false; | ||||
|   mouse.UseDefaultGraphic(); | ||||
|   gIconbar.Visible = true; | ||||
| } | ||||
|  | ||||
| function close_restore_game_dialog() | ||||
| { | ||||
|   gRestoreGame.Visible = false; | ||||
|   mouse.UseDefaultGraphic(); | ||||
|   gIconbar.Visible = true; | ||||
| } | ||||
|  | ||||
| // Called when a key is pressed. keycode holds the key's ASCII code | ||||
| function on_key_press(eKeyCode keycode) { | ||||
|   // The following is called before "if game is paused keycode=0", so | ||||
|   // it'll happen even when the game is paused. | ||||
|    | ||||
|   if ((keycode == eKeyEscape) && gRestartYN.Visible) { | ||||
|     //Use ESC to cancel restart. | ||||
|     gRestartYN.Visible = false;  | ||||
|     gIconbar.Visible = true; | ||||
|     // If the panel's not ON, then the player must have gotten here by tapping F9, | ||||
|     // therefore his cursor needs restoring. If the panel IS on, then it doesn't, | ||||
|     // because it's already a pointer. Get used to thinking like this!! | ||||
|     if (!gPanel.Visible) mouse.UseDefaultGraphic();  | ||||
|     return; | ||||
|   } | ||||
|   if ((keycode == eKeyEscape) && gPanel.Visible) { | ||||
|     // Use ESC to turn the panel off. | ||||
|     gPanel.Visible = false;  | ||||
|     mouse.UseDefaultGraphic(); | ||||
|     gIconbar.Visible = true; | ||||
|     return; | ||||
|   } | ||||
|   if ((keycode == eKeyEscape) && (gSaveGame.Visible)) | ||||
|   { | ||||
|     // Use ESC to close the save game dialog | ||||
|     close_save_game_dialog(); | ||||
|     return; | ||||
|   } | ||||
|   if ((keycode == eKeyEscape) && (gRestoreGame.Visible)) | ||||
|   { | ||||
|     // Use ESC to close the restore game dialog | ||||
|     close_restore_game_dialog(); | ||||
|     return; | ||||
|   } | ||||
|    | ||||
|   if (keycode == eKeyReturn) {  | ||||
|     // ENTER, in this case merely confirms restart | ||||
|     if (gRestartYN.Visible) RestartGame(); | ||||
|   } | ||||
|  | ||||
|   if (IsGamePaused() || (IsInterfaceEnabled() == 0)) | ||||
|   { | ||||
|     // If the game is paused with a modal GUI on the | ||||
|     // screen, or the player interface is disabled in | ||||
|     // a cut scene, ignore any keypresses. | ||||
|     return; | ||||
|   } | ||||
|  | ||||
|   // FUNCTION KEYS AND SYSTEM SHORTCUTS | ||||
|   if (keycode == eKeyEscape) { | ||||
|     // ESC | ||||
|     gPanel.Visible = true;  | ||||
|     gIconbar.Visible = false; | ||||
|     mouse.UseModeGraphic(eModePointer); | ||||
|   } | ||||
|   if (keycode == eKeyCtrlQ)  QuitGame(1);   // Ctrl-Q | ||||
|   if (keycode == eKeyF5) show_save_game_dialog();   // F5 | ||||
|   if (keycode == eKeyF7) show_restore_game_dialog();  // F7 | ||||
|   if (keycode == eKeyF9) { | ||||
|     // F9, asks the player to confirm restarting (so much better to always confirm first) | ||||
|     gRestartYN.Visible = true;   | ||||
|     gIconbar.Visible = false; | ||||
|     mouse.UseModeGraphic(eModePointer); | ||||
|   } | ||||
|   if (keycode == eKeyF12) SaveScreenShot("scrnshot.bmp");  // F12 | ||||
|   if (keycode == eKeyTab)   show_inventory_window();  // Tab, show inventory | ||||
|  | ||||
|   // GAME COMMAND SHORTCUTS | ||||
|   if (keycode == 'W') mouse.Mode=eModeWalkto; //Notice this alternate way to indicate keycodes. | ||||
|   if (keycode == 'L') mouse.Mode=eModeLookat; //Note that all we do here is set modes. | ||||
|   if (keycode == 'U') mouse.Mode=eModeInteract; //If you want something else to happen, such as GUI buttons highlighting, | ||||
|   if (keycode == 'T') mouse.Mode=eModeTalkto; //you'll need some more scripting done. | ||||
|   if (keycode == 'I') mouse.Mode=eModeUseinv; //But this will, as-is, give you some standard keyboard shortcuts your players will very much appreciate. | ||||
|  | ||||
|   // For extra cursor modes, such as pick up, feel free to add as you will. | ||||
|   // Uncomment the line below if you use the "Pick Up" mode. | ||||
|   //if (keycode == 'P' || keycode == 'G') mouse.Mode=eModePickup;  | ||||
|  | ||||
|   // DEBUG FUNCTIONS | ||||
|   if (keycode == eKeyCtrlS)  Debug(0,0);  // Ctrl-S, give all inventory | ||||
|   if (keycode == eKeyCtrlV)  Debug(1,0);  // Ctrl-V, version | ||||
|   if (keycode == eKeyCtrlA)  Debug(2,0);  // Ctrl-A, show walkable areas | ||||
|   if (keycode == eKeyCtrlX)  Debug(3,0);  // Ctrl-X, teleport to room | ||||
|   if (keycode == eKeyCtrlW && game.debug_mode)  | ||||
|     player.PlaceOnWalkableArea(); //Ctrl-W, move to walkable area  | ||||
| } | ||||
|  | ||||
|  | ||||
| function on_mouse_click(MouseButton button) { | ||||
|   // called when a mouse button is clicked. button is either LEFT or RIGHT | ||||
|   if (IsGamePaused() == 1) { | ||||
|     // Game is paused, so do nothing (ie. don't allow mouse click) | ||||
|   } | ||||
|   else if (button == eMouseLeft) { | ||||
|     ProcessClick(mouse.x, mouse.y, mouse.Mode ); | ||||
|   } | ||||
|   else if (button == eMouseRight || button == eMouseWheelSouth){ | ||||
|     // right-click our mouse-wheel down, so cycle cursor | ||||
|     mouse.SelectNextMode(); | ||||
|   } | ||||
|   else if (button == eMouseMiddle) {  | ||||
|     // Middle-button-click, default make character walk to clicked area (a little shortcut) | ||||
|     // Could have been just "player.Walk(mouse.x,mouse.y)", but it's best to | ||||
|     // leave our options open - what if you have a special script triggered | ||||
|     // on "walking" mode? | ||||
|     ProcessClick(mouse.x, mouse.y, eModeWalkto);  | ||||
|   } | ||||
|   else if (button == eMouseWheelNorth) {  | ||||
|     // Mouse-wheel up, cycle cursors  | ||||
|     // If mode isn't WALK, set the previous mode (notice usage of numbers instead | ||||
|     // of eNums, when it suits us)... | ||||
|     if (mouse.Mode>0) mouse.Mode=mouse.Mode-1;  | ||||
|     else  | ||||
|     {  | ||||
|       // ...but if it is WALK mode... | ||||
|       if (player.ActiveInventory!=null)  | ||||
|       { | ||||
|         //...and the player has a selected inventory item, set mouse mode to UseInv.  | ||||
|         mouse.Mode=eModeUseinv;  | ||||
|       } | ||||
|       else  | ||||
|       { | ||||
|         // If they don't, however, just set it to mode TALK (change this line if you add more cursor modes) | ||||
|         mouse.Mode=eModeTalkto;  | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| function interface_click(int interface, int button) { | ||||
|   // This function is obsolete, from 2.62 and earlier versions. | ||||
| } | ||||
|  | ||||
| function btnInvUp_Click(GUIControl *control, MouseButton button) { | ||||
|   invCustomInv.ScrollUp(); | ||||
| } | ||||
|  | ||||
| function btnInvDown_Click(GUIControl *control, MouseButton button) { | ||||
|   invCustomInv.ScrollDown(); | ||||
| } | ||||
|  | ||||
| function btnInvOK_Click(GUIControl *control, MouseButton button) { | ||||
| 	// They pressed the OK button, close the GUI | ||||
| 	gInventory.Visible = false; | ||||
| 	mouse.UseDefaultGraphic(); | ||||
| } | ||||
|  | ||||
| function btnInvSelect_Click(GUIControl *control, MouseButton button) { | ||||
|    | ||||
| 	// They pressed SELECT, so switch to the Get cursor | ||||
| 	mouse.Mode = eModeInteract; | ||||
| 	// But, override the appearance to look like the arrow | ||||
| 	mouse.UseModeGraphic(eModePointer); | ||||
| } | ||||
|  | ||||
| function btnIconInv_Click(GUIControl *control, MouseButton button) { | ||||
|    | ||||
|   show_inventory_window(); | ||||
| } | ||||
|  | ||||
| function btnIconCurInv_Click(GUIControl *control, MouseButton button) { | ||||
|    | ||||
|   if (player.ActiveInventory != null) | ||||
|     mouse.Mode = eModeUseinv; | ||||
| } | ||||
|  | ||||
| function btnIconSave_Click(GUIControl *control, MouseButton button)  | ||||
| { | ||||
|   show_save_game_dialog(); | ||||
| } | ||||
|  | ||||
| function btnIconLoad_Click(GUIControl *control, MouseButton button)  | ||||
| { | ||||
|   show_restore_game_dialog(); | ||||
| } | ||||
|  | ||||
| function btnIconExit_Click(GUIControl *control, MouseButton button) { | ||||
|    | ||||
|   QuitGame(1); | ||||
| } | ||||
|  | ||||
| function btnIconAbout_Click(GUIControl *control, MouseButton button) { | ||||
|    | ||||
|   gPanel.Visible=true; | ||||
|   gIconbar.Visible=false; | ||||
|   mouse.UseModeGraphic(eModePointer); | ||||
| } | ||||
|  | ||||
| function cEgo_Look() | ||||
| { | ||||
|   Display("Damn, I'm looking good!"); | ||||
| } | ||||
|  | ||||
| function cEgo_Interact() | ||||
| { | ||||
|   Display("You rub your hands up and down your clothes."); | ||||
| } | ||||
|  | ||||
| function cEgo_Talk() | ||||
| { | ||||
|   Display("Talking to yourself is a sign of madness!"); | ||||
| } | ||||
|  | ||||
| //START OF CONTROL PANEL FUNCTIONS | ||||
| function btnSave_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   gPanel.Visible = false; | ||||
|   mouse.UseDefaultGraphic(); | ||||
|   gIconbar.Visible = true; | ||||
|   Wait(1); | ||||
|   btnIconSave_Click(btnIconSave, eMouseLeft); | ||||
| } | ||||
|  | ||||
| function gControl_OnClick(GUI *theGui, MouseButton button) | ||||
| { | ||||
|  | ||||
| } | ||||
|  | ||||
| function btnAbout_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
| Display("Adventure Game Studio run-time engine default game."); | ||||
| } | ||||
|  | ||||
| function btnQuit_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   gPanel.Visible = false; | ||||
|   Wait(1); | ||||
|   QuitGame(1); | ||||
|   gPanel.Visible = true; | ||||
|   gIconbar.Visible = false; | ||||
|   mouse.UseModeGraphic(eModePointer); | ||||
| } | ||||
|  | ||||
| function btnLoad_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   gPanel.Visible = false; | ||||
|   mouse.UseDefaultGraphic(); | ||||
|   gIconbar.Visible = true; | ||||
|   Wait(1); | ||||
|   btnIconLoad_Click(btnIconLoad, eMouseLeft); | ||||
| } | ||||
|  | ||||
| function btnResume_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   gPanel.Visible = false; | ||||
|   mouse.UseDefaultGraphic(); | ||||
|   gIconbar.Visible = true; | ||||
| } | ||||
|  | ||||
| function sldAudio_OnChange(GUIControl *control) | ||||
| { | ||||
|   System.Volume = sldAudio.Value; | ||||
| } | ||||
|  | ||||
| function sldVoice_OnChange(GUIControl *control) | ||||
| { | ||||
|   // Sets voice volume. Note that we don't check for the existence of speech.vox -  | ||||
|   // we did that in game_start, so if it's not there the slider won't even be available. | ||||
|   SetSpeechVolume(sldVoice.Value);  | ||||
| } | ||||
|  | ||||
| function btnVoice_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   // Note that we don't check for the existence of speech.vox - we did that in game_start, | ||||
|   // so if it's not there the button won't even be available. | ||||
|   if (btnVoice.Text == "Voice and Text") {  | ||||
|     SetVoiceMode(eSpeechVoiceOnly);  | ||||
|     btnVoice.Text = "Voice only"; | ||||
|   } | ||||
|   else if (btnVoice.Text == "Voice only") { | ||||
|     SetVoiceMode(eSpeechTextOnly); | ||||
|     btnVoice.Text = "Text only"; | ||||
|   } | ||||
|   else if (btnVoice.Text == "Text only") { | ||||
|     SetVoiceMode(eSpeechVoiceAndText); | ||||
|     btnVoice.Text = "Voice and Text"; | ||||
|   } | ||||
| } | ||||
|  | ||||
| function sldGamma_OnChange(GUIControl *control) | ||||
| { | ||||
|   // Set the gamma. Note there's no need to check for anything else, as we ensured, | ||||
|   // in game_start, that the slider won't even appear if it's not possible to do this. | ||||
|   System.Gamma = sldGamma.Value;  | ||||
| } | ||||
|  | ||||
| function btnDefault_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   // Reset everything to default. You'll have to edit these as well as the sliders | ||||
|   // if you'd rather have different default parameters. | ||||
|   System.Volume = 100; | ||||
|   sldAudio.Value = System.Volume; | ||||
|   sldSpeed.Value = 40; | ||||
|   SetGameSpeed(40); | ||||
|   if (IsSpeechVoxAvailable()) { | ||||
|      SetVoiceMode(eSpeechVoiceAndText); | ||||
|      btnVoice.Text = "Voice and Text"; | ||||
|      sldVoice.Value = 255; | ||||
|      SetSpeechVolume(255); | ||||
|   } | ||||
|   if (System.SupportsGammaControl) { | ||||
|     System.Gamma = 100; | ||||
|     sldGamma.Value = 100; | ||||
|   } | ||||
| } | ||||
| //END OF CONTROL PANEL FUNCTIONS | ||||
|  | ||||
| function dialog_request(int param)  | ||||
| { | ||||
|   // This is used by the dialog text parser if you need to process | ||||
|   // text that the player types in to the parser. | ||||
|   // It is not used by default. | ||||
| } | ||||
|  | ||||
| function sldSpeed_OnChange(GUIControl *control) | ||||
| { | ||||
|   SetGameSpeed(sldSpeed.Value); | ||||
| } | ||||
|  | ||||
| function btnRestart_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   gRestartYN.Visible=true; | ||||
|   gIconbar.Visible=false; | ||||
| } | ||||
|  | ||||
| function btnRestartYes_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   RestartGame(); | ||||
| } | ||||
|  | ||||
| function btnRestartNo_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   gRestartYN.Visible = false; | ||||
|   gIconbar.Visible = true; | ||||
|   // If the panel's not ON, then the player must have gotten here by tapping F9, | ||||
|   // therefore his cursor needs restoring. If the panel IS on, then it doesn't, | ||||
|   // because it's already a pointer. Get used to thinking like this!! | ||||
|   if (!gPanel.Visible) mouse.UseDefaultGraphic();  | ||||
| } | ||||
|  | ||||
| function btnCancelSave_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   close_save_game_dialog(); | ||||
| } | ||||
|  | ||||
| function btnSaveGame_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   int gameSlotToSaveInto = lstSaveGamesList.ItemCount + 1; | ||||
|   int i = 0; | ||||
|   while (i < lstSaveGamesList.ItemCount) | ||||
|   { | ||||
|     if (lstSaveGamesList.Items[i] == txtNewSaveName.Text) | ||||
|     { | ||||
|       gameSlotToSaveInto = lstSaveGamesList.SaveGameSlots[i]; | ||||
|     } | ||||
|     i++; | ||||
|   } | ||||
|   SaveGameSlot(gameSlotToSaveInto, txtNewSaveName.Text); | ||||
|   close_save_game_dialog(); | ||||
| } | ||||
|  | ||||
| function btnCancelRestore_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   close_restore_game_dialog(); | ||||
| } | ||||
|  | ||||
| function btnRestoreGame_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   if (lstRestoreGamesList.SelectedIndex >= 0) | ||||
|   { | ||||
|     RestoreGameSlot(lstRestoreGamesList.SaveGameSlots[lstRestoreGamesList.SelectedIndex]); | ||||
|   } | ||||
|   close_restore_game_dialog(); | ||||
| } | ||||
|  | ||||
| function lstSaveGamesList_OnSelectionCh(GUIControl *control) | ||||
| { | ||||
|   txtNewSaveName.Text = lstSaveGamesList.Items[lstSaveGamesList.SelectedIndex]; | ||||
| } | ||||
|  | ||||
| function txtNewSaveName_OnActivate(GUIControl *control) | ||||
| { | ||||
|   // Pressing return in the text box simulates clicking the Save button | ||||
|   btnSaveGame_OnClick(control, eMouseLeft); | ||||
| } | ||||
|  | ||||
| function btnDeleteSave_OnClick(GUIControl *control, MouseButton button) | ||||
| { | ||||
|   if (lstSaveGamesList.SelectedIndex >= 0) | ||||
|   { | ||||
|     DeleteSaveSlot(lstSaveGamesList.SaveGameSlots[lstSaveGamesList.SelectedIndex]); | ||||
|     lstSaveGamesList.FillSaveGameList(); | ||||
|   } | ||||
| } | ||||
							
								
								
									
										4
									
								
								samples/AGS Script/GlobalScript.ash
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								samples/AGS Script/GlobalScript.ash
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | ||||
| // Main header script - this will be included into every script in | ||||
| // the game (local and global). Do not place functions here; rather, | ||||
| // place import definitions and #define names here to be used by all | ||||
| // scripts. | ||||
							
								
								
									
										216
									
								
								samples/AGS Script/KeyboardMovement_102.asc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										216
									
								
								samples/AGS Script/KeyboardMovement_102.asc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,216 @@ | ||||
| // Main script for module 'KeyboardMovement' | ||||
|  | ||||
| //**************************************************************************************************** | ||||
| // DEFINITIONS | ||||
| //**************************************************************************************************** | ||||
|  | ||||
| #define DISTANCE 10000// distance player walks in Tapping mode before he stops | ||||
|  | ||||
| enum KeyboardMovement_Directions { | ||||
| 	eKeyboardMovement_Stop,  | ||||
| 	eKeyboardMovement_DownLeft,  | ||||
| 	eKeyboardMovement_Down,  | ||||
| 	eKeyboardMovement_DownRight,  | ||||
| 	eKeyboardMovement_Left,  | ||||
| 	eKeyboardMovement_Right,  | ||||
| 	eKeyboardMovement_UpLeft,  | ||||
| 	eKeyboardMovement_Up,  | ||||
| 	eKeyboardMovement_UpRight | ||||
| }; | ||||
|  | ||||
| //**************************************************************************************************** | ||||
| // VARIABLES | ||||
| //**************************************************************************************************** | ||||
|  | ||||
| // keycodes as variables for future key customization functions (static variables?): | ||||
| int KeyboardMovement_KeyDown = 380; // down arrow | ||||
| int KeyboardMovement_KeyLeft = 375; // left arrow | ||||
| int KeyboardMovement_KeyRight = 377; // right arrow | ||||
| int KeyboardMovement_KeyUp = 372; // up arrow | ||||
| int KeyboardMovement_KeyDownRight = 381; // PgDn (numpad) | ||||
| int KeyboardMovement_KeyUpRight = 373; // PgUp (numpad) | ||||
| int KeyboardMovement_KeyDownLeft = 379; // End (numpad) | ||||
| int KeyboardMovement_KeyUpLeft = 371; // Home (numpad) | ||||
| int KeyboardMovement_KeyStop = 376; // 5 (numpad) | ||||
|  | ||||
| KeyboardMovement_Modes KeyboardMovement_Mode = eKeyboardMovement_None; // stores current keyboard control mode (disabled by default) | ||||
|  | ||||
| KeyboardMovement_Directions KeyboardMovement_CurrentDirection = eKeyboardMovement_Stop; // stores current walking direction of player character | ||||
|  | ||||
| //**************************************************************************************************** | ||||
| // USER FUNCTIONS | ||||
| //**************************************************************************************************** | ||||
|  | ||||
| //==================================================================================================== | ||||
|  | ||||
| static function KeyboardMovement::SetMode(KeyboardMovement_Modes mode) { | ||||
| 	KeyboardMovement_Mode = mode; | ||||
| } | ||||
|  | ||||
| //==================================================================================================== | ||||
|  | ||||
| // key customization functions here | ||||
|  | ||||
| //==================================================================================================== | ||||
|  | ||||
| //**************************************************************************************************** | ||||
| // EVENT HANDLER FUNCTIONS | ||||
| //**************************************************************************************************** | ||||
|  | ||||
| //==================================================================================================== | ||||
|  | ||||
| function repeatedly_execute() { | ||||
|  | ||||
| 	//-------------------------------------------------- | ||||
| 	// Pressing mode | ||||
| 	//-------------------------------------------------- | ||||
|  | ||||
| 	if ((IsGamePaused() == true) || (KeyboardMovement_Mode != eKeyboardMovement_Pressing) || (IsInterfaceEnabled() == false) || (player.on == false)) return 0; | ||||
| 	  // if game is paused, module or mode disabled, interface disabled or player character hidden, quit function | ||||
|  | ||||
| 	KeyboardMovement_Directions newdirection; // declare variable storing new direction | ||||
|  | ||||
| 	// get new direction: | ||||
| 	if ( ((IsKeyPressed(KeyboardMovement_KeyDown)) && (IsKeyPressed(KeyboardMovement_KeyRight))) || (IsKeyPressed(KeyboardMovement_KeyDownRight)) ) newdirection = eKeyboardMovement_DownRight; // if down&right arrows or PgDn (numeric pad) held down, set new direction to Down-Right | ||||
| 	else if ( ((IsKeyPressed(KeyboardMovement_KeyUp)) && (IsKeyPressed(KeyboardMovement_KeyRight))) || (IsKeyPressed(KeyboardMovement_KeyUpRight)) ) newdirection = eKeyboardMovement_UpRight; // up&right arrows or PgUp (numpad) | ||||
| 	else if ( ((IsKeyPressed(KeyboardMovement_KeyDown)) && (IsKeyPressed(KeyboardMovement_KeyLeft))) || (IsKeyPressed(KeyboardMovement_KeyDownLeft)) ) newdirection = eKeyboardMovement_DownLeft; // down&left arrows or End (numpad) | ||||
| 	else if ( ((IsKeyPressed(KeyboardMovement_KeyUp)) && (IsKeyPressed(KeyboardMovement_KeyLeft))) || (IsKeyPressed(KeyboardMovement_KeyUpLeft)) ) newdirection = eKeyboardMovement_UpLeft; // up&left arrows or Home (numpad) | ||||
| 	else if (IsKeyPressed(KeyboardMovement_KeyDown)) newdirection = eKeyboardMovement_Down; // down arrow | ||||
| 	else if (IsKeyPressed(KeyboardMovement_KeyLeft)) newdirection = eKeyboardMovement_Left; // left arrow | ||||
| 	else if (IsKeyPressed(KeyboardMovement_KeyRight)) newdirection = eKeyboardMovement_Right; // right arrow | ||||
| 	else if (IsKeyPressed(KeyboardMovement_KeyUp)) newdirection = eKeyboardMovement_Up; // up arrow | ||||
| 	else newdirection = eKeyboardMovement_Stop; // if none of the above held down, set it to stop player character | ||||
|  | ||||
| 	if (IsKeyPressed(KeyboardMovement_KeyStop)) newdirection = eKeyboardMovement_Stop; // if 5 (numeric pad) held down, stop player character, regardless of whether some of the above are held down | ||||
|  | ||||
| 	if (newdirection != KeyboardMovement_CurrentDirection) { // if new direction is different from current direction | ||||
|  | ||||
| 		if (newdirection == eKeyboardMovement_Stop) player.StopMoving(); // if new direction is the Stop command, stop movement of player character | ||||
| 		else { // if new direction is NOT the Stop command | ||||
|  | ||||
| 			int dx, dy; // declare variables storing new walk coordinates | ||||
| 			if (newdirection == eKeyboardMovement_DownRight) { | ||||
| 				dx = DISTANCE; | ||||
| 				dy = DISTANCE; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_UpRight) { | ||||
| 				dx = DISTANCE; | ||||
| 				dy = -DISTANCE; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_DownLeft) { | ||||
| 				dx = -DISTANCE; | ||||
| 				dy = DISTANCE; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_UpLeft) { | ||||
| 				dx = -DISTANCE; | ||||
| 				dy = -DISTANCE; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_Down) { | ||||
| 				dx = 0; | ||||
| 				dy = DISTANCE; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_Left) { | ||||
| 				dx = -DISTANCE; | ||||
| 				dy = 0; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_Right) { | ||||
| 				dx = DISTANCE; | ||||
| 				dy = 0; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_Up) { | ||||
| 				dx = 0; | ||||
| 				dy = -DISTANCE; | ||||
| 			} | ||||
|  | ||||
| 			player.WalkStraight(player.x + dx, player.y + dy, eNoBlock); // walk player character to the new coordinates | ||||
| 		} | ||||
| 		KeyboardMovement_CurrentDirection = newdirection; // update current direction to new direction | ||||
|  | ||||
| 	} | ||||
|  | ||||
| } | ||||
|  | ||||
| //==================================================================================================== | ||||
|  | ||||
| function on_key_press(int keycode) { | ||||
|  | ||||
| 	//-------------------------------------------------- | ||||
| 	// Tapping mode | ||||
| 	//-------------------------------------------------- | ||||
|  | ||||
| 	if ((IsGamePaused() == true) || (KeyboardMovement_Mode != eKeyboardMovement_Tapping) || (IsInterfaceEnabled() == false) || (player.on == false)) return 0; | ||||
| 	  // if game is paused, module or mode disabled, interface disabled or player character hidden, quit function | ||||
|  | ||||
| 	KeyboardMovement_Directions newdirection; // declare variable storing new direction | ||||
|  | ||||
| 	// get new direction: | ||||
| 	if (keycode == KeyboardMovement_KeyDownRight) newdirection = eKeyboardMovement_DownRight; // if down-right key pressed, set new direction to Down-Right | ||||
| 	else if (keycode == KeyboardMovement_KeyUpRight) newdirection = eKeyboardMovement_UpRight; | ||||
| 	else if (keycode == KeyboardMovement_KeyDownLeft) newdirection = eKeyboardMovement_DownLeft; | ||||
| 	else if (keycode == KeyboardMovement_KeyUpLeft) newdirection = eKeyboardMovement_UpLeft; | ||||
| 	else if (keycode == KeyboardMovement_KeyDown) newdirection = eKeyboardMovement_Down; | ||||
| 	else if (keycode == KeyboardMovement_KeyLeft) newdirection = eKeyboardMovement_Left; | ||||
| 	else if (keycode == KeyboardMovement_KeyRight) newdirection = eKeyboardMovement_Right; | ||||
| 	else if (keycode == KeyboardMovement_KeyUp) newdirection = eKeyboardMovement_Up; | ||||
| 	else if (keycode == KeyboardMovement_KeyStop) newdirection = eKeyboardMovement_Stop; // if stop key pressed, set to stop player character | ||||
|  | ||||
| 	if (newdirection != KeyboardMovement_CurrentDirection) { // if new direction is different from current direction | ||||
|  | ||||
| 		if (newdirection == eKeyboardMovement_Stop) player.StopMoving(); // if new direction is the Stop command, stop movement of player character | ||||
| 		else { // if new direction is NOT the Stop command | ||||
|  | ||||
| 			int dx, dy; // declare variables storing new walk coordinates | ||||
| 			if (newdirection == eKeyboardMovement_DownRight) { | ||||
| 				dx = DISTANCE; | ||||
| 				dy = DISTANCE; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_UpRight) { | ||||
| 				dx = DISTANCE; | ||||
| 				dy = -DISTANCE; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_DownLeft) { | ||||
| 				dx = -DISTANCE; | ||||
| 				dy = DISTANCE; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_UpLeft) { | ||||
| 				dx = -DISTANCE; | ||||
| 				dy = -DISTANCE; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_Down) { | ||||
| 				dx = 0; | ||||
| 				dy = DISTANCE; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_Left) { | ||||
| 				dx = -DISTANCE; | ||||
| 				dy = 0; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_Right) { | ||||
| 				dx = DISTANCE; | ||||
| 				dy = 0; | ||||
| 			} | ||||
| 			else if (newdirection == eKeyboardMovement_Up) { | ||||
| 				dx = 0; | ||||
| 				dy = -DISTANCE; | ||||
| 			} | ||||
|  | ||||
| 			player.WalkStraight(player.x + dx, player.y + dy, eNoBlock); // walk player character to the new coordinates | ||||
| 		} | ||||
| 		KeyboardMovement_CurrentDirection = newdirection; // update current direction to new direction | ||||
|  | ||||
| 	} | ||||
| 	else { // if new direction is same as current direction | ||||
| 		player.StopMoving(); // stop player character | ||||
| 		KeyboardMovement_CurrentDirection = eKeyboardMovement_Stop; // update current direction | ||||
| 	} | ||||
|  | ||||
| } | ||||
|  | ||||
| //==================================================================================================== | ||||
|  | ||||
| function on_event(EventType event, int data) { | ||||
|  | ||||
| 	if (event == eEventLeaveRoom) KeyboardMovement_CurrentDirection = eKeyboardMovement_Stop; | ||||
|  | ||||
| } | ||||
|  | ||||
| //==================================================================================================== | ||||
							
								
								
									
										13
									
								
								samples/AGS Script/KeyboardMovement_102.ash
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								samples/AGS Script/KeyboardMovement_102.ash
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| // Script header for module 'KeyboardMovement' | ||||
|  | ||||
| #define KeyboardMovement_VERSION 101 | ||||
|  | ||||
| enum KeyboardMovement_Modes { | ||||
| 	eKeyboardMovement_None,  | ||||
| 	eKeyboardMovement_Tapping,  | ||||
| 	eKeyboardMovement_Pressing | ||||
| }; | ||||
|  | ||||
| struct KeyboardMovement { | ||||
| 	import static function SetMode(KeyboardMovement_Modes mode); | ||||
| }; | ||||
							
								
								
									
										18
									
								
								samples/APL/DeepakChopra.apl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								samples/APL/DeepakChopra.apl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| ⍝   You can try this at http://tryapl.org/ | ||||
| ⍝   I can not explain how much I suddenly love this crypto-language | ||||
|  | ||||
|  | ||||
|  | ||||
| Starts     ← 'Experiential truth ' 'The physical world ' 'Non-judgment '       'Quantum physics ' | ||||
| Middles    ← 'nurtures an '        'projects onto '      'imparts reality to ' 'constructs with ' | ||||
| Qualifiers ← 'abundance of '       'the barrier of '     'self-righteous '     'potential ' | ||||
| Finishes   ← 'marvel.'             'choices.'            'creativity.'         'actions.' | ||||
|  | ||||
| rf     ← {(?⍴⍵)⊃⍵} | ||||
| erf    ← {rf ¨ ⍵} | ||||
|  | ||||
| deepak ← {erf Starts Middles Qualifiers Finishes} | ||||
|  | ||||
|  | ||||
|  | ||||
| deepak ⍬ | ||||
							
								
								
									
										304
									
								
								samples/Chapel/distributions.chpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										304
									
								
								samples/Chapel/distributions.chpl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,304 @@ | ||||
| // | ||||
| // Distributions Primer | ||||
| // | ||||
| // This primer demonstrates uses of some of Chapel's standard | ||||
| // distributions.  To use these distributions in a Chapel program, | ||||
| // the respective module must be used: | ||||
| // | ||||
| use BlockDist, CyclicDist, BlockCycDist, ReplicatedDist; | ||||
| use DimensionalDist2D, ReplicatedDim, BlockCycDim; | ||||
|  | ||||
| // | ||||
| // For each distribution, we'll create a distributed domain and array | ||||
| // and then initialize it just to give a brief flavor of how the | ||||
| // distribution maps across locales.  Running this example on 6 | ||||
| // locales does a nice job of illustrating the distribution | ||||
| // characteristics. | ||||
| // | ||||
| // All of these distributions support options to map to a different | ||||
| // virtual locale grid than the one used by default (a | ||||
| // multidimensional factoring of the built-in Locales array), as well | ||||
| // as to control the amount of parallelism used in data parallel | ||||
| // loops.  See the Standard Distributions chapter of the language spec | ||||
| // for more details. | ||||
| // | ||||
|  | ||||
| // | ||||
| // Make the program size configurable from the command line. | ||||
| // | ||||
| config const n = 8; | ||||
|  | ||||
| // | ||||
| // Declare a 2-dimensional domain Space that we will later use to | ||||
| // initialize the distributed domains. | ||||
| // | ||||
| const Space = {1..n, 1..n}; | ||||
|  | ||||
| // | ||||
| // The Block distribution distributes a bounding box from | ||||
| // n-dimensional space across the target locale array viewed as an | ||||
| // n-dimensional virtual locale grid.  The bounding box is blocked | ||||
| // into roughly equal portions across the locales.  Note that domains | ||||
| // declared over a Block distribution can also store indices outside | ||||
| // of the bounding box; the bounding box is merely used to compute | ||||
| // the blocking of space. | ||||
| // | ||||
| // In this example, we declare a 2-dimensional Block-distributed | ||||
| // domain BlockSpace and a Block-distributed array BA declared over | ||||
| // the domain. | ||||
| // | ||||
| const BlockSpace = Space dmapped Block(boundingBox=Space); | ||||
| var BA: [BlockSpace] int; | ||||
|  | ||||
| // | ||||
| // To illustrate how the index set is distributed across locales, | ||||
| // we'll use a forall loop to initialize each array element to the | ||||
| // locale ID that stores that index/element/iteration. | ||||
| // | ||||
| forall ba in BA do | ||||
|   ba = here.id; | ||||
|  | ||||
| // | ||||
| // Output the Block-distributed array to visually see how the elements | ||||
| // are partitioned across the locales. | ||||
| // | ||||
| writeln("Block Array Index Map"); | ||||
| writeln(BA); | ||||
| writeln(); | ||||
|  | ||||
| // | ||||
| // Most of Chapel's standard distributions support an optional | ||||
| // targetLocales argument that permits you to pass in your own | ||||
| // array of locales to be targeted.  In general, the targetLocales | ||||
| // argument should match the rank of the distribution.  So for | ||||
| // example, to map a Block to a [numLocales x 1] view of the | ||||
| // locale set, one could do something like this: | ||||
|  | ||||
| // | ||||
| // We start by creating our own array of the locale values.  Here | ||||
| // we use the standard array reshape function for convenience, | ||||
| // but more generally, this array could be accessed/assigned like any | ||||
| // other. | ||||
| // | ||||
|  | ||||
| var MyLocaleView = {0..#numLocales, 1..1}; | ||||
| var MyLocales: [MyLocaleView] locale = reshape(Locales, MyLocaleView); | ||||
|  | ||||
| // | ||||
| // Then we'll declare a distributed domain/array that targets | ||||
| // this view of the locales: | ||||
| //  | ||||
|  | ||||
| const BlockSpace2 = Space dmapped Block(boundingBox=Space, | ||||
|                                         targetLocales=MyLocales); | ||||
| var BA2: [BlockSpace2] int; | ||||
|  | ||||
| // | ||||
| // Then we'll do a similar computation as before to verify where | ||||
| // everything ended up: | ||||
| // | ||||
| forall ba in BA2 do | ||||
|   ba = here.id; | ||||
|  | ||||
| writeln("Block Array Index Map"); | ||||
| writeln(BA2); | ||||
| writeln(); | ||||
|  | ||||
|  | ||||
|  | ||||
| // | ||||
| // Next, we'll perform a similar computation for the Cyclic distribution. | ||||
| // Cyclic distributions start at a designated n-dimensional index and | ||||
| // distribute the n-dimensional space across an n-dimensional array | ||||
| // of locales in a round-robin fashion (in each dimension).  As with | ||||
| // the Block distribution, domains may be declared using the | ||||
| // distribution who have lower indices that the starting index; that | ||||
| // value should just be considered a parameterization of how the | ||||
| // distribution is defined. | ||||
| // | ||||
| const CyclicSpace = Space dmapped Cyclic(startIdx=Space.low); | ||||
| var CA: [CyclicSpace] int; | ||||
|  | ||||
| forall ca in CA do | ||||
|   ca = here.id; | ||||
|  | ||||
| writeln("Cyclic Array Index Map"); | ||||
| writeln(CA); | ||||
| writeln(); | ||||
|  | ||||
|  | ||||
| // | ||||
| // Next, we'll declare a Block-Cyclic distribution.  These | ||||
| // distributions also deal out indices in a round-robin fashion, | ||||
| // but rather than dealing out singleton indices, they deal out blocks | ||||
| // of indices.  Thus, the BlockCyclic distribution is parameterized | ||||
| // by a starting index (as with Cyclic) and a block size (per | ||||
| // dimension) specifying how large the chunks to be dealt out are. | ||||
| //  | ||||
| const BlkCycSpace = Space dmapped BlockCyclic(startIdx=Space.low,  | ||||
|                                               blocksize=(2, 3)); | ||||
| var BCA: [BlkCycSpace] int; | ||||
|  | ||||
| forall bca in BCA do | ||||
|   bca = here.id; | ||||
|  | ||||
| writeln("Block-Cyclic Array Index Map"); | ||||
| writeln(BCA); | ||||
| writeln(); | ||||
|  | ||||
|  | ||||
| // | ||||
| // The ReplicatedDist distribution is different: each of the | ||||
| // original domain's indices - and the corresponding array elements - | ||||
| // is replicated onto each locale. (Note: consistency among these | ||||
| // array replicands is NOT maintained automatically.) | ||||
| // | ||||
| // This replication is observable in some cases but not others, | ||||
| // as shown below. Note: this behavior may change in the future. | ||||
| // | ||||
| const ReplicatedSpace = Space dmapped ReplicatedDist(); | ||||
| var RA: [ReplicatedSpace] int; | ||||
|  | ||||
| // The replication is observable - this visits each replicand. | ||||
| forall ra in RA do | ||||
|   ra = here.id; | ||||
|  | ||||
| writeln("Replicated Array Index Map, ", RA.numElements, " elements total"); | ||||
| writeln(RA); | ||||
| writeln(); | ||||
|  | ||||
| // | ||||
| // The replication is observable when the replicated array is | ||||
| // on the left-hand side. If the right-hand side is not replicated, | ||||
| // it is copied into each replicand. | ||||
| // We illustrate this using a non-distributed array. | ||||
| // | ||||
| var A: [Space] int = [(i,j) in Space] i*100 + j; | ||||
| RA = A; | ||||
| writeln("Replicated Array after being array-assigned into"); | ||||
| writeln(RA); | ||||
| writeln(); | ||||
|  | ||||
| // | ||||
| // Analogously, each replicand will be visited and | ||||
| // other participated expressions will be computed on each locale | ||||
| // (a) when the replicated array is assigned a scalar: | ||||
| //       RA = 5; | ||||
| // (b) when it appears first in a zippered forall loop: | ||||
| //       forall (ra, a) in zip(RA, A) do ...; | ||||
| // (c) when it appears in a for loop: | ||||
| //       for ra in RA do ...; | ||||
| // | ||||
| // Zippering (RA,A) or (A,RA) in a 'for' loop will generate | ||||
| // an error due to their different number of elements. | ||||
|  | ||||
| // Let RA store the Index Map again, for the examples below. | ||||
| forall ra in RA do | ||||
|   ra = here.id; | ||||
|  | ||||
| // | ||||
| // Only the local replicand is accessed - replication is NOT observable | ||||
| // and consistency is NOT maintained - when: | ||||
| // (a) the replicated array is indexed - an individual element is read... | ||||
| // | ||||
| on Locales(0) do | ||||
|   writeln("on ", here, ": ", RA(Space.low)); | ||||
| on Locales(LocaleSpace.high) do | ||||
|   writeln("on ", here, ": ", RA(Space.low)); | ||||
| writeln(); | ||||
|  | ||||
| // ...or an individual element is written; | ||||
| on Locales(LocaleSpace.high) do | ||||
|   RA(Space.low) = 7777; | ||||
|  | ||||
| writeln("Replicated Array after being indexed into"); | ||||
| writeln(RA); | ||||
| writeln(); | ||||
|  | ||||
| // | ||||
| // (b) the replicated array is on the right-hand side of an assignment... | ||||
| // | ||||
| on Locales(LocaleSpace.high) do | ||||
|   A = RA + 4; | ||||
| writeln("Non-Replicated Array after assignment from Replicated Array + 4"); | ||||
| writeln(A); | ||||
| writeln(); | ||||
|  | ||||
| // | ||||
| // (c) ...or, generally, the replicated array or domain participates | ||||
| //     in a zippered forall loop, but not in the first position. | ||||
| //     The loop could look like: | ||||
| // | ||||
| //       forall (a, (i,j), ra) in (A, ReplicatedSpace, RA) do ...; | ||||
| // | ||||
|  | ||||
|  | ||||
| // | ||||
| // The DimensionalDist2D distribution lets us build a 2D distribution | ||||
| // as a composition of specifiers for individual dimensions. | ||||
| // Under such a "dimensional" distribution each dimension is handled | ||||
| // independently of the other. | ||||
| // | ||||
| // The dimension specifiers are similar to the corresponding multi-dimensional | ||||
| // distributions in constructor arguments and index-to-locale mapping rules. | ||||
| // However, instead of an array of locales, a specifier constructor | ||||
| // accepts just the number of locales that the indices in the corresponding | ||||
| // dimension will be distributed across. | ||||
| // | ||||
| // The DimensionalDist2D constructor requires: | ||||
| // * an [0..nl1-1, 0..nl2-1] array of locales, where | ||||
| //   nl1 and nl2 are the number of locales in each dimension, and | ||||
| // * two dimension specifiers, created for nl1 and nl2 locale counts, resp. | ||||
| // | ||||
| // Presently, the following dimension specifiers are available | ||||
| // (shown here with their constructor arguments): | ||||
| // | ||||
| // * ReplicatedDim(numLocales) | ||||
| // * BlockDim(numLocales, boundingBoxLow, boundingBoxHigh) | ||||
| // * BlockCyclicDim(lowIdx, blockSize, numLocales) | ||||
| // | ||||
|  | ||||
| // | ||||
| // The following example creates a dimensional distribution that | ||||
| // replicates over 2 locales (when available) in the first dimemsion | ||||
| // and distributes using block-cyclic distribution in the second dimension. | ||||
| // The example computes nl1 and nl2 and reshapes MyLocales correspondingly. | ||||
| // | ||||
|  | ||||
| var (nl1, nl2) = if numLocales == 1 then (1, 1) else (2, numLocales/2); | ||||
| MyLocaleView = {0..#nl1, 0..#nl2}; | ||||
| MyLocales = reshape(Locales[0..#nl1*nl2], MyLocaleView); | ||||
|  | ||||
| const DimReplicatedBlockcyclicSpace = Space | ||||
|   dmapped DimensionalDist2D(MyLocales, | ||||
|                             new ReplicatedDim(numLocales = nl1), | ||||
|                             new BlockCyclicDim(numLocales = nl2, | ||||
|                                                lowIdx = 1, blockSize = 2)); | ||||
|  | ||||
| var DRBA: [DimReplicatedBlockcyclicSpace] int; | ||||
|  | ||||
| // The ReplicatedDim specifier always accesses the local replicand. | ||||
| // (This differs from how the ReplicatedDist distribution works.) | ||||
| // | ||||
| // This example visits each replicand. The behavior is the same | ||||
| // regardless of the second index into MyLocales below. | ||||
|  | ||||
| for locId1 in 0..#nl1 do on MyLocales[locId1, 0] { | ||||
|  | ||||
|   forall drba in DRBA do | ||||
|     drba = here.id; | ||||
|  | ||||
|   writeln("Dimensional2D(Replicated,BlockCyclic) Array Index Map", | ||||
|           " from ", here); | ||||
|  | ||||
|   // Technicality: 'writeln(DRBA)' would read DRBA always on Locale 0. | ||||
|   // Since we want to see what DRBA contains on the current locale, | ||||
|   // we use 'Helper' that is mapped using the default distribution. | ||||
|   // 'Helper = DRBA' captures the view of DRBA on the current locale, | ||||
|   // which we then print out. | ||||
|  | ||||
|   const Helper: [Space] int = DRBA; | ||||
|   writeln(Helper); | ||||
|   writeln(); | ||||
|  | ||||
| } | ||||
							
								
								
									
										1
									
								
								samples/Chapel/hello.chpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								samples/Chapel/hello.chpl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| writeln("Hello, world!");    // print 'Hello, world!' to the console | ||||
							
								
								
									
										1692
									
								
								samples/Chapel/lulesh.chpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1692
									
								
								samples/Chapel/lulesh.chpl
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										147
									
								
								samples/Chapel/nbody.chpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										147
									
								
								samples/Chapel/nbody.chpl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,147 @@ | ||||
| /* The Computer Language Benchmarks Game | ||||
|    http://benchmarksgame.alioth.debian.org/ | ||||
|  | ||||
|    contributed by Albert Sidelnik | ||||
|    modified by Brad Chamberlain | ||||
| */ | ||||
|  | ||||
|  | ||||
| // | ||||
| // The number of timesteps to simulate; may be set via the command-line | ||||
| // | ||||
| config const n = 10000; | ||||
|  | ||||
| // | ||||
| // Constants representing pi, the solar mass, and the number of days per year | ||||
| // | ||||
| const pi = 3.141592653589793, | ||||
|       solarMass = 4 * pi**2, | ||||
|       daysPerYear = 365.24; | ||||
|  | ||||
| // | ||||
| // a record representing one of the bodies in the solar system | ||||
| // | ||||
| record body { | ||||
|   var pos: 3*real; | ||||
|   var v: 3*real; | ||||
|   var mass: real;  // does not change after it is set up | ||||
| } | ||||
|  | ||||
| // | ||||
| // the array of bodies that we'll be simulating | ||||
| // | ||||
| var bodies = [/* sun */ | ||||
|               new body(mass = solarMass), | ||||
|  | ||||
|               /* jupiter */ | ||||
|               new body(pos = ( 4.84143144246472090e+00, | ||||
|                               -1.16032004402742839e+00, | ||||
|                               -1.03622044471123109e-01), | ||||
|                          v = ( 1.66007664274403694e-03 * daysPerYear, | ||||
|                                7.69901118419740425e-03 * daysPerYear, | ||||
|                               -6.90460016972063023e-05 * daysPerYear), | ||||
|                       mass =   9.54791938424326609e-04 * solarMass), | ||||
|    | ||||
|               /* saturn */ | ||||
|               new body(pos = ( 8.34336671824457987e+00, | ||||
|                                4.12479856412430479e+00, | ||||
|                               -4.03523417114321381e-01), | ||||
|                          v = (-2.76742510726862411e-03 * daysPerYear, | ||||
|                                4.99852801234917238e-03 * daysPerYear, | ||||
|                                2.30417297573763929e-05 * daysPerYear), | ||||
|                       mass =   2.85885980666130812e-04 * solarMass), | ||||
|  | ||||
|               /* uranus */ | ||||
|               new body(pos = ( 1.28943695621391310e+01, | ||||
|                               -1.51111514016986312e+01, | ||||
|                               -2.23307578892655734e-01), | ||||
|                          v = ( 2.96460137564761618e-03 * daysPerYear, | ||||
|                                2.37847173959480950e-03 * daysPerYear, | ||||
|                               -2.96589568540237556e-05 * daysPerYear), | ||||
|                       mass =   4.36624404335156298e-05 * solarMass), | ||||
|  | ||||
|               /* neptune */ | ||||
|               new body(pos = ( 1.53796971148509165e+01, | ||||
|                               -2.59193146099879641e+01, | ||||
|                                1.79258772950371181e-01), | ||||
|                          v = ( 2.68067772490389322e-03 * daysPerYear, | ||||
|                                1.62824170038242295e-03 * daysPerYear, | ||||
|                               -9.51592254519715870e-05 * daysPerYear), | ||||
|                       mass =   5.15138902046611451e-05 * solarMass) | ||||
|               ]; | ||||
|  | ||||
| // | ||||
| // the number of bodies to be simulated | ||||
| // | ||||
| const numbodies = bodies.numElements; | ||||
|  | ||||
| // | ||||
| // The computation involves initializing the sun's velocity, | ||||
| // writing the initial energy, advancing the system through 'n' | ||||
| // timesteps, and writing the final energy. | ||||
| // | ||||
| proc main() { | ||||
|   initSun(); | ||||
|  | ||||
|   writef("%.9r\n", energy()); | ||||
|   for 1..n do | ||||
|     advance(0.01); | ||||
|   writef("%.9r\n", energy()); | ||||
| } | ||||
|  | ||||
| // | ||||
| // compute the sun's initial velocity | ||||
| // | ||||
| proc initSun() { | ||||
|   const p = + reduce (for b in bodies do (b.v * b.mass)); | ||||
|   bodies[1].v = -p / solarMass; | ||||
| } | ||||
|  | ||||
| // | ||||
| // advance the positions and velocities of all the bodies | ||||
| // | ||||
| proc advance(dt) { | ||||
|   for i in 1..numbodies { | ||||
|     for j in i+1..numbodies { | ||||
|       updateVelocities(bodies[i], bodies[j]); | ||||
|        | ||||
|       inline proc updateVelocities(ref b1, ref b2) { | ||||
|         const dpos = b1.pos - b2.pos, | ||||
|                mag = dt / sqrt(sumOfSquares(dpos))**3; | ||||
|          | ||||
|         b1.v -= dpos * b2.mass * mag; | ||||
|         b2.v += dpos * b1.mass * mag; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|    | ||||
|   for b in bodies do | ||||
|     b.pos += dt * b.v; | ||||
| } | ||||
|  | ||||
| // | ||||
| // compute the energy of the bodies | ||||
| // | ||||
| proc energy() { | ||||
|   var e = 0.0; | ||||
|    | ||||
|   for i in 1..numbodies { | ||||
|     const b1 = bodies[i]; | ||||
|      | ||||
|     e += 0.5 * b1.mass * sumOfSquares(b1.v); | ||||
|      | ||||
|     for j in i+1..numbodies { | ||||
|       const b2 = bodies[j]; | ||||
|        | ||||
|       e -= (b1.mass * b2.mass) / sqrt(sumOfSquares(b1.pos - b2.pos)); | ||||
|     } | ||||
|   } | ||||
|    | ||||
|   return e; | ||||
| } | ||||
|  | ||||
| // | ||||
| // a helper routine to compute the sum of squares of a 3-tuple's components | ||||
| // | ||||
| inline proc sumOfSquares(x) | ||||
|   return x(1)**2 + x(2)**2 + x(3)**2; | ||||
							
								
								
									
										145
									
								
								samples/Chapel/quicksort.chpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										145
									
								
								samples/Chapel/quicksort.chpl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,145 @@ | ||||
| // | ||||
| // An example of a parallel quick sort implementation that uses | ||||
| // "cobegin" to make each recursive call in parallel and "serial" to | ||||
| // limit the number of threads. | ||||
| // | ||||
|  | ||||
| use Random, Time; // for random number generation and the Timer class | ||||
|  | ||||
| var timer: Timer; // to time the sort | ||||
|  | ||||
| config var n: int = 2**15;      // the size of the array to be sorted | ||||
| config var thresh: int = 1;     // the recursive depth to serialize | ||||
| config var verbose: int = 0;    // print out this many elements in array | ||||
| config var timing: bool = true; // set timing to false to disable timer | ||||
|  | ||||
| var A: [1..n] real; // array of real numbers | ||||
|  | ||||
| // | ||||
| // initialize array with random numbers | ||||
| // | ||||
| fillRandom(A); | ||||
|  | ||||
| // | ||||
| // print out front of array if verbose flag is set | ||||
| // | ||||
| if verbose > 0 then | ||||
|   writeln("A[1..", verbose, "] = ", A[1..verbose]); | ||||
|  | ||||
| // | ||||
| // start timer, call parallel quick sort routine, stop timer | ||||
| // | ||||
| if timing then timer.start(); | ||||
| pqsort(A, thresh); | ||||
| if timing then timer.stop(); | ||||
|  | ||||
| // | ||||
| // report sort time | ||||
| // | ||||
| if timing then writeln("sorted in ", timer.elapsed(), " seconds"); | ||||
|  | ||||
| // | ||||
| // print out front of array if verbose flag is set | ||||
| //   values should now be in sorted order | ||||
| // | ||||
| if verbose > 0 then | ||||
|   writeln("A[1..", verbose, "] = ", A[1..verbose]); | ||||
|  | ||||
| // | ||||
| // verify that array is sorted or halt | ||||
| // | ||||
| for i in 2..n do | ||||
|   if A(i) < A(i-1) then | ||||
|     halt("A(", i-1, ") == ", A(i-1), " > A(", i, ") == ", A(i)); | ||||
|  | ||||
| writeln("verification success"); | ||||
|  | ||||
| // | ||||
| // pqsort -- parallel quick sort | ||||
| // | ||||
| //   arr: generic 1D array of values (real, int, ...) | ||||
| //   thresh: number of recursive calls to make before serializing | ||||
| //   low: lower bound of array to start sort at, defaults to whole array | ||||
| //   high: upper bound of array to stop sort at, defaults to whole array | ||||
| // | ||||
| proc pqsort(arr: [], | ||||
|            thresh: int, | ||||
|            low: int = arr.domain.low, | ||||
|            high: int = arr.domain.high) where arr.rank == 1 { | ||||
|  | ||||
|   // | ||||
|   // base case: arr[low..high] is small enough to bubble sort | ||||
|   // | ||||
|   if high - low < 8 { | ||||
|     bubbleSort(arr, low, high); | ||||
|     return; | ||||
|   } | ||||
|  | ||||
|   // | ||||
|   // determine pivot and partition arr[low..high] | ||||
|   // | ||||
|   const pivotVal = findPivot(); | ||||
|   const pivotLoc = partition(pivotVal); | ||||
|  | ||||
|   // | ||||
|   // make recursive calls to parallel quick sort each unsorted half of | ||||
|   // the array; if thresh is 0 or less, start executing conquer tasks | ||||
|   // serially | ||||
|   // | ||||
|   serial thresh <= 0 do cobegin { | ||||
|     pqsort(arr, thresh-1, low, pivotLoc-1); | ||||
|     pqsort(arr, thresh-1, pivotLoc+1, high); | ||||
|   } | ||||
|  | ||||
|   // | ||||
|   // findPivot -- helper routine to find pivot value using simple | ||||
|   //              median-of-3 method, returns pivot value | ||||
|   // | ||||
|   proc findPivot() { | ||||
|     const mid = low + (high-low+1) / 2; | ||||
|  | ||||
|     if arr(mid) < arr(low) then arr(mid) <=> arr(low); | ||||
|     if arr(high) < arr(low) then arr(high) <=> arr(low); | ||||
|     if arr(high) < arr(mid) then arr(high) <=> arr(mid); | ||||
|  | ||||
|     const pivotVal = arr(mid); | ||||
|     arr(mid) = arr(high-1); | ||||
|     arr(high-1) = pivotVal; | ||||
|  | ||||
|     return pivotVal; | ||||
|   } | ||||
|  | ||||
|   // | ||||
|   // partition -- helper routine to partition array such that all | ||||
|   //              values less than pivot are to its left and all | ||||
|   //              values greater than pivot are to its right, returns | ||||
|   //              pivot location | ||||
|   // | ||||
|   proc partition(pivotVal) { | ||||
|     var ilo = low, ihi = high-1; | ||||
|     while (ilo < ihi) { | ||||
|       do { ilo += 1; } while arr(ilo) < pivotVal; | ||||
|       do { ihi -= 1; } while pivotVal < arr(ihi); | ||||
|       if (ilo < ihi) { | ||||
|         arr(ilo) <=> arr(ihi); | ||||
|       } | ||||
|     } | ||||
|     arr(high-1) = arr(ilo); | ||||
|     arr(ilo) = pivotVal; | ||||
|     return ilo; | ||||
|   } | ||||
| } | ||||
|  | ||||
| // | ||||
| // bubbleSort -- bubble sort for base case of quick sort | ||||
| // | ||||
| //   arr: generic 1D array of values (real, int, ...) | ||||
| //   low: lower bound of array to start sort at | ||||
| //   high: upper bound of array to stop sort at | ||||
| // | ||||
| proc bubbleSort(arr: [], low: int, high: int) where arr.rank == 1 { | ||||
|   for i in low..high do | ||||
|     for j in low..high-1 do | ||||
|       if arr(j) > arr(j+1) then | ||||
|         arr(j) <=> arr(j+1); | ||||
| } | ||||
							
								
								
									
										146
									
								
								samples/Clojure/index.cljs.hl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								samples/Clojure/index.cljs.hl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,146 @@ | ||||
| ;; Copyright (c) Alan Dipert and Micha Niskin. All rights reserved. | ||||
| ;; The use and distribution terms for this software are covered by the | ||||
| ;; Eclipse Public License 1.0 (http://opensource.org/licenses/eclipse-1.0.php) | ||||
| ;; which can be found in the file epl-v10.html at the root of this distribution. | ||||
| ;; By using this software in any fashion, you are agreeing to be bound by | ||||
| ;; the terms of this license. | ||||
| ;; You must not remove this notice, or any other, from this software. | ||||
|  | ||||
| (page "index.html" | ||||
|   (:refer-clojure :exclude [nth]) | ||||
|   (:require | ||||
|    [tailrecursion.hoplon.reload        :refer [reload-all]] | ||||
|    [tailrecursion.hoplon.util          :refer [nth name pluralize]] | ||||
|    [tailrecursion.hoplon.storage-atom  :refer [local-storage]])) | ||||
|  | ||||
| ;; utility functions ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||
|  | ||||
| (declare route state editing) | ||||
|  | ||||
| (reload-all) | ||||
|  | ||||
| (def mapvi  (comp vec map-indexed)) | ||||
|  | ||||
| (defn dissocv [v i] | ||||
|   (let [z (- (dec (count v)) i)] | ||||
|     (cond (neg?  z) v | ||||
|           (zero? z) (pop v) | ||||
|           (pos?  z) (into (subvec v 0 i) (subvec v (inc i)))))) | ||||
|  | ||||
| (defn decorate [todo route editing i] | ||||
|   (let [{done? :completed text :text} todo] | ||||
|     (-> todo (assoc :editing (= editing i) | ||||
|                     :visible (and (not (empty? text)) | ||||
|                                   (or (= "#/" route) | ||||
|                                       (and (= "#/active" route) (not done?)) | ||||
|                                       (and (= "#/completed" route) done?))))))) | ||||
|  | ||||
| ;; persisted state cell (AKA: stem cell) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||
|  | ||||
| (def   state        (-> (cell []) (local-storage ::store))) | ||||
|  | ||||
| ;; local state cells ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||
|  | ||||
| (defc  loaded?      false) | ||||
| (defc  editing      nil) | ||||
| (def   route        (route-cell "#/")) | ||||
|  | ||||
| ;; formula cells (computed state) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||
|  | ||||
| (defc= completed    (filter :completed state)) | ||||
| (defc= active       (remove :completed state)) | ||||
| (defc= plural-item  (pluralize "item" (count active))) | ||||
| (defc= todos        (mapvi #(list %1 (decorate %2 route editing %1)) state)) | ||||
|  | ||||
| ;; state transition functions ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||
|  | ||||
| (defn  todo        [t]   {:completed false :text t}) | ||||
| (defn  destroy!    [i]   (swap! state dissocv i)) | ||||
| (defn  done!       [i v] (swap! state assoc-in [i :completed] v)) | ||||
| (defn  clear-done! [& _] (swap! state #(vec (remove :completed %)))) | ||||
| (defn  new!        [t]   (when (not (empty? t)) (swap! state conj (todo t)))) | ||||
| (defn  all-done!   [v]   (swap! state #(mapv (fn [x] (assoc x :completed v)) %))) | ||||
| (defn  editing!    [i v] (reset! editing (if v i nil))) | ||||
| (defn  text!       [i v] (if (empty? v) (destroy! i) (swap! state assoc-in [i :text] v))) | ||||
|  | ||||
| ;; page ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||
|  | ||||
| (html :lang "en" | ||||
|   (head | ||||
|     (meta :charset "utf-8") | ||||
|     (meta :http-equiv "X-UA-Compatible" :content "IE=edge,chrome=1") | ||||
|     (link :rel "stylesheet" :href "base.css") | ||||
|     (title "Hoplon • TodoMVC")) | ||||
|   (body | ||||
|     (noscript | ||||
|       (div :id "noscript" | ||||
|         (p "JavaScript is required to view this page."))) | ||||
|     (div | ||||
|       (section :id "todoapp" | ||||
|         (header :id "header" | ||||
|           (h1 "todos") | ||||
|           (form :on-submit #(do (new! (val-id :new-todo)) | ||||
|                                 (do! (by-id :new-todo) :value "")) | ||||
|             (input | ||||
|               :id "new-todo" | ||||
|               :type "text" | ||||
|               :autofocus true | ||||
|               :placeholder "What needs to be done?" | ||||
|               :on-blur #(do! (by-id :new-todo) :value "")))) | ||||
|         (section | ||||
|           :id "main" | ||||
|           :do-toggle (cell= (not (and (empty? active) (empty? completed)))) | ||||
|           (input | ||||
|             :id "toggle-all" | ||||
|             :type "checkbox" | ||||
|             :do-attr (cell= {:checked (empty? active)})  | ||||
|             :on-click #(all-done! (val-id :toggle-all))) | ||||
|           (label :for "toggle-all" | ||||
|             "Mark all as complete") | ||||
|           (ul :id "todo-list" | ||||
|             (loop-tpl | ||||
|               :reverse true | ||||
|               :bind-ids [done# edit#] | ||||
|               :bindings [[i {edit? :editing done? :completed todo-text :text show? :visible}] todos]  | ||||
|               (li | ||||
|                 :do-class (cell= {:completed done? :editing edit?})  | ||||
|                 :do-toggle show? | ||||
|                 (div :class "view" :on-dblclick #(editing! @i true) | ||||
|                   (input | ||||
|                     :id done#  | ||||
|                     :type "checkbox" | ||||
|                     :class "toggle" | ||||
|                     :do-attr (cell= {:checked done?})  | ||||
|                     :on-click #(done! @i (val-id done#))) | ||||
|                   (label (text "~{todo-text}")) | ||||
|                   (button | ||||
|                     :type "submit" | ||||
|                     :class "destroy" | ||||
|                     :on-click  #(destroy! @i))) | ||||
|                 (form :on-submit #(editing! @i false) | ||||
|                   (input | ||||
|                     :id edit# | ||||
|                     :type "text" | ||||
|                     :class "edit" | ||||
|                     :do-value todo-text | ||||
|                     :do-focus edit? | ||||
|                     :on-blur #(when @edit? (editing! @i false)) | ||||
|                     :on-change #(when @edit? (text! @i (val-id edit#))))))))) | ||||
|         (footer  | ||||
|           :id "footer" | ||||
|           :do-toggle (cell= (not (and (empty? active) (empty? completed)))) | ||||
|           (span :id "todo-count" | ||||
|             (strong (text "~(count active) ")) | ||||
|             (span (text "~{plural-item} left"))) | ||||
|           (ul :id "filters" | ||||
|             (li (a :href "#/"          :do-class (cell= {:selected (= "#/" route)})          "All")) | ||||
|             (li (a :href "#/active"    :do-class (cell= {:selected (= "#/active" route)})    "Active")) | ||||
|             (li (a :href "#/completed" :do-class (cell= {:selected (= "#/completed" route)}) "Completed"))) | ||||
|           (button | ||||
|             :type      "submit" | ||||
|             :id        "clear-completed" | ||||
|             :on-click  #(clear-done!) | ||||
|             (text "Clear completed (~(count completed))")))) | ||||
|       (footer :id "info"  | ||||
|         (p "Double-click to edit a todo") | ||||
|         (p "Part of " (a :href "http://github.com/tailrecursion/hoplon-demos/" "hoplon-demos"))))))  | ||||
							
								
								
									
										239
									
								
								samples/ColdFusion CFC/exampleScript.cfc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										239
									
								
								samples/ColdFusion CFC/exampleScript.cfc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,239 @@ | ||||
| /** | ||||
| ******************************************************************************** | ||||
| ContentBox - A Modular Content Platform | ||||
| Copyright 2012 by Luis Majano and Ortus Solutions, Corp | ||||
| www.gocontentbox.org | www.luismajano.com | www.ortussolutions.com | ||||
| ******************************************************************************** | ||||
| Apache License, Version 2.0 | ||||
|  | ||||
| Copyright Since [2012] [Luis Majano and Ortus Solutions,Corp] | ||||
|  | ||||
| Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| you may not use this file except in compliance with the License. | ||||
| You may obtain a copy of the License at | ||||
|  | ||||
| http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
| Unless required by applicable law or agreed to in writing, software | ||||
| distributed under the License is distributed on an "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| See the License for the specific language governing permissions and | ||||
| limitations under the License. | ||||
| ******************************************************************************** | ||||
| * A generic content service for content objects | ||||
| */ | ||||
| component extends="coldbox.system.orm.hibernate.VirtualEntityService" singleton{ | ||||
|  | ||||
| 	// DI | ||||
| 	property name="settingService"			inject="id:settingService@cb"; | ||||
| 	property name="cacheBox"				inject="cachebox"; | ||||
| 	property name="log"						inject="logbox:logger:{this}"; | ||||
| 	property name="customFieldService" 	 	inject="customFieldService@cb"; | ||||
| 	property name="categoryService" 	 	inject="categoryService@cb"; | ||||
| 	property name="commentService" 	 		inject="commentService@cb"; | ||||
| 	property name="contentVersionService"	inject="contentVersionService@cb"; | ||||
| 	property name="authorService"			inject="authorService@cb"; | ||||
| 	property name="populator"				inject="wirebox:populator"; | ||||
| 	property name="systemUtil"				inject="SystemUtil@cb"; | ||||
| 	 | ||||
| 	/* | ||||
| 	* Constructor | ||||
| 	* @entityName.hint The content entity name to bind this service to. | ||||
| 	*/ | ||||
| 	ContentService function init(entityName="cbContent"){ | ||||
| 		// init it | ||||
| 		super.init(entityName=arguments.entityName, useQueryCaching=true); | ||||
|  | ||||
| 		// Test scope coloring in pygments | ||||
| 		this.colorTestVar = "Just for testing pygments!"; | ||||
| 		cookie.colorTestVar = ""; | ||||
| 		client.colorTestVar = "" | ||||
| 		session.colorTestVar = ""; | ||||
| 		application.colorTestVar = ""; | ||||
|  | ||||
| 		return this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	* Clear all content caches | ||||
| 	* @async.hint Run it asynchronously or not, defaults to false | ||||
| 	*/ | ||||
| 	function clearAllCaches(boolean async=false){ | ||||
| 		var settings = settingService.getAllSettings(asStruct=true); | ||||
| 		// Get appropriate cache provider | ||||
| 		var cache = cacheBox.getCache( settings.cb_content_cacheName ); | ||||
| 		cache.clearByKeySnippet(keySnippet="cb-content",async=arguments.async); | ||||
| 		return this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	* Clear all page wrapper caches | ||||
| 	* @async.hint Run it asynchronously or not, defaults to false | ||||
| 	*/ | ||||
| 	function clearAllPageWrapperCaches(boolean async=false){ | ||||
| 		var settings = settingService.getAllSettings(asStruct=true); | ||||
| 		// Get appropriate cache provider | ||||
| 		var cache = cacheBox.getCache( settings.cb_content_cacheName ); | ||||
| 		cache.clearByKeySnippet(keySnippet="cb-content-pagewrapper",async=arguments.async); | ||||
| 		return this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	* Clear all page wrapper caches | ||||
| 	* @slug.hint The slug partial to clean on | ||||
| 	* @async.hint Run it asynchronously or not, defaults to false | ||||
| 	*/ | ||||
| 	function clearPageWrapperCaches(required any slug, boolean async=false){ | ||||
| 		var settings = settingService.getAllSettings(asStruct=true); | ||||
| 		// Get appropriate cache provider | ||||
| 		var cache = cacheBox.getCache( settings.cb_content_cacheName ); | ||||
| 		cache.clearByKeySnippet(keySnippet="cb-content-pagewrapper-#arguments.slug#",async=arguments.async); | ||||
| 		return this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	* Clear a page wrapper cache | ||||
| 	* @slug.hint The slug to clean | ||||
| 	* @async.hint Run it asynchronously or not, defaults to false | ||||
| 	*/ | ||||
| 	function clearPageWrapper(required any slug, boolean async=false){ | ||||
| 		var settings = settingService.getAllSettings(asStruct=true); | ||||
| 		// Get appropriate cache provider | ||||
| 		var cache = cacheBox.getCache( settings.cb_content_cacheName ); | ||||
| 		cache.clear("cb-content-pagewrapper-#arguments.slug#/"); | ||||
| 		return this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	* Searches published content with cool paramters, remember published content only | ||||
| 	* @searchTerm.hint The search term to search | ||||
| 	* @max.hint The maximum number of records to paginate | ||||
| 	* @offset.hint The offset in the pagination | ||||
| 	* @asQuery.hint Return as query or array of objects, defaults to array of objects | ||||
| 	* @sortOrder.hint The sorting of the search results, defaults to publishedDate DESC | ||||
| 	* @isPublished.hint Search for published, non-published or both content objects [true, false, 'all'] | ||||
| 	* @searchActiveContent.hint Search only content titles or both title and active content. Defaults to both. | ||||
| 	*/ | ||||
| 	function searchContent( | ||||
| 		any searchTerm="",  | ||||
| 		numeric max=0,  | ||||
| 		numeric offset=0,  | ||||
| 		boolean asQuery=false,  | ||||
| 		any sortOrder="publishedDate DESC",  | ||||
| 		any isPublished=true,  | ||||
| 		boolean searchActiveContent=true){ | ||||
|  | ||||
| 		var results = {}; | ||||
| 		var c = newCriteria(); | ||||
|  | ||||
| 		// only published content | ||||
| 		if( isBoolean( arguments.isPublished ) ){ | ||||
| 			// Published bit | ||||
| 			c.isEq( "isPublished", javaCast( "Boolean", arguments.isPublished ) ); | ||||
| 			// Published eq true evaluate other params | ||||
| 			if( arguments.isPublished ){ | ||||
| 				c.isLt("publishedDate", now() ) | ||||
| 				.$or( c.restrictions.isNull("expireDate"), c.restrictions.isGT("expireDate", now() ) ) | ||||
| 				.isEq("passwordProtection",""); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		// Search Criteria | ||||
| 		if( len( arguments.searchTerm ) ){ | ||||
| 			// like disjunctions | ||||
| 			c.createAlias("activeContent","ac"); | ||||
| 			// Do we search title and active content or just title? | ||||
| 			if( arguments.searchActiveContent ){ | ||||
| 				c.$or( c.restrictions.like("title","%#arguments.searchTerm#%"), | ||||
| 				  	  c.restrictions.like("ac.content", "%#arguments.searchTerm#%") ); | ||||
| 			} | ||||
| 			else{ | ||||
| 				c.like( "title", "%#arguments.searchTerm#%" );  | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		// run criteria query and projections count | ||||
| 		results.count = c.count( "contentID" ); | ||||
| 		results.content = c.resultTransformer( c.DISTINCT_ROOT_ENTITY ) | ||||
| 							.list(offset=arguments.offset, max=arguments.max, sortOrder=arguments.sortOrder, asQuery=arguments.asQuery); | ||||
| 	 | ||||
| 		return results; | ||||
| 	} | ||||
|  | ||||
| /********************************************* PRIVATE *********************************************/ | ||||
| 	 | ||||
|  | ||||
| 	/** | ||||
| 	* Update the content hits | ||||
| 	* @contentID.hint The content id to update | ||||
| 	*/ | ||||
| 	private function syncUpdateHits(required contentID){ | ||||
| 		var q = new Query(sql="UPDATE cb_content SET hits = hits + 1 WHERE contentID = #arguments.contentID#").execute(); | ||||
| 		return this; | ||||
| 	} | ||||
| 	 | ||||
| 	 | ||||
| 	private function closureTest(){ | ||||
| 		methodCall( | ||||
| 			param1, | ||||
| 			function( arg1, required arg2 ){ | ||||
| 				var settings = settingService.getAllSettings(asStruct=true); | ||||
| 				// Get appropriate cache provider | ||||
| 				var cache = cacheBox.getCache( settings.cb_content_cacheName ); | ||||
| 				cache.clear("cb-content-pagewrapper-#arguments.slug#/"); | ||||
| 				return this; | ||||
| 			}, | ||||
| 			param1 | ||||
| 		); | ||||
| 	} | ||||
| 	 | ||||
| 	private function StructliteralTest(){ | ||||
| 		return { | ||||
| 			foo = bar, | ||||
| 			brad = 'Wood', | ||||
| 			func = function( arg1, required arg2 ){ | ||||
| 				var settings = settingService.getAllSettings(asStruct=true); | ||||
| 				// Get appropriate cache provider | ||||
| 				var cache = cacheBox.getCache( settings.cb_content_cacheName ); | ||||
| 				cache.clear("cb-content-pagewrapper-#arguments.slug#/"); | ||||
| 				return this; | ||||
| 			}, | ||||
| 			array = [ | ||||
| 				1, | ||||
| 				2, | ||||
| 				3, | ||||
| 				4, | ||||
| 				5, | ||||
| 				'test', | ||||
| 				'testing', | ||||
| 				'testerton', | ||||
| 				{ | ||||
| 					foo = true, | ||||
| 					brad = false, | ||||
| 					wood = null | ||||
| 				} | ||||
| 			], | ||||
| 			last = "final" | ||||
| 		}; | ||||
| 	} | ||||
| 	 | ||||
| 	private function arrayliteralTest(){ | ||||
| 		return [ | ||||
| 			1, | ||||
| 			2, | ||||
| 			3, | ||||
| 			4, | ||||
| 			5, | ||||
| 			'test', | ||||
| 			'testing', | ||||
| 			'testerton', | ||||
| 			{ | ||||
| 				foo = true, | ||||
| 				brad = false, | ||||
| 				wood = null | ||||
| 			}, | ||||
| 			'testy-von-testavich' | ||||
| 		]; | ||||
| 	} | ||||
| 	 | ||||
| } | ||||
							
								
								
									
										18
									
								
								samples/ColdFusion CFC/exampleTag.cfc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								samples/ColdFusion CFC/exampleTag.cfc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| <cfcomponent> | ||||
| 	 | ||||
| 	<cffunction name="init" access="public" returntype="any"> | ||||
| 		<cfargument name="arg1" type="any" required="true"> | ||||
| 		<cfset this.myVariable = arguments.arg1> | ||||
|  | ||||
| 		<cfreturn this> | ||||
| 	</cffunction> | ||||
|  | ||||
| 	<cffunction name="testFunc" access="private" returntype="void"> | ||||
| 		<cfargument name="arg1" type="any" required="false"> | ||||
| 		 | ||||
| 		<cfif structKeyExists(arguments, "arg1")> | ||||
| 			<cfset writeoutput("Argument exists")> | ||||
| 		</cfif> | ||||
| 	</cffunction> | ||||
| 	 | ||||
| </cfcomponent> | ||||
							
								
								
									
										50
									
								
								samples/ColdFusion/example.cfm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								samples/ColdFusion/example.cfm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,50 @@ | ||||
| <!--- cfcomment ---> | ||||
| <!--- nested <!--- cfcomment ---> ---> | ||||
| <!--- multi-line | ||||
| nested | ||||
| <!--- | ||||
| cfcomment | ||||
| ---> | ||||
| ---> | ||||
| <!-- html comment --> | ||||
| <html> | ||||
| <head> | ||||
| <title>Date Functions</title> | ||||
| </head> | ||||
| <body> | ||||
| <cfset RightNow = Now()> | ||||
| <cfoutput> | ||||
|  #RightNow#<br /> | ||||
|  #DateFormat(RightNow)#<br /> | ||||
|  #DateFormat(RightNow,"mm/dd/yy")#<br /> | ||||
|  #TimeFormat(RightNow)#<br /> | ||||
|  #TimeFormat(RightNow,"hh:mm tt")#<br /> | ||||
|  #IsDate(RightNow)#<br /> | ||||
|  #IsDate("January 31, 2007")#<br /> | ||||
|  #IsDate("foo")#<br /> | ||||
|  #DaysInMonth(RightNow)# | ||||
| </cfoutput> | ||||
| <cfset x="x"> | ||||
| <cfset y="y"> | ||||
| <cfset z="z"> | ||||
| <cfoutput group="x"> | ||||
|     #x# | ||||
|     <cfoutput>#y#</cfoutput> | ||||
|     #z# | ||||
| </cfoutput> | ||||
| </body> | ||||
| </html> | ||||
|  | ||||
| <cfset person = "Paul"> | ||||
| <cfset greeting = "Hello #person#"> | ||||
|  | ||||
| <cfset greeting = "Hello" & " world!"> | ||||
| <cfset a = 5> | ||||
| <cfset b = 10> | ||||
| <cfset c = a^b> | ||||
| <cfset c = a MOD b> | ||||
| <cfset c = a / b> | ||||
| <cfset c = a * b> | ||||
| <cfset c = a + b> | ||||
| <cfset c = a - b> | ||||
| <!--- <!-- another <!--- nested --> ---> comment ---> | ||||
							
								
								
									
										580
									
								
								samples/Cycript/utils.cy
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										580
									
								
								samples/Cycript/utils.cy
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,580 @@ | ||||
| (function(utils) { | ||||
| 	// Load C functions declared in utils.loadFuncs | ||||
| 	var shouldLoadCFuncs = true; | ||||
| 	// Expose the C functions to cycript's global scope | ||||
| 	var shouldExposeCFuncs = true; | ||||
| 	// Expose C constants to cycript's global scope | ||||
| 	var shouldExposeConsts = true; | ||||
| 	// Expose functions defined here to cycript's global scope | ||||
| 	var shouldExposeFuncs = true; | ||||
| 	// Which functions to expose | ||||
| 	var funcsToExpose = ["exec", "include", "sizeof", "logify", "apply", "str2voidPtr", "voidPtr2str", "double2voidPtr", "voidPtr2double", "isMemoryReadable", "isObject", "makeStruct"]; | ||||
| 	 | ||||
| 	// C functions that utils.loadFuncs loads | ||||
| 	var CFuncsDeclarations = [ | ||||
| 		// <stdlib.h> | ||||
| 		"void *calloc(size_t num, size_t size)", | ||||
| 		// <string.h> | ||||
| 		"char *strcpy(char *restrict dst, const char *restrict src)", | ||||
| 		"char *strdup(const char *s1)", | ||||
| 		"void* memset(void* dest, int ch, size_t count)", | ||||
| 		// <stdio.h> | ||||
| 		"FILE *fopen(const char *, const char *)", | ||||
| 		"int fclose(FILE *)", | ||||
| 		"size_t fread(void *restrict, size_t, size_t, FILE *restrict)", | ||||
| 		"size_t fwrite(const void *restrict, size_t, size_t, FILE *restrict)", | ||||
| 		// <mach.h> | ||||
| 		"mach_port_t mach_task_self()", | ||||
| 		"kern_return_t task_for_pid(mach_port_name_t target_tport, int pid, mach_port_name_t *tn)", | ||||
| 		"kern_return_t mach_vm_protect(vm_map_t target_task, mach_vm_address_t address, mach_vm_size_t size, boolean_t set_maximum, vm_prot_t new_protection)", | ||||
| 		"kern_return_t mach_vm_write(vm_map_t target_task, mach_vm_address_t address, vm_offset_t data, mach_msg_type_number_t dataCnt)", | ||||
| 		"kern_return_t mach_vm_read(vm_map_t target_task, mach_vm_address_t address, mach_vm_size_t size, vm_offset_t *data, mach_msg_type_number_t *dataCnt)", | ||||
| 	]; | ||||
| 	 | ||||
| 	/* | ||||
| 		Replacement for eval that can handle @encode etc. | ||||
| 		 | ||||
| 		Usage: | ||||
| 			cy# utils.exec("@encode(void *(int, char))") | ||||
| 			@encode(void*(int,char)) | ||||
| 	*/ | ||||
| 	utils.exec = function(str) { | ||||
| 		var mkdir = @encode(int (const char *, int))(dlsym(RTLD_DEFAULT, "mkdir")); | ||||
| 		var tempnam = @encode(char *(const char *, const char *))(dlsym(RTLD_DEFAULT, "tempnam")); | ||||
| 		var fopen = @encode(void *(const char *, const char *))(dlsym(RTLD_DEFAULT, "fopen")); | ||||
| 		var fclose = @encode(int (void *))(dlsym(RTLD_DEFAULT, "fclose")); | ||||
| 		var fwrite = @encode(int (const char *, int, int, void *))(dlsym(RTLD_DEFAULT, "fwrite")); | ||||
| 		var symlink = @encode(int (const char *, const char *))(dlsym(RTLD_DEFAULT, "symlink")); | ||||
| 		var unlink = @encode(int (const char *))(dlsym(RTLD_DEFAULT, "unlink")); | ||||
| 		var getenv = @encode(const char *(const char *))(dlsym(RTLD_DEFAULT, "getenv")); | ||||
| 		var setenv = @encode(int (const char *, const char *, int))(dlsym(RTLD_DEFAULT, "setenv")); | ||||
| 		 | ||||
| 		var libdir = "/usr/lib/cycript0.9"; | ||||
| 		var dir = libdir + "/tmp"; | ||||
|  | ||||
| 		mkdir(dir, 0777); | ||||
| 		 | ||||
| 		// This is needed because tempnam seems to ignore the first argument on i386 | ||||
| 		var old_tmpdir = getenv("TMPDIR"); | ||||
| 		setenv("TMPDIR", dir, 1); | ||||
|  | ||||
| 		// No freeing :( | ||||
| 		var f = tempnam(dir, "exec-"); | ||||
| 		setenv("TMPDIR", old_tmpdir, 1); | ||||
| 		if(!f) { | ||||
| 			return false; | ||||
| 		} | ||||
|  | ||||
| 		symlink(f, f + ".cy"); | ||||
| 		 | ||||
| 		str = "exports.result = " + str; | ||||
|  | ||||
| 		var handle = fopen(f, "w"); | ||||
| 		fwrite(str, str.length, 1, handle); | ||||
| 		fclose(handle); | ||||
| 		 | ||||
| 		var r; | ||||
| 		var except = null; | ||||
| 		try { | ||||
| 			r = require(f.replace(libdir + "/", "")); | ||||
| 		} catch(e) { | ||||
| 			except = e; | ||||
| 		} | ||||
|  | ||||
| 		unlink(f + ".cy"); | ||||
| 		unlink(f); | ||||
| 		 | ||||
| 		if(except !== null) { | ||||
| 			throw except; | ||||
| 		} | ||||
|  | ||||
| 		return r.result; | ||||
| 	}; | ||||
| 	 | ||||
| 	/* | ||||
| 		Applies known typedefs | ||||
| 		Used in utils.include and utils.makeStruct | ||||
| 		 | ||||
| 		Usage: | ||||
| 			cy# utils.applyTypedefs("mach_vm_address_t") | ||||
| 			"uint64_t" | ||||
| 	*/ | ||||
| 	utils.applyTypedefs = function(str) { | ||||
| 		var typedefs = { | ||||
| 			"struct": "", | ||||
| 			"restrict": "", | ||||
| 			"FILE": "void", | ||||
| 			"size_t": "uint64_t", | ||||
| 			"uintptr_t": "unsigned long", | ||||
| 			"kern_return_t": "int", | ||||
| 			"mach_port_t": "unsigned int", | ||||
| 			"mach_port_name_t": "unsigned int", | ||||
| 			"vm_offset_t": "unsigned long", | ||||
| 			"vm_size_t": "unsigned long", | ||||
| 			"mach_vm_address_t": "uint64_t", | ||||
| 			"mach_vm_offset_t": "uint64_t", | ||||
| 			"mach_vm_size_t": "uint64_t", | ||||
| 			"vm_map_offset_t": "uint64_t", | ||||
| 			"vm_map_address_t": "uint64_t", | ||||
| 			"vm_map_size_t": "uint64_t", | ||||
| 			"mach_port_context_t": "uint64_t", | ||||
| 			"vm_map_t": "unsigned int", | ||||
| 			"boolean_t": "unsigned int", | ||||
| 			"vm_prot_t": "int", | ||||
| 			"mach_msg_type_number_t": "unsigned int", | ||||
| 			"cpu_type_t": "int", | ||||
| 			"cpu_subtype_t": "int", | ||||
| 			"cpu_threadtype_t": "int", | ||||
| 		}; | ||||
| 		 | ||||
| 		for(var k in typedefs) { | ||||
| 			str = str.replace(new RegExp("(\\s|\\*|,|\\(|^)" + k + "(\\s|\\*|,|\\)|$)", "g"), "$1" + typedefs[k] + "$2"); | ||||
| 		} | ||||
| 		 | ||||
| 		return str; | ||||
| 	}; | ||||
| 	 | ||||
| 	/* | ||||
| 		Parses a C function declaration and returns the function name and cycript type | ||||
| 		If load is true, tries to load it into cycript using utils.exec | ||||
| 		 | ||||
| 		Usage: | ||||
| 			cy# var str = "void *calloc(size_t num, size_t size)"; | ||||
| 			"void *calloc(size_t num, size_t size)" | ||||
| 			cy# utils.include(str) | ||||
| 			["calloc","@encode(void *(uint64_t num,  uint64_t size))(140735674376857)"] | ||||
| 			cy# var ret = utils.include(str, true) | ||||
| 			["calloc",0x7fff93e0e299] | ||||
| 			cy# ret[1].type | ||||
| 			@encode(void*(unsigned long long int,unsigned long long int)) | ||||
| 			cy# ret[1](100, 1) | ||||
| 			0x100444100 | ||||
| 	*/ | ||||
| 	utils.include = function(str, load) { | ||||
| 		var re = /^\s*([^(]*(?:\s+|\*))(\w*)\s*\(([^)]*)\)\s*;?\s*$/; | ||||
| 		var match = re.exec(str); | ||||
| 		if(!match) { | ||||
| 			return -1; | ||||
| 		} | ||||
| 		var rType = utils.applyTypedefs(match[1]); | ||||
| 		var name = match[2]; | ||||
| 		var args = match[3]; | ||||
|  | ||||
| 		var argsRe = /([^,]+)(?:,|$)/g; | ||||
| 		var argsTypes = []; | ||||
| 		while((match = argsRe.exec(args)) !== null) { | ||||
| 			var type = utils.applyTypedefs(match[1]); | ||||
| 			argsTypes.push(type); | ||||
| 		} | ||||
| 		 | ||||
| 		var encodeString = "@encode("; | ||||
| 		encodeString += rType + "("; | ||||
| 		encodeString += argsTypes.join(", ") + "))"; | ||||
|  | ||||
| 		var fun = dlsym(RTLD_DEFAULT, name); | ||||
| 		if(fun !== null) { | ||||
| 			encodeString += "(" + fun + ")"; | ||||
| 			if(load) { | ||||
| 				return [name, utils.exec(encodeString)]; | ||||
| 			} | ||||
| 		} else if(load) { | ||||
| 			throw "Function couldn't be found with dlsym!"; | ||||
| 		} | ||||
|  | ||||
| 		return [name, encodeString]; | ||||
| 	}; | ||||
| 	 | ||||
| 	/* | ||||
| 		Loads the function declaration in the defs array using utils.exec and exposes to cycript's global scope | ||||
| 		Is automatically called if shouldLoadCFuncs is true | ||||
| 	*/ | ||||
| 	utils.funcs = {}; | ||||
| 	utils.loadfuncs = function(expose) { | ||||
| 		for(var i = 0; i < CFuncsDeclarations.length; i++) { | ||||
| 			try { | ||||
| 				var o = utils.include(CFuncsDeclarations[i], true); | ||||
| 				utils.funcs[o[0]] = o[1]; | ||||
| 				if(expose) { | ||||
| 					Cycript.all[o[0]] = o[1]; | ||||
| 				} | ||||
| 			} catch(e) { | ||||
| 				system.print("Failed to load function: " + i); | ||||
| 				try { | ||||
| 					system.print(utils.include(CFuncsDeclarations[i])); | ||||
| 				} catch(e2) { | ||||
| 					 | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	}; | ||||
| 	 | ||||
| 	/* | ||||
| 		Calculates the size of a type like the C operator sizeof | ||||
| 		 | ||||
| 		Usage: | ||||
| 			cy# utils.sizeof(int) | ||||
| 			4 | ||||
| 			cy# utils.sizeof(@encode(void *)) | ||||
| 			8 | ||||
| 			cy# utils.sizeof("mach_vm_address_t") | ||||
| 			8 | ||||
| 	*/ | ||||
| 	utils.sizeof = function(type) { | ||||
| 		if(typeof type === "string") { | ||||
| 			type = utils.applyTypedefs(type); | ||||
| 			type = utils.exec("@encode(" + type + ")"); | ||||
| 		} | ||||
| 		 | ||||
| 		// (const) char * has "infinite" preceision | ||||
| 		if(type.toString().slice(-1) === "*") { | ||||
| 			return utils.sizeof(@encode(void *)); | ||||
| 		} | ||||
| 		 | ||||
| 		// float and double | ||||
| 		if(type.toString() === @encode(float).toString()) { | ||||
| 			return 4; | ||||
| 		} else if (type.toString() === @encode(double).toString()) { | ||||
| 			return 8; | ||||
| 		} | ||||
|  | ||||
| 		var typeInstance = type(0); | ||||
| 		 | ||||
| 		if(typeInstance instanceof Object) { | ||||
| 			// Arrays | ||||
| 			if("length" in typeInstance) { | ||||
| 				return typeInstance.length * utils.sizeof(typeInstance.type); | ||||
| 			} | ||||
| 			 | ||||
| 			// Structs | ||||
| 			if(typeInstance.toString() === "[object Struct]") { | ||||
| 				var typeStr = type.toString(); | ||||
| 				var arrayTypeStr = "[2" + typeStr + "]"; | ||||
| 				var arrayType = new Type(arrayTypeStr); | ||||
| 				 | ||||
| 				var arrayInstance = new arrayType; | ||||
| 				 | ||||
| 				return @encode(void *)(&(arrayInstance[1])) - @encode(void *)(&(arrayInstance[0])); | ||||
| 			} | ||||
| 		} | ||||
| 		 | ||||
| 		for(var i = 0; i < 5; i++) { | ||||
| 			var maxSigned = Math.pow(2, 8 * Math.pow(2, i) - 1) - 1; | ||||
| 			if(i === 3) { | ||||
| 				// Floating point fix ;^) | ||||
| 				maxSigned /= 1000; | ||||
| 			} | ||||
|  | ||||
| 			// can't use !== or sizeof(void *) === 0.5 | ||||
| 			if(type(maxSigned) != maxSigned) { | ||||
| 				return Math.pow(2, i - 1); | ||||
| 			} | ||||
| 		} | ||||
| 	}; | ||||
| 	 | ||||
| 	/* | ||||
| 		Logs a specific message sent to an instance of a class like logify.pl in theos | ||||
| 		Requires Cydia Substrate (com.saurik.substrate.MS) and NSLog (org.cycript.NSLog) modules | ||||
| 		Returns the old message returned by MS.hookMessage (Note: this is not just the old message!) | ||||
| 		 | ||||
| 		Usage: | ||||
| 			cy# var oldm = utils.logify(objc_getMetaClass(NSNumber), @selector(numberWithDouble:)) | ||||
| 			... | ||||
| 			cy# var n = [NSNumber numberWithDouble:1.5] | ||||
| 			2014-07-28 02:26:39.805 cycript[71213:507] +[<NSNumber: 0x10032d0c4> numberWithDouble:1.5] | ||||
| 			2014-07-28 02:26:39.806 cycript[71213:507]  = 1.5 | ||||
| 			@1.5 | ||||
| 	*/ | ||||
| 	utils.logify = function(cls, sel) { | ||||
| 		@import com.saurik.substrate.MS; | ||||
| 		@import org.cycript.NSLog; | ||||
| 		 | ||||
| 		var oldm = {}; | ||||
| 		 | ||||
| 		MS.hookMessage(cls, sel, function() { | ||||
| 			var args = [].slice.call(arguments); | ||||
| 			 | ||||
| 			var selFormat = sel.toString().replace(/:/g, ":%@ ").trim(); | ||||
| 			var logFormat = "%@[<%@: 0x%@> " + selFormat + "]"; | ||||
| 			 | ||||
| 			var standardArgs = [logFormat, class_isMetaClass(cls)? "+": "-", cls.toString(), (&this).valueOf().toString(16)]; | ||||
| 			var logArgs = standardArgs.concat(args); | ||||
| 			 | ||||
| 			NSLog.apply(null, logArgs); | ||||
| 			 | ||||
| 			var r = oldm->apply(this, arguments); | ||||
| 			 | ||||
| 			if(r !== undefined) { | ||||
| 				NSLog(" = %@", r); | ||||
| 			} | ||||
| 			 | ||||
| 			return r; | ||||
| 		}, oldm); | ||||
| 		 | ||||
| 		return oldm; | ||||
| 	}; | ||||
| 	 | ||||
| 	/* | ||||
| 		Calls a C function by providing its name and arguments | ||||
| 		Doesn't support structs | ||||
| 		Return value is always a void pointer | ||||
| 		 | ||||
| 		Usage: | ||||
| 			cy# utils.apply("printf", ["%s %.3s, %d -> %c, float: %f\n", "foo", "barrrr", 97, 97, 1.5]) | ||||
| 			foo bar, 97 -> a, float: 1.500000 | ||||
| 			0x22 | ||||
| 	*/ | ||||
| 	utils.apply = function(fun, args) { | ||||
| 		if(!(args instanceof Array)) { | ||||
| 			throw "Args needs to be an array!"; | ||||
| 		} | ||||
| 		 | ||||
| 		var argc = args.length; | ||||
| 		var voidPtr = @encode(void *); | ||||
| 		var argTypes = []; | ||||
| 		for(var i = 0; i < argc; i++) { | ||||
| 			var argType = voidPtr; | ||||
| 			 | ||||
| 			var arg = args[i]; | ||||
| 			if(typeof arg === "string") { | ||||
| 				argType = @encode(char *); | ||||
| 			} | ||||
| 			if(typeof arg === "number" && arg % 1 !== 0) { | ||||
| 				argType = @encode(double); | ||||
| 			} | ||||
| 			 | ||||
| 			argTypes.push(argType); | ||||
| 		} | ||||
| 		 | ||||
| 		var type = voidPtr.functionWith.apply(voidPtr, argTypes); | ||||
| 		 | ||||
| 		if(typeof fun === "string") { | ||||
| 			fun = dlsym(RTLD_DEFAULT, fun); | ||||
| 		} | ||||
| 		 | ||||
| 		if(!fun) { | ||||
| 			throw "Function not found!"; | ||||
| 		} | ||||
|  | ||||
| 		return type(fun).apply(null, args); | ||||
| 	}; | ||||
| 	 | ||||
| 	/* | ||||
| 		Converts a string (char *) to a void pointer (void *) | ||||
| 		You can't cast to strings to void pointers and vice versa in cycript. Blame saurik. | ||||
| 		 | ||||
| 		Usage: | ||||
| 			cy# var voidPtr = utils.str2voidPtr("foobar") | ||||
| 			0x100331590 | ||||
| 			cy# utils.voidPtr2str(voidPtr) | ||||
| 			"foobar" | ||||
| 	*/ | ||||
| 	utils.str2voidPtr = function(str) { | ||||
| 		var strdup = @encode(void *(char *))(dlsym(RTLD_DEFAULT, "strdup")); | ||||
| 		return strdup(str); | ||||
| 	}; | ||||
| 	 | ||||
| 	/* | ||||
| 		The inverse function of str2voidPtr | ||||
| 	*/ | ||||
| 	utils.voidPtr2str = function(voidPtr) { | ||||
| 		var strdup = @encode(char *(void *))(dlsym(RTLD_DEFAULT, "strdup")); | ||||
| 		return strdup(voidPtr); | ||||
| 	}; | ||||
| 	 | ||||
| 	/* | ||||
| 		Converts a double into a void pointer | ||||
| 		This can be used to view the binary representation of a floating point number | ||||
| 		 | ||||
| 		Usage: | ||||
| 			cy# var n = utils.double2voidPtr(-1.5) | ||||
| 			0xbff8000000000000 | ||||
| 			cy# utils.voidPtr2double(n) | ||||
| 			-1.5 | ||||
| 	*/ | ||||
| 	utils.double2voidPtr = function(n) { | ||||
| 		var doublePtr = new double; | ||||
| 		*doublePtr = n; | ||||
| 		 | ||||
| 		var voidPtrPtr = @encode(void **)(doublePtr); | ||||
| 		 | ||||
| 		return *voidPtrPtr; | ||||
| 	}; | ||||
| 	 | ||||
| 	/* | ||||
| 		The inverse function of double2voidPtr | ||||
| 	*/ | ||||
| 	utils.voidPtr2double = function(voidPtr) { | ||||
| 		var voidPtrPtr = new @encode(void **); | ||||
| 		*voidPtrPtr = voidPtr; | ||||
| 		 | ||||
| 		var doublePtr = @encode(double *)(voidPtrPtr); | ||||
| 		 | ||||
| 		return *doublePtr; | ||||
| 	}; | ||||
| 	 | ||||
| 	/* | ||||
| 		Determines in a safe way if a memory location is readable | ||||
| 		 | ||||
| 		Usage: | ||||
| 			cy# utils.isMemoryReadable(0) | ||||
| 			false | ||||
| 			cy# utils.isMemoryReadable(0x1337) | ||||
| 			false | ||||
| 			cy# utils.isMemoryReadable(NSObject) | ||||
| 			true | ||||
| 			cy# var a = malloc(100); utils.isMemoryReadable(a) | ||||
| 			true | ||||
| 	*/ | ||||
| 	utils.isMemoryReadable = function(ptr) { | ||||
| 		if(typeof ptr === "string") { | ||||
| 			return true; | ||||
| 		} | ||||
| 		 | ||||
| 		var fds = new @encode(int [2]); | ||||
| 		utils.apply("pipe", [fds]); | ||||
| 		var result = utils.apply("write", [fds[1], ptr, 1]) == 1; | ||||
| 		 | ||||
| 		utils.apply("close", [fds[0]]); | ||||
| 		utils.apply("close", [fds[1]]); | ||||
| 		 | ||||
| 		return result; | ||||
| 	}; | ||||
| 	 | ||||
| 	/* | ||||
| 		Determines in a safe way if the memory location contains an Objective-C object | ||||
|  | ||||
| 		Usage: | ||||
| 			cy# utils.isObject(0) | ||||
| 			false | ||||
| 			cy# utils.isObject(0x1337) | ||||
| 			false | ||||
| 			cy# utils.isObject(NSObject) | ||||
| 			true | ||||
| 			cy# utils.isObject(objc_getMetaClass(NSObject)) | ||||
| 			true | ||||
| 			cy# utils.isObject([new NSObject init]) | ||||
| 			true | ||||
| 			cy# var a = malloc(100); utils.isObject(a) | ||||
| 			false | ||||
| 			cy# *@encode(void **)(a) = NSObject; utils.isObject(a) | ||||
| 			true | ||||
| 	*/ | ||||
| 	utils.isObject = function(obj) { | ||||
| 		obj = @encode(void *)(obj); | ||||
| 		var lastObj = -1; | ||||
| 		 | ||||
| 		function objc_isa_ptr(obj) { | ||||
| 			// See http://www.sealiesoftware.com/blog/archive/2013/09/24/objc_explain_Non-pointer_isa.html | ||||
| 			var objc_debug_isa_class_mask = 0x00000001fffffffa; | ||||
| 			obj = (obj & 1)? (obj & objc_debug_isa_class_mask): obj; | ||||
| 			 | ||||
| 			if((obj & (utils.sizeof(@encode(void *)) - 1)) != 0) { | ||||
| 				return null; | ||||
| 			} else { | ||||
| 				return obj; | ||||
| 			} | ||||
| 		} | ||||
| 		 | ||||
| 		function ptrValue(obj) { | ||||
| 			return obj? obj.valueOf(): null; | ||||
| 		} | ||||
| 		 | ||||
| 		var foundMetaClass = false; | ||||
| 		 | ||||
| 		for(obj = objc_isa_ptr(obj); utils.isMemoryReadable(obj); ) { | ||||
| 			obj = *@encode(void **)(obj); | ||||
| 			 | ||||
| 			if(ptrValue(obj) == ptrValue(lastObj)) { | ||||
| 				foundMetaClass = true; | ||||
| 				break; | ||||
| 			} | ||||
| 			 | ||||
| 			lastObj = obj; | ||||
| 		} | ||||
| 		 | ||||
| 		if(!foundMetaClass) { | ||||
| 			return false; | ||||
| 		} | ||||
| 		 | ||||
| 		if(lastObj === -1 || lastObj === null) { | ||||
| 			return false; | ||||
| 		} | ||||
| 		 | ||||
| 		var obj_class = objc_isa_ptr(@encode(void **)(obj)[1]); | ||||
| 		 | ||||
| 		if(!utils.isMemoryReadable(obj_class)) { | ||||
| 			return false; | ||||
| 		} | ||||
| 		 | ||||
| 		var metaclass = objc_isa_ptr(@encode(void **)(obj_class)[0]); | ||||
| 		var superclass = objc_isa_ptr(@encode(void **)(obj_class)[1]); | ||||
| 		 | ||||
| 		return ptrValue(obj) == ptrValue(metaclass) && superclass == null; | ||||
| 	}; | ||||
| 	 | ||||
| 	/* | ||||
| 		Creates a cycript struct type from a C struct definition | ||||
| 		 | ||||
| 		Usage: | ||||
| 			cy# var foo = makeStruct("int a; short b; char c; uint64_t d; double e;", "foo"); | ||||
| 			@encode(foo) | ||||
| 			cy# var f = new foo | ||||
| 			&{a:0,b:0,c:0,d:0,e:0} | ||||
| 			cy# f->a = 100; f | ||||
| 			&{a:100,b:0,c:0,d:0,e:0} | ||||
| 			cy# *@encode(int *)(f) | ||||
| 			100 | ||||
| 	*/ | ||||
| 	utils.makeStruct = function(str, name) {		 | ||||
| 		var fieldRe = /(?:\s|\n)*([^;]+\s*(?:\s|\*))([^;]+)\s*;/g; | ||||
| 		 | ||||
| 		if(!name) { | ||||
| 			name = "struct" + Math.floor(Math.random() * 100000); | ||||
| 		} | ||||
| 		var typeStr = "{" + name + "="; | ||||
| 		 | ||||
| 		while((match = fieldRe.exec(str)) !== null) { | ||||
| 			var fieldType = utils.applyTypedefs(match[1]); | ||||
| 			var fieldName = match[2]; | ||||
| 			var encodedType = utils.exec("@encode(" + fieldType + ")").toString(); | ||||
| 			 | ||||
| 			typeStr += '"' + fieldName + '"' + encodedType; | ||||
| 		} | ||||
| 		 | ||||
| 		typeStr += "}"; | ||||
| 		 | ||||
| 		return new Type(typeStr); | ||||
| 	}; | ||||
| 	 | ||||
| 	// Various constants | ||||
| 	utils.constants = { | ||||
| 		VM_PROT_NONE:       0x0, | ||||
| 		VM_PROT_READ:       0x1, | ||||
| 		VM_PROT_WRITE:      0x2, | ||||
| 		VM_PROT_EXECUTE:    0x4, | ||||
| 		VM_PROT_NO_CHANGE:  0x8, | ||||
| 		VM_PROT_COPY:       0x10, | ||||
| 		VM_PROT_WANTS_COPY: 0x10, | ||||
| 		VM_PROT_IS_MASK:    0x40, | ||||
| 	}; | ||||
| 	var c = utils.constants; | ||||
| 	c.VM_PROT_DEFAULT = c.VM_PROT_READ | c.VM_PROT_WRITE; | ||||
| 	c.VM_PROT_ALL =     c.VM_PROT_READ | c.VM_PROT_WRITE | c.VM_PROT_EXECUTE; | ||||
| 	 | ||||
| 	if(shouldExposeConsts) { | ||||
| 		for(var k in c) { | ||||
| 			Cycript.all[k] = c[k]; | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	if(shouldExposeFuncs) { | ||||
| 		for(var i = 0; i < funcsToExpose.length; i++) { | ||||
| 			var name = funcsToExpose[i]; | ||||
| 			Cycript.all[name] = utils[name]; | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	if(shouldLoadCFuncs) { | ||||
| 		utils.loadfuncs(shouldExposeCFuncs); | ||||
| 	} | ||||
| })(exports); | ||||
							
								
								
									
										23
									
								
								samples/EmberScript/momentComponent.em
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								samples/EmberScript/momentComponent.em
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | ||||
| class App.FromNowView extends Ember.View | ||||
|     tagName: 'time' | ||||
|     template: Ember.Handlebars.compile '{{view.output}}' | ||||
|     output: ~> | ||||
|         return moment(@value).fromNow() | ||||
|  | ||||
|     didInsertElement: -> | ||||
|         @tick() | ||||
|  | ||||
|     tick: -> | ||||
|         f = -> | ||||
|             @notifyPropertyChange 'output' | ||||
|             @tick() | ||||
|  | ||||
|         nextTick = Ember.run.later(this, f, 1000) | ||||
|         @set 'nextTick', nextTick | ||||
|  | ||||
|     willDestroyElement: -> | ||||
|         nextTick = @nextTick | ||||
|         Ember.run.cancel nextTick | ||||
|  | ||||
| Ember.Handlebars.helper 'fromNow', App.FromNowView | ||||
|  | ||||
							
								
								
									
										31
									
								
								samples/HTML+ERB/fishbowl.html.erb.deface
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								samples/HTML+ERB/fishbowl.html.erb.deface
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <!-- insert_before '[data-hook="buttons"]' --> | ||||
| <% if Spree::Config[:enable_fishbowl] %> | ||||
| <div class="row"> | ||||
|   <div class="twelve columns" id="fishbowl_preferences"> | ||||
|     <fieldset class="no-border-bottom"> | ||||
|       <legend align="center"><%= t(:fishbowl_settings)%></legend> | ||||
|       <% @fishbowl_options.each do |key| %> | ||||
|           <div class="field"> | ||||
|             <%= label_tag(key, t(key.to_s.gsub('fishbowl_', '').to_sym) + ': ') + tag(:br) %> | ||||
|             <%= text_field_tag('preferences[' + key.to_s + ']', Spree::Config[key], { :size => 10, :class => 'fullwidth' }) %> | ||||
|           </div> | ||||
|       <% end %> | ||||
|       <div class="field"> | ||||
|         <%= hidden_field_tag 'preferences[fishbowl_always_fetch_current_inventory]', '0' %> | ||||
|         <%= check_box_tag('preferences[fishbowl_always_fetch_current_inventory]', "1", Spree::Config[:fishbowl_always_fetch_current_inventory]) %> | ||||
|         <%= t(:always_fetch_current_inventory) %> | ||||
|       </div> | ||||
|       <% if !@location_groups.empty? %> | ||||
|         <div class="field"> | ||||
|           <%= label_tag(:fishbowl_location_group, t(:location_group) + ': ') + tag(:br) %> | ||||
|           <%= select('preferences', 'fishbowl_location_group', @location_groups, { :selected => Spree::Config[:fishbowl_location_group]}, { :class => ['select2', 'fullwidth'] }) %> | ||||
|         </div> | ||||
|       <% end %> | ||||
|     </fieldset> | ||||
|   </div> | ||||
| </div> | ||||
|  | ||||
| <script type="text/javascript"> | ||||
|   $('.select2').select2(); | ||||
| </script> | ||||
| <% end %> | ||||
							
								
								
									
										39
									
								
								samples/HTML+ERB/index.html.erb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								samples/HTML+ERB/index.html.erb
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | ||||
| <% provide(:title, @header) %> | ||||
| <% present @users do |user_presenter| %> | ||||
| 	<div class="row key-header"> | ||||
| 		<h1><%= @header %></h1> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class='row'> | ||||
| 		<div class='small-12 columns'> | ||||
| 			<%= will_paginate %> | ||||
| 		</div> | ||||
| 	</div> | ||||
| 	<div class="row key-table"> | ||||
| 		<div class="small-12 columns"> | ||||
| 			<div class="row key-table-row"> | ||||
| 				<div class="small-2 columns">Name</div> | ||||
| 				<div class="small-3 columns">Email</div> | ||||
| 				<div class="small-1 columns">Chords</div> | ||||
| 				<div class="small-1 columns">Keys</div> | ||||
| 				<div class="small-1 columns">Tunings</div> | ||||
| 				<div class="small-1 columns">Credits</div> | ||||
| 				<div class="small-1 columns">Prem?</div> | ||||
| 				<div class="small-2 columns">Since?</div> | ||||
| 			</div> | ||||
|  | ||||
| 			<% if @users == [] %> | ||||
| 				<div class="row key-table-row"> | ||||
| 					<div class="small-4 small-centered columns">No Users</div> | ||||
| 				</div> | ||||
| 			<% else %> | ||||
| 				<%= render @users %> | ||||
| 			<% end %> | ||||
| 		</div> | ||||
| 	</div> | ||||
| 	<div class='row'> | ||||
| 		<div class='small-12 columns'> | ||||
| 			<%= will_paginate %> | ||||
| 		</div> | ||||
| 	</div> | ||||
| <% end %> | ||||
							
								
								
									
										29
									
								
								samples/Haml/buttons.html.haml.deface
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								samples/Haml/buttons.html.haml.deface
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| / | ||||
|   replace '.actions' | ||||
|  | ||||
| .pull-right | ||||
|   .btn-group | ||||
|     = link_to page.url, target: "_blank", title: t('.view_live_html'), class: "tip btn btn-xs btn-default" do | ||||
|       %i.icon-picture.row-black | ||||
|        | ||||
|     = link_to refinery.edit_admin_page_path(page.nested_url, | ||||
|         switch_locale: (page.translations.first.locale unless page.translated_to_default_locale?)), | ||||
|         title: t('edit', :scope => 'refinery.admin.pages'), | ||||
|         class: "tip btn btn-xs btn-default" do | ||||
|       %i.icon-edit.row-blue | ||||
|        | ||||
|      | ||||
|     - if page.deletable? | ||||
|       = link_to refinery.admin_page_path(page.nested_url),  | ||||
|           methode: :delete, | ||||
|           title: t('delete', :scope => 'refinery.admin.pages'),  | ||||
|           class: "tip cancel confirm-delete btn btn-xs btn-default",  | ||||
|           data: { confirm: t('message', scope: 'refinery.admin.delete', title: page_title_with_translations(page)) } do | ||||
|         %i.icon-trash.row-red | ||||
|     - else | ||||
|       %button.btn.btn-xs.btn-default.disabled | ||||
|         %i.icon-trash | ||||
|        | ||||
|   .btn-group | ||||
|     = link_to refinery.new_admin_page_path(:parent_id => page.id), title: t('new', :scope => 'refinery.admin.pages'), class: "tip btn btn-xs btn-default" do | ||||
|       %i.icon-plus.row-green | ||||
							
								
								
									
										38
									
								
								samples/IGOR Pro/functions.ipf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								samples/IGOR Pro/functions.ipf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | ||||
| #pragma rtGlobals=3 | ||||
|  | ||||
| Function FooBar() | ||||
| 	return 0 | ||||
| End | ||||
|  | ||||
| Function FooBarSubType() : ButtonControl | ||||
| 	return 0 | ||||
| End | ||||
|  | ||||
| Function/D FooBarVar() | ||||
| 	return 0 | ||||
| End | ||||
|  | ||||
| static Function FooBarStatic() | ||||
| 	return 0 | ||||
| End | ||||
|  | ||||
| threadsafe static Function FooBarStaticThreadsafe() | ||||
| 	return 0 | ||||
| End | ||||
|  | ||||
| threadsafe Function FooBarThread() | ||||
| 	return 0 | ||||
| End | ||||
|  | ||||
| Function CallOperationsAndBuiltInFuncs(string var) | ||||
|  | ||||
| 	string someDQString = "abcd" | ||||
|  | ||||
| 	Make/N=(1,2,3,4) myWave | ||||
| 	Redimension/N=(-1,-1,-1,5) myWave | ||||
|  | ||||
| 	print strlen(someDQString) | ||||
|  | ||||
| 	return 0 | ||||
| End | ||||
|  | ||||
							
								
								
									
										21
									
								
								samples/IGOR Pro/generic.ipf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								samples/IGOR Pro/generic.ipf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| #pragma rtGlobals=3 | ||||
|  | ||||
| StrConstant myConstString="abcd" | ||||
| // some comment | ||||
| constant myConst=123 | ||||
|  | ||||
| Structure struct1 | ||||
| 	string str | ||||
| 	variable var | ||||
| EndStructure | ||||
|  | ||||
| static Structure struct2 | ||||
| 	string str | ||||
| 	variable var | ||||
| EndStructure | ||||
|  | ||||
| #include "someFile" | ||||
|  | ||||
| #ifdef NOT_DEFINED | ||||
| 	// conditional compilation | ||||
| #endif | ||||
							
								
								
									
										74
									
								
								samples/LSL/LSL.lsl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										74
									
								
								samples/LSL/LSL.lsl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,74 @@ | ||||
| /* | ||||
|     Testing syntax highlighting | ||||
|     for the Linden Scripting Language | ||||
| */ | ||||
|  | ||||
| integer someIntNormal       = 3672; | ||||
| integer someIntHex          = 0x00000000; | ||||
| integer someIntMath         = PI_BY_TWO; | ||||
|  | ||||
| integer event               = 5673;// 'event' is invalid.illegal | ||||
|  | ||||
| key someKeyTexture          = TEXTURE_DEFAULT; | ||||
| string someStringSpecial    = EOF; | ||||
|  | ||||
| some_user_defined_function_without_return_type(string inputAsString) | ||||
| { | ||||
|     llSay(PUBLIC_CHANNEL, inputAsString); | ||||
| } | ||||
|  | ||||
| string user_defined_function_returning_a_string(key inputAsKey) | ||||
| { | ||||
|     return (string)inputAsKey; | ||||
| } | ||||
|  | ||||
| default | ||||
| { | ||||
|     state_entry() | ||||
|     { | ||||
|         key someKey = NULL_KEY; | ||||
|         someKey = llGetOwner(); | ||||
|  | ||||
|         string someString = user_defined_function_returning_a_string(someKey); | ||||
|  | ||||
|         some_user_defined_function_without_return_type(someString); | ||||
|     } | ||||
|  | ||||
|     touch_start(integer num_detected) | ||||
|     { | ||||
|         list agentsInRegion = llGetAgentList(AGENT_LIST_REGION, []); | ||||
|         integer numOfAgents = llGetListLength(agentsInRegion); | ||||
|  | ||||
|         integer index;                                                          // defaults to 0 | ||||
|         for (; index <= numOfAgents - 1; index++)                               // for each agent in region | ||||
|         { | ||||
|             llRegionSayTo(llList2Key(agentsInRegion, index), PUBLIC_CHANNEL, "Hello, Avatar!"); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     touch_end(integer num_detected) | ||||
|     { | ||||
|         someIntNormal       = 3672; | ||||
|         someIntHex          = 0x00000000; | ||||
|         someIntMath         = PI_BY_TWO; | ||||
|  | ||||
|         event               = 5673;// 'event' is invalid.illegal | ||||
|  | ||||
|         someKeyTexture      = TEXTURE_DEFAULT; | ||||
|         someStringSpecial   = EOF; | ||||
|  | ||||
|         llSetInventoryPermMask("some item", MASK_NEXT, PERM_ALL);// 'llSetInventoryPermMask' is reserved.godmode | ||||
|  | ||||
|         llWhisper(PUBLIC_CHANNEL, "Leaving \"default\" now..."); | ||||
|         state other; | ||||
|     } | ||||
| } | ||||
|  | ||||
| state other | ||||
| { | ||||
|     state_entry() | ||||
|     { | ||||
|         llWhisper(PUBLIC_CHANNEL, "Entered \"state other\", returning to \"default\" again..."); | ||||
|         state default; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										43
									
								
								samples/LookML/comments.view.lookml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								samples/LookML/comments.view.lookml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | ||||
| - view: comments | ||||
|   fields: | ||||
|  | ||||
|   - dimension: id | ||||
|     primary_key: true | ||||
|     type: int | ||||
|     sql: ${TABLE}.id | ||||
|  | ||||
|   - dimension: body | ||||
|     sql: ${TABLE}.body | ||||
|  | ||||
|   - dimension_group: created | ||||
|     type: time | ||||
|     timeframes: [time, date, week, month] | ||||
|     sql: ${TABLE}.created_at | ||||
|  | ||||
|   - dimension: headline_id | ||||
|     type: int | ||||
|     hidden: true | ||||
|     sql: ${TABLE}.headline_id | ||||
|  | ||||
|   - dimension_group: updated | ||||
|     type: time | ||||
|     timeframes: [time, date, week, month] | ||||
|     sql: ${TABLE}.updated_at | ||||
|  | ||||
|   - dimension: user_id | ||||
|     type: int | ||||
|     hidden: true | ||||
|     sql: ${TABLE}.user_id | ||||
|  | ||||
|   - measure: count | ||||
|     type: count | ||||
|     detail: detail* | ||||
|  | ||||
|  | ||||
|   # ----- Detail ------ | ||||
|   sets: | ||||
|     detail: | ||||
|       - id | ||||
|       - headlines.id | ||||
|       - headlines.name | ||||
|       - users.id | ||||
							
								
								
									
										9
									
								
								samples/Opal/DeepakChopra.opal
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								samples/Opal/DeepakChopra.opal
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| -- Deepak Chopra nonsense text generator | ||||
| -- see https://github.com/StoneCypher/DeepakChopra_Opal/ | ||||
|  | ||||
| starts = ["Experiential truth ", "The physical world ", "Non-judgment ", "Quantum physics "] | ||||
| middles = ["nurtures an ", "projects onto ", "imparts reality to ", "constructs with "] | ||||
| qualifiers = ["abundance of ", "the barrier of ", "self-righteous ", "potential "] | ||||
| finishes = ["marvel.", "choices.", "creativity.", "actions."] | ||||
|  | ||||
| alert starts.sample + middles.sample + qualifiers.sample + finishes.sample | ||||
							
								
								
									
										13
									
								
								samples/OpenSCAD/not_simple.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								samples/OpenSCAD/not_simple.scad
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| // A more complicated 3D shape in OpenSCAD | ||||
| $fn=32; | ||||
|  | ||||
| difference() { | ||||
|     // main shape | ||||
|     union() { | ||||
|         translate( [ 0, 0,  2 ] ) cube( [ 15, 15, 4 ], center=true ); | ||||
|         translate( [ 0, 0, 13 ] ) cylinder( h=25, r1=5, r2=3, center=true ); | ||||
|         translate( [ 0, 0, 28 ] ) sphere( r=6 ); | ||||
|     } | ||||
|     // hole through center | ||||
|     translate( [ 0, 0, 17 ] ) cylinder( h=35, r=2, center=true ); | ||||
| } | ||||
							
								
								
									
										3
									
								
								samples/OpenSCAD/simple.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								samples/OpenSCAD/simple.scad
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| // Simple sphere in OpenSCAD | ||||
|  | ||||
| sphere( r=10 ); | ||||
							
								
								
									
										34
									
								
								samples/PHP/filenames/.php
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										34
									
								
								samples/PHP/filenames/.php
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,34 @@ | ||||
| #!/usr/bin/env php | ||||
| <? | ||||
| $aMenuLinks = Array( | ||||
| 	Array( | ||||
| 		"Blog",  | ||||
| 		SITE_DIR,  | ||||
| 		Array(),  | ||||
| 		Array(),  | ||||
| 		""  | ||||
| 	), | ||||
| 	Array( | ||||
| 		"Photos",  | ||||
| 		SITE_DIR."photo/",  | ||||
| 		Array(),  | ||||
| 		Array(),  | ||||
| 		""  | ||||
| 	), | ||||
| 	Array( | ||||
| 		"About me",  | ||||
| 		SITE_DIR."about.php",  | ||||
| 		Array(),  | ||||
| 		Array(),  | ||||
| 		""  | ||||
| 	), | ||||
| 	Array( | ||||
| 		"Contact",  | ||||
| 		SITE_DIR."contacts.php",  | ||||
| 		Array(),  | ||||
| 		Array(),  | ||||
| 		""  | ||||
| 	), | ||||
|  | ||||
| ); | ||||
| ?> | ||||
							
								
								
									
										447
									
								
								samples/Perl/example.cgi
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										447
									
								
								samples/Perl/example.cgi
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,447 @@ | ||||
| #!/usr/bin/perl | ||||
|  | ||||
| # v1.0 | ||||
| # nagiostat, program to insert performance-data from Nagios into RRD-archives | ||||
| # Copyright (C) 2004  Carl Bingel / Svensk IT konsult AB | ||||
| # | ||||
| # This program is free software; you can redistribute it and/or | ||||
| # modify it under the terms of the GNU General Public License | ||||
| # as published by the Free Software Foundation; either version 2 | ||||
| # of the License, or (at your option) any later version. | ||||
| # | ||||
| # This program is distributed in the hope that it will be useful, | ||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| # GNU General Public License for more details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with this program; if not, write to the Free Software | ||||
| # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. | ||||
|  | ||||
| use strict; | ||||
|  | ||||
| ## Basic configuration options | ||||
| my $BASE_DIR = "/usr/share/nagiostat"; | ||||
| my $CONFIG_FILE = "/etc/nagios/nagiostat.conf";  ## Config-file location | ||||
| my $DEBUG_LOG_FILE = "/var/spool/nagiostat/debug.log";    ## Specify where to create log-file and what filename (must be writable by nagios-user!) | ||||
| my $DEBUGLEVEL = 1;              ## 0=Nothing, 1=Errors, 2=Warnings, 3=Debug | ||||
| my $DEBUGOUTPUT = 0;		 ## 0=file, 1=STDERR, 2=STDOUT (for cgi) | ||||
|  | ||||
| require 'shellwords.pl'; | ||||
|  | ||||
| ## Global vars | ||||
| my $DEBUG_TIMESTAMP=0; | ||||
|  | ||||
| ## Find out how program is run | ||||
| if( $ARGV[0] eq "-t") {		## -t = test configuration-file | ||||
|   print STDERR "nagiostat: Testing configuration-file..\n"; | ||||
|   $DEBUGLEVEL=3; | ||||
|   $DEBUGOUTPUT=1;    ## output errors to console and not file | ||||
|   my $c = &read_config(); | ||||
|   abort(); | ||||
| } elsif( $ARGV[0] eq "-p") {	## -p = parse performance-data (when started by nagios) | ||||
|   &parse_perfdata(); | ||||
| } else { | ||||
|   if( exists $ENV{'GATEWAY_INTERFACE'}) {	## we are run as a CGI-script! | ||||
|     $DEBUGOUTPUT=2;  ## output errors to web-browser | ||||
|     &run_as_cgi(); | ||||
|   } else {                                ## print some help-info | ||||
|     print STDERR "nagiostat: usage: | ||||
|         -t	Test configuration-file | ||||
|         -p	Parse/import performance-data (used when called from nagios) | ||||
| "; | ||||
|   } | ||||
| } | ||||
|  | ||||
| abort(); | ||||
|  | ||||
| sub abort { | ||||
|    ## logfile: write blank if we wrote anything... | ||||
|    if( $DEBUG_TIMESTAMP!=0) { | ||||
|      debug( 1, "");	 | ||||
|    } | ||||
|    exit; | ||||
| } | ||||
|  | ||||
| ## | ||||
| ##  Program is called as CGI | ||||
| ## | ||||
| sub run_as_cgi { | ||||
|    use CGI; | ||||
|    my $cgi = new CGI; | ||||
|     | ||||
|    my $graph_name = $cgi->param( "graph_name"); | ||||
|    my $graph_iteration = $cgi->param( "graph_iteration"); | ||||
|  | ||||
|    if( $graph_iteration eq "") { | ||||
|       print "Content-type: text/html\nExpires: 0\n\n"; | ||||
|    } else { | ||||
|       print "Content-type: image/gif\nExpires: 0\n\n"; | ||||
|    } | ||||
|  | ||||
|    my $config = read_config(); | ||||
|  | ||||
|    if( $graph_name eq "") {       | ||||
|       ## | ||||
|       ## display index of graphs | ||||
|       ## | ||||
|       display_htmltemplate( $config->{'htmltemplatepath'}."/".$config->{'graphindextemplate'}, $graph_name, $config); | ||||
|    } else {                      ## display graph | ||||
|       if( ! exists $config->{'graphs'}->{$graph_name}) { | ||||
|          debug( 1, "ERROR: Graph '$graph_name' does not exist!"); | ||||
|          exit; | ||||
|       } elsif( $graph_iteration eq "") { | ||||
|          ## | ||||
|          ## Display HTML-page with all the graphs | ||||
|          ## | ||||
|          if( ! -r $config->{'htmltemplatepath'}."/".$config->{'graphs'}->{$graph_name}->{'htmltemplate'}) { | ||||
|             debug( 1, "ERROR: HTML-template '".($config->{'htmltemplatepath'}."/".$config->{'graphs'}->{$graph_name}->{'htmltemplate'})."' is not readable by effective userid!"); | ||||
|             exit; | ||||
|          } | ||||
|          display_htmltemplate( $config->{'htmltemplatepath'}."/".$config->{'graphs'}->{$graph_name}->{'htmltemplate'}, $graph_name, $config); | ||||
|       } else {                    | ||||
|          ## | ||||
|          ## generate graph (call 'rrdtool graph') | ||||
|          ## | ||||
|          my $rrdtool_cmdline = $config->{'rrdtoolpath'}." graph - ".join( " ", @{$config->{'plottemplates'}->{ $config->{'graphs'}->{$graph_name}->{'plottemplate'} } });  | ||||
|           | ||||
|          ## expand variables | ||||
|          my $rrdarchive = $config->{'rrdarchivepath'}."/".$config->{'graphs'}->{$graph_name}->{'rrdfilename'}; | ||||
|          $rrdtool_cmdline =~ s/\$f/$rrdarchive/g; | ||||
|          my $t_start = $config->{'graphtimetemplates'}->{ $config->{'graphs'}->{$graph_name}->{'graphtimetemplate'} }->[$graph_iteration]->{'starttime'}; | ||||
|          $rrdtool_cmdline =~ s/\$s/$t_start/g; | ||||
|          my $t_end = $config->{'graphtimetemplates'}->{ $config->{'graphs'}->{$graph_name}->{'graphtimetemplate'} }->[$graph_iteration]->{'endtime'}; | ||||
|          $rrdtool_cmdline =~ s/\$e/$t_end/g; | ||||
|          my $t_descr = $config->{'graphtimetemplates'}->{ $config->{'graphs'}->{$graph_name}->{'graphtimetemplate'} }->[$graph_iteration]->{'description'}; | ||||
|          $rrdtool_cmdline =~ s/\$d/$t_descr/g; | ||||
|  | ||||
|          ## Call rrdtool (should probably be fixed to call it in a better way, like exec) | ||||
|          print `$rrdtool_cmdline`; | ||||
|       } | ||||
|  | ||||
|    } | ||||
|  | ||||
| } | ||||
|  | ||||
| ## Display HTML template (and do variable-substitution and other stuff) | ||||
| ## | ||||
| sub display_htmltemplate { | ||||
|    my( $filename, $graph_name, $config) = @_; | ||||
|  | ||||
|    if( -r $filename) { | ||||
|       open( HTML, $filename); | ||||
|       while( <HTML>) { | ||||
|          ## All is a big regex.. :-) | ||||
|          s/\$(\w+)/my $t=sub {    | ||||
|             my $varname = $_[0]; | ||||
|             if( $varname eq "GRAPHNAME") {                           ## return the name of the graph | ||||
|                if( $config->{'graphs'}->{$graph_name}->{'title'} ne "") { | ||||
|                   return( $config->{'graphs'}->{$graph_name}->{'title'}); | ||||
|                } else { | ||||
|                   return( "Graph ".$graph_name); | ||||
|                } | ||||
|             } elsif( $varname eq "CURRENTTIME") {                    ## return current date-time | ||||
|                return( localtime()); | ||||
|             } elsif( $varname eq "GRAPHINDEX" || $varname eq "GRAPHINDEX_ONEROW") {    ## return HTML-code for index of the different graphs | ||||
|                my $return_html; | ||||
|                foreach my $gn ( sort keys %{$config->{'graphs'}}) {            | ||||
|                      $return_html.=(($varname eq "GRAPHINDEX")?"<LI>":""). | ||||
|                      "<A HREF=\"?graph_name=$gn\">".($config->{'graphs'}->{$gn}->{'title'})."<\/A>".                  # must escape slash since were inside an regex! | ||||
|                      (($varname eq "GRAPHINDEX_ONEROW")?"  ":""); | ||||
|                } | ||||
|                return( $return_html); | ||||
|             } elsif( $varname eq "GRAPH_AUTOGENERATE") {             ## return HTML-code for displaying the actual graph-images | ||||
|                my $iteration_id=0; | ||||
|                my $return_html; | ||||
|                foreach my $time ( @{ $config->{'graphtimetemplates'}->{ $config->{'graphs'}->{$graph_name}->{'graphtimetemplate'} } }) { | ||||
|                  $return_html.="<P>".($time->{'description'})."<BR><IMG SRC=\"?graph_name=$graph_name&graph_iteration=$iteration_id\">";  | ||||
|                  $iteration_id++; | ||||
|                } | ||||
|                return( $return_html); | ||||
|             } else {                                                 ## unknown variable | ||||
|                return( "##UNKNOWN-VARIABLE##"); | ||||
|             } | ||||
|          }; &$t($1)/eig;   ## i thought that regex would never end! | ||||
|          print; | ||||
|       } | ||||
|       close( HTML); | ||||
|    } else { | ||||
|       print "ERROR: HTML-template '$filename' does not exist or is not readable by effective userid."; | ||||
|    } | ||||
|  | ||||
| } | ||||
|  | ||||
| ## | ||||
| ##  Process incoming performance-data (parse output from check-plugin and insert values into rrd-archives) | ||||
| ## | ||||
| sub parse_perfdata { | ||||
|  | ||||
|   $DEBUG_TIMESTAMP=0; | ||||
|    | ||||
|   my $config = read_config(); | ||||
|  | ||||
|   my $rrd_updates; | ||||
|  | ||||
|   ##  Provide more symbolic names (same names as the macros in nagios configuration-file) | ||||
|  | ||||
|   my( $LASTCHECK, $HOSTNAME, $SERVICEDESCR, $SERVICESTATE, $OUTPUT, $PERFDATA) = split( /\|!!\|/, $ARGV[1]); | ||||
|   debug( 3, "**INCOMING PERFDATA:\n  LASTCHECK=$LASTCHECK\n  HOSTNAME=$HOSTNAME\n  SERVICEDESCR=\"$SERVICEDESCR\"\n  SERVICESTATE=\"$SERVICESTATE\"\n  OUTPUT=\"$OUTPUT\"\n  PERFDATA=\"$PERFDATA\""); | ||||
|    | ||||
|   my $host_and_descr_found; | ||||
|   ## Loop through all host_regexes | ||||
|   foreach my $host_regex ( keys %{$config->{'regexes'}}) { | ||||
|     ## Loop through all service_description_regexes | ||||
|     foreach my $service_regex ( keys %{$config->{'regexes'}->{$host_regex}}) { | ||||
|       if( ($HOSTNAME =~ m/$host_regex/i) && ($SERVICEDESCR =~ m/$service_regex/i) ) {     ## match! | ||||
|         $host_and_descr_found=1; | ||||
|         ## Loop through all InsertValue-lines with same host and service_description match | ||||
|         foreach my $insert_value ( @{$config->{'regexes'}->{$host_regex}->{$service_regex}} ) { | ||||
|           ## Loop through all regexes that should match values in the output/perfdata | ||||
|           foreach my $regex ( @{ $config->{'valueregextemplates'}->{$insert_value->{'regextemplate'}} }) { | ||||
|              my $regex_string = $regex->{'regex'}; | ||||
|              if( $regex->{'regex_what'} eq "output") {         ## do regex on "output" | ||||
|                 if( $OUTPUT =~ m/$regex_string/) { | ||||
|                    debug( 3, " +VALUE: ".$1); | ||||
|                    push( @{$rrd_updates->{$insert_value->{'rrdarchive'}}->{'value'}}, $1); | ||||
|                    push( @{$rrd_updates->{$insert_value->{'rrdarchive'}}->{'dsaname'}}, $regex->{'dsaname'}); | ||||
|                    $rrd_updates->{$insert_value->{'rrdarchive'}}->{'rrdcreatetemplate'} = $insert_value->{'rrdcreatetemplate'};  #$config->{'regexes'}->{$host_regex}->{$service_regex}->[0]->{'rrdcreatetemplate'}; | ||||
|                 } else { | ||||
|                    debug( 2, "**WARNING: No match for value with regex on output '$regex_string'."); | ||||
|                 } | ||||
|              } else {                                          ## do regex on "perfdata" | ||||
|                 if( $PERFDATA =~ m/$regex_string/) { | ||||
|                    debug( 3, " +VALUE: ".$1); | ||||
|                    push( @{$rrd_updates->{$insert_value->{'rrdarchive'}}->{'value'}}, $1); | ||||
|                    push( @{$rrd_updates->{$insert_value->{'rrdarchive'}}->{'dsaname'}}, $regex->{'dsaname'}); | ||||
|                    $rrd_updates->{$insert_value->{'rrdarchive'}}->{'rrdcreatetemplate'} = $insert_value->{'rrdcreatetemplate'};  #$config->{'regexes'}->{$host_regex}->{$service_regex}->[0]->{'rrdcreatetemplate'}; | ||||
|                 } else { | ||||
|                    debug( 2, "**WARNING: No match for value with regex on perfdata '$regex_string'."); | ||||
|                 } | ||||
|              } | ||||
|           } | ||||
|         } | ||||
|          | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|    | ||||
|   if( !$host_and_descr_found) { | ||||
|     debug( 2, "**WARNING: Hostname and description didn't match any of the regexes in the config-file."); | ||||
|   } else { | ||||
|     ## | ||||
|     ## Insert the value into the RRD by calling the rrdtool (may be several rrd-archives) | ||||
|     ## | ||||
|     foreach my $archive ( keys %{$rrd_updates}) { | ||||
|       debug( 3, " =INSERT into '$archive': ".join( ",", @{$rrd_updates->{$archive}->{'value'}} )." DSA-names=".join( ",", @{$rrd_updates->{$archive}->{'dsaname'}}) ); | ||||
|        | ||||
|       my $rrdarchive_filename = $config->{'rrdarchivepath'}."/".$archive; | ||||
|        | ||||
|       ## Create RRD-Archive (according to template) if it does not exist | ||||
|       if( ! -e $rrdarchive_filename) { | ||||
|          my $rrdtool_cmdline = $config->{'rrdtoolpath'}." create ".$rrdarchive_filename." ".(join( " ", @{$config->{'rrdcreatetemplates'}->{$rrd_updates->{$archive}->{'rrdcreatetemplate'}}})); | ||||
|          debug( 2, "**CREATING: $rrdarchive_filename, cmdline='".$rrdtool_cmdline."'."); | ||||
|          `$rrdtool_cmdline`; | ||||
|       } | ||||
|  | ||||
|       ## Check if rrd-archive is writable | ||||
|       if( ! -w $rrdarchive_filename) {					## check wheter RRD-archive exists | ||||
|         debug( 1, "!!ERROR: RRD-archive '".$rrdarchive_filename."' does not exist or is not writable by effective UID."); abort(); | ||||
|       } | ||||
|  | ||||
|       ## Assemle command-line for rrdtool | ||||
|       my $rrdtool_cmdline = $config->{'rrdtoolpath'}." update ".$rrdarchive_filename. | ||||
| 	                    " --template ".join( ":", @{$rrd_updates->{$archive}->{'dsaname'}}). | ||||
|                             " $LASTCHECK:".join( ":", @{$rrd_updates->{$archive}->{'value'}}); | ||||
|       debug( 3, " !RRDCMDLINE: ".$rrdtool_cmdline); | ||||
|       my $result = `$rrdtool_cmdline`; | ||||
|       if( $result ne "") { | ||||
|         debug( 1, "!!RESULT: $result"); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## | ||||
| ##  Read config-file and check for errors | ||||
| ## | ||||
| sub read_config { | ||||
|   my $config; | ||||
|   open( CONFIG, $CONFIG_FILE); | ||||
|   my( $line_counter); | ||||
|   while( <CONFIG>) { | ||||
|     $line_counter++; | ||||
|     chomp; | ||||
|     my( @args) = &shellwords( $_); | ||||
|     my $orig_confline = $_; | ||||
|     $args[0] = uc( $args[0]); | ||||
|    | ||||
|     if( $args[0] eq "INSERTVALUE") {	##  INSERTVALUE-command | ||||
|       shift @args; | ||||
|       my( $rrd_filename, $rrdcreatetemplate, $hostname_regex, $servicedescr_regex, $regex_template) = @args; | ||||
|  | ||||
|       if( ! exists $config->{'rrdcreatetemplates'}->{$rrdcreatetemplate}) { | ||||
|          debug( 1, "!!ERROR: RRDCreateTemplate '$rrdcreatetemplate' is not defined but refered to in line $line_counter."); abort(); | ||||
|       } | ||||
|       if( $hostname_regex !~ m/^\/(.*)\/$/) {			## verify hostname regex | ||||
|         debug( 1, "!!ERROR: Hostname regex should be enclosed in slashes, i.e. /HOSTNAME/ and optionally enclosed in quotes if needed. Conf-line $line_counter."); abort(); | ||||
|       } else { | ||||
|         $hostname_regex = $1; | ||||
|       } | ||||
|       if( $servicedescr_regex !~ m/^\/(.*)\/$/) {			## verify service description regex | ||||
|         debug( 1, "!!ERROR: Service-description regex should be enclosed in slashes, i.e. /SERVICEDESCR/ and optionally enclosed in quotes if needed. Config-line $line_counter."); | ||||
|         abort(); | ||||
|       } else { | ||||
|         $servicedescr_regex = $1; | ||||
|       } | ||||
|       if( ! exists $config->{'valueregextemplates'}->{$regex_template}) {  ## verify value-regex-template exists | ||||
|          debug( 1, "!!ERROR: VALUEREGEXTEMPLATE '$regex_template' is not defined on line $line_counter."); abort(); | ||||
|       } | ||||
|       push( @{$config->{'regexes'}->{$hostname_regex}->{$servicedescr_regex}}, { | ||||
|             'rrdarchive' => $rrd_filename, | ||||
|             'rrdcreatetemplate' => $rrdcreatetemplate, | ||||
|             'regextemplate' => $regex_template | ||||
|             } ); | ||||
|     } elsif( $args[0] =~ m/^(\s*)#/ || $args[0] eq "") {	## comment or blank row | ||||
|       ## do nuthin | ||||
|     } elsif( $args[0] eq "RRDTOOLPATH") {               ## RRDToolPath args: path | ||||
|       $config->{'rrdtoolpath'} = $args[1]; | ||||
|     } elsif( $args[0] eq "PLOTTEMPLATE") {		## PlotTemplate args: name,htmltemplate,parameters.. | ||||
|       shift @args; | ||||
|       my( $name, @params) = @args; | ||||
|       if( $name eq "") { | ||||
|         debug( 1, "!!ERROR: PLOTTEMPLATE-name must be specified on line $line_counter."); abort(); | ||||
|       } | ||||
|       if( exists $config->{'plottemplates'}->{$name}) { | ||||
|         debug( 1, "!!ERROR: PLOTTTEMPLATE-names must be uniqe. Duplicate name found on line: $line_counter."); abort(); | ||||
|       } | ||||
|       $config->{'plottemplates'}->{$name} = [ @params]; | ||||
|     } elsif( $args[0] eq "GRAPHTIMETEMPLATE") {         ## GraphTimeTemplate args: name,parameters.. | ||||
|       shift @args; | ||||
|       my( $name, @params) = @args; | ||||
|       if( $name eq "") { | ||||
|         debug( 1, "!!ERROR: GRAPHTIMETEMPLATE-name must be specified on line $line_counter."); abort(); | ||||
|       } | ||||
|       if( exists $config->{'graphtimetemplates'}->{$name}) { | ||||
|         debug( 1, "!!ERROR: GRAPHTIMETEMPLATE-names must be uniqe. Duplicate name found on line: $line_counter."); abort(); | ||||
|       } | ||||
|       foreach my $time_template (@params) { | ||||
|          my( $t_start, $t_end, @t_descr) = split( /:/, $time_template); | ||||
|          my $t_descr = join( ":", @t_descr);    # workaround if ':' is used in description-string | ||||
|          if( $t_start eq "" || $t_end eq "") { | ||||
|             debug( 1, "!!ERROR: GRAPHTIMETEMPLATE, each time-definition should be defined as '<starttime>:<endtime>:<description>' on line $line_counter."); | ||||
|          } | ||||
|          push( @{$config->{'graphtimetemplates'}->{$name}}, { | ||||
|              'starttime' => $t_start, | ||||
|              'endtime' => $t_end, | ||||
|              'description' => $t_descr | ||||
|          }); | ||||
|       } | ||||
|     } elsif( $args[0] eq "RRDCREATETEMPLATE") {         ## RRDCreateTemplate | ||||
|       shift @args; | ||||
|       my( $name, @params) = @args; | ||||
|       if( $name eq "") { | ||||
|         debug( 1, "!!ERROR: RRDCREATETEMPLATE-name must be specified on line $line_counter."); abort(); | ||||
|       } | ||||
|       if( exists $config->{'rrdcreatetemplates'}->{$name}) { | ||||
|         debug( 1, "!!ERROR: RRDCREATETEMPLATE-names must be uniq. Duplicate name found on line: $line_counter."); abort(); | ||||
|       } | ||||
|       $config->{'rrdcreatetemplates'}->{$name} = [ @params]; | ||||
|     } elsif( $args[0] eq "VALUEREGEXTEMPLATE") {        ## ValueRegexTemplate | ||||
|       shift @args; | ||||
|       my( $template_name, @regexes) = @args; | ||||
|       if( $template_name eq "") { | ||||
|          debug( 1, "!!ERROR: VALUEREGEXTEMPLATE-name must be specified on line $line_counter."); abort(); | ||||
|       } | ||||
|       foreach my $r (@regexes) { | ||||
|          if( $r !~ m/^(output|perfdata):(\w+):\/(.*)\/$/) { | ||||
|            debug( 1, "!!ERROR: Value-regex should be formatted as 'output:dsaname:/regex/' or 'perfdata:dsaname:/regex/' depending on in which field to extract the data. The value should be within parantheses in the regex. Config-line $line_counter."); | ||||
|            abort(); | ||||
|          } else { | ||||
|            my( $regex_what, $dsa_name, $regex) = ( $1, $2, $3); | ||||
|            push( @{$config->{'valueregextemplates'}->{$template_name}}, {  | ||||
|                    'regex_what' => $regex_what,  | ||||
|                    'regex' => $regex,  | ||||
|                    'dsaname' => $dsa_name | ||||
|                   } ); | ||||
|          } | ||||
|       } | ||||
|     } elsif( $args[0] eq "RRDARCHIVEPATH") {            ## RRDARCHIVEPATH | ||||
|       $config->{'rrdarchivepath'} = $args[1]; | ||||
|     } elsif( $args[0] eq "HTMLTEMPLATEPATH") {          ## HTMLTemplatePath | ||||
|       $config->{'htmltemplatepath'} = $args[1]; | ||||
|     } elsif( $args[0] eq "GRAPHINDEXTEMPLATE") {        ## GraphIndexTemplate | ||||
|       $config->{'graphindextemplate'} = $args[1]; | ||||
|     } elsif( $args[0] eq "GRAPH") {			## GRAPH args: name,rrdfilename,rrdcreatetemplate,graphtimetemplate,plottemplate,htmltemplate | ||||
|       if( $args[1] eq "") { | ||||
| 	debug( 1, "!!ERROR: GRAPH-name must be specified on line $line_counter."); abort(); | ||||
|       } | ||||
|       if( ! exists $config->{'graphtimetemplates'}->{$args[3]}) { | ||||
|         debug( 1, "!!ERROR: Unknown GRAPHTIMETEMPLATE on line $line_counter."); abort(); | ||||
|       } | ||||
|       if( ! exists $config->{'plottemplates'}->{$args[4]}) { | ||||
|         debug( 1, "!!ERROR: Unknown PLOTTEMPLATE on line $line_counter."); abort(); | ||||
|       } | ||||
|       if( exists $config->{'graphs'}->{$args[1]}) { | ||||
|         debug( 1, "!!ERROR: Graphnames must be uniqe. Duplicate name found on line: $line_counter."); | ||||
|         abort(); | ||||
|       } else { | ||||
|         $config->{'graphs'}->{$args[1]} = { | ||||
| 		'graphname' => $args[1], | ||||
| 		'rrdfilename' => $args[2], | ||||
|                 'graphtimetemplate' => $args[3], | ||||
|                 'plottemplate' => $args[4], | ||||
|                 'htmltemplate' => $args[5], | ||||
|                 'title' => $args[6] | ||||
|         }; | ||||
|       } | ||||
|     } else { | ||||
|       debug( 1, "!!ERROR: Unknown config-file directive on line $line_counter: '".$args[0]."'"); | ||||
|     } | ||||
|   } | ||||
|   close( CONFIG); | ||||
|  | ||||
|   if( ! -x $config->{'rrdtoolpath'}) { | ||||
|     debug( 1, "!!ERROR: RRDTOOLPATH does not point to executable rrdtool-binary."); | ||||
|     abort(); | ||||
|   } | ||||
|   if( ! -x $config->{'rrdarchivepath'}) { | ||||
|      debug( 1, "!!ERROR: RRDARCHIVEPATH, '".($config->{'rrdarchivepath'})."' is not readable by effective userid."); abort(); | ||||
|   } | ||||
|   if( ! -x $config->{'htmltemplatepath'}) { | ||||
|      debug( 1, "!!ERROR: HTMLTEMPLATEPATH, '".($config->{'htmltemplatepath'})."' is not readable by effective userid."); abort(); | ||||
|   } | ||||
|  | ||||
|   return( $config); | ||||
| } | ||||
|  | ||||
|  | ||||
| ##  | ||||
| ##  Write debug-output/logging | ||||
| ## | ||||
| sub debug { | ||||
|   my( $level, $msg) = @_; | ||||
|   if( $DEBUGLEVEL >= $level) { | ||||
|  | ||||
|     ## write timestamp | ||||
|     if( !$DEBUG_TIMESTAMP) {	 | ||||
|       $DEBUG_TIMESTAMP=1; | ||||
|       debug( 1, scalar localtime()); | ||||
|     } | ||||
|  | ||||
|     ## write to file or STDERR | ||||
|     if( $DEBUGOUTPUT == 0) { | ||||
|       open( DEBUGOUTPUT, ">>".$DEBUG_LOG_FILE); | ||||
|       print DEBUGOUTPUT $msg."\n"; | ||||
|       close( DEBUGOUTPUT); | ||||
|     } elsif( $DEBUGOUTPUT == 2) { | ||||
|       print "<BR><PRE>$msg</PRE>"; | ||||
|     } else { | ||||
|       print STDERR $msg."\n"; | ||||
|     } | ||||
|  | ||||
|   } | ||||
| } | ||||
							
								
								
									
										11
									
								
								samples/Perl/strict.t
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								samples/Perl/strict.t
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| use Test::Base; | ||||
|  | ||||
| __DATA__ | ||||
| === Strict Test | ||||
|  | ||||
| --- perl strict | ||||
| my $x = 5; | ||||
| --- strict | ||||
| use strict; | ||||
| use warnings; | ||||
| my $x = 5; | ||||
							
								
								
									
										10
									
								
								samples/PigLatin/example.pig
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								samples/PigLatin/example.pig
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| /** | ||||
|  * sample.pig | ||||
|  */ | ||||
|  | ||||
| REGISTER $SOME_JAR; | ||||
|  | ||||
| A = LOAD 'person' USING PigStorage() AS (name:chararray, age:int); -- Load person | ||||
| B = FOREACH A generate name; | ||||
| DUMP B; | ||||
|  | ||||
							
								
								
									
										1051
									
								
								samples/Prolog/admin.pl
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										1051
									
								
								samples/Prolog/admin.pl
									
									
									
									
									
										Executable file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										5
									
								
								samples/Prolog/ex6.pl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								samples/Prolog/ex6.pl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| %6.8 | ||||
| subset(Set, Subset) :- | ||||
| 	append(L1, Subset, Set). | ||||
| powerset(Set, Subset) :- | ||||
| 	bagof(Subset, subset(Set, Subset), Subset). | ||||
							
								
								
									
										68
									
								
								samples/SQF/fn_remoteExecFnc.sqf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								samples/SQF/fn_remoteExecFnc.sqf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | ||||
| /* | ||||
|  * Author: commy2 | ||||
|  * | ||||
|  * Execute a function on a remote machine in mp. | ||||
|  *  | ||||
|  * Argument: | ||||
|  * 0: Function arguments (Array) | ||||
|  * 1: Function to execute, has to be defined on the remote machine first (String) | ||||
|  * 2: The function will be executed where this unit is local OR the mode were this function should be executed. (Object OR Number, optional default: 2) | ||||
|  * 		Mode 0: execute on this machine only | ||||
|  * 		Mode 1: execute on server | ||||
|  * 		Mode 2: execute on all clients + server | ||||
|  * 		Mode 3: execute on dedicated only | ||||
|  *  | ||||
|  * Return value: | ||||
|  * Nothing | ||||
|  */ | ||||
|  | ||||
| private ["_arguments", "_function", "_unit", "_id"]; | ||||
|  | ||||
| AGM_Core_remoteFnc = _this; | ||||
|  | ||||
| _arguments = _this select 0; | ||||
| _function = call compile (_this select 1); | ||||
| _unit = _this select 2; | ||||
|  | ||||
| if (isNil "_unit") then { | ||||
| 	_unit = 2; | ||||
| }; | ||||
|  | ||||
| if (typeName _unit == "SCALAR") exitWith { | ||||
| 	switch (_unit) do { | ||||
| 		case 0 : { | ||||
| 			_arguments call _function; | ||||
| 		}; | ||||
| 		case 1 : { | ||||
| 			if (isServer) then { | ||||
| 				_arguments call _function; | ||||
| 			} else { | ||||
| 				publicVariableServer "AGM_Core_remoteFnc"; | ||||
| 			}; | ||||
| 		}; | ||||
| 		case 2 : { | ||||
| 			_arguments call _function; | ||||
|  | ||||
| 			AGM_Core_remoteFnc set [2, 0]; | ||||
| 			publicVariable "AGM_Core_remoteFnc"; | ||||
| 		}; | ||||
| 		case 3 : { | ||||
| 			if (isDedicated) then { | ||||
| 				_arguments call _function; | ||||
| 			} else { | ||||
| 				if (!isServer) then {publicVariableServer "AGM_Core_remoteFnc"}; | ||||
| 			}; | ||||
| 		}; | ||||
| 	}; | ||||
| }; | ||||
|  | ||||
| if (local _unit) then { | ||||
| 	_arguments call _function; | ||||
| } else { | ||||
| 	if (isServer) then { | ||||
| 		_id = owner _unit; | ||||
| 		_id publicVariableClient "AGM_Core_remoteFnc"; | ||||
| 	} else { | ||||
| 		publicVariableServer "AGM_Core_remoteFnc"; | ||||
| 	}; | ||||
| }; | ||||
							
								
								
									
										19
									
								
								samples/SQF/macros.hqf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								samples/SQF/macros.hqf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| #include <version.hqf> | ||||
|  | ||||
| #define SET(VAR,VALUE) private #VAR; VAR = VALUE; | ||||
| #define CONV(VAR,ARRAY,POOL) VAR = ARRAY select (POOL find VAR); | ||||
|  | ||||
| #define ALL_HITPOINTS_MAN [ \ | ||||
|   "HitHead", "HitBody", \ | ||||
|   "HitLeftArm", "HitRightArm", \ | ||||
|   "HitLeftLeg","HitRightLeg" \ | ||||
| ] | ||||
|  | ||||
| #define ALL_HITPOINTS_VEH [ \ | ||||
|   "HitBody", "HitHull", "HitEngine", "HitFuel", \ | ||||
|   "HitTurret", "HitGun", \ | ||||
|   "HitLTrack", "HitRTrack", \ | ||||
|   "HitLFWheel", "HitRFWheel", "HitLF2Wheel", "HitRF2Wheel", "HitLMWheel", "HitRMWheel", "HitLBWheel", "HitRBWheel", \ | ||||
|   "HitAvionics", "HitHRotor", "HitVRotor", \ | ||||
|   "HitRGlass", "HitLGlass", "HitGlass1", "HitGlass2", "HitGlass3", "HitGlass4", "HitGlass5", "HitGlass6" \ | ||||
| ] | ||||
							
								
								
									
										119
									
								
								samples/TeX/authortitle.cbx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										119
									
								
								samples/TeX/authortitle.cbx
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,119 @@ | ||||
| \ProvidesFile{authortitle.cbx} | ||||
| [\abx@cbxid] | ||||
|  | ||||
| \ExecuteBibliographyOptions{uniquename,uniquelist,autocite=footnote} | ||||
|  | ||||
| \renewcommand*{\iffinalcitedelim}{\iflastcitekey} | ||||
|  | ||||
| \newbool{cbx:parens} | ||||
|  | ||||
| \newbibmacro*{cite}{% | ||||
|   \iffieldundef{shorthand} | ||||
|     {\ifnameundef{labelname} | ||||
|        {} | ||||
|        {\printnames{labelname}% | ||||
|         \setunit{\nametitledelim}}% | ||||
|      \usebibmacro{cite:title}}% | ||||
|     {\usebibmacro{cite:shorthand}}} | ||||
|  | ||||
| \newbibmacro*{citetitle}{% | ||||
|   \iffieldundef{shorthand} | ||||
|     {\usebibmacro{cite:title}}% | ||||
|     {\usebibmacro{cite:shorthand}}} | ||||
|  | ||||
| \newbibmacro*{textcite}{% | ||||
|   \ifnameundef{labelname} | ||||
|     {} | ||||
|     {\printnames{labelname}% | ||||
|      \setunit{% | ||||
|        \global\booltrue{cbx:parens}% | ||||
|        \addspace\bibopenparen}}% | ||||
|   \ifnumequal{\value{citecount}}{1} | ||||
|     {\usebibmacro{prenote}} | ||||
|     {}% | ||||
|   \iffieldundef{shorthand} | ||||
|     {\usebibmacro{cite:title}}% | ||||
|     {\usebibmacro{cite:shorthand}}} | ||||
|  | ||||
| \newbibmacro*{cite:title}{% | ||||
|   \printtext[bibhyperref]{% | ||||
|     \printfield[citetitle]{labeltitle}}} | ||||
|  | ||||
| \newbibmacro*{cite:shorthand}{% | ||||
|   \printtext[bibhyperref]{\printfield{shorthand}}} | ||||
|  | ||||
| \newbibmacro*{textcite:postnote}{% | ||||
|   \iffieldundef{postnote} | ||||
|     {\ifbool{cbx:parens} | ||||
|        {\bibcloseparen} | ||||
|        {}} | ||||
|     {\ifbool{cbx:parens} | ||||
|        {\postnotedelim} | ||||
|        {\addspace\bibopenparen}% | ||||
|      \printfield{postnote}\bibcloseparen}} | ||||
|  | ||||
| \DeclareCiteCommand{\cite} | ||||
|   {\usebibmacro{prenote}} | ||||
|   {\usebibmacro{citeindex}% | ||||
|    \usebibmacro{cite}} | ||||
|   {\multicitedelim} | ||||
|   {\usebibmacro{postnote}} | ||||
|  | ||||
| \DeclareCiteCommand*{\cite} | ||||
|   {\usebibmacro{prenote}} | ||||
|   {\usebibmacro{citeindex}% | ||||
|    \usebibmacro{citetitle}} | ||||
|   {\multicitedelim} | ||||
|   {\usebibmacro{postnote}} | ||||
|  | ||||
| \DeclareCiteCommand{\parencite}[\mkbibparens] | ||||
|   {\usebibmacro{prenote}} | ||||
|   {\usebibmacro{citeindex}% | ||||
|    \usebibmacro{cite}} | ||||
|   {\multicitedelim} | ||||
|   {\usebibmacro{postnote}} | ||||
|  | ||||
| \DeclareCiteCommand*{\parencite}[\mkbibparens] | ||||
|   {\usebibmacro{prenote}} | ||||
|   {\usebibmacro{citeindex}% | ||||
|    \usebibmacro{citetitle}} | ||||
|   {\multicitedelim} | ||||
|   {\usebibmacro{postnote}} | ||||
|  | ||||
| \DeclareCiteCommand{\footcite}[\mkbibfootnote] | ||||
|   {\usebibmacro{prenote}} | ||||
|   {\usebibmacro{citeindex}% | ||||
|    \usebibmacro{cite}} | ||||
|   {\multicitedelim} | ||||
|   {\usebibmacro{postnote}} | ||||
|  | ||||
| \DeclareCiteCommand{\footcitetext}[\mkbibfootnotetext] | ||||
|   {\usebibmacro{prenote}} | ||||
|   {\usebibmacro{citeindex}% | ||||
|    \usebibmacro{cite}} | ||||
|   {\multicitedelim} | ||||
|   {\usebibmacro{postnote}} | ||||
|  | ||||
| \DeclareCiteCommand{\smartcite}[\iffootnote\mkbibparens\mkbibfootnote] | ||||
|   {\usebibmacro{prenote}} | ||||
|   {\usebibmacro{citeindex}% | ||||
|    \usebibmacro{cite}} | ||||
|   {\multicitedelim} | ||||
|   {\usebibmacro{postnote}} | ||||
|  | ||||
| \DeclareCiteCommand{\textcite} | ||||
|   {\boolfalse{cbx:parens}} | ||||
|   {\usebibmacro{citeindex}% | ||||
|    \iffirstcitekey | ||||
|      {\setcounter{textcitetotal}{1}} | ||||
|      {\stepcounter{textcitetotal}% | ||||
|       \textcitedelim}% | ||||
|    \usebibmacro{textcite}} | ||||
|   {\ifbool{cbx:parens} | ||||
|      {\bibcloseparen\global\boolfalse{cbx:parens}} | ||||
|      {}} | ||||
|   {\usebibmacro{textcite:postnote}} | ||||
|  | ||||
| \DeclareMultiCiteCommand{\textcites}{\textcite}{} | ||||
|  | ||||
| \endinput | ||||
							
								
								
									
										554
									
								
								samples/TeX/english.lbx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										554
									
								
								samples/TeX/english.lbx
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,554 @@ | ||||
| \ProvidesFile{english.lbx} | ||||
| [\abx@lbxid] | ||||
|  | ||||
| \DeclareRedundantLanguages{english,american}{english,american,british, | ||||
| canadian,australian,newzealand,USenglish,UKenglish} | ||||
|  | ||||
| \DeclareBibliographyExtras{% | ||||
|   \protected\def\bibrangedash{% | ||||
|     \textendash\penalty\hyphenpenalty}% breakable dash | ||||
|   \protected\def\bibdatedash{\bibrangedash}% | ||||
|   \def\finalandcomma{\addcomma}% | ||||
|   \def\finalandsemicolon{\addsemicolon}% | ||||
|   \protected\def\mkbibordinal#1{% | ||||
|     \begingroup | ||||
|     \@tempcnta0#1\relax\number\@tempcnta | ||||
|     \@whilenum\@tempcnta>100\do{\advance\@tempcnta-100\relax}% | ||||
|     \ifnum\@tempcnta>20 | ||||
|       \@whilenum\@tempcnta>9\do{\advance\@tempcnta-10\relax}% | ||||
|     \fi | ||||
|     \ifcase\@tempcnta th\or st\or nd\or rd\else th\fi | ||||
|     \endgroup}% | ||||
|   \protected\def\mkbibmascord{\mkbibordinal}% | ||||
|   \protected\def\mkbibfemord{\mkbibordinal}% | ||||
|   \protected\def\mkbibneutord{\mkbibordinal}% | ||||
|   \protected\def\mkbibdatelong#1#2#3{% | ||||
|     \iffieldundef{#2} | ||||
|       {} | ||||
|       {\mkbibmonth{\thefield{#2}}% | ||||
|        \iffieldundef{#3} | ||||
|          {\iffieldundef{#1}{}{\space}} | ||||
| 	 {\nobreakspace}}% | ||||
|     \iffieldundef{#3} | ||||
|       {} | ||||
|       {\stripzeros{\thefield{#3}}% | ||||
|        \iffieldundef{#1}{}{,\space}}% | ||||
|      \iffieldbibstring{#1} | ||||
|        {\bibstring{\thefield{#1}}} | ||||
|        {\stripzeros{\thefield{#1}}}}% | ||||
|   \protected\def\mkbibdateshort#1#2#3{% | ||||
|     \iffieldundef{#2} | ||||
|       {} | ||||
|       {\mkdatezeros{\thefield{#2}}% | ||||
|        \iffieldundef{#3} | ||||
|          {\iffieldundef{#1}{}{/}} | ||||
|          {/}}% | ||||
|     \iffieldundef{#3} | ||||
|       {} | ||||
|       {\mkdatezeros{\thefield{#3}}% | ||||
|        \iffieldundef{#1}{}{/}}% | ||||
|      \iffieldbibstring{#1} | ||||
|        {\bibstring{\thefield{#1}}} | ||||
|        {\mkdatezeros{\thefield{#1}}}}% | ||||
|   \savecommand\mkbibrangecomp | ||||
|   \savecommand\mkbibrangecompextra | ||||
|   \savecommand\mkbibrangeterse | ||||
|   \savecommand\mkbibrangeterseextra | ||||
|   \protected\def\mkbibrangecomp{% | ||||
|     \lbx@us@mkbibrangetrunc@long{long}}% | ||||
|   \protected\def\mkbibrangeterse{% | ||||
|     \lbx@us@mkbibrangetrunc@short{short}}% | ||||
|   \protected\def\mkbibrangecompextra{% | ||||
|     \lbx@us@mkbibrangetruncextra@long{long}}% | ||||
|   \protected\def\mkbibrangeterseextra{% | ||||
|     \lbx@us@mkbibrangetruncextra@short{short}}% | ||||
| } | ||||
|  | ||||
| \UndeclareBibliographyExtras{% | ||||
|   \restorecommand\mkbibrangecomp | ||||
|   \restorecommand\mkbibrangecompextra | ||||
|   \restorecommand\mkbibrangeterse | ||||
|   \restorecommand\mkbibrangeterseextra | ||||
| } | ||||
|  | ||||
| \DeclareBibliographyStrings{% | ||||
|   bibliography     = {{Bibliography}{Bibliography}}, | ||||
|   references       = {{References}{References}}, | ||||
|   shorthands       = {{List of Abbreviations}{Abbreviations}}, | ||||
|   editor           = {{editor}{ed\adddot}}, | ||||
|   editors          = {{editors}{eds\adddot}}, | ||||
|   compiler         = {{compiler}{comp\adddot}}, | ||||
|   compilers        = {{compilers}{comp\adddot}}, | ||||
|   redactor         = {{redactor}{red\adddot}}, | ||||
|   redactors        = {{redactors}{red\adddot}}, | ||||
|   reviser          = {{reviser}{rev\adddot}}, | ||||
|   revisers         = {{revisers}{rev\adddot}}, | ||||
|   founder          = {{founder}{found\adddot}}, | ||||
|   founders         = {{founders}{found\adddot}}, | ||||
|   continuator      = {{continued}{cont\adddot}},% FIXME: unsure | ||||
|   continuators     = {{continued}{cont\adddot}},% FIXME: unsure | ||||
|   collaborator     = {{collaborator}{collab\adddot}},% FIXME: unsure | ||||
|   collaborators    = {{collaborators}{collab\adddot}},% FIXME: unsure | ||||
|   translator       = {{translator}{trans\adddot}}, | ||||
|   translators      = {{translators}{trans\adddot}}, | ||||
|   commentator      = {{commentator}{comm\adddot}}, | ||||
|   commentators     = {{commentators}{comm\adddot}}, | ||||
|   annotator        = {{annotator}{annot\adddot}}, | ||||
|   annotators       = {{annotators}{annot\adddot}}, | ||||
|   commentary       = {{commentary}{comm\adddot}}, | ||||
|   annotations      = {{annotations}{annot\adddot}}, | ||||
|   introduction     = {{introduction}{intro\adddot}}, | ||||
|   foreword         = {{foreword}{forew\adddot}}, | ||||
|   afterword        = {{afterword}{afterw\adddot}}, | ||||
|   editortr         = {{editor and translator}% | ||||
|                       {ed\adddotspace and trans\adddot}}, | ||||
|   editorstr        = {{editors and translators}% | ||||
|                       {eds\adddotspace and trans\adddot}}, | ||||
|   editorco         = {{editor and commentator}% | ||||
|                       {ed\adddotspace and comm\adddot}}, | ||||
|   editorsco        = {{editors and commentators}% | ||||
|                       {eds\adddotspace and comm\adddot}}, | ||||
|   editoran         = {{editor and annotator}% | ||||
|                       {ed\adddotspace and annot\adddot}}, | ||||
|   editorsan        = {{editors and annotators}% | ||||
|                       {eds\adddotspace and annot\adddot}}, | ||||
|   editorin         = {{editor and introduction}% | ||||
|                       {ed\adddotspace and introd\adddot}}, | ||||
|   editorsin        = {{editors and introduction}% | ||||
|                       {eds\adddotspace and introd\adddot}}, | ||||
|   editorfo         = {{editor and foreword}% | ||||
|                       {ed\adddotspace and forew\adddot}}, | ||||
|   editorsfo        = {{editors and foreword}% | ||||
|                       {eds\adddotspace and forew\adddot}}, | ||||
|   editoraf         = {{editor and afterword}% | ||||
|                       {ed\adddotspace and afterw\adddot}}, | ||||
|   editorsaf        = {{editors and afterword}% | ||||
|                       {eds\adddotspace and afterw\adddot}}, | ||||
|   editortrco       = {{editor, translator\finalandcomma\ and commentator}% | ||||
|                       {ed.,\addabbrvspace trans\adddot\finalandcomma\ and comm\adddot}}, | ||||
|   editorstrco      = {{editors, translators\finalandcomma\ and commentators}% | ||||
|                       {eds.,\addabbrvspace trans\adddot\finalandcomma\ and comm\adddot}}, | ||||
|   editortran       = {{editor, translator\finalandcomma\ and annotator}% | ||||
|                       {ed.,\addabbrvspace trans\adddot\finalandcomma\ and annot\adddot}}, | ||||
|   editorstran      = {{editors, translators\finalandcomma\ and annotators}% | ||||
|                       {eds.,\addabbrvspace trans\adddot\finalandcomma\ and annot\adddot}}, | ||||
|   editortrin       = {{editor, translator\finalandcomma\ and introduction}% | ||||
|                       {ed.,\addabbrvspace trans\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   editorstrin      = {{editors, translators\finalandcomma\ and introduction}% | ||||
|                       {eds.,\addabbrvspace trans\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   editortrfo       = {{editor, translator\finalandcomma\ and foreword}% | ||||
|                       {ed.,\addabbrvspace trans\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   editorstrfo      = {{editors, translators\finalandcomma\ and foreword}% | ||||
|                       {eds.,\addabbrvspace trans\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   editortraf       = {{editor, translator\finalandcomma\ and afterword}% | ||||
|                       {ed.,\addabbrvspace trans\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   editorstraf      = {{editors, translators\finalandcomma\ and afterword}% | ||||
|                       {eds.,\addabbrvspace trans\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   editorcoin       = {{editor, commentator\finalandcomma\ and introduction}% | ||||
|                       {ed.,\addabbrvspace comm\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   editorscoin      = {{editors, commentators\finalandcomma\ and introduction}% | ||||
|                       {eds.,\addabbrvspace comm\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   editorcofo       = {{editor, commentator\finalandcomma\ and foreword}% | ||||
|                       {ed.,\addabbrvspace comm\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   editorscofo      = {{editors, commentators\finalandcomma\ and foreword}% | ||||
|                       {eds.,\addabbrvspace comm\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   editorcoaf       = {{editor, commentator\finalandcomma\ and afterword}% | ||||
|                       {ed.,\addabbrvspace comm\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   editorscoaf      = {{editors, commentators\finalandcomma\ and afterword}% | ||||
|                       {eds.,\addabbrvspace comm\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   editoranin       = {{editor, annotator\finalandcomma\ and introduction}% | ||||
|                       {ed.,\addabbrvspace annot\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   editorsanin      = {{editors, annotators\finalandcomma\ and introduction}% | ||||
|                       {eds.,\addabbrvspace annot\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   editoranfo       = {{editor, annotator\finalandcomma\ and foreword}% | ||||
|                       {ed.,\addabbrvspace annot\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   editorsanfo      = {{editors, annotators\finalandcomma\ and foreword}% | ||||
|                       {eds.,\addabbrvspace annot\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   editoranaf       = {{editor, annotator\finalandcomma\ and afterword}% | ||||
|                       {ed.,\addabbrvspace annot\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   editorsanaf      = {{editors, annotators\finalandcomma\ and afterword}% | ||||
|                       {eds.,\addabbrvspace annot\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   editortrcoin     = {{editor, translator, commentator\finalandcomma\ and introduction}% | ||||
|                       {ed.,\addabbrvspace trans., comm\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   editorstrcoin    = {{editors, translators, commentators\finalandcomma\ and introduction}% | ||||
|                       {eds.,\addabbrvspace trans., comm\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   editortrcofo     = {{editor, translator, commentator\finalandcomma\ and foreword}% | ||||
|                       {ed.,\addabbrvspace trans., comm\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   editorstrcofo    = {{editors, translators, commentators\finalandcomma\ and foreword}% | ||||
|                       {eds.,\addabbrvspace trans., comm\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   editortrcoaf     = {{editor, translator, commentator\finalandcomma\ and afterword}% | ||||
|                       {ed.,\addabbrvspace trans., comm\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   editorstrcoaf    = {{editors, translators, commentators\finalandcomma\ and afterword}% | ||||
|                       {eds.,\addabbrvspace trans., comm\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   editortranin     = {{editor, translator, annotator\finalandcomma\ and introduction}% | ||||
|                       {ed.,\addabbrvspace trans., annot\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   editorstranin    = {{editors, translators, annotators\finalandcomma\ and introduction}% | ||||
|                       {eds.,\addabbrvspace trans., annot\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   editortranfo     = {{editor, translator, annotator\finalandcomma\ and foreword}% | ||||
|                       {ed.,\addabbrvspace trans., annot\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   editorstranfo    = {{editors, translators, annotators\finalandcomma\ and foreword}% | ||||
|                       {eds.,\addabbrvspace trans., annot\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   editortranaf     = {{editor, translator, annotator\finalandcomma\ and afterword}% | ||||
|                       {ed.,\addabbrvspace trans., annot\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   editorstranaf    = {{editors, translators, annotators\finalandcomma\ and afterword}% | ||||
|                       {eds.,\addabbrvspace trans., annot\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   translatorco     = {{translator and commentator}% | ||||
|                       {trans\adddot\ and comm\adddot}}, | ||||
|   translatorsco    = {{translators and commentators}% | ||||
|                       {trans\adddot\ and comm\adddot}}, | ||||
|   translatoran     = {{translator and annotator}% | ||||
|                       {trans\adddot\ and annot\adddot}}, | ||||
|   translatorsan    = {{translators and annotators}% | ||||
|                       {trans\adddot\ and annot\adddot}}, | ||||
|   translatorin     = {{translation and introduction}% | ||||
|                       {trans\adddot\ and introd\adddot}}, | ||||
|   translatorsin    = {{translation and introduction}% | ||||
|                       {trans\adddot\ and introd\adddot}}, | ||||
|   translatorfo     = {{translation and foreword}% | ||||
|                       {trans\adddot\ and forew\adddot}}, | ||||
|   translatorsfo    = {{translation and foreword}% | ||||
|                       {trans\adddot\ and forew\adddot}}, | ||||
|   translatoraf     = {{translation and afterword}% | ||||
|                       {trans\adddot\ and afterw\adddot}}, | ||||
|   translatorsaf    = {{translation and afterword}% | ||||
|                       {trans\adddot\ and afterw\adddot}}, | ||||
|   translatorcoin   = {{translation, commentary\finalandcomma\ and introduction}% | ||||
|                       {trans., comm\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   translatorscoin  = {{translation, commentary\finalandcomma\ and introduction}% | ||||
|                       {trans., comm\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   translatorcofo   = {{translation, commentary\finalandcomma\ and foreword}% | ||||
|                       {trans., comm\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   translatorscofo  = {{translation, commentary\finalandcomma\ and foreword}% | ||||
|                       {trans., comm\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   translatorcoaf   = {{translation, commentary\finalandcomma\ and afterword}% | ||||
|                       {trans., comm\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   translatorscoaf  = {{translation, commentary\finalandcomma\ and afterword}% | ||||
|                       {trans., comm\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   translatoranin   = {{translation, annotations\finalandcomma\ and introduction}% | ||||
|                       {trans., annot\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   translatorsanin  = {{translation, annotations\finalandcomma\ and introduction}% | ||||
|                       {trans., annot\adddot\finalandcomma\ and introd\adddot}}, | ||||
|   translatoranfo   = {{translation, annotations\finalandcomma\ and foreword}% | ||||
|                       {trans., annot\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   translatorsanfo  = {{translation, annotations\finalandcomma\ and foreword}% | ||||
|                       {trans., annot\adddot\finalandcomma\ and forew\adddot}}, | ||||
|   translatoranaf   = {{translation, annotations\finalandcomma\ and afterword}% | ||||
|                       {trans., annot\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   translatorsanaf  = {{translation, annotations\finalandcomma\ and afterword}% | ||||
|                       {trans., annot\adddot\finalandcomma\ and afterw\adddot}}, | ||||
|   byauthor         = {{by}{by}}, | ||||
|   byeditor         = {{edited by}{ed\adddotspace by}}, | ||||
|   bycompiler       = {{compiled by}{comp\adddotspace by}}, | ||||
|   byredactor       = {{redacted by}{red\adddotspace by}}, | ||||
|   byreviser        = {{revised by}{rev\adddotspace by}}, | ||||
|   byreviewer       = {{reviewed by}{rev\adddotspace by}}, | ||||
|   byfounder        = {{founded by}{found\adddotspace by}}, | ||||
|   bycontinuator    = {{continued by}{cont\adddotspace by}}, | ||||
|   bycollaborator   = {{in collaboration with}{in collab\adddotspace with}},% FIXME: unsure | ||||
|   bytranslator     = {{translated \lbx@lfromlang\ by}{trans\adddot\ \lbx@sfromlang\ by}}, | ||||
|   bycommentator    = {{commented by}{comm\adddot\ by}}, | ||||
|   byannotator      = {{annotated by}{annot\adddot\ by}}, | ||||
|   withcommentator  = {{with a commentary by}{with a comment\adddot\ by}}, | ||||
|   withannotator    = {{with annotations by}{with annots\adddot\ by}}, | ||||
|   withintroduction = {{with an introduction by}{with an intro\adddot\ by}}, | ||||
|   withforeword     = {{with a foreword by}{with a forew\adddot\ by}}, | ||||
|   withafterword    = {{with an afterword by}{with an afterw\adddot\ by}}, | ||||
|   byeditortr       = {{edited and translated \lbx@lfromlang\ by}% | ||||
|                       {ed\adddotspace and trans\adddot\ \lbx@sfromlang\ by}}, | ||||
|   byeditorco       = {{edited and commented by}% | ||||
|                       {ed\adddotspace and comm\adddot\ by}}, | ||||
|   byeditoran       = {{edited and annotated by}% | ||||
|                       {ed\adddotspace and annot\adddot\ by}}, | ||||
|   byeditorin       = {{edited, with an introduction, by}% | ||||
|                       {ed.,\addabbrvspace with an introd., by}}, | ||||
|   byeditorfo       = {{edited, with a foreword, by}% | ||||
|                       {ed.,\addabbrvspace with a forew., by}}, | ||||
|   byeditoraf       = {{edited, with an afterword, by}% | ||||
|                       {ed.,\addabbrvspace with an afterw., by}}, | ||||
|   byeditortrco     = {{edited, translated \lbx@lfromlang\finalandcomma\ and commented by}% | ||||
|                       {ed.,\addabbrvspace trans\adddot\ \lbx@sfromlang\finalandcomma\ and comm\adddot\ by}}, | ||||
|   byeditortran     = {{edited, translated \lbx@lfromlang\finalandcomma\ and annotated by}% | ||||
|                       {ed.,\addabbrvspace trans\adddot\ \lbx@sfromlang\finalandcomma\ and annot\adddot\ by}}, | ||||
|   byeditortrin     = {{edited and translated \lbx@lfromlang, with an introduction, by}% | ||||
|                       {ed\adddotspace and trans\adddot\ \lbx@sfromlang, with an introd., by}}, | ||||
|   byeditortrfo     = {{edited and translated \lbx@lfromlang, with a foreword, by}% | ||||
|                       {ed\adddotspace and trans\adddot\ \lbx@sfromlang, with a forew., by}}, | ||||
|   byeditortraf     = {{edited and translated \lbx@lfromlang, with an afterword, by}% | ||||
|                       {ed\adddotspace and trans\adddot\ \lbx@sfromlang, with an afterw., by}}, | ||||
|   byeditorcoin     = {{edited and commented, with an introduction, by}% | ||||
|                       {ed\adddotspace and comm., with an introd., by}}, | ||||
|   byeditorcofo     = {{edited and commented, with a foreword, by}% | ||||
|                       {ed\adddotspace and comm., with a forew., by}}, | ||||
|   byeditorcoaf     = {{edited and commented, with an afterword, by}% | ||||
|                       {ed\adddotspace and comm., with an afterw., by}}, | ||||
|   byeditoranin     = {{edited and annotated, with an introduction, by}% | ||||
|                       {ed\adddotspace and annot., with an introd., by}}, | ||||
|   byeditoranfo     = {{edited and annotated, with a foreword, by}% | ||||
|                       {ed\adddotspace and annot., with a forew., by}}, | ||||
|   byeditoranaf     = {{edited and annotated, with an afterword, by}% | ||||
|                       {ed\adddotspace and annot., with an afterw., by}}, | ||||
|   byeditortrcoin   = {{edited, translated \lbx@lfromlang\finalandcomma\ and commented, with an introduction, by}% | ||||
|                       {ed.,\addabbrvspace trans\adddot\ \lbx@sfromlang\finalandcomma\ and comm., with an introd., by}}, | ||||
|   byeditortrcofo   = {{edited, translated \lbx@lfromlang\finalandcomma\ and commented, with a foreword, by}% | ||||
|                       {ed.,\addabbrvspace trans\adddot\ \lbx@sfromlang\finalandcomma\ and comm., with a forew., by}}, | ||||
|   byeditortrcoaf   = {{edited, translated \lbx@lfromlang\finalandcomma\ and commented, with an afterword, by}% | ||||
|                       {ed.,\addabbrvspace trans\adddot\ \lbx@sfromlang\finalandcomma\ and comm., with an afterw., by}}, | ||||
|   byeditortranin   = {{edited, translated \lbx@lfromlang\finalandcomma\ and annotated, with an introduction, by}% | ||||
|                       {ed.,\addabbrvspace trans\adddot\ \lbx@sfromlang\finalandcomma\ and annot, with an introd., by}}, | ||||
|   byeditortranfo   = {{edited, translated \lbx@lfromlang\finalandcomma\ and annotated, with a foreword, by}% | ||||
|                       {ed.,\addabbrvspace trans\adddot\ \lbx@sfromlang\finalandcomma\ and annot, with a forew., by}}, | ||||
|   byeditortranaf   = {{edited, translated \lbx@lfromlang\finalandcomma\ and annotated, with an afterword, by}% | ||||
|                       {ed.,\addabbrvspace trans\adddot\ \lbx@sfromlang\finalandcomma\ and annot, with an afterw., by}}, | ||||
|   bytranslatorco   = {{translated \lbx@lfromlang\ and commented by}% | ||||
|                       {trans\adddot\ \lbx@sfromlang\ and comm\adddot\ by}}, | ||||
|   bytranslatoran   = {{translated \lbx@lfromlang\ and annotated by}% | ||||
|                       {trans\adddot\ \lbx@sfromlang\ and annot\adddot\ by}}, | ||||
|   bytranslatorin   = {{translated \lbx@lfromlang, with an introduction, by}% | ||||
|                       {trans\adddot\ \lbx@sfromlang, with an introd., by}}, | ||||
|   bytranslatorfo   = {{translated \lbx@lfromlang, with a foreword, by}% | ||||
|                       {trans\adddot\ \lbx@sfromlang, with a forew., by}}, | ||||
|   bytranslatoraf   = {{translated \lbx@lfromlang, with an afterword, by}% | ||||
|                       {trans\adddot\ \lbx@sfromlang, with an afterw., by}}, | ||||
|   bytranslatorcoin = {{translated \lbx@lfromlang\ and commented, with an introduction, by}% | ||||
|                       {trans\adddot\ \lbx@sfromlang\ and comm., with an introd., by}}, | ||||
|   bytranslatorcofo = {{translated \lbx@lfromlang\ and commented, with a foreword, by}% | ||||
|                       {trans\adddot\ \lbx@sfromlang\ and comm., with a forew., by}}, | ||||
|   bytranslatorcoaf = {{translated \lbx@lfromlang\ and commented, with an afterword, by}% | ||||
|                       {trans\adddot\ \lbx@sfromlang\ and comm., with an afterw., by}}, | ||||
|   bytranslatoranin = {{translated \lbx@lfromlang\ and annotated, with an introduction, by}% | ||||
|                       {trans\adddot\ \lbx@sfromlang\ and annot., with an introd., by}}, | ||||
|   bytranslatoranfo = {{translated \lbx@lfromlang\ and annotated, with a foreword, by}% | ||||
|                       {trans\adddot\ \lbx@sfromlang\ and annot., with a forew., by}}, | ||||
|   bytranslatoranaf = {{translated \lbx@lfromlang\ and annotated, with an afterword, by}% | ||||
|                       {trans\adddot\ \lbx@sfromlang\ and annot., with an afterw., by}}, | ||||
|   and              = {{and}{and}}, | ||||
|   andothers        = {{et\addabbrvspace al\adddot}{et\addabbrvspace al\adddot}}, | ||||
|   andmore          = {{et\addabbrvspace al\adddot}{et\addabbrvspace al\adddot}}, | ||||
|   volume           = {{volume}{vol\adddot}}, | ||||
|   volumes          = {{volumes}{vols\adddot}}, | ||||
|   involumes        = {{in}{in}}, | ||||
|   jourvol          = {{volume}{vol\adddot}}, | ||||
|   jourser          = {{series}{ser\adddot}}, | ||||
|   book             = {{book}{book}}, | ||||
|   part             = {{part}{part}}, | ||||
|   issue            = {{issue}{issue}}, | ||||
|   newseries        = {{new series}{new ser\adddot}}, | ||||
|   oldseries        = {{old series}{old ser\adddot}}, | ||||
|   edition          = {{edition}{ed\adddot}}, | ||||
|   reprint          = {{reprint}{repr\adddot}}, | ||||
|   reprintof        = {{reprint of}{repr\adddotspace of}}, | ||||
|   reprintas        = {{reprinted as}{rpt\adddotspace as}}, | ||||
|   reprintfrom      = {{reprinted from}{repr\adddotspace from}}, | ||||
|   reviewof         = {{review of}{rev\adddotspace of}}, | ||||
|   translationof    = {{translation of}{trans\adddotspace of}}, | ||||
|   translationas    = {{translated as}{trans\adddotspace as}}, | ||||
|   translationfrom  = {{translated from}{trans\adddotspace from}}, | ||||
|   origpubas        = {{originally published as}{orig\adddotspace pub\adddotspace as}}, | ||||
|   origpubin        = {{originally published in}{orig\adddotspace pub\adddotspace in}}, | ||||
|   astitle          = {{as}{as}}, | ||||
|   bypublisher      = {{by}{by}}, | ||||
|   page             = {{page}{p\adddot}}, | ||||
|   pages            = {{pages}{pp\adddot}}, | ||||
|   column           = {{column}{col\adddot}}, | ||||
|   columns          = {{columns}{cols\adddot}}, | ||||
|   line             = {{line}{l\adddot}}, | ||||
|   lines            = {{lines}{ll\adddot}}, | ||||
|   nodate           = {{no date}{n\adddot d\adddot}}, | ||||
|   verse            = {{verse}{v\adddot}}, | ||||
|   verses           = {{verses}{vv\adddot}}, | ||||
|   section          = {{section}{\S}}, | ||||
|   sections         = {{sections}{\S\S}}, | ||||
|   paragraph        = {{paragraph}{par\adddot}}, | ||||
|   paragraphs       = {{paragraphs}{par\adddot}}, | ||||
|   in               = {{in}{in}}, | ||||
|   inseries         = {{in}{in}}, | ||||
|   ofseries         = {{of}{of}}, | ||||
|   number           = {{number}{no\adddot}}, | ||||
|   chapter          = {{chapter}{chap\adddot}}, | ||||
|   mathesis         = {{Master's thesis}{MA\addabbrvspace thesis}}, | ||||
|   phdthesis        = {{PhD\addabbrvspace thesis}{PhD\addabbrvspace thesis}}, | ||||
|   candthesis       = {{Candidate thesis}{Cand\adddotspace thesis}}, | ||||
|   resreport        = {{research report}{research rep\adddot}}, | ||||
|   techreport       = {{technical report}{tech\adddotspace rep\adddot}}, | ||||
|   software         = {{computer software}{comp\adddotspace software}}, | ||||
|   datacd           = {{CD-ROM}{CD-ROM}}, | ||||
|   audiocd          = {{audio CD}{audio CD}}, | ||||
|   version          = {{version}{version}}, | ||||
|   url              = {{address}{address}}, | ||||
|   urlfrom          = {{available from}{available from}}, | ||||
|   urlseen          = {{visited on}{visited on}}, | ||||
|   inpreparation    = {{in preparation}{in preparation}}, | ||||
|   submitted        = {{submitted}{submitted}}, | ||||
|   forthcoming      = {{forthcoming}{forthcoming}}, | ||||
|   inpress          = {{in press}{in press}}, | ||||
|   prepublished     = {{pre-published}{pre-published}}, | ||||
|   citedas          = {{henceforth cited as}{henceforth cited as}}, | ||||
|   thiscite         = {{especially}{esp\adddot}}, | ||||
|   seenote          = {{see note}{see n\adddot}}, | ||||
|   quotedin         = {{quoted in}{qtd\adddotspace in}}, | ||||
|   idem             = {{idem}{idem}}, | ||||
|   idemsm           = {{idem}{idem}}, | ||||
|   idemsf           = {{eadem}{eadem}}, | ||||
|   idemsn           = {{idem}{idem}}, | ||||
|   idempm           = {{eidem}{eidem}}, | ||||
|   idempf           = {{eaedem}{eaedem}}, | ||||
|   idempn           = {{eadem}{eadem}}, | ||||
|   idempp           = {{eidem}{eidem}}, | ||||
|   ibidem           = {{ibidem}{ibid\adddot}}, | ||||
|   opcit            = {{op\adddotspace cit\adddot}{op\adddotspace cit\adddot}}, | ||||
|   loccit           = {{loc\adddotspace cit\adddot}{loc\adddotspace cit\adddot}}, | ||||
|   confer           = {{cf\adddot}{cf\adddot}}, | ||||
|   sequens          = {{sq\adddot}{sq\adddot}}, | ||||
|   sequentes        = {{sqq\adddot}{sqq\adddot}}, | ||||
|   passim           = {{passim}{pass\adddot}}, | ||||
|   see              = {{see}{see}}, | ||||
|   seealso          = {{see also}{see also}}, | ||||
|   backrefpage      = {{cited on page}{cit\adddotspace on p\adddot}}, | ||||
|   backrefpages     = {{cited on pages}{cit\adddotspace on pp\adddot}}, | ||||
|   january          = {{January}{Jan\adddot}}, | ||||
|   february         = {{February}{Feb\adddot}}, | ||||
|   march            = {{March}{Mar\adddot}}, | ||||
|   april            = {{April}{Apr\adddot}}, | ||||
|   may              = {{May}{May}}, | ||||
|   june             = {{June}{June}}, | ||||
|   july             = {{July}{July}}, | ||||
|   august           = {{August}{Aug\adddot}}, | ||||
|   september        = {{September}{Sept\adddot}}, | ||||
|   october          = {{October}{Oct\adddot}}, | ||||
|   november         = {{November}{Nov\adddot}}, | ||||
|   december         = {{December}{Dec\adddot}}, | ||||
|   langamerican     = {{American}{American}}, | ||||
|   langbrazilian    = {{Brazilian}{Brazilian}}, | ||||
|   langcatalan      = {{Catalan}{Catalan}}, | ||||
|   langcroatian     = {{Croatian}{Croatian}}, | ||||
|   langczech        = {{Czech}{Czech}}, | ||||
|   langdanish       = {{Danish}{Danish}}, | ||||
|   langdutch        = {{Dutch}{Dutch}}, | ||||
|   langenglish      = {{English}{English}}, | ||||
|   langfinnish      = {{Finnish}{Finnish}}, | ||||
|   langfrench       = {{French}{French}}, | ||||
|   langgerman       = {{German}{German}}, | ||||
|   langgreek        = {{Greek}{Greek}}, | ||||
|   langitalian      = {{Italian}{Italian}}, | ||||
|   langlatin        = {{Latin}{Latin}}, | ||||
|   langnorwegian    = {{Norwegian}{Norwegian}}, | ||||
|   langpolish       = {{Polish}{Polish}}, | ||||
|   langportuguese   = {{Portuguese}{Portuguese}}, | ||||
|   langrussian      = {{Russian}{Russian}}, | ||||
|   langslovene      = {{Slovene}{Slovene}}, | ||||
|   langspanish      = {{Spanish}{Spanish}}, | ||||
|   langswedish      = {{Swedish}{Swedish}}, | ||||
|   fromamerican     = {{from the American}{from the American}}, | ||||
|   frombrazilian    = {{from the Brazilian}{from the Brazilian}}, | ||||
|   fromcatalan      = {{from the Catalan}{from the Catalan}}, | ||||
|   fromcroatian     = {{from the Croatian}{from the Croatian}}, | ||||
|   fromczech        = {{from the Czech}{from the Czech}}, | ||||
|   fromdanish       = {{from the Danish}{from the Danish}}, | ||||
|   fromdutch        = {{from the Dutch}{from the Dutch}}, | ||||
|   fromenglish      = {{from the English}{from the English}}, | ||||
|   fromfinnish      = {{from the Finnish}{from the Finnish}}, | ||||
|   fromfrench       = {{from the French}{from the French}}, | ||||
|   fromgerman       = {{from the German}{from the German}}, | ||||
|   fromgreek        = {{from the Greek}{from the Greek}}, | ||||
|   fromitalian      = {{from the Italian}{from the Italian}}, | ||||
|   fromlatin        = {{from the Latin}{from the Latin}}, | ||||
|   fromnorwegian    = {{from the Norwegian}{from the Norwegian}}, | ||||
|   frompolish       = {{from the Polish}{from the Polish}}, | ||||
|   fromportuguese   = {{from the Portuguese}{from the Portuguese}}, | ||||
|   fromrussian      = {{from the Russian}{from the Russian}}, | ||||
|   fromslovene      = {{from the Slovene}{from the Slovene}}, | ||||
|   fromspanish      = {{from the Spanish}{from the Spanish}}, | ||||
|   fromswedish      = {{from the Swedish}{from the Swedish}}, | ||||
|   countryde        = {{Germany}{DE}}, | ||||
|   countryeu        = {{European Union}{EU}}, | ||||
|   countryep        = {{European Union}{EP}}, | ||||
|   countryfr        = {{France}{FR}}, | ||||
|   countryuk        = {{United Kingdom}{GB}}, | ||||
|   countryus        = {{United States of America}{US}}, | ||||
|   patent           = {{patent}{pat\adddot}}, | ||||
|   patentde         = {{German patent}{German pat\adddot}}, | ||||
|   patenteu         = {{European patent}{European pat\adddot}}, | ||||
|   patentfr         = {{French patent}{French pat\adddot}}, | ||||
|   patentuk         = {{British patent}{British pat\adddot}}, | ||||
|   patentus         = {{U.S\adddotspace patent}{U.S\adddotspace pat\adddot}}, | ||||
|   patreq           = {{patent request}{pat\adddot\ req\adddot}}, | ||||
|   patreqde         = {{German patent request}{German pat\adddot\ req\adddot}}, | ||||
|   patreqeu         = {{European patent request}{European pat\adddot\ req\adddot}}, | ||||
|   patreqfr         = {{French patent request}{French pat\adddot\ req\adddot}}, | ||||
|   patrequk         = {{British patent request}{British pat\adddot\ req\adddot}}, | ||||
|   patrequs         = {{U.S\adddotspace patent request}{U.S\adddotspace pat\adddot\ req\adddot}}, | ||||
|   file             = {{file}{file}}, | ||||
|   library          = {{library}{library}}, | ||||
|   abstract         = {{abstract}{abstract}}, | ||||
|   annotation       = {{annotations}{annotations}}, | ||||
| } | ||||
|  | ||||
| \protected\gdef\lbx@us@mkbibrangetrunc@long#1#2{% | ||||
|   \iffieldundef{#2year} | ||||
|     {} | ||||
|     {\printtext[#2date]{% | ||||
|        \iffieldsequal{#2year}{#2endyear} | ||||
| 	 {\csuse{mkbibdate#1}{}{#2month}{#2day}} | ||||
| 	 {\csuse{mkbibdate#1}{#2year}{#2month}{#2day}}% | ||||
|        \iffieldundef{#2endyear} | ||||
| 	 {} | ||||
| 	 {\iffieldequalstr{#2endyear}{} | ||||
|             {\mbox{\bibdatedash}} | ||||
| 	    {\bibdatedash | ||||
| 	     \iffieldsequal{#2year}{#2endyear} | ||||
| 	       {\iffieldsequal{#2month}{#2endmonth} | ||||
|         	  {\csuse{mkbibdate#1}{#2endyear}{}{#2endday}} | ||||
| 		  {\csuse{mkbibdate#1}{#2endyear}{#2endmonth}{#2endday}}} | ||||
| 	       {\csuse{mkbibdate#1}{#2endyear}{#2endmonth}{#2endday}}}}}}} | ||||
|  | ||||
| \protected\gdef\lbx@us@mkbibrangetrunc@short#1#2{% | ||||
|   \iffieldundef{#2year} | ||||
|     {} | ||||
|     {\printtext[#2date]{% | ||||
|        \iffieldsequal{#2year}{#2endyear} | ||||
|          {\csuse{mkbibdate#1}{}{#2month}{#2day}} | ||||
|          {\csuse{mkbibdate#1}{#2year}{#2month}{#2day}}% | ||||
|        \iffieldundef{#2endyear} | ||||
|          {} | ||||
|          {\iffieldequalstr{#2endyear}{} | ||||
|             {\mbox{\bibdatedash}} | ||||
|             {\bibdatedash | ||||
|              \csuse{mkbibdate#1}{#2endyear}{#2endmonth}{#2endday}}}}}} | ||||
|  | ||||
| \protected\gdef\lbx@us@mkbibrangetruncextra@long#1#2{% | ||||
|   \iffieldundef{#2year} | ||||
|     {} | ||||
|     {\printtext[#2date]{% | ||||
|        \iffieldsequal{#2year}{#2endyear} | ||||
|          {\csuse{mkbibdate#1}{}{#2month}{#2day}} | ||||
|          {\csuse{mkbibdate#1}{#2year}{#2month}{#2day}}% | ||||
|        \iffieldundef{#2endyear} | ||||
|          {\printfield{extrayear}} | ||||
|          {\iffieldequalstr{#2endyear}{} | ||||
|             {\printfield{extrayear}% | ||||
|              \mbox{\bibdatedash}} | ||||
|             {\bibdatedash | ||||
|              \iffieldsequal{#2year}{#2endyear} | ||||
|                {\iffieldsequal{#2month}{#2endmonth} | ||||
|                   {\csuse{mkbibdate#1}{#2endyear}{}{#2endday}} | ||||
|                   {\csuse{mkbibdate#1}{#2endyear}{#2endmonth}{#2endday}}} | ||||
|                {\csuse{mkbibdate#1}{#2endyear}{#2endmonth}{#2endday}}% | ||||
|              \printfield{extrayear}}}}}} | ||||
|  | ||||
| \protected\gdef\lbx@us@mkbibrangetruncextra@short#1#2{% | ||||
|   \iffieldundef{#2year} | ||||
|     {} | ||||
|     {\printtext[#2date]{% | ||||
|        \iffieldsequal{#2year}{#2endyear} | ||||
|          {\csuse{mkbibdate#1}{}{#2month}{#2day}} | ||||
|          {\csuse{mkbibdate#1}{#2year}{#2month}{#2day}}% | ||||
|        \iffieldundef{#2endyear} | ||||
|          {\printfield{extrayear}} | ||||
|          {\iffieldequalstr{#2endyear}{} | ||||
|             {\printfield{extrayear}% | ||||
|           \mbox{\bibdatedash}} | ||||
|          {\bibdatedash | ||||
|           \csuse{mkbibdate#1}{#2endyear}{#2endmonth}{#2endday}% | ||||
|        \printfield{extrayear}}}}}} | ||||
|  | ||||
| \endinput | ||||
							
								
								
									
										6
									
								
								samples/TeX/verbose.bbx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								samples/TeX/verbose.bbx
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| \ProvidesFile{verbose.bbx} | ||||
| [\abx@bbxid] | ||||
|  | ||||
| \RequireBibliographyStyle{authortitle} | ||||
|  | ||||
| \endinput | ||||
							
								
								
									
										542
									
								
								samples/XML/filenames/.cproject
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										542
									
								
								samples/XML/filenames/.cproject
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,542 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||
| <?fileVersion 4.0.0?> | ||||
|  | ||||
| <cproject storage_type_id="org.eclipse.cdt.core.XmlProjectDescriptionStorage"> | ||||
| 	<storageModule moduleId="org.eclipse.cdt.core.settings"> | ||||
| 		<cconfiguration id="cdt.managedbuild.config.gnu.exe.debug.1803931088"> | ||||
| 			<storageModule buildSystemId="org.eclipse.cdt.managedbuilder.core.configurationDataProvider" id="cdt.managedbuild.config.gnu.exe.debug.1803931088" moduleId="org.eclipse.cdt.core.settings" name="Debug"> | ||||
| 				<externalSettings/> | ||||
| 				<extensions> | ||||
| 					<extension id="org.eclipse.cdt.core.ELF" point="org.eclipse.cdt.core.BinaryParser"/> | ||||
| 					<extension id="org.eclipse.cdt.core.GCCErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||
| 					<extension id="org.eclipse.cdt.core.GASErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||
| 					<extension id="org.eclipse.cdt.core.GLDErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||
| 					<extension id="org.eclipse.cdt.core.GmakeErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||
| 					<extension id="org.eclipse.cdt.core.CWDLocator" point="org.eclipse.cdt.core.ErrorParser"/> | ||||
| 				</extensions> | ||||
| 			</storageModule> | ||||
| 			<storageModule moduleId="cdtBuildSystem" version="4.0.0"> | ||||
| 				<configuration artifactName="Graph抽象資料結構" buildArtefactType="org.eclipse.cdt.build.core.buildArtefactType.exe" buildProperties="org.eclipse.cdt.build.core.buildType=org.eclipse.cdt.build.core.buildType.debug,org.eclipse.cdt.build.core.buildArtefactType=org.eclipse.cdt.build.core.buildArtefactType.exe" cleanCommand="rm -rf" description="" id="cdt.managedbuild.config.gnu.exe.debug.1803931088" name="Debug" parent="cdt.managedbuild.config.gnu.exe.debug"> | ||||
| 					<folderInfo id="cdt.managedbuild.config.gnu.exe.debug.1803931088." name="/" resourcePath=""> | ||||
| 						<toolChain id="cdt.managedbuild.toolchain.gnu.exe.debug.1808064337" name="Linux GCC" superClass="cdt.managedbuild.toolchain.gnu.exe.debug"> | ||||
| 							<targetPlatform id="cdt.managedbuild.target.gnu.platform.exe.debug.475427293" name="Debug Platform" superClass="cdt.managedbuild.target.gnu.platform.exe.debug"/> | ||||
| 							<builder buildPath="${workspace_loc:/Graph抽象資料結構/Debug}" id="cdt.managedbuild.target.gnu.builder.exe.debug.939020465" keepEnvironmentInBuildfile="false" managedBuildOn="true" name="Gnu Make Builder" superClass="cdt.managedbuild.target.gnu.builder.exe.debug"/> | ||||
| 							<tool id="cdt.managedbuild.tool.gnu.archiver.base.1433738663" name="GCC Archiver" superClass="cdt.managedbuild.tool.gnu.archiver.base"/> | ||||
| 							<tool id="cdt.managedbuild.tool.gnu.cpp.compiler.exe.debug.1829995894" name="GCC C++ Compiler" superClass="cdt.managedbuild.tool.gnu.cpp.compiler.exe.debug"> | ||||
| 								<option id="gnu.cpp.compiler.exe.debug.option.optimization.level.442000851" name="Optimization Level" superClass="gnu.cpp.compiler.exe.debug.option.optimization.level" value="gnu.cpp.compiler.optimization.level.none" valueType="enumerated"/> | ||||
| 								<option id="gnu.cpp.compiler.exe.debug.option.debugging.level.508927038" name="Debug Level" superClass="gnu.cpp.compiler.exe.debug.option.debugging.level" value="gnu.cpp.compiler.debugging.level.max" valueType="enumerated"/> | ||||
| 								<option id="gnu.cpp.compiler.option.include.paths.343012625" name="Include paths (-I)" superClass="gnu.cpp.compiler.option.include.paths"/> | ||||
| 								<option id="gnu.cpp.compiler.option.preprocessor.def.432825827" name="Defined symbols (-D)" superClass="gnu.cpp.compiler.option.preprocessor.def" valueType="definedSymbols"> | ||||
| 									<listOptionValue builtIn="false" value="DEBUG"/> | ||||
| 								</option> | ||||
| 								<inputType id="cdt.managedbuild.tool.gnu.cpp.compiler.input.1791758539" superClass="cdt.managedbuild.tool.gnu.cpp.compiler.input"/> | ||||
| 							</tool> | ||||
| 							<tool id="cdt.managedbuild.tool.gnu.c.compiler.exe.debug.1529597285" name="GCC C Compiler" superClass="cdt.managedbuild.tool.gnu.c.compiler.exe.debug"> | ||||
| 								<option defaultValue="gnu.c.optimization.level.none" id="gnu.c.compiler.exe.debug.option.optimization.level.1364110929" name="Optimization Level" superClass="gnu.c.compiler.exe.debug.option.optimization.level" valueType="enumerated"/> | ||||
| 								<option id="gnu.c.compiler.exe.debug.option.debugging.level.1080217050" name="Debug Level" superClass="gnu.c.compiler.exe.debug.option.debugging.level" value="gnu.c.debugging.level.max" valueType="enumerated"/> | ||||
| 								<option id="gnu.c.compiler.option.include.paths.1256182591" name="Include paths (-I)" superClass="gnu.c.compiler.option.include.paths"/> | ||||
| 								<option id="gnu.c.compiler.option.preprocessor.def.symbols.1858410383" name="Defined symbols (-D)" superClass="gnu.c.compiler.option.preprocessor.def.symbols" valueType="definedSymbols"> | ||||
| 									<listOptionValue builtIn="false" value="DEBUG"/> | ||||
| 								</option> | ||||
| 								<inputType id="cdt.managedbuild.tool.gnu.c.compiler.input.24351646" superClass="cdt.managedbuild.tool.gnu.c.compiler.input"/> | ||||
| 							</tool> | ||||
| 							<tool id="cdt.managedbuild.tool.gnu.c.linker.exe.debug.1253142147" name="GCC C Linker" superClass="cdt.managedbuild.tool.gnu.c.linker.exe.debug"/> | ||||
| 							<tool id="cdt.managedbuild.tool.gnu.cpp.linker.exe.debug.2139040707" name="GCC C++ Linker" superClass="cdt.managedbuild.tool.gnu.cpp.linker.exe.debug"> | ||||
| 								<inputType id="cdt.managedbuild.tool.gnu.cpp.linker.input.1870115166" superClass="cdt.managedbuild.tool.gnu.cpp.linker.input"> | ||||
| 									<additionalInput kind="additionalinputdependency" paths="$(USER_OBJS)"/> | ||||
| 									<additionalInput kind="additionalinput" paths="$(LIBS)"/> | ||||
| 								</inputType> | ||||
| 							</tool> | ||||
| 							<tool id="cdt.managedbuild.tool.gnu.assembler.exe.debug.2025871733" name="GCC Assembler" superClass="cdt.managedbuild.tool.gnu.assembler.exe.debug"> | ||||
| 								<inputType id="cdt.managedbuild.tool.gnu.assembler.input.1643445921" superClass="cdt.managedbuild.tool.gnu.assembler.input"/> | ||||
| 							</tool> | ||||
| 						</toolChain> | ||||
| 					</folderInfo> | ||||
| 					<sourceEntries> | ||||
| 						<entry flags="VALUE_WORKSPACE_PATH|RESOLVED" kind="sourcePath" name=""/> | ||||
| 					</sourceEntries> | ||||
| 				</configuration> | ||||
| 			</storageModule> | ||||
| 			<storageModule moduleId="org.eclipse.cdt.core.externalSettings"/> | ||||
| 			<storageModule moduleId="org.eclipse.cdt.internal.ui.text.commentOwnerProjectMappings"/> | ||||
| 			<storageModule moduleId="org.eclipse.cdt.core.language.mapping"/> | ||||
| 		</cconfiguration> | ||||
| 		<cconfiguration id="cdt.managedbuild.config.gnu.exe.release.32754498"> | ||||
| 			<storageModule buildSystemId="org.eclipse.cdt.managedbuilder.core.configurationDataProvider" id="cdt.managedbuild.config.gnu.exe.release.32754498" moduleId="org.eclipse.cdt.core.settings" name="Release"> | ||||
| 				<externalSettings/> | ||||
| 				<extensions> | ||||
| 					<extension id="org.eclipse.cdt.core.ELF" point="org.eclipse.cdt.core.BinaryParser"/> | ||||
| 					<extension id="org.eclipse.cdt.core.GCCErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||
| 					<extension id="org.eclipse.cdt.core.GASErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||
| 					<extension id="org.eclipse.cdt.core.GLDErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||
| 					<extension id="org.eclipse.cdt.core.GmakeErrorParser" point="org.eclipse.cdt.core.ErrorParser"/> | ||||
| 					<extension id="org.eclipse.cdt.core.CWDLocator" point="org.eclipse.cdt.core.ErrorParser"/> | ||||
| 				</extensions> | ||||
| 			</storageModule> | ||||
| 			<storageModule moduleId="cdtBuildSystem" version="4.0.0"> | ||||
| 				<configuration artifactName="Graph抽象資料結構" buildArtefactType="org.eclipse.cdt.build.core.buildArtefactType.exe" buildProperties="org.eclipse.cdt.build.core.buildType=org.eclipse.cdt.build.core.buildType.release,org.eclipse.cdt.build.core.buildArtefactType=org.eclipse.cdt.build.core.buildArtefactType.exe" cleanCommand="rm -rf" description="" id="cdt.managedbuild.config.gnu.exe.release.32754498" name="Release" parent="cdt.managedbuild.config.gnu.exe.release"> | ||||
| 					<folderInfo id="cdt.managedbuild.config.gnu.exe.release.32754498." name="/" resourcePath=""> | ||||
| 						<toolChain id="cdt.managedbuild.toolchain.gnu.exe.release.1285242355" name="Linux GCC" superClass="cdt.managedbuild.toolchain.gnu.exe.release"> | ||||
| 							<targetPlatform id="cdt.managedbuild.target.gnu.platform.exe.release.1495976902" name="Debug Platform" superClass="cdt.managedbuild.target.gnu.platform.exe.release"/> | ||||
| 							<builder buildPath="${workspace_loc:/Graph抽象資料結構/Release}" id="cdt.managedbuild.target.gnu.builder.exe.release.1973733698" keepEnvironmentInBuildfile="false" managedBuildOn="true" name="Gnu Make Builder" superClass="cdt.managedbuild.target.gnu.builder.exe.release"/> | ||||
| 							<tool id="cdt.managedbuild.tool.gnu.archiver.base.1600860298" name="GCC Archiver" superClass="cdt.managedbuild.tool.gnu.archiver.base"/> | ||||
| 							<tool id="cdt.managedbuild.tool.gnu.cpp.compiler.exe.release.1473926095" name="GCC C++ Compiler" superClass="cdt.managedbuild.tool.gnu.cpp.compiler.exe.release"> | ||||
| 								<option id="gnu.cpp.compiler.exe.release.option.optimization.level.1632726668" name="Optimization Level" superClass="gnu.cpp.compiler.exe.release.option.optimization.level" value="gnu.cpp.compiler.optimization.level.most" valueType="enumerated"/> | ||||
| 								<option id="gnu.cpp.compiler.exe.release.option.debugging.level.2009085397" name="Debug Level" superClass="gnu.cpp.compiler.exe.release.option.debugging.level" value="gnu.cpp.compiler.debugging.level.none" valueType="enumerated"/> | ||||
| 								<option id="gnu.cpp.compiler.option.include.paths.1869632172" name="Include paths (-I)" superClass="gnu.cpp.compiler.option.include.paths"/> | ||||
| 								<option id="gnu.cpp.compiler.option.preprocessor.def.1246679568" name="Defined symbols (-D)" superClass="gnu.cpp.compiler.option.preprocessor.def" valueType="definedSymbols"> | ||||
| 									<listOptionValue builtIn="false" value="NDEBUG"/> | ||||
| 								</option> | ||||
| 								<inputType id="cdt.managedbuild.tool.gnu.cpp.compiler.input.1744095710" superClass="cdt.managedbuild.tool.gnu.cpp.compiler.input"/> | ||||
| 							</tool> | ||||
| 							<tool id="cdt.managedbuild.tool.gnu.c.compiler.exe.release.478520411" name="GCC C Compiler" superClass="cdt.managedbuild.tool.gnu.c.compiler.exe.release"> | ||||
| 								<option defaultValue="gnu.c.optimization.level.most" id="gnu.c.compiler.exe.release.option.optimization.level.1683736183" name="Optimization Level" superClass="gnu.c.compiler.exe.release.option.optimization.level" valueType="enumerated"/> | ||||
| 								<option id="gnu.c.compiler.exe.release.option.debugging.level.171063916" name="Debug Level" superClass="gnu.c.compiler.exe.release.option.debugging.level" value="gnu.c.debugging.level.none" valueType="enumerated"/> | ||||
| 								<option id="gnu.c.compiler.option.include.paths.1466846915" name="Include paths (-I)" superClass="gnu.c.compiler.option.include.paths"/> | ||||
| 								<option id="gnu.c.compiler.option.preprocessor.def.symbols.659261280" name="Defined symbols (-D)" superClass="gnu.c.compiler.option.preprocessor.def.symbols" valueType="definedSymbols"> | ||||
| 									<listOptionValue builtIn="false" value="NDEBUG"/> | ||||
| 								</option> | ||||
| 								<inputType id="cdt.managedbuild.tool.gnu.c.compiler.input.892999416" superClass="cdt.managedbuild.tool.gnu.c.compiler.input"/> | ||||
| 							</tool> | ||||
| 							<tool id="cdt.managedbuild.tool.gnu.c.linker.exe.release.977357087" name="GCC C Linker" superClass="cdt.managedbuild.tool.gnu.c.linker.exe.release"/> | ||||
| 							<tool id="cdt.managedbuild.tool.gnu.cpp.linker.exe.release.1587341853" name="GCC C++ Linker" superClass="cdt.managedbuild.tool.gnu.cpp.linker.exe.release"> | ||||
| 								<inputType id="cdt.managedbuild.tool.gnu.cpp.linker.input.1655647987" superClass="cdt.managedbuild.tool.gnu.cpp.linker.input"> | ||||
| 									<additionalInput kind="additionalinputdependency" paths="$(USER_OBJS)"/> | ||||
| 									<additionalInput kind="additionalinput" paths="$(LIBS)"/> | ||||
| 								</inputType> | ||||
| 							</tool> | ||||
| 							<tool id="cdt.managedbuild.tool.gnu.assembler.exe.release.721843795" name="GCC Assembler" superClass="cdt.managedbuild.tool.gnu.assembler.exe.release"> | ||||
| 								<inputType id="cdt.managedbuild.tool.gnu.assembler.input.827453761" superClass="cdt.managedbuild.tool.gnu.assembler.input"/> | ||||
| 							</tool> | ||||
| 						</toolChain> | ||||
| 					</folderInfo> | ||||
| 					<sourceEntries> | ||||
| 						<entry flags="VALUE_WORKSPACE_PATH|RESOLVED" kind="sourcePath" name=""/> | ||||
| 					</sourceEntries> | ||||
| 				</configuration> | ||||
| 			</storageModule> | ||||
| 			<storageModule moduleId="org.eclipse.cdt.core.externalSettings"/> | ||||
| 			<storageModule moduleId="org.eclipse.cdt.internal.ui.text.commentOwnerProjectMappings"/> | ||||
| 			<storageModule moduleId="org.eclipse.cdt.core.language.mapping"/> | ||||
| 		</cconfiguration> | ||||
| 	</storageModule> | ||||
| 	<storageModule moduleId="cdtBuildSystem" version="4.0.0"> | ||||
| 		<project id="Graph抽象資料結構.cdt.managedbuild.target.gnu.exe.1361850129" name="Executable" projectType="cdt.managedbuild.target.gnu.exe"/> | ||||
| 	</storageModule> | ||||
| 	<storageModule moduleId="scannerConfiguration"> | ||||
| 		<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId="org.eclipse.cdt.make.core.GCCStandardMakePerProjectProfile"/> | ||||
| 		<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerProjectProfile"> | ||||
| 			<buildOutputProvider> | ||||
| 				<openAction enabled="true" filePath=""/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</buildOutputProvider> | ||||
| 			<scannerInfoProvider id="specsFile"> | ||||
| 				<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</scannerInfoProvider> | ||||
| 		</profile> | ||||
| 		<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerFileProfile"> | ||||
| 			<buildOutputProvider> | ||||
| 				<openAction enabled="true" filePath=""/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</buildOutputProvider> | ||||
| 			<scannerInfoProvider id="makefileGenerator"> | ||||
| 				<runAction arguments="-f ${project_name}_scd.mk" command="make" useDefault="true"/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</scannerInfoProvider> | ||||
| 		</profile> | ||||
| 		<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfile"> | ||||
| 			<buildOutputProvider> | ||||
| 				<openAction enabled="true" filePath=""/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</buildOutputProvider> | ||||
| 			<scannerInfoProvider id="specsFile"> | ||||
| 				<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</scannerInfoProvider> | ||||
| 		</profile> | ||||
| 		<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileCPP"> | ||||
| 			<buildOutputProvider> | ||||
| 				<openAction enabled="true" filePath=""/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</buildOutputProvider> | ||||
| 			<scannerInfoProvider id="specsFile"> | ||||
| 				<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.cpp" command="g++" useDefault="true"/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</scannerInfoProvider> | ||||
| 		</profile> | ||||
| 		<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC"> | ||||
| 			<buildOutputProvider> | ||||
| 				<openAction enabled="true" filePath=""/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</buildOutputProvider> | ||||
| 			<scannerInfoProvider id="specsFile"> | ||||
| 				<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.c" command="gcc" useDefault="true"/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</scannerInfoProvider> | ||||
| 		</profile> | ||||
| 		<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfile"> | ||||
| 			<buildOutputProvider> | ||||
| 				<openAction enabled="true" filePath=""/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</buildOutputProvider> | ||||
| 			<scannerInfoProvider id="specsFile"> | ||||
| 				<runAction arguments="-c 'gcc -E -P -v -dD "${plugin_state_location}/${specs_file}"'" command="sh" useDefault="true"/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</scannerInfoProvider> | ||||
| 		</profile> | ||||
| 		<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileCPP"> | ||||
| 			<buildOutputProvider> | ||||
| 				<openAction enabled="true" filePath=""/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</buildOutputProvider> | ||||
| 			<scannerInfoProvider id="specsFile"> | ||||
| 				<runAction arguments="-c 'g++ -E -P -v -dD "${plugin_state_location}/specs.cpp"'" command="sh" useDefault="true"/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</scannerInfoProvider> | ||||
| 		</profile> | ||||
| 		<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileC"> | ||||
| 			<buildOutputProvider> | ||||
| 				<openAction enabled="true" filePath=""/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</buildOutputProvider> | ||||
| 			<scannerInfoProvider id="specsFile"> | ||||
| 				<runAction arguments="-c 'gcc -E -P -v -dD "${plugin_state_location}/specs.c"'" command="sh" useDefault="true"/> | ||||
| 				<parser enabled="true"/> | ||||
| 			</scannerInfoProvider> | ||||
| 		</profile> | ||||
| 		<scannerConfigBuildInfo instanceId="cdt.managedbuild.config.gnu.exe.debug.1803931088;cdt.managedbuild.config.gnu.exe.debug.1803931088.;cdt.managedbuild.tool.gnu.c.compiler.exe.debug.1529597285;cdt.managedbuild.tool.gnu.c.compiler.input.24351646"> | ||||
| 			<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC"/> | ||||
| 			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerProjectProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerFileProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="makefileGenerator"> | ||||
| 					<runAction arguments="-f ${project_name}_scd.mk" command="make" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileCPP"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.cpp" command="g++" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.c" command="gcc" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-c 'gcc -E -P -v -dD "${plugin_state_location}/${specs_file}"'" command="sh" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileCPP"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-c 'g++ -E -P -v -dD "${plugin_state_location}/specs.cpp"'" command="sh" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileC"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-c 'gcc -E -P -v -dD "${plugin_state_location}/specs.c"'" command="sh" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 		</scannerConfigBuildInfo> | ||||
| 		<scannerConfigBuildInfo instanceId="cdt.managedbuild.config.gnu.exe.release.32754498;cdt.managedbuild.config.gnu.exe.release.32754498.;cdt.managedbuild.tool.gnu.cpp.compiler.exe.release.1473926095;cdt.managedbuild.tool.gnu.cpp.compiler.input.1744095710"> | ||||
| 			<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileCPP"/> | ||||
| 			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerProjectProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerFileProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="makefileGenerator"> | ||||
| 					<runAction arguments="-f ${project_name}_scd.mk" command="make" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileCPP"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.cpp" command="g++" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.c" command="gcc" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-c 'gcc -E -P -v -dD "${plugin_state_location}/${specs_file}"'" command="sh" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileCPP"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-c 'g++ -E -P -v -dD "${plugin_state_location}/specs.cpp"'" command="sh" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileC"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-c 'gcc -E -P -v -dD "${plugin_state_location}/specs.c"'" command="sh" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 		</scannerConfigBuildInfo> | ||||
| 		<scannerConfigBuildInfo instanceId="cdt.managedbuild.config.gnu.exe.debug.1803931088;cdt.managedbuild.config.gnu.exe.debug.1803931088.;cdt.managedbuild.tool.gnu.cpp.compiler.exe.debug.1829995894;cdt.managedbuild.tool.gnu.cpp.compiler.input.1791758539"> | ||||
| 			<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileCPP"/> | ||||
| 			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerProjectProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerFileProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="makefileGenerator"> | ||||
| 					<runAction arguments="-f ${project_name}_scd.mk" command="make" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileCPP"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.cpp" command="g++" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.c" command="gcc" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-c 'gcc -E -P -v -dD "${plugin_state_location}/${specs_file}"'" command="sh" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileCPP"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-c 'g++ -E -P -v -dD "${plugin_state_location}/specs.cpp"'" command="sh" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileC"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-c 'gcc -E -P -v -dD "${plugin_state_location}/specs.c"'" command="sh" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 		</scannerConfigBuildInfo> | ||||
| 		<scannerConfigBuildInfo instanceId="cdt.managedbuild.config.gnu.exe.release.32754498;cdt.managedbuild.config.gnu.exe.release.32754498.;cdt.managedbuild.tool.gnu.c.compiler.exe.release.478520411;cdt.managedbuild.tool.gnu.c.compiler.input.892999416"> | ||||
| 			<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC"/> | ||||
| 			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerProjectProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerFileProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="makefileGenerator"> | ||||
| 					<runAction arguments="-f ${project_name}_scd.mk" command="make" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileCPP"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.cpp" command="g++" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.c" command="gcc" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfile"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-c 'gcc -E -P -v -dD "${plugin_state_location}/${specs_file}"'" command="sh" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileCPP"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-c 'g++ -E -P -v -dD "${plugin_state_location}/specs.cpp"'" command="sh" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileC"> | ||||
| 				<buildOutputProvider> | ||||
| 					<openAction enabled="true" filePath=""/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</buildOutputProvider> | ||||
| 				<scannerInfoProvider id="specsFile"> | ||||
| 					<runAction arguments="-c 'gcc -E -P -v -dD "${plugin_state_location}/specs.c"'" command="sh" useDefault="true"/> | ||||
| 					<parser enabled="true"/> | ||||
| 				</scannerInfoProvider> | ||||
| 			</profile> | ||||
| 		</scannerConfigBuildInfo> | ||||
| 	</storageModule> | ||||
| 	<storageModule moduleId="refreshScope"/> | ||||
| </cproject> | ||||
| @@ -140,6 +140,13 @@ class TestBlob < Test::Unit::TestCase | ||||
|     assert !blob("Perl/script.pl").binary? | ||||
|   end | ||||
|  | ||||
|   def test_all_binary | ||||
|     Samples.each do |sample| | ||||
|       blob = blob(sample[:path]) | ||||
|       assert ! (blob.likely_binary? || blob.binary?), "#{sample[:path]} is a binary file" | ||||
|     end | ||||
|   end | ||||
|  | ||||
|   def test_text | ||||
|     assert blob("Text/README").text? | ||||
|     assert blob("Text/dump.sql").text? | ||||
| @@ -185,9 +192,9 @@ class TestBlob < Test::Unit::TestCase | ||||
|     assert !blob("Text/README").generated? | ||||
|  | ||||
|     # Xcode project files | ||||
|     assert blob("XML/MainMenu.xib").generated? | ||||
|     assert !blob("XML/MainMenu.xib").generated? | ||||
|     assert blob("Binary/MainMenu.nib").generated? | ||||
|     assert blob("XML/project.pbxproj").generated? | ||||
|     assert !blob("XML/project.pbxproj").generated? | ||||
|  | ||||
|     # Gemfile.locks | ||||
|     assert blob("Gemfile.lock").generated? | ||||
| @@ -386,6 +393,10 @@ class TestBlob < Test::Unit::TestCase | ||||
|     # NuGet Packages | ||||
|     assert blob("packages/Modernizr.2.0.6/Content/Scripts/modernizr-2.0.6-development-only.js").vendored? | ||||
|  | ||||
|     # Font Awesome | ||||
|     assert blob("some/asset/path/font-awesome.min.css").vendored? | ||||
|     assert blob("some/asset/path/font-awesome.css").vendored? | ||||
|  | ||||
|     # Normalize | ||||
|     assert blob("some/asset/path/normalize.css").vendored? | ||||
|  | ||||
| @@ -406,6 +417,11 @@ class TestBlob < Test::Unit::TestCase | ||||
|     assert blob("cordova-2.1.0.js").vendored? | ||||
|     assert blob("cordova-2.1.0.min.js").vendored? | ||||
|  | ||||
|     # Foundation js | ||||
|     assert blob("foundation.js").vendored? | ||||
|     assert blob("foundation.min.js").vendored? | ||||
|     assert blob("foundation.abide.js").vendored? | ||||
|  | ||||
|     # Vagrant | ||||
|     assert blob("Vagrantfile").vendored? | ||||
|  | ||||
|   | ||||
| @@ -17,6 +17,7 @@ class TestLanguage < Test::Unit::TestCase | ||||
|     assert_equal Lexer['C'], Language['OpenCL'].lexer | ||||
|     assert_equal Lexer['C'], Language['XS'].lexer | ||||
|     assert_equal Lexer['C++'], Language['C++'].lexer | ||||
|     assert_equal Lexer['Chapel'], Language['Chapel'].lexer | ||||
|     assert_equal Lexer['Coldfusion HTML'], Language['ColdFusion'].lexer | ||||
|     assert_equal Lexer['Coq'], Language['Coq'].lexer | ||||
|     assert_equal Lexer['FSharp'], Language['F#'].lexer | ||||
| @@ -32,6 +33,7 @@ class TestLanguage < Test::Unit::TestCase | ||||
|     assert_equal Lexer['Java'], Language['ChucK'].lexer | ||||
|     assert_equal Lexer['Java'], Language['Java'].lexer | ||||
|     assert_equal Lexer['JavaScript'], Language['JavaScript'].lexer | ||||
|     assert_equal Lexer['LSL'], Language['LSL'].lexer | ||||
|     assert_equal Lexer['MOOCode'], Language['Moocode'].lexer | ||||
|     assert_equal Lexer['MuPAD'], Language['mupad'].lexer | ||||
|     assert_equal Lexer['NASM'], Language['Assembly'].lexer | ||||
| @@ -45,7 +47,6 @@ class TestLanguage < Test::Unit::TestCase | ||||
|     assert_equal Lexer['Ruby'], Language['Mirah'].lexer | ||||
|     assert_equal Lexer['Ruby'], Language['Ruby'].lexer | ||||
|     assert_equal Lexer['S'], Language['R'].lexer | ||||
|     assert_equal Lexer['Scheme'], Language['Emacs Lisp'].lexer | ||||
|     assert_equal Lexer['Scheme'], Language['Nu'].lexer | ||||
|     assert_equal Lexer['Racket'], Language['Racket'].lexer | ||||
|     assert_equal Lexer['Scheme'], Language['Scheme'].lexer | ||||
| @@ -71,6 +72,7 @@ class TestLanguage < Test::Unit::TestCase | ||||
|     assert_equal Language['C'], Language.find_by_alias('c') | ||||
|     assert_equal Language['C++'], Language.find_by_alias('c++') | ||||
|     assert_equal Language['C++'], Language.find_by_alias('cpp') | ||||
|     assert_equal Language['Chapel'], Language.find_by_alias('chpl') | ||||
|     assert_equal Language['CoffeeScript'], Language.find_by_alias('coffee') | ||||
|     assert_equal Language['CoffeeScript'], Language.find_by_alias('coffee-script') | ||||
|     assert_equal Language['ColdFusion'], Language.find_by_alias('cfm') | ||||
| @@ -167,7 +169,7 @@ class TestLanguage < Test::Unit::TestCase | ||||
|     assert_equal 'pot',           Language['Gettext Catalog'].search_term | ||||
|     assert_equal 'irc',           Language['IRC log'].search_term | ||||
|     assert_equal 'lhs',           Language['Literate Haskell'].search_term | ||||
|     assert_equal 'ruby',          Language['Mirah'].search_term | ||||
|     assert_equal 'mirah',         Language['Mirah'].search_term | ||||
|     assert_equal 'raw',           Language['Raw token data'].search_term | ||||
|     assert_equal 'bash',          Language['Shell'].search_term | ||||
|     assert_equal 'vim',           Language['VimL'].search_term | ||||
| @@ -185,6 +187,7 @@ class TestLanguage < Test::Unit::TestCase | ||||
|  | ||||
|   def test_programming | ||||
|     assert_equal :programming, Language['JavaScript'].type | ||||
|     assert_equal :programming, Language['LSL'].type | ||||
|     assert_equal :programming, Language['Perl'].type | ||||
|     assert_equal :programming, Language['PowerShell'].type | ||||
|     assert_equal :programming, Language['Python'].type | ||||
| @@ -249,13 +252,13 @@ class TestLanguage < Test::Unit::TestCase | ||||
|     assert_equal Language['Nginx'], Language.find_by_filename('nginx.conf').first | ||||
|     assert_equal ['C', 'C++', 'Objective-C'], Language.find_by_filename('foo.h').map(&:name).sort | ||||
|     assert_equal [], Language.find_by_filename('rb') | ||||
|     assert_equal [], Language.find_by_filename('.rb') | ||||
|     assert_equal [], Language.find_by_filename('.nkt') | ||||
|     assert_equal [], Language.find_by_filename('.null') | ||||
|     assert_equal [Language['Shell']], Language.find_by_filename('.bashrc') | ||||
|     assert_equal [Language['Shell']], Language.find_by_filename('bash_profile') | ||||
|     assert_equal [Language['Shell']], Language.find_by_filename('.zshrc') | ||||
|     assert_equal [Language['Clojure']], Language.find_by_filename('riemann.config') | ||||
|     assert_equal [Language['HTML+Django']], Language.find_by_filename('index.jinja') | ||||
|     assert_equal [Language['Chapel']], Language.find_by_filename('examples/hello.chpl') | ||||
|   end | ||||
|  | ||||
|   def test_find_by_shebang | ||||
| @@ -325,6 +328,7 @@ class TestLanguage < Test::Unit::TestCase | ||||
|     assert_equal '#3581ba', Language['Python'].color | ||||
|     assert_equal '#f1e05a', Language['JavaScript'].color | ||||
|     assert_equal '#31859c', Language['TypeScript'].color | ||||
|     assert_equal '#3d9970', Language['LSL'].color | ||||
|   end | ||||
|  | ||||
|   def test_colors | ||||
| @@ -337,6 +341,7 @@ class TestLanguage < Test::Unit::TestCase | ||||
|     assert_equal 'coffee', Language['CoffeeScript'].ace_mode | ||||
|     assert_equal 'csharp', Language['C#'].ace_mode | ||||
|     assert_equal 'css', Language['CSS'].ace_mode | ||||
|     assert_equal 'lsl', Language['LSL'].ace_mode | ||||
|     assert_equal 'javascript', Language['JavaScript'].ace_mode | ||||
|   end | ||||
|  | ||||
| @@ -351,6 +356,7 @@ class TestLanguage < Test::Unit::TestCase | ||||
|   end | ||||
|  | ||||
|   def test_extensions | ||||
|     assert Language['LSL'].extensions.include?('.lsl') | ||||
|     assert Language['Perl'].extensions.include?('.pl') | ||||
|     assert Language['Python'].extensions.include?('.py') | ||||
|     assert Language['Ruby'].extensions.include?('.rb') | ||||
|   | ||||
| @@ -35,15 +35,33 @@ class TestSamples < Test::Unit::TestCase | ||||
|     assert_equal data['tokens_total'], data['language_tokens'].inject(0) { |n, (_, c)| n += c } | ||||
|     assert_equal data['tokens_total'], data['tokens'].inject(0) { |n, (_, ts)| n += ts.inject(0) { |m, (_, c)| m += c } } | ||||
|   end | ||||
|    | ||||
|  | ||||
|   # Check that there aren't samples with extensions that aren't explicitly defined in languages.yml | ||||
|   def test_parity | ||||
|     extensions = Samples::DATA['extnames'] | ||||
|     languages_yml = File.expand_path("../../lib/linguist/languages.yml", __FILE__) | ||||
|     languages = YAML.load_file(languages_yml) | ||||
|  | ||||
|     languages.each do |name, options| | ||||
|       options['extensions'] ||= [] | ||||
|  | ||||
|       if extnames = extensions[name] | ||||
|         extnames.each do |extname| | ||||
|           next if extname == '.script!' | ||||
|           assert options['extensions'].include?(extname), "#{name} has a sample with extension (#{extname}) that isn't explicitly defined in languages.yml" | ||||
|         end | ||||
|       end | ||||
|     end | ||||
|   end | ||||
|  | ||||
|   # If a language extension isn't globally unique then make sure there are samples | ||||
|   def test_presence | ||||
|     Linguist::Language.all.each do |language| | ||||
|       language.all_extensions.each do |extension| | ||||
|         language_matches = Language.find_by_filename("foo#{extension}") | ||||
|          | ||||
|  | ||||
|         # If there is more than one language match for a given extension | ||||
|         # then check that there are examples for that language with the extension  | ||||
|         # then check that there are examples for that language with the extension | ||||
|         if language_matches.length > 1 | ||||
|           language_matches.each do |language| | ||||
|             assert File.directory?("samples/#{language.name}"), "#{language.name} is missing a samples directory" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user