mirror of
				https://github.com/KevinMidboe/linguist.git
				synced 2025-10-29 17:50:22 +00:00 
			
		
		
		
	Compare commits
	
		
			320 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 8a6d7f67ed | ||
|  | bcb016a938 | ||
|  | 065c6c02a8 | ||
|  | f7386fcd72 | ||
|  | df703ef997 | ||
|  | 9f6c421d91 | ||
|  | 91370ae955 | ||
|  | ffc0be191e | ||
|  | 6e9f6da2a2 | ||
|  | c8cb7b7cab | ||
|  | 7baa130d8d | ||
|  | 332d97b57f | ||
|  | 9c0dbdd48e | ||
|  | bec0052065 | ||
|  | 5010f32421 | ||
|  | ded4672ccc | ||
|  | 03bb48cf28 | ||
|  | e71eefe8fc | ||
|  | c203781e1b | ||
|  | 7a2be16d77 | ||
|  | 77126e9e17 | ||
|  | d1d5c61df5 | ||
|  | 09323c8bbc | ||
|  | ac9f82544a | ||
|  | 2e4e602787 | ||
|  | 9d0ba5801b | ||
|  | 0cd7d85ec4 | ||
|  | b0f674e511 | ||
|  | 2b411aad90 | ||
|  | 1c6483a499 | ||
|  | 6edf4498ce | ||
|  | b160a39678 | ||
|  | 86b4de89bd | ||
|  | a35d9a8d29 | ||
|  | 8012876d5e | ||
|  | 2e3e8c5b89 | ||
|  | 5284608942 | ||
|  | ea2c7d8b27 | ||
|  | b0db064d09 | ||
|  | 3ff1e38f6c | ||
|  | b533b682d5 | ||
|  | f87436d499 | ||
|  | 178d4756ef | ||
|  | 5152bd7124 | ||
|  | b5015b6cc7 | ||
|  | 097900a327 | ||
|  | 1d2a6c38c7 | ||
|  | cc87ceb0d5 | ||
|  | a38f77683b | ||
|  | d8da05cde2 | ||
|  | 554b5bfe7f | ||
|  | 86aa4c3f3d | ||
|  | 19b8721225 | ||
|  | 0cb1ebc41e | ||
|  | c7c4883f49 | ||
|  | d8b4d4639c | ||
|  | ebe45e6f37 | ||
|  | cb016f8439 | ||
|  | 92212d2652 | ||
|  | 950882be78 | ||
|  | 036855072e | ||
|  | 29bbf50900 | ||
|  | ca59303dba | ||
|  | e21f35039b | ||
|  | f2b377fae8 | ||
|  | 24a36bf4bb | ||
|  | 3284450dc4 | ||
|  | ea9d326819 | ||
|  | 4cc679c1e5 | ||
|  | c49ce55714 | ||
|  | 9d4b5416a5 | ||
|  | 82285df54b | ||
|  | e67c1789b8 | ||
|  | 015af19eaf | ||
|  | 156985ed52 | ||
|  | 71d1bd75c0 | ||
|  | 8e7c9c4bc4 | ||
|  | 7b7236fe30 | ||
|  | 55d997f43a | ||
|  | 1829b38339 | ||
|  | e4c28e12cf | ||
|  | 066cf45f4a | ||
|  | ac32b09a6b | ||
|  | 92296f4b4b | ||
|  | 3b4d2499eb | ||
|  | f38e15790e | ||
|  | b67c2bc2b2 | ||
|  | 393c9b759e | ||
|  | 54a7cf6785 | ||
|  | 1cf7a6389c | ||
|  | c204d7c297 | ||
|  | 5932f5f273 | ||
|  | 98977c87db | ||
|  | ff457af2d4 | ||
|  | 0e86ab9044 | ||
|  | 3d39e842ec | ||
|  | 16c1aa2845 | ||
|  | d0cf883558 | ||
|  | 64e4830aad | ||
|  | 0c47f2af75 | ||
|  | 14c5d8c95a | ||
|  | 6850499056 | ||
|  | 9288f784a1 | ||
|  | dab75f6f97 | ||
|  | 4a017d9033 | ||
|  | 6f896d988f | ||
|  | 35a9d241fc | ||
|  | 9ba0a7db64 | ||
|  | 9968503872 | ||
|  | 34218c5f58 | ||
|  | ebd41f1f20 | ||
|  | 62b1816297 | ||
|  | 2dfb864e4e | ||
|  | 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 | ||
|  | 8cdb8ed48d | ||
|  | 417bf7e1c9 | ||
|  | 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 | ||
|  | 149f8967ad | ||
|  | c8754292f4 | ||
|  | e376fe921b | ||
|  | 61faea0298 | ||
|  | 8d8020ddb5 | ||
|  | 7d13b9eb99 | ||
|  | 6ed0a05b44 | ||
|  | c4c479578a | ||
|  | 441caa91dd | ||
|  | 20154eb049 | ||
|  | 84ea710d42 | ||
|  | 8d524d618e | ||
|  | 9fa34ab1fe | ||
|  | 47db1cf1ac | ||
|  | f2f9b70659 | ||
|  | 61c93ab08c | ||
|  | d72f3fae33 | ||
|  | 3f14d15722 | ||
|  | 963c0b46a0 | ||
|  | 66b4977a67 | ||
|  | 126c2147e9 | ||
|  | f7c42a4e6a | ||
|  | b1ea1fd96f | ||
|  | a5475bf839 | ||
|  | be9e187cc6 | ||
|  | d5098c6f66 | ||
|  | 41fc785330 | ||
|  | 4d83bf34f3 | ||
|  | 3a797e2583 | ||
|  | 7802030a53 | ||
|  | e8e1e0ca23 | ||
|  | 973431be40 | ||
|  | 24fb5a8e29 | ||
|  | 37d161c290 | ||
|  | ddefa5f9e6 | ||
|  | 955dd3d4d5 | ||
|  | d125205564 | ||
|  | 7fa1b52497 | ||
|  | a90d21899a | ||
|  | 569058f481 | ||
|  | 4ecda08f1f | ||
|  | 3b23059c09 | ||
|  | a474ffc101 | ||
|  | f7672b837a | ||
|  | 5235871fd8 | ||
|  | cac9873e20 | ||
|  | 9094923de9 | ||
|  | 6454c96e6a | ||
|  | 7fbb9edc0f | ||
|  | 0a717f5c81 | ||
|  | dab9777621 | ||
|  | c8d1e9def1 | ||
|  | 272dd45a43 | ||
|  | 5abec96df7 | ||
|  | e860f961a9 | ||
|  | b9ecf61dcb | ||
|  | 437f81c4a0 | ||
|  | 26dad7dada | ||
|  | b1e5d6f8f8 | ||
|  | 8c7b54d6e3 | ||
|  | fea0d8963c | ||
|  | 7aca52c68c | ||
|  | 529d3faaf8 | ||
|  | 9f0f4657a2 | ||
|  | 90ff1b5896 | ||
|  | feb82e34d6 | ||
|  | 4d7a34c177 | ||
|  | 5c3385ecd8 | ||
|  | a1af3a509c | ||
|  | 2913a87cc4 | ||
|  | 69cc86c572 | ||
|  | 60144c907e | ||
|  | 1828cf6fc7 | ||
|  | ad4d273241 | ||
|  | 0d03a94cde | ||
|  | c4b876472f | ||
|  | 6af5adaac1 | ||
|  | 17a28f2e91 | ||
|  | baaa7a5c13 | ||
|  | cfeb2a833c | ||
|  | e6fd58b3aa | ||
|  | 2ef905ef1e | ||
|  | db80aa84dc | ||
|  | f404cc16a1 | ||
|  | 8b4acf7023 | ||
|  | 7393c2ef91 | ||
|  | 4948ec2999 | ||
|  | 408a325732 | ||
|  | 5ca211b9f7 | ||
|  | bc7596a8b5 | ||
|  | 6762ca8aa7 | ||
|  | bb7d6ab429 | ||
|  | 986611ac36 | ||
|  | 94b4ad1de6 | ||
|  | 3e2f18bf3f | ||
|  | 48c06cc299 | ||
|  | f10821ac49 | ||
|  | cd5298dee6 | ||
|  | a8c955609a | ||
|  | c5acce0604 | ||
|  | a6ccce7b76 | ||
|  | aa72012d41 | ||
|  | 06e095e5fc | ||
|  | 2f4ea20fdd | ||
|  | 81fcb4452e | ||
|  | 4f1a5cd456 | ||
|  | ae2d3d7e61 | ||
|  | 58ae0908e3 | ||
|  | e91caeaade | ||
|  | bd694c60e1 | ||
|  | 5580f39df2 | ||
|  | 04f4b05412 | 
							
								
								
									
										0
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
								
								
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,3 +1,5 @@ | |||||||
| Gemfile.lock | Gemfile.lock | ||||||
| .bundle/ | .bundle/ | ||||||
| vendor/ | vendor/ | ||||||
|  | benchmark/ | ||||||
|  | lib/linguist/samples.json | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| before_install:  | before_install: | ||||||
|   - git fetch origin master:master |   - git fetch origin master:master | ||||||
|   - git fetch origin v2.0.0:v2.0.0 |   - git fetch origin v2.0.0:v2.0.0 | ||||||
|  |   - git fetch origin test/attributes:test/attributes | ||||||
|   - sudo apt-get install libicu-dev -y |   - sudo apt-get install libicu-dev -y | ||||||
|   - gem update --system 2.1.11 |  | ||||||
| rvm: | rvm: | ||||||
|   - 1.9.3 |   - 1.9.3 | ||||||
|   - 2.0.0 |   - 2.0.0 | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								Gemfile
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								Gemfile
									
									
									
									
									
								
							| @@ -1,2 +1,3 @@ | |||||||
| source 'https://rubygems.org' | source 'https://rubygems.org' | ||||||
| gemspec | gemspec | ||||||
|  | gem 'rugged', '0.21.1b2' | ||||||
|   | |||||||
| @@ -102,10 +102,6 @@ We try to only add languages once they have some usage on GitHub, so please note | |||||||
|  |  | ||||||
| Almost all bug fixes or new language additions should come with some additional code samples. Just drop them under [`samples/`](https://github.com/github/linguist/tree/master/samples) in the correct subdirectory and our test suite will automatically test them. In most cases you shouldn't need to add any new assertions. | Almost all bug fixes or new language additions should come with some additional code samples. Just drop them under [`samples/`](https://github.com/github/linguist/tree/master/samples) in the correct subdirectory and our test suite will automatically test them. In most cases you shouldn't need to add any new assertions. | ||||||
|  |  | ||||||
| To update the `samples.json` after adding new files to [`samples/`](https://github.com/github/linguist/tree/master/samples): |  | ||||||
|  |  | ||||||
|     bundle exec rake samples |  | ||||||
|  |  | ||||||
| ### A note on language extensions | ### A note on language extensions | ||||||
|  |  | ||||||
| Linguist has a number of methods available to it for identifying the language of a particular file. The initial lookup is based upon the extension of the file, possible file extensions are defined in an array called `extensions`. Take a look at this example for example for `Perl`: | Linguist has a number of methods available to it for identifying the language of a particular file. The initial lookup is based upon the extension of the file, possible file extensions are defined in an array called `extensions`. Take a look at this example for example for `Perl`: | ||||||
|   | |||||||
							
								
								
									
										82
									
								
								Rakefile
									
									
									
									
									
								
							
							
						
						
									
										82
									
								
								Rakefile
									
									
									
									
									
								
							| @@ -7,6 +7,16 @@ task :default => :test | |||||||
|  |  | ||||||
| Rake::TestTask.new | Rake::TestTask.new | ||||||
|  |  | ||||||
|  | # Extend test task to check for samples | ||||||
|  | task :test => :check_samples | ||||||
|  |  | ||||||
|  | desc "Check that we have samples.json generated" | ||||||
|  | task :check_samples do | ||||||
|  |   unless File.exist?('lib/linguist/samples.json') | ||||||
|  |     Rake::Task[:samples].invoke | ||||||
|  |   end | ||||||
|  | end | ||||||
|  |  | ||||||
| task :samples do | task :samples do | ||||||
|   require 'linguist/samples' |   require 'linguist/samples' | ||||||
|   require 'yajl' |   require 'yajl' | ||||||
| @@ -15,13 +25,74 @@ task :samples do | |||||||
|   File.open('lib/linguist/samples.json', 'w') { |io| io.write json } |   File.open('lib/linguist/samples.json', 'w') { |io| io.write json } | ||||||
| end | end | ||||||
|  |  | ||||||
| task :build_gem do | task :build_gem => :samples do | ||||||
|   languages = YAML.load_file("lib/linguist/languages.yml") |   languages = YAML.load_file("lib/linguist/languages.yml") | ||||||
|   File.write("lib/linguist/languages.json", JSON.dump(languages)) |   File.write("lib/linguist/languages.json", JSON.dump(languages)) | ||||||
|   `gem build github-linguist.gemspec` |   `gem build github-linguist.gemspec` | ||||||
|   File.delete("lib/linguist/languages.json") |   File.delete("lib/linguist/languages.json") | ||||||
| end | end | ||||||
|  |  | ||||||
|  | namespace :benchmark do | ||||||
|  |   benchmark_path = "benchmark/results" | ||||||
|  |  | ||||||
|  |   # $ bundle exec rake benchmark:generate CORPUS=path/to/samples | ||||||
|  |   desc "Generate results for" | ||||||
|  |   task :generate do | ||||||
|  |     ref = `git rev-parse HEAD`.strip[0,8] | ||||||
|  |  | ||||||
|  |     corpus = File.expand_path(ENV["CORPUS"] || "samples") | ||||||
|  |  | ||||||
|  |     require 'linguist/language' | ||||||
|  |  | ||||||
|  |     results = Hash.new | ||||||
|  |     Dir.glob("#{corpus}/**/*").each do |file| | ||||||
|  |       next unless File.file?(file) | ||||||
|  |       filename = file.gsub("#{corpus}/", "") | ||||||
|  |       results[filename] = Linguist::FileBlob.new(file).language | ||||||
|  |     end | ||||||
|  |  | ||||||
|  |     # Ensure results directory exists | ||||||
|  |     FileUtils.mkdir_p("benchmark/results") | ||||||
|  |  | ||||||
|  |     # Write results | ||||||
|  |     if `git status`.include?('working directory clean') | ||||||
|  |       result_filename = "benchmark/results/#{File.basename(corpus)}-#{ref}.json" | ||||||
|  |     else | ||||||
|  |       result_filename = "benchmark/results/#{File.basename(corpus)}-#{ref}-unstaged.json" | ||||||
|  |     end | ||||||
|  |  | ||||||
|  |     File.write(result_filename, results.to_json) | ||||||
|  |     puts "wrote #{result_filename}" | ||||||
|  |   end | ||||||
|  |  | ||||||
|  |   # $ bundle exec rake benchmark:compare REFERENCE=path/to/reference.json CANDIDATE=path/to/candidate.json | ||||||
|  |   desc "Compare results" | ||||||
|  |   task :compare do | ||||||
|  |     reference_file = ENV["REFERENCE"] | ||||||
|  |     candidate_file = ENV["CANDIDATE"] | ||||||
|  |  | ||||||
|  |     reference = JSON.parse(File.read(reference_file)) | ||||||
|  |     reference_counts = Hash.new(0) | ||||||
|  |     reference.each { |filename, language| reference_counts[language] += 1 } | ||||||
|  |  | ||||||
|  |     candidate = JSON.parse(File.read(candidate_file)) | ||||||
|  |     candidate_counts = Hash.new(0) | ||||||
|  |     candidate.each { |filename, language| candidate_counts[language] += 1 } | ||||||
|  |  | ||||||
|  |     changes = diff(reference_counts, candidate_counts) | ||||||
|  |  | ||||||
|  |     if changes.any? | ||||||
|  |       changes.each do |language, (before, after)| | ||||||
|  |         before_percent = 100 * before / reference.size.to_f | ||||||
|  |         after_percent = 100 * after / candidate.size.to_f | ||||||
|  |         puts "%s changed from %.1f%% to %.1f%%" % [language || 'unknown', before_percent, after_percent] | ||||||
|  |       end | ||||||
|  |     else | ||||||
|  |       puts "No changes" | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  | end | ||||||
|  |  | ||||||
| namespace :classifier do | namespace :classifier do | ||||||
|   LIMIT = 1_000 |   LIMIT = 1_000 | ||||||
|  |  | ||||||
| @@ -37,7 +108,7 @@ namespace :classifier do | |||||||
|       next if file_language.nil? || file_language == 'Text' |       next if file_language.nil? || file_language == 'Text' | ||||||
|       begin |       begin | ||||||
|         data = open(file_url).read |         data = open(file_url).read | ||||||
|         guessed_language, score = Linguist::Classifier.classify(Linguist::Samples::DATA, data).first |         guessed_language, score = Linguist::Classifier.classify(Linguist::Samples.cache, data).first | ||||||
|  |  | ||||||
|         total += 1 |         total += 1 | ||||||
|         guessed_language == file_language ? correct += 1 : incorrect += 1 |         guessed_language == file_language ? correct += 1 : incorrect += 1 | ||||||
| @@ -71,3 +142,10 @@ namespace :classifier do | |||||||
|     end |     end | ||||||
|   end |   end | ||||||
| end | end | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def diff(a, b) | ||||||
|  |   (a.keys | b.keys).each_with_object({}) do |key, diff| | ||||||
|  |     diff[key] = [a[key], b[key]] unless a[key] == b[key] | ||||||
|  |   end | ||||||
|  | end | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ | |||||||
| #     usage: linguist <path> [<--breakdown>] | #     usage: linguist <path> [<--breakdown>] | ||||||
|  |  | ||||||
| require 'linguist/file_blob' | require 'linguist/file_blob' | ||||||
|  | require 'linguist/language' | ||||||
| require 'linguist/repository' | require 'linguist/repository' | ||||||
| require 'rugged' | require 'rugged' | ||||||
|  |  | ||||||
| @@ -30,7 +31,7 @@ if File.directory?(path) | |||||||
|     puts |     puts | ||||||
|     file_breakdown = repo.breakdown_by_file |     file_breakdown = repo.breakdown_by_file | ||||||
|     file_breakdown.each do |lang, files| |     file_breakdown.each do |lang, files| | ||||||
|       puts "#{lang}:"  |       puts "#{lang}:" | ||||||
|       files.each do |file| |       files.each do |file| | ||||||
|         puts file |         puts file | ||||||
|       end |       end | ||||||
|   | |||||||
| @@ -17,10 +17,10 @@ Gem::Specification.new do |s| | |||||||
|   s.add_dependency 'escape_utils',    '~> 1.0.1' |   s.add_dependency 'escape_utils',    '~> 1.0.1' | ||||||
|   s.add_dependency 'mime-types',      '~> 1.19' |   s.add_dependency 'mime-types',      '~> 1.19' | ||||||
|   s.add_dependency 'pygments.rb',     '~> 0.6.0' |   s.add_dependency 'pygments.rb',     '~> 0.6.0' | ||||||
|   s.add_dependency 'rugged',          '~> 0.21.0' |  | ||||||
|  |  | ||||||
|   s.add_development_dependency 'json' |   s.add_development_dependency 'json' | ||||||
|   s.add_development_dependency 'mocha' |   s.add_development_dependency 'mocha' | ||||||
|  |   s.add_development_dependency 'pry' | ||||||
|   s.add_development_dependency 'rake' |   s.add_development_dependency 'rake' | ||||||
|   s.add_development_dependency 'yajl-ruby' |   s.add_development_dependency 'yajl-ruby' | ||||||
| end | end | ||||||
|   | |||||||
| @@ -1,6 +1,4 @@ | |||||||
| require 'linguist/generated' | require 'linguist/generated' | ||||||
| require 'linguist/language' |  | ||||||
|  |  | ||||||
| require 'charlock_holmes' | require 'charlock_holmes' | ||||||
| require 'escape_utils' | require 'escape_utils' | ||||||
| require 'mime/types' | require 'mime/types' | ||||||
|   | |||||||
| @@ -52,5 +52,20 @@ module Linguist | |||||||
|     def size |     def size | ||||||
|       File.size(@path) |       File.size(@path) | ||||||
|     end |     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 | ||||||
| end | end | ||||||
|   | |||||||
| @@ -54,7 +54,7 @@ module Linguist | |||||||
|       name == 'Gemfile.lock' || |       name == 'Gemfile.lock' || | ||||||
|         minified_files? || |         minified_files? || | ||||||
|         compiled_coffeescript? || |         compiled_coffeescript? || | ||||||
|         xcode_project_file? || |         xcode_file? || | ||||||
|         generated_parser? || |         generated_parser? || | ||||||
|         generated_net_docfile? || |         generated_net_docfile? || | ||||||
|         generated_net_designer_file? || |         generated_net_designer_file? || | ||||||
| @@ -63,18 +63,19 @@ module Linguist | |||||||
|         generated_jni_header? || |         generated_jni_header? || | ||||||
|         composer_lock? || |         composer_lock? || | ||||||
|         node_modules? || |         node_modules? || | ||||||
|  |         godeps? || | ||||||
|         vcr_cassette? || |         vcr_cassette? || | ||||||
|         generated_by_zephir? |         generated_by_zephir? | ||||||
|     end |     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. |     # file extension. | ||||||
|     # |     # | ||||||
|     # Returns true of false. |     # Returns true of false. | ||||||
|     def xcode_project_file? |     def xcode_file? | ||||||
|       ['.xib', '.nib', '.storyboard', '.pbxproj', '.xcworkspacedata', '.xcuserstate'].include?(extname) |       ['.nib', '.xcworkspacedata', '.xcuserstate'].include?(extname) | ||||||
|     end |     end | ||||||
|  |  | ||||||
|     # Internal: Is the blob minified files? |     # Internal: Is the blob minified files? | ||||||
| @@ -231,11 +232,19 @@ module Linguist | |||||||
|       !!name.match(/node_modules\//) |       !!name.match(/node_modules\//) | ||||||
|     end |     end | ||||||
|  |  | ||||||
|  |     # Internal: Is the blob part of Godeps/, | ||||||
|  |     # which are not meant for humans in pull requests. | ||||||
|  |     # | ||||||
|  |     # Returns true or false. | ||||||
|  |     def godeps? | ||||||
|  |       !!name.match(/Godeps\//) | ||||||
|  |     end | ||||||
|  |  | ||||||
|     # Internal: Is the blob a generated php composer lock file? |     # Internal: Is the blob a generated php composer lock file? | ||||||
|     # |     # | ||||||
|     # Returns true or false. |     # Returns true or false. | ||||||
|     def composer_lock? |     def composer_lock? | ||||||
|       !!name.match(/composer.lock/) |       !!name.match(/composer\.lock/) | ||||||
|     end |     end | ||||||
|  |  | ||||||
|     # Internal: Is the blob a generated by Zephir |     # Internal: Is the blob a generated by Zephir | ||||||
| @@ -256,3 +265,4 @@ module Linguist | |||||||
|     end |     end | ||||||
|   end |   end | ||||||
| end | end | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| module Linguist | module Linguist | ||||||
|   # A collection of simple heuristics that can be used to better analyze languages. |   # A collection of simple heuristics that can be used to better analyze languages. | ||||||
|   class Heuristics |   class Heuristics | ||||||
|     ACTIVE = false |     ACTIVE = true | ||||||
|  |  | ||||||
|     # Public: Given an array of String language names, |     # Public: Given an array of String language names, | ||||||
|     # apply heuristics against the given data and return an array |     # apply heuristics against the given data and return an array | ||||||
| @@ -13,28 +13,20 @@ module Linguist | |||||||
|     # Returns an array of Languages or [] |     # Returns an array of Languages or [] | ||||||
|     def self.find_by_heuristics(data, languages) |     def self.find_by_heuristics(data, languages) | ||||||
|       if active? |       if active? | ||||||
|         if languages.all? { |l| ["Objective-C", "C++"].include?(l) } |  | ||||||
|           disambiguate_c(data, languages) |  | ||||||
|         end |  | ||||||
|         if languages.all? { |l| ["Perl", "Prolog"].include?(l) } |         if languages.all? { |l| ["Perl", "Prolog"].include?(l) } | ||||||
|           disambiguate_pl(data, languages) |           result = disambiguate_pl(data, languages) | ||||||
|         end |         end | ||||||
|         if languages.all? { |l| ["ECL", "Prolog"].include?(l) } |         if languages.all? { |l| ["ECL", "Prolog"].include?(l) } | ||||||
|           disambiguate_ecl(data, languages) |           result = disambiguate_ecl(data, languages) | ||||||
|         end |  | ||||||
|         if languages.all? { |l| ["TypeScript", "XML"].include?(l) } |  | ||||||
|           disambiguate_ts(data, languages) |  | ||||||
|         end |         end | ||||||
|         if languages.all? { |l| ["Common Lisp", "OpenCL"].include?(l) } |         if languages.all? { |l| ["Common Lisp", "OpenCL"].include?(l) } | ||||||
|           disambiguate_cl(data, languages) |           result = disambiguate_cl(data, languages) | ||||||
|         end |  | ||||||
|         if languages.all? { |l| ["Rebol", "R"].include?(l) } |  | ||||||
|           disambiguate_r(data, languages) |  | ||||||
|         end |         end | ||||||
|  |         return result | ||||||
|       end |       end | ||||||
|     end |     end | ||||||
|  |  | ||||||
|     # .h extensions are ambigious between C, C++, and Objective-C. |     # .h extensions are ambiguous between C, C++, and Objective-C. | ||||||
|     # We want to shortcut look for Objective-C _and_ now C++ too! |     # We want to shortcut look for Objective-C _and_ now C++ too! | ||||||
|     # |     # | ||||||
|     # Returns an array of Languages or [] |     # Returns an array of Languages or [] | ||||||
|   | |||||||
| @@ -9,6 +9,8 @@ end | |||||||
| require 'linguist/classifier' | require 'linguist/classifier' | ||||||
| require 'linguist/heuristics' | require 'linguist/heuristics' | ||||||
| require 'linguist/samples' | require 'linguist/samples' | ||||||
|  | require 'linguist/file_blob' | ||||||
|  | require 'linguist/blob_helper' | ||||||
|  |  | ||||||
| module Linguist | module Linguist | ||||||
|   # Language names that are recognizable by GitHub. Defined languages |   # Language names that are recognizable by GitHub. Defined languages | ||||||
| @@ -104,12 +106,13 @@ module Linguist | |||||||
|       # |       # | ||||||
|       # We'll perform a more comprehensive test later which actually involves |       # We'll perform a more comprehensive test later which actually involves | ||||||
|       # looking for binary characters in the blob |       # looking for binary characters in the blob | ||||||
|       return nil if blob.likely_binary? |       return nil if blob.likely_binary? || blob.binary? | ||||||
|  |  | ||||||
|       # A bit of an elegant hack. If the file is executable but extensionless, |       # A bit of an elegant hack. If the file is executable but extensionless, | ||||||
|       # append a "magic" extension so it can be classified with other |       # append a "magic" extension so it can be classified with other | ||||||
|       # languages that have shebang scripts. |       # 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!" |         name += ".script!" | ||||||
|       end |       end | ||||||
|  |  | ||||||
| @@ -124,7 +127,7 @@ module Linguist | |||||||
|         possible_language_names = possible_languages.map(&:name) |         possible_language_names = possible_languages.map(&:name) | ||||||
|  |  | ||||||
|         # Don't bother with binary contents or an empty file |         # Don't bother with binary contents or an empty file | ||||||
|         if blob.binary? || data.nil? || data == "" |         if data.nil? || data == "" | ||||||
|           nil |           nil | ||||||
|         # Check if there's a shebang line and use that as authoritative |         # Check if there's a shebang line and use that as authoritative | ||||||
|         elsif (result = find_by_shebang(data)) && !result.empty? |         elsif (result = find_by_shebang(data)) && !result.empty? | ||||||
| @@ -132,8 +135,8 @@ module Linguist | |||||||
|         # No shebang. Still more work to do. Try to find it with our heuristics. |         # No shebang. Still more work to do. Try to find it with our heuristics. | ||||||
|         elsif (determined = Heuristics.find_by_heuristics(data, possible_language_names)) && !determined.empty? |         elsif (determined = Heuristics.find_by_heuristics(data, possible_language_names)) && !determined.empty? | ||||||
|           determined.first |           determined.first | ||||||
|         # Lastly, fall back to the probablistic classifier. |         # Lastly, fall back to the probabilistic classifier. | ||||||
|         elsif classified = Classifier.classify(Samples::DATA, data, possible_language_names ).first |         elsif classified = Classifier.classify(Samples.cache, data, possible_language_names).first | ||||||
|           # Return the actual Language object based of the string language name (i.e., first element of `#classify`) |           # Return the actual Language object based of the string language name (i.e., first element of `#classify`) | ||||||
|           Language[classified[0]] |           Language[classified[0]] | ||||||
|         end |         end | ||||||
| @@ -189,7 +192,8 @@ module Linguist | |||||||
|     # |     # | ||||||
|     # Returns all matching Languages or [] if none were found. |     # Returns all matching Languages or [] if none were found. | ||||||
|     def self.find_by_filename(filename) |     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] + |       langs = @filename_index[basename] + | ||||||
|               @extension_index[extname] |               @extension_index[extname] | ||||||
|       langs.compact.uniq |       langs.compact.uniq | ||||||
| @@ -401,7 +405,7 @@ module Linguist | |||||||
|     # |     # | ||||||
|     # Returns the extensions Array |     # Returns the extensions Array | ||||||
|     attr_reader :filenames |     attr_reader :filenames | ||||||
|      |  | ||||||
|     # Public: Return all possible extensions for language |     # Public: Return all possible extensions for language | ||||||
|     def all_extensions |     def all_extensions | ||||||
|       (extensions + [primary_extension]).uniq |       (extensions + [primary_extension]).uniq | ||||||
| @@ -506,9 +510,9 @@ module Linguist | |||||||
|     end |     end | ||||||
|   end |   end | ||||||
|  |  | ||||||
|   extensions = Samples::DATA['extnames'] |   extensions = Samples.cache['extnames'] | ||||||
|   interpreters = Samples::DATA['interpreters'] |   interpreters = Samples.cache['interpreters'] | ||||||
|   filenames = Samples::DATA['filenames'] |   filenames = Samples.cache['filenames'] | ||||||
|   popular = YAML.load_file(File.expand_path("../popular.yml", __FILE__)) |   popular = YAML.load_file(File.expand_path("../popular.yml", __FILE__)) | ||||||
|  |  | ||||||
|   languages_yml = File.expand_path("../languages.yml", __FILE__) |   languages_yml = File.expand_path("../languages.yml", __FILE__) | ||||||
| @@ -528,6 +532,7 @@ module Linguist | |||||||
|     if extnames = extensions[name] |     if extnames = extensions[name] | ||||||
|       extnames.each do |extname| |       extnames.each do |extname| | ||||||
|         if !options['extensions'].include?(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 |           options['extensions'] << extname | ||||||
|         end |         end | ||||||
|       end |       end | ||||||
|   | |||||||
| @@ -28,6 +28,16 @@ ABAP: | |||||||
|   extensions: |   extensions: | ||||||
|   - .abap |   - .abap | ||||||
|  |  | ||||||
|  | AGS Script: | ||||||
|  |   type: programming | ||||||
|  |   lexer: C++ | ||||||
|  |   color: "#B9D9FF" | ||||||
|  |   aliases: | ||||||
|  |   - ags | ||||||
|  |   extensions: | ||||||
|  |   - .asc | ||||||
|  |   - .ash | ||||||
|  |  | ||||||
| ANTLR: | ANTLR: | ||||||
|   type: programming |   type: programming | ||||||
|   color: "#9DC3FF" |   color: "#9DC3FF" | ||||||
| @@ -35,6 +45,12 @@ ANTLR: | |||||||
|   extensions: |   extensions: | ||||||
|   - .g4 |   - .g4 | ||||||
|  |  | ||||||
|  | APL: | ||||||
|  |   type: programming | ||||||
|  |   color: "#8a0707" | ||||||
|  |   extensions: | ||||||
|  |   - .apl | ||||||
|  |  | ||||||
| ASP: | ASP: | ||||||
|   type: programming |   type: programming | ||||||
|   color: "#6a40fd" |   color: "#6a40fd" | ||||||
| @@ -103,7 +119,7 @@ ApacheConf: | |||||||
|  |  | ||||||
| Apex: | Apex: | ||||||
|   type: programming |   type: programming | ||||||
|   lexer: Text only |   lexer: Java | ||||||
|   extensions: |   extensions: | ||||||
|   - .cls |   - .cls | ||||||
|  |  | ||||||
| @@ -157,7 +173,6 @@ Assembly: | |||||||
|   - nasm |   - nasm | ||||||
|   extensions: |   extensions: | ||||||
|   - .asm |   - .asm | ||||||
|   - .inc |  | ||||||
|  |  | ||||||
| Augeas: | Augeas: | ||||||
|   type: programming |   type: programming | ||||||
| @@ -261,13 +276,14 @@ C: | |||||||
|   extensions: |   extensions: | ||||||
|   - .c |   - .c | ||||||
|   - .cats |   - .cats | ||||||
|  |   - .h | ||||||
|   - .w |   - .w | ||||||
|  |  | ||||||
| C#: | C#: | ||||||
|   type: programming |   type: programming | ||||||
|   ace_mode: csharp |   ace_mode: csharp | ||||||
|   search_term: csharp |   search_term: csharp | ||||||
|   color: "#5a25a2" |   color: "#178600" | ||||||
|   aliases: |   aliases: | ||||||
|   - csharp |   - csharp | ||||||
|   extensions: |   extensions: | ||||||
| @@ -289,6 +305,7 @@ C++: | |||||||
|   - .cc |   - .cc | ||||||
|   - .cxx |   - .cxx | ||||||
|   - .H |   - .H | ||||||
|  |   - .h | ||||||
|   - .h++ |   - .h++ | ||||||
|   - .hh |   - .hh | ||||||
|   - .hpp |   - .hpp | ||||||
| @@ -322,7 +339,7 @@ CLIPS: | |||||||
| CMake: | CMake: | ||||||
|   extensions: |   extensions: | ||||||
|   - .cmake |   - .cmake | ||||||
|   - .cmake.in |   - .in | ||||||
|   filenames: |   filenames: | ||||||
|   - CMakeLists.txt |   - CMakeLists.txt | ||||||
|  |  | ||||||
| @@ -347,6 +364,14 @@ Ceylon: | |||||||
|   extensions: |   extensions: | ||||||
|   - .ceylon |   - .ceylon | ||||||
|  |  | ||||||
|  | Chapel: | ||||||
|  |   type: programming | ||||||
|  |   color: "#8dc63f" | ||||||
|  |   aliases: | ||||||
|  |   - chpl | ||||||
|  |   extensions: | ||||||
|  |   - .chpl | ||||||
|  |  | ||||||
| ChucK: | ChucK: | ||||||
|   lexer: Java |   lexer: Java | ||||||
|   extensions: |   extensions: | ||||||
| @@ -355,9 +380,8 @@ ChucK: | |||||||
| Cirru: | Cirru: | ||||||
|   type: programming |   type: programming | ||||||
|   color: "#aaaaff" |   color: "#aaaaff" | ||||||
|   # ace_mode: cirru |   ace_mode: cirru | ||||||
|   # lexer: Cirru |   lexer: Cirru | ||||||
|   lexer: Text only |  | ||||||
|   extensions: |   extensions: | ||||||
|   - .cirru |   - .cirru | ||||||
|  |  | ||||||
| @@ -381,7 +405,7 @@ Clojure: | |||||||
|   - .cljscm |   - .cljscm | ||||||
|   - .cljx |   - .cljx | ||||||
|   - .hic |   - .hic | ||||||
|   - .cljs.hl |   - .hl | ||||||
|   filenames: |   filenames: | ||||||
|   - riemann.config |   - riemann.config | ||||||
|  |  | ||||||
| @@ -404,14 +428,27 @@ CoffeeScript: | |||||||
|  |  | ||||||
| ColdFusion: | ColdFusion: | ||||||
|   type: programming |   type: programming | ||||||
|  |   group: ColdFusion | ||||||
|   lexer: Coldfusion HTML |   lexer: Coldfusion HTML | ||||||
|   ace_mode: coldfusion |   ace_mode: coldfusion | ||||||
|   color: "#ed2cd6" |   color: "#ed2cd6" | ||||||
|   search_term: cfm |   search_term: cfm | ||||||
|   aliases: |   aliases: | ||||||
|   - cfm |   - cfm | ||||||
|  |   - cfml | ||||||
|   extensions: |   extensions: | ||||||
|   - .cfm |   - .cfm | ||||||
|  |  | ||||||
|  | ColdFusion CFC: | ||||||
|  |   type: programming | ||||||
|  |   group: ColdFusion | ||||||
|  |   lexer: Coldfusion CFC | ||||||
|  |   ace_mode: coldfusion | ||||||
|  |   color: "#ed2cd6" | ||||||
|  |   search_term: cfc | ||||||
|  |   aliases: | ||||||
|  |   - cfc | ||||||
|  |   extensions: | ||||||
|   - .cfc |   - .cfc | ||||||
|  |  | ||||||
| Common Lisp: | Common Lisp: | ||||||
| @@ -445,6 +482,7 @@ Coq: | |||||||
|   type: programming |   type: programming | ||||||
|   extensions: |   extensions: | ||||||
|   - .coq |   - .coq | ||||||
|  |   - .v | ||||||
|  |  | ||||||
| Cpp-ObjDump: | Cpp-ObjDump: | ||||||
|   type: data |   type: data | ||||||
| @@ -480,6 +518,12 @@ Cuda: | |||||||
|   - .cu |   - .cu | ||||||
|   - .cuh |   - .cuh | ||||||
|  |  | ||||||
|  | Cycript: | ||||||
|  |   type: programming | ||||||
|  |   lexer: JavaScript | ||||||
|  |   extensions: | ||||||
|  |   - .cy | ||||||
|  |  | ||||||
| Cython: | Cython: | ||||||
|   type: programming |   type: programming | ||||||
|   group: Python |   group: Python | ||||||
| @@ -534,6 +578,7 @@ Dart: | |||||||
| Diff: | Diff: | ||||||
|   extensions: |   extensions: | ||||||
|   - .diff |   - .diff | ||||||
|  |   - .patch | ||||||
|  |  | ||||||
| Dogescript: | Dogescript: | ||||||
|   type: programming |   type: programming | ||||||
| @@ -582,7 +627,7 @@ Eagle: | |||||||
|  |  | ||||||
| Eiffel: | Eiffel: | ||||||
|   type: programming |   type: programming | ||||||
|   lexer: Text only |   lexer: Eiffel | ||||||
|   color: "#946d57" |   color: "#946d57" | ||||||
|   extensions: |   extensions: | ||||||
|   - .e |   - .e | ||||||
| @@ -602,7 +647,7 @@ Elm: | |||||||
|  |  | ||||||
| Emacs Lisp: | Emacs Lisp: | ||||||
|   type: programming |   type: programming | ||||||
|   lexer: Scheme |   lexer: Common Lisp | ||||||
|   color: "#c065db" |   color: "#c065db" | ||||||
|   aliases: |   aliases: | ||||||
|   - elisp |   - elisp | ||||||
| @@ -613,11 +658,20 @@ Emacs Lisp: | |||||||
|   - .el |   - .el | ||||||
|   - .emacs |   - .emacs | ||||||
|  |  | ||||||
|  | EmberScript: | ||||||
|  |   type: programming | ||||||
|  |   color: "#f64e3e" | ||||||
|  |   lexer: CoffeeScript | ||||||
|  |   extensions: | ||||||
|  |   - .em | ||||||
|  |   - .emberscript | ||||||
|  |  | ||||||
| Erlang: | Erlang: | ||||||
|   type: programming |   type: programming | ||||||
|   color: "#0faf8d" |   color: "#0faf8d" | ||||||
|   extensions: |   extensions: | ||||||
|   - .erl |   - .erl | ||||||
|  |   - .escript | ||||||
|   - .hrl |   - .hrl | ||||||
|  |  | ||||||
| F#: | F#: | ||||||
| @@ -693,6 +747,8 @@ Forth: | |||||||
|   extensions: |   extensions: | ||||||
|   - .fth |   - .fth | ||||||
|   - .4th |   - .4th | ||||||
|  |   - .forth | ||||||
|  |   - .frt | ||||||
|  |  | ||||||
| Frege: | Frege: | ||||||
|   type: programming |   type: programming | ||||||
| @@ -701,6 +757,14 @@ Frege: | |||||||
|   extensions: |   extensions: | ||||||
|   - .fr |   - .fr | ||||||
|  |  | ||||||
|  | G-code: | ||||||
|  |   type: data | ||||||
|  |   lexer: Text only | ||||||
|  |   extensions: | ||||||
|  |   - .g | ||||||
|  |   - .gco | ||||||
|  |   - .gcode | ||||||
|  |  | ||||||
| Game Maker Language: | Game Maker Language: | ||||||
|   type: programming |   type: programming | ||||||
|   color: "#8ad353" |   color: "#8ad353" | ||||||
| @@ -730,6 +794,12 @@ GAS: | |||||||
|   - .s |   - .s | ||||||
|   - .S |   - .S | ||||||
|  |  | ||||||
|  | GDScript: | ||||||
|  |   type: programming | ||||||
|  |   lexer: Text only | ||||||
|  |   extensions: | ||||||
|  |   - .gd | ||||||
|  |  | ||||||
| GLSL: | GLSL: | ||||||
|   group: C |   group: C | ||||||
|   type: programming |   type: programming | ||||||
| @@ -801,6 +871,9 @@ Gosu: | |||||||
|   color: "#82937f" |   color: "#82937f" | ||||||
|   extensions: |   extensions: | ||||||
|   - .gs |   - .gs | ||||||
|  |   - .gst | ||||||
|  |   - .gsx | ||||||
|  |   - .vark | ||||||
|  |  | ||||||
| Grace: | Grace: | ||||||
|   type: programming |   type: programming | ||||||
| @@ -819,6 +892,12 @@ Grammatical Framework: | |||||||
|   searchable: true |   searchable: true | ||||||
|   color: "#ff0000" |   color: "#ff0000" | ||||||
|  |  | ||||||
|  | Graph Modeling Language: | ||||||
|  |   type: data | ||||||
|  |   lexer: Text only | ||||||
|  |   extensions: | ||||||
|  |   - .gml | ||||||
|  |  | ||||||
| Groff: | Groff: | ||||||
|   extensions: |   extensions: | ||||||
|   - .man |   - .man | ||||||
| @@ -836,6 +915,7 @@ Groovy: | |||||||
|   color: "#e69f56" |   color: "#e69f56" | ||||||
|   extensions: |   extensions: | ||||||
|   - .groovy |   - .groovy | ||||||
|  |   - .gradle | ||||||
|   - .grt |   - .grt | ||||||
|   - .gtpl |   - .gtpl | ||||||
|   - .gvy |   - .gvy | ||||||
| @@ -858,7 +938,6 @@ HTML: | |||||||
|   extensions: |   extensions: | ||||||
|   - .html |   - .html | ||||||
|   - .htm |   - .htm | ||||||
|   - .html.hl |  | ||||||
|   - .st |   - .st | ||||||
|   - .xhtml |   - .xhtml | ||||||
|  |  | ||||||
| @@ -878,9 +957,7 @@ HTML+ERB: | |||||||
|   - erb |   - erb | ||||||
|   extensions: |   extensions: | ||||||
|   - .erb |   - .erb | ||||||
|   - .erb.deface |   - .deface | ||||||
|   - .html.erb |  | ||||||
|   - .html.erb.deface |  | ||||||
|  |  | ||||||
| HTML+PHP: | HTML+PHP: | ||||||
|   type: markup |   type: markup | ||||||
| @@ -898,17 +975,14 @@ Haml: | |||||||
|   type: markup |   type: markup | ||||||
|   extensions: |   extensions: | ||||||
|   - .haml |   - .haml | ||||||
|   - .haml.deface |   - .deface | ||||||
|   - .html.haml.deface |  | ||||||
|  |  | ||||||
| Handlebars: | Handlebars: | ||||||
|   type: markup |   type: markup | ||||||
|   lexer: Text only |   lexer: Handlebars | ||||||
|   extensions: |   extensions: | ||||||
|   - .handlebars |   - .handlebars | ||||||
|   - .hbs |   - .hbs | ||||||
|   - .html.handlebars |  | ||||||
|   - .html.hbs |  | ||||||
|  |  | ||||||
| Harbour: | Harbour: | ||||||
|   type: programming |   type: programming | ||||||
| @@ -934,7 +1008,7 @@ Haxe: | |||||||
|  |  | ||||||
| Hy: | Hy: | ||||||
|   type: programming |   type: programming | ||||||
|   lexer: Clojure |   lexer: Hy | ||||||
|   ace_mode: clojure |   ace_mode: clojure | ||||||
|   color: "#7891b1" |   color: "#7891b1" | ||||||
|   extensions: |   extensions: | ||||||
| @@ -946,6 +1020,13 @@ IDL: | |||||||
|   color: "#e3592c" |   color: "#e3592c" | ||||||
|   extensions: |   extensions: | ||||||
|   - .pro |   - .pro | ||||||
|  |   - .dlm | ||||||
|  |  | ||||||
|  | IGOR Pro: | ||||||
|  |   type: programming | ||||||
|  |   lexer: Igor | ||||||
|  |   extensions: | ||||||
|  |   - .ipf | ||||||
|  |  | ||||||
| INI: | INI: | ||||||
|   type: data |   type: data | ||||||
| @@ -968,7 +1049,7 @@ Idris: | |||||||
|  |  | ||||||
| Inform 7: | Inform 7: | ||||||
|   type: programming |   type: programming | ||||||
|   lexer: Text only |   lexer: Inform 7 | ||||||
|   wrap: true |   wrap: true | ||||||
|   extensions: |   extensions: | ||||||
|   - .ni |   - .ni | ||||||
| @@ -1020,6 +1101,7 @@ JSON: | |||||||
|   searchable: false |   searchable: false | ||||||
|   extensions: |   extensions: | ||||||
|   - .json |   - .json | ||||||
|  |   - .lock | ||||||
|   - .sublime-keymap |   - .sublime-keymap | ||||||
|   - .sublime-mousemap |   - .sublime-mousemap | ||||||
|   - .sublime-project |   - .sublime-project | ||||||
| @@ -1088,6 +1170,7 @@ JavaScript: | |||||||
|   - .es6 |   - .es6 | ||||||
|   - .frag |   - .frag | ||||||
|   - .jake |   - .jake | ||||||
|  |   - .jsb | ||||||
|   - .jsfl |   - .jsfl | ||||||
|   - .jsm |   - .jsm | ||||||
|   - .jss |   - .jss | ||||||
| @@ -1142,12 +1225,31 @@ LLVM: | |||||||
|   extensions: |   extensions: | ||||||
|   - .ll |   - .ll | ||||||
|  |  | ||||||
|  | LSL: | ||||||
|  |   type: programming | ||||||
|  |   lexer: LSL | ||||||
|  |   ace_mode: lsl | ||||||
|  |   extensions: | ||||||
|  |   - .lsl | ||||||
|  |   interpreters: | ||||||
|  |   - lsl | ||||||
|  |   color: '#3d9970' | ||||||
|  |  | ||||||
|  | LabVIEW: | ||||||
|  |   type: programming | ||||||
|  |   lexer: Text only | ||||||
|  |   extensions: | ||||||
|  |   - .lvproj | ||||||
|  |  | ||||||
| Lasso: | Lasso: | ||||||
|   type: programming |   type: programming | ||||||
|   lexer: Lasso |   lexer: Lasso | ||||||
|   color: "#2584c3" |   color: "#2584c3" | ||||||
|   extensions: |   extensions: | ||||||
|   - .lasso |   - .lasso | ||||||
|  |   - .las | ||||||
|  |   - .lasso9 | ||||||
|  |   - .ldml | ||||||
|  |  | ||||||
| Latte: | Latte: | ||||||
|   type: markup |   type: markup | ||||||
| @@ -1226,6 +1328,14 @@ Logtalk: | |||||||
|   - .lgt |   - .lgt | ||||||
|   - .logtalk |   - .logtalk | ||||||
|  |  | ||||||
|  | LookML: | ||||||
|  |   type: programming | ||||||
|  |   lexer: YAML | ||||||
|  |   ace_mode: yaml | ||||||
|  |   color: "#652B81" | ||||||
|  |   extensions: | ||||||
|  |   - .lookml | ||||||
|  |  | ||||||
| Lua: | Lua: | ||||||
|   type: programming |   type: programming | ||||||
|   ace_mode: lua |   ace_mode: lua | ||||||
| @@ -1233,6 +1343,7 @@ Lua: | |||||||
|   extensions: |   extensions: | ||||||
|   - .lua |   - .lua | ||||||
|   - .nse |   - .nse | ||||||
|  |   - .pd_lua | ||||||
|   - .rbxs |   - .rbxs | ||||||
|   interpreters: |   interpreters: | ||||||
|   - lua |   - lua | ||||||
| @@ -1298,7 +1409,7 @@ Mathematica: | |||||||
|   - .mathematica |   - .mathematica | ||||||
|   - .m |   - .m | ||||||
|   - .nb |   - .nb | ||||||
|   lexer: Text only |   lexer: Mathematica | ||||||
|  |  | ||||||
| Matlab: | Matlab: | ||||||
|   type: programming |   type: programming | ||||||
| @@ -1346,7 +1457,7 @@ MiniD: # Legacy | |||||||
| Mirah: | Mirah: | ||||||
|   type: programming |   type: programming | ||||||
|   lexer: Ruby |   lexer: Ruby | ||||||
|   search_term: ruby |   search_term: mirah | ||||||
|   color: "#c7a938" |   color: "#c7a938" | ||||||
|   extensions: |   extensions: | ||||||
|   - .druby |   - .druby | ||||||
| @@ -1378,6 +1489,7 @@ Myghty: | |||||||
| NSIS: | NSIS: | ||||||
|   extensions: |   extensions: | ||||||
|   - .nsi |   - .nsi | ||||||
|  |   - .nsh | ||||||
|  |  | ||||||
| Nemerle: | Nemerle: | ||||||
|   type: programming |   type: programming | ||||||
| @@ -1442,6 +1554,7 @@ OCaml: | |||||||
|   color: "#3be133" |   color: "#3be133" | ||||||
|   extensions: |   extensions: | ||||||
|   - .ml |   - .ml | ||||||
|  |   - .eliom | ||||||
|   - .eliomi |   - .eliomi | ||||||
|   - .ml4 |   - .ml4 | ||||||
|   - .mli |   - .mli | ||||||
| @@ -1462,6 +1575,7 @@ Objective-C: | |||||||
|   - objc |   - objc | ||||||
|   extensions: |   extensions: | ||||||
|   - .m |   - .m | ||||||
|  |   - .h | ||||||
|  |  | ||||||
| Objective-C++: | Objective-C++: | ||||||
|   type: programming |   type: programming | ||||||
| @@ -1493,6 +1607,13 @@ Opa: | |||||||
|   extensions: |   extensions: | ||||||
|   - .opa |   - .opa | ||||||
|  |  | ||||||
|  | Opal: | ||||||
|  |   type: programming | ||||||
|  |   color: "#f7ede0" | ||||||
|  |   lexer: Text only | ||||||
|  |   extensions: | ||||||
|  |   - .opal | ||||||
|  |  | ||||||
| OpenCL: | OpenCL: | ||||||
|   type: programming |   type: programming | ||||||
|   group: C |   group: C | ||||||
| @@ -1509,6 +1630,13 @@ OpenEdge ABL: | |||||||
|   - abl |   - abl | ||||||
|   extensions: |   extensions: | ||||||
|   - .p |   - .p | ||||||
|  |   - .cls | ||||||
|  |  | ||||||
|  | OpenSCAD: | ||||||
|  |   type: programming | ||||||
|  |   lexer: Text only | ||||||
|  |   extensions: | ||||||
|  |   - .scad | ||||||
|  |  | ||||||
| Org: | Org: | ||||||
|   type: prose |   type: prose | ||||||
| @@ -1547,6 +1675,7 @@ PHP: | |||||||
|   - .php |   - .php | ||||||
|   - .aw |   - .aw | ||||||
|   - .ctp |   - .ctp | ||||||
|  |   - .module | ||||||
|   - .php3 |   - .php3 | ||||||
|   - .php4 |   - .php4 | ||||||
|   - .php5 |   - .php5 | ||||||
| @@ -1558,7 +1687,7 @@ PHP: | |||||||
|  |  | ||||||
| Pan: | Pan: | ||||||
|   type: programming |   type: programming | ||||||
|   lexer: Text only |   lexer: Pan | ||||||
|   color: '#cc0000' |   color: '#cc0000' | ||||||
|   extensions: |   extensions: | ||||||
|   - .pan |   - .pan | ||||||
| @@ -1595,7 +1724,9 @@ Pascal: | |||||||
|   extensions: |   extensions: | ||||||
|   - .pas |   - .pas | ||||||
|   - .dfm |   - .dfm | ||||||
|  |   - .dpr | ||||||
|   - .lpr |   - .lpr | ||||||
|  |   - .pp | ||||||
|  |  | ||||||
| Perl: | Perl: | ||||||
|   type: programming |   type: programming | ||||||
| @@ -1604,12 +1735,15 @@ Perl: | |||||||
|   extensions: |   extensions: | ||||||
|   - .pl |   - .pl | ||||||
|   - .PL |   - .PL | ||||||
|  |   - .cgi | ||||||
|  |   - .fcgi | ||||||
|   - .perl |   - .perl | ||||||
|   - .ph |   - .ph | ||||||
|   - .plx |   - .plx | ||||||
|   - .pm |   - .pm | ||||||
|   - .pod |   - .pod | ||||||
|   - .psgi |   - .psgi | ||||||
|  |   - .t | ||||||
|   interpreters: |   interpreters: | ||||||
|   - perl |   - perl | ||||||
|  |  | ||||||
| @@ -1626,6 +1760,13 @@ Perl6: | |||||||
|   - .pl6 |   - .pl6 | ||||||
|   - .pm6 |   - .pm6 | ||||||
|  |  | ||||||
|  | PigLatin: | ||||||
|  |   type: programming | ||||||
|  |   color: "#fcd7de" | ||||||
|  |   lexer: Text only | ||||||
|  |   extensions: | ||||||
|  |   - .pig | ||||||
|  |  | ||||||
| Pike: | Pike: | ||||||
|   type: programming |   type: programming | ||||||
|   color: "#066ab2" |   color: "#066ab2" | ||||||
| @@ -1674,11 +1815,12 @@ Processing: | |||||||
|  |  | ||||||
| Prolog: | Prolog: | ||||||
|   type: programming |   type: programming | ||||||
|  |   lexer: Logtalk | ||||||
|   color: "#74283c" |   color: "#74283c" | ||||||
|   extensions: |   extensions: | ||||||
|   - .prolog |  | ||||||
|   - .ecl |  | ||||||
|   - .pl |   - .pl | ||||||
|  |   - .ecl | ||||||
|  |   - .prolog | ||||||
|  |  | ||||||
| Propeller Spin: | Propeller Spin: | ||||||
|   type: programming |   type: programming | ||||||
| @@ -1723,6 +1865,7 @@ Python: | |||||||
|   color: "#3581ba" |   color: "#3581ba" | ||||||
|   extensions: |   extensions: | ||||||
|   - .py |   - .py | ||||||
|  |   - .cgi | ||||||
|   - .gyp |   - .gyp | ||||||
|   - .lmi |   - .lmi | ||||||
|   - .pyde |   - .pyde | ||||||
| @@ -1778,7 +1921,7 @@ R: | |||||||
|  |  | ||||||
| RDoc: | RDoc: | ||||||
|   type: prose |   type: prose | ||||||
|   lexer: Text only |   lexer: Rd | ||||||
|   ace_mode: rdoc |   ace_mode: rdoc | ||||||
|   wrap: true |   wrap: true | ||||||
|   extensions: |   extensions: | ||||||
| @@ -1818,6 +1961,7 @@ Racket: | |||||||
|   - .rkt |   - .rkt | ||||||
|   - .rktd |   - .rktd | ||||||
|   - .rktl |   - .rktl | ||||||
|  |   - .scrbl | ||||||
|  |  | ||||||
| Ragel in Ruby Host: | Ragel in Ruby Host: | ||||||
|   type: programming |   type: programming | ||||||
| @@ -1887,7 +2031,10 @@ Ruby: | |||||||
|   - .god |   - .god | ||||||
|   - .irbrc |   - .irbrc | ||||||
|   - .mspec |   - .mspec | ||||||
|  |   - .pluginspec | ||||||
|   - .podspec |   - .podspec | ||||||
|  |   - .rabl | ||||||
|  |   - .rake | ||||||
|   - .rbuild |   - .rbuild | ||||||
|   - .rbw |   - .rbw | ||||||
|   - .rbx |   - .rbx | ||||||
| @@ -1932,6 +2079,14 @@ SCSS: | |||||||
|   extensions: |   extensions: | ||||||
|   - .scss |   - .scss | ||||||
|  |  | ||||||
|  | SQF: | ||||||
|  |   type: programming | ||||||
|  |   color: "#FFCB1F" | ||||||
|  |   lexer: C++ | ||||||
|  |   extensions: | ||||||
|  |   - .sqf | ||||||
|  |   - .hqf | ||||||
|  |  | ||||||
| SQL: | SQL: | ||||||
|   type: data |   type: data | ||||||
|   ace_mode: sql |   ace_mode: sql | ||||||
| @@ -1961,6 +2116,7 @@ Sass: | |||||||
|   group: CSS |   group: CSS | ||||||
|   extensions: |   extensions: | ||||||
|   - .sass |   - .sass | ||||||
|  |   - .scss | ||||||
|  |  | ||||||
| Scala: | Scala: | ||||||
|   type: programming |   type: programming | ||||||
| @@ -1968,6 +2124,7 @@ Scala: | |||||||
|   color: "#7dd3b0" |   color: "#7dd3b0" | ||||||
|   extensions: |   extensions: | ||||||
|   - .scala |   - .scala | ||||||
|  |   - .sbt | ||||||
|   - .sc |   - .sc | ||||||
|  |  | ||||||
| Scaml: | Scaml: | ||||||
| @@ -1983,6 +2140,7 @@ Scheme: | |||||||
|   - .scm |   - .scm | ||||||
|   - .sld |   - .sld | ||||||
|   - .sls |   - .sls | ||||||
|  |   - .sps | ||||||
|   - .ss |   - .ss | ||||||
|   interpreters: |   interpreters: | ||||||
|   - guile |   - guile | ||||||
| @@ -1994,6 +2152,8 @@ Scilab: | |||||||
|   type: programming |   type: programming | ||||||
|   extensions: |   extensions: | ||||||
|   - .sci |   - .sci | ||||||
|  |   - .sce | ||||||
|  |   - .tst | ||||||
|  |  | ||||||
| Self: | Self: | ||||||
|   type: programming |   type: programming | ||||||
| @@ -2013,8 +2173,11 @@ Shell: | |||||||
|   - zsh |   - zsh | ||||||
|   extensions: |   extensions: | ||||||
|   - .sh |   - .sh | ||||||
|  |   - .bash | ||||||
|   - .bats |   - .bats | ||||||
|  |   - .cgi | ||||||
|   - .tmux |   - .tmux | ||||||
|  |   - .zsh | ||||||
|   interpreters: |   interpreters: | ||||||
|   - bash |   - bash | ||||||
|   - sh |   - sh | ||||||
| @@ -2081,6 +2244,7 @@ Standard ML: | |||||||
|   extensions: |   extensions: | ||||||
|   - .ML |   - .ML | ||||||
|   - .fun |   - .fun | ||||||
|  |   - .sig | ||||||
|   - .sml |   - .sml | ||||||
|  |  | ||||||
| Stata: | Stata: | ||||||
| @@ -2161,10 +2325,13 @@ TeX: | |||||||
|   extensions: |   extensions: | ||||||
|   - .tex |   - .tex | ||||||
|   - .aux |   - .aux | ||||||
|  |   - .bbx | ||||||
|   - .bib |   - .bib | ||||||
|  |   - .cbx | ||||||
|   - .cls |   - .cls | ||||||
|   - .dtx |   - .dtx | ||||||
|   - .ins |   - .ins | ||||||
|  |   - .lbx | ||||||
|   - .ltx |   - .ltx | ||||||
|   - .mkii |   - .mkii | ||||||
|   - .mkiv |   - .mkiv | ||||||
| @@ -2281,6 +2448,7 @@ Visual Basic: | |||||||
|   extensions: |   extensions: | ||||||
|   - .vb |   - .vb | ||||||
|   - .bas |   - .bas | ||||||
|  |   - .cls | ||||||
|   - .frm |   - .frm | ||||||
|   - .frx |   - .frx | ||||||
|   - .vba |   - .vba | ||||||
| @@ -2309,6 +2477,7 @@ XML: | |||||||
|   - wsdl |   - wsdl | ||||||
|   extensions: |   extensions: | ||||||
|   - .xml |   - .xml | ||||||
|  |   - .ant | ||||||
|   - .axml |   - .axml | ||||||
|   - .ccxml |   - .ccxml | ||||||
|   - .clixml |   - .clixml | ||||||
| @@ -2322,6 +2491,7 @@ XML: | |||||||
|   - .fsproj |   - .fsproj | ||||||
|   - .glade |   - .glade | ||||||
|   - .grxml |   - .grxml | ||||||
|  |   - .ivy | ||||||
|   - .jelly |   - .jelly | ||||||
|   - .kml |   - .kml | ||||||
|   - .launch |   - .launch | ||||||
|   | |||||||
| @@ -1,8 +1,13 @@ | |||||||
| require 'linguist/blob_helper' | require 'linguist/blob_helper' | ||||||
|  | require 'linguist/language' | ||||||
| require 'rugged' | require 'rugged' | ||||||
|  |  | ||||||
| module Linguist | module Linguist | ||||||
|   class LazyBlob |   class LazyBlob | ||||||
|  |     GIT_ATTR = ['linguist-language', 'linguist-vendored'] | ||||||
|  |     GIT_ATTR_OPTS = { :priority => [:index], :skip_system => true } | ||||||
|  |     GIT_ATTR_FLAGS = Rugged::Repository::Attributes.parse_opts(GIT_ATTR_OPTS) | ||||||
|  |  | ||||||
|     include BlobHelper |     include BlobHelper | ||||||
|  |  | ||||||
|     MAX_SIZE = 128 * 1024 |     MAX_SIZE = 128 * 1024 | ||||||
| @@ -19,6 +24,29 @@ module Linguist | |||||||
|       @mode = mode |       @mode = mode | ||||||
|     end |     end | ||||||
|  |  | ||||||
|  |     def git_attributes | ||||||
|  |       @git_attributes ||= repository.fetch_attributes( | ||||||
|  |         name, GIT_ATTR, GIT_ATTR_FLAGS) | ||||||
|  |     end | ||||||
|  |  | ||||||
|  |     def vendored? | ||||||
|  |       if attr = git_attributes['linguist-vendored'] | ||||||
|  |         return boolean_attribute(attr) | ||||||
|  |       else | ||||||
|  |         return super | ||||||
|  |       end | ||||||
|  |     end | ||||||
|  |  | ||||||
|  |     def language | ||||||
|  |       return @language if defined?(@language) | ||||||
|  |  | ||||||
|  |       @language = if lang = git_attributes['linguist-language'] | ||||||
|  |         Language.find_by_name(lang) | ||||||
|  |       else | ||||||
|  |         super | ||||||
|  |       end | ||||||
|  |     end | ||||||
|  |  | ||||||
|     def data |     def data | ||||||
|       load_blob! |       load_blob! | ||||||
|       @data |       @data | ||||||
| @@ -30,6 +58,12 @@ module Linguist | |||||||
|     end |     end | ||||||
|  |  | ||||||
|     protected |     protected | ||||||
|  |  | ||||||
|  |     # Returns true if the attribute is present and not the string "false". | ||||||
|  |     def boolean_attribute(attr) | ||||||
|  |       attr != "false" | ||||||
|  |     end | ||||||
|  |  | ||||||
|     def load_blob! |     def load_blob! | ||||||
|       @data, @size = Rugged::Blob.to_buffer(repository, oid, MAX_SIZE) if @data.nil? |       @data, @size = Rugged::Blob.to_buffer(repository, oid, MAX_SIZE) if @data.nil? | ||||||
|     end |     end | ||||||
|   | |||||||
| @@ -110,18 +110,30 @@ module Linguist | |||||||
|         if @old_commit_oid == @commit_oid |         if @old_commit_oid == @commit_oid | ||||||
|           @old_stats |           @old_stats | ||||||
|         else |         else | ||||||
|           compute_stats(@old_commit_oid, @commit_oid, @old_stats) |           compute_stats(@old_commit_oid, @old_stats) | ||||||
|         end |         end | ||||||
|       end |       end | ||||||
|     end |     end | ||||||
|  |  | ||||||
|  |     def read_index | ||||||
|  |       attr_index = Rugged::Index.new | ||||||
|  |       attr_index.read_tree(current_tree) | ||||||
|  |       repository.index = attr_index | ||||||
|  |     end | ||||||
|  |  | ||||||
|  |     def current_tree | ||||||
|  |       @tree ||= Rugged::Commit.lookup(repository, @commit_oid).tree | ||||||
|  |     end | ||||||
|  |  | ||||||
|     protected |     protected | ||||||
|     def compute_stats(old_commit_oid, commit_oid, cache = nil) |  | ||||||
|  |     def compute_stats(old_commit_oid, cache = nil) | ||||||
|       file_map = cache ? cache.dup : {} |       file_map = cache ? cache.dup : {} | ||||||
|       old_tree = old_commit_oid && Rugged::Commit.lookup(repository, old_commit_oid).tree |       old_tree = old_commit_oid && Rugged::Commit.lookup(repository, old_commit_oid).tree | ||||||
|       new_tree = Rugged::Commit.lookup(repository, commit_oid).tree |  | ||||||
|  |  | ||||||
|       diff = Rugged::Tree.diff(repository, old_tree, new_tree) |       read_index | ||||||
|  |  | ||||||
|  |       diff = Rugged::Tree.diff(repository, old_tree, current_tree) | ||||||
|  |  | ||||||
|       diff.each_delta do |delta| |       diff.each_delta do |delta| | ||||||
|         old = delta.old_file[:path] |         old = delta.old_file[:path] | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -17,9 +17,11 @@ module Linguist | |||||||
|     PATH = File.expand_path('../samples.json', __FILE__) |     PATH = File.expand_path('../samples.json', __FILE__) | ||||||
|  |  | ||||||
|     # Hash of serialized samples object |     # Hash of serialized samples object | ||||||
|     if File.exist?(PATH) |     def self.cache | ||||||
|       serializer = defined?(JSON) ? JSON : YAML |       @cache ||= begin | ||||||
|       DATA = serializer.load(File.read(PATH)) |         serializer = defined?(JSON) ? JSON : YAML | ||||||
|  |         serializer.load(File.read(PATH)) | ||||||
|  |       end | ||||||
|     end |     end | ||||||
|  |  | ||||||
|     # Public: Iterate over each sample. |     # Public: Iterate over each sample. | ||||||
|   | |||||||
| @@ -33,15 +33,34 @@ | |||||||
| # Erlang bundles | # Erlang bundles | ||||||
| - ^rebar$ | - ^rebar$ | ||||||
|  |  | ||||||
|  | # Go dependencies | ||||||
|  | - Godeps/_workspace/ | ||||||
|  |  | ||||||
| # Bootstrap minified css and js | # Bootstrap minified css and js | ||||||
| - (^|/)bootstrap([^.]*)(\.min)?\.(js|css)$ | - (^|/)bootstrap([^.]*)(\.min)?\.(js|css)$ | ||||||
|  |  | ||||||
|  | # Font Awesome | ||||||
|  | - font-awesome.min.css | ||||||
|  | - font-awesome.css | ||||||
|  |  | ||||||
| # Foundation css | # Foundation css | ||||||
| - foundation.min.css | - foundation.min.css | ||||||
| - foundation.css | - foundation.css | ||||||
|  |  | ||||||
|  | # Normalize.css | ||||||
|  | - normalize.css | ||||||
|  |  | ||||||
|  | # Bourbon SCSS | ||||||
|  | - (^|/)[Bb]ourbon/.*\.css$ | ||||||
|  | - (^|/)[Bb]ourbon/.*\.scss$ | ||||||
|  |  | ||||||
|  | # Animate.css | ||||||
|  | - animate.css | ||||||
|  | - animate.min.css | ||||||
|  |  | ||||||
| # Vendored dependencies | # Vendored dependencies | ||||||
| - thirdparty/ | - third[-_]?party/ | ||||||
|  | - 3rd[-_]?party/ | ||||||
| - vendors?/ | - vendors?/ | ||||||
| - extern(al)?/ | - extern(al)?/ | ||||||
|  |  | ||||||
| @@ -109,6 +128,10 @@ | |||||||
| - (^|/)modernizr\-\d\.\d+(\.\d+)?(\.min)?\.js$ | - (^|/)modernizr\-\d\.\d+(\.\d+)?(\.min)?\.js$ | ||||||
| - (^|/)modernizr\.custom\.\d+\.js$ | - (^|/)modernizr\.custom\.\d+\.js$ | ||||||
|  |  | ||||||
|  | # Knockout | ||||||
|  | - (^|/)knockout-(\d+\.){3}(debug\.)?js$ | ||||||
|  | - knockout-min.js | ||||||
|  |  | ||||||
| ## Python ## | ## Python ## | ||||||
|  |  | ||||||
| # django | # django | ||||||
| @@ -125,6 +148,9 @@ | |||||||
|  |  | ||||||
| ## Obj-C ## | ## Obj-C ## | ||||||
|  |  | ||||||
|  | # Cocoapods | ||||||
|  | - ^Pods/ | ||||||
|  |  | ||||||
| # Sparkle | # Sparkle | ||||||
| - (^|/)Sparkle/ | - (^|/)Sparkle/ | ||||||
|  |  | ||||||
| @@ -192,6 +218,9 @@ | |||||||
| - (^|/)cordova([^.]*)(\.min)?\.js$ | - (^|/)cordova([^.]*)(\.min)?\.js$ | ||||||
| - (^|/)cordova\-\d\.\d(\.\d)?(\.min)?\.js$ | - (^|/)cordova\-\d\.\d(\.\d)?(\.min)?\.js$ | ||||||
|  |  | ||||||
|  | # Foundation js | ||||||
|  | - foundation(\..*)?\.js$ | ||||||
|  |  | ||||||
| # Vagrant | # Vagrant | ||||||
| - ^Vagrantfile$ | - ^Vagrantfile$ | ||||||
|  |  | ||||||
| @@ -209,3 +238,7 @@ | |||||||
| - octicons.css | - octicons.css | ||||||
| - octicons.min.css | - octicons.min.css | ||||||
| - sprockets-octicons.scss | - sprockets-octicons.scss | ||||||
|  |  | ||||||
|  | # Typesafe Activator | ||||||
|  | - (^|/)activator$ | ||||||
|  | - (^|/)activator\.bat$ | ||||||
|   | |||||||
| @@ -1,3 +1,3 @@ | |||||||
| module Linguist | module Linguist | ||||||
|   VERSION = "3.0.2" |   VERSION = "3.2.0" | ||||||
| end | 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 ⍬ | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,503 +0,0 @@ | |||||||
|  |  | ||||||
| ; flat assembler interface for Win32 |  | ||||||
| ; Copyright (c) 1999-2014, Tomasz Grysztar. |  | ||||||
| ; All rights reserved. |  | ||||||
|  |  | ||||||
| CREATE_NEW	       = 1 |  | ||||||
| CREATE_ALWAYS	       = 2 |  | ||||||
| OPEN_EXISTING	       = 3 |  | ||||||
| OPEN_ALWAYS	       = 4 |  | ||||||
| TRUNCATE_EXISTING      = 5 |  | ||||||
|  |  | ||||||
| FILE_SHARE_READ        = 1 |  | ||||||
| FILE_SHARE_WRITE       = 2 |  | ||||||
| FILE_SHARE_DELETE      = 4 |  | ||||||
|  |  | ||||||
| GENERIC_READ	       = 80000000h |  | ||||||
| GENERIC_WRITE	       = 40000000h |  | ||||||
|  |  | ||||||
| STD_INPUT_HANDLE       = 0FFFFFFF6h |  | ||||||
| STD_OUTPUT_HANDLE      = 0FFFFFFF5h |  | ||||||
| STD_ERROR_HANDLE       = 0FFFFFFF4h |  | ||||||
|  |  | ||||||
| MEM_COMMIT	       = 1000h |  | ||||||
| MEM_RESERVE	       = 2000h |  | ||||||
| MEM_DECOMMIT	       = 4000h |  | ||||||
| MEM_RELEASE	       = 8000h |  | ||||||
| MEM_FREE	       = 10000h |  | ||||||
| MEM_PRIVATE	       = 20000h |  | ||||||
| MEM_MAPPED	       = 40000h |  | ||||||
| MEM_RESET	       = 80000h |  | ||||||
| MEM_TOP_DOWN	       = 100000h |  | ||||||
|  |  | ||||||
| PAGE_NOACCESS	       = 1 |  | ||||||
| PAGE_READONLY	       = 2 |  | ||||||
| PAGE_READWRITE	       = 4 |  | ||||||
| PAGE_WRITECOPY	       = 8 |  | ||||||
| PAGE_EXECUTE	       = 10h |  | ||||||
| PAGE_EXECUTE_READ      = 20h |  | ||||||
| PAGE_EXECUTE_READWRITE = 40h |  | ||||||
| PAGE_EXECUTE_WRITECOPY = 80h |  | ||||||
| PAGE_GUARD	       = 100h |  | ||||||
| PAGE_NOCACHE	       = 200h |  | ||||||
|  |  | ||||||
| init_memory: |  | ||||||
| 	xor	eax,eax |  | ||||||
| 	mov	[memory_start],eax |  | ||||||
| 	mov	eax,esp |  | ||||||
| 	and	eax,not 0FFFh |  | ||||||
| 	add	eax,1000h-10000h |  | ||||||
| 	mov	[stack_limit],eax |  | ||||||
| 	mov	eax,[memory_setting] |  | ||||||
| 	shl	eax,10 |  | ||||||
| 	jnz	allocate_memory |  | ||||||
| 	push	buffer |  | ||||||
| 	call	[GlobalMemoryStatus] |  | ||||||
| 	mov	eax,dword [buffer+20] |  | ||||||
| 	mov	edx,dword [buffer+12] |  | ||||||
| 	cmp	eax,0 |  | ||||||
| 	jl	large_memory |  | ||||||
| 	cmp	edx,0 |  | ||||||
| 	jl	large_memory |  | ||||||
| 	shr	eax,2 |  | ||||||
| 	add	eax,edx |  | ||||||
| 	jmp	allocate_memory |  | ||||||
|     large_memory: |  | ||||||
| 	mov	eax,80000000h |  | ||||||
|     allocate_memory: |  | ||||||
| 	mov	edx,eax |  | ||||||
| 	shr	edx,2 |  | ||||||
| 	mov	ecx,eax |  | ||||||
| 	sub	ecx,edx |  | ||||||
| 	mov	[memory_end],ecx |  | ||||||
| 	mov	[additional_memory_end],edx |  | ||||||
| 	push	PAGE_READWRITE |  | ||||||
| 	push	MEM_COMMIT |  | ||||||
| 	push	eax |  | ||||||
| 	push	0 |  | ||||||
| 	call	[VirtualAlloc] |  | ||||||
| 	or	eax,eax |  | ||||||
| 	jz	not_enough_memory |  | ||||||
| 	mov	[memory_start],eax |  | ||||||
| 	add	eax,[memory_end] |  | ||||||
| 	mov	[memory_end],eax |  | ||||||
| 	mov	[additional_memory],eax |  | ||||||
| 	add	[additional_memory_end],eax |  | ||||||
| 	ret |  | ||||||
|     not_enough_memory: |  | ||||||
| 	mov	eax,[additional_memory_end] |  | ||||||
| 	shl	eax,1 |  | ||||||
| 	cmp	eax,4000h |  | ||||||
| 	jb	out_of_memory |  | ||||||
| 	jmp	allocate_memory |  | ||||||
|  |  | ||||||
| exit_program: |  | ||||||
| 	movzx	eax,al |  | ||||||
| 	push	eax |  | ||||||
| 	mov	eax,[memory_start] |  | ||||||
| 	test	eax,eax |  | ||||||
| 	jz	do_exit |  | ||||||
| 	push	MEM_RELEASE |  | ||||||
| 	push	0 |  | ||||||
| 	push	eax |  | ||||||
| 	call	[VirtualFree] |  | ||||||
|     do_exit: |  | ||||||
| 	call	[ExitProcess] |  | ||||||
|  |  | ||||||
| get_environment_variable: |  | ||||||
| 	mov	ecx,[memory_end] |  | ||||||
| 	sub	ecx,edi |  | ||||||
| 	cmp	ecx,4000h |  | ||||||
| 	jbe	buffer_for_variable_ok |  | ||||||
| 	mov	ecx,4000h |  | ||||||
|     buffer_for_variable_ok: |  | ||||||
| 	push	ecx |  | ||||||
| 	push	edi |  | ||||||
| 	push	esi |  | ||||||
| 	call	[GetEnvironmentVariable] |  | ||||||
| 	add	edi,eax |  | ||||||
| 	cmp	edi,[memory_end] |  | ||||||
| 	jae	out_of_memory |  | ||||||
| 	ret |  | ||||||
|  |  | ||||||
| open: |  | ||||||
| 	push	0 |  | ||||||
| 	push	0 |  | ||||||
| 	push	OPEN_EXISTING |  | ||||||
| 	push	0 |  | ||||||
| 	push	FILE_SHARE_READ |  | ||||||
| 	push	GENERIC_READ |  | ||||||
| 	push	edx |  | ||||||
| 	call	[CreateFile] |  | ||||||
| 	cmp	eax,-1 |  | ||||||
| 	je	file_error |  | ||||||
| 	mov	ebx,eax |  | ||||||
| 	clc |  | ||||||
| 	ret |  | ||||||
|     file_error: |  | ||||||
| 	stc |  | ||||||
| 	ret |  | ||||||
| create: |  | ||||||
| 	push	0 |  | ||||||
| 	push	0 |  | ||||||
| 	push	CREATE_ALWAYS |  | ||||||
| 	push	0 |  | ||||||
| 	push	FILE_SHARE_READ |  | ||||||
| 	push	GENERIC_WRITE |  | ||||||
| 	push	edx |  | ||||||
| 	call	[CreateFile] |  | ||||||
| 	cmp	eax,-1 |  | ||||||
| 	je	file_error |  | ||||||
| 	mov	ebx,eax |  | ||||||
| 	clc |  | ||||||
| 	ret |  | ||||||
| write: |  | ||||||
| 	push	0 |  | ||||||
| 	push	bytes_count |  | ||||||
| 	push	ecx |  | ||||||
| 	push	edx |  | ||||||
| 	push	ebx |  | ||||||
| 	call	[WriteFile] |  | ||||||
| 	or	eax,eax |  | ||||||
| 	jz	file_error |  | ||||||
| 	clc |  | ||||||
| 	ret |  | ||||||
| read: |  | ||||||
| 	mov	ebp,ecx |  | ||||||
| 	push	0 |  | ||||||
| 	push	bytes_count |  | ||||||
| 	push	ecx |  | ||||||
| 	push	edx |  | ||||||
| 	push	ebx |  | ||||||
| 	call	[ReadFile] |  | ||||||
| 	or	eax,eax |  | ||||||
| 	jz	file_error |  | ||||||
| 	cmp	ebp,[bytes_count] |  | ||||||
| 	jne	file_error |  | ||||||
| 	clc |  | ||||||
| 	ret |  | ||||||
| close: |  | ||||||
| 	push	ebx |  | ||||||
| 	call	[CloseHandle] |  | ||||||
| 	ret |  | ||||||
| lseek: |  | ||||||
| 	movzx	eax,al |  | ||||||
| 	push	eax |  | ||||||
| 	push	0 |  | ||||||
| 	push	edx |  | ||||||
| 	push	ebx |  | ||||||
| 	call	[SetFilePointer] |  | ||||||
| 	ret |  | ||||||
|  |  | ||||||
| display_string: |  | ||||||
| 	push	[con_handle] |  | ||||||
| 	call	[GetStdHandle] |  | ||||||
| 	mov	ebp,eax |  | ||||||
| 	mov	edi,esi |  | ||||||
| 	or	ecx,-1 |  | ||||||
| 	xor	al,al |  | ||||||
| 	repne	scasb |  | ||||||
| 	neg	ecx |  | ||||||
| 	sub	ecx,2 |  | ||||||
| 	push	0 |  | ||||||
| 	push	bytes_count |  | ||||||
| 	push	ecx |  | ||||||
| 	push	esi |  | ||||||
| 	push	ebp |  | ||||||
| 	call	[WriteFile] |  | ||||||
| 	ret |  | ||||||
| display_character: |  | ||||||
| 	push	ebx |  | ||||||
| 	mov	[character],dl |  | ||||||
| 	push	[con_handle] |  | ||||||
| 	call	[GetStdHandle] |  | ||||||
| 	mov	ebx,eax |  | ||||||
| 	push	0 |  | ||||||
| 	push	bytes_count |  | ||||||
| 	push	1 |  | ||||||
| 	push	character |  | ||||||
| 	push	ebx |  | ||||||
| 	call	[WriteFile] |  | ||||||
| 	pop	ebx |  | ||||||
| 	ret |  | ||||||
| display_number: |  | ||||||
| 	push	ebx |  | ||||||
| 	mov	ecx,1000000000 |  | ||||||
| 	xor	edx,edx |  | ||||||
| 	xor	bl,bl |  | ||||||
|       display_loop: |  | ||||||
| 	div	ecx |  | ||||||
| 	push	edx |  | ||||||
| 	cmp	ecx,1 |  | ||||||
| 	je	display_digit |  | ||||||
| 	or	bl,bl |  | ||||||
| 	jnz	display_digit |  | ||||||
| 	or	al,al |  | ||||||
| 	jz	digit_ok |  | ||||||
| 	not	bl |  | ||||||
|       display_digit: |  | ||||||
| 	mov	dl,al |  | ||||||
| 	add	dl,30h |  | ||||||
| 	push	ecx |  | ||||||
| 	call	display_character |  | ||||||
| 	pop	ecx |  | ||||||
|       digit_ok: |  | ||||||
| 	mov	eax,ecx |  | ||||||
| 	xor	edx,edx |  | ||||||
| 	mov	ecx,10 |  | ||||||
| 	div	ecx |  | ||||||
| 	mov	ecx,eax |  | ||||||
| 	pop	eax |  | ||||||
| 	or	ecx,ecx |  | ||||||
| 	jnz	display_loop |  | ||||||
| 	pop	ebx |  | ||||||
| 	ret |  | ||||||
|  |  | ||||||
| display_user_messages: |  | ||||||
| 	mov	[displayed_count],0 |  | ||||||
| 	call	show_display_buffer |  | ||||||
| 	cmp	[displayed_count],1 |  | ||||||
| 	jb	line_break_ok |  | ||||||
| 	je	make_line_break |  | ||||||
| 	mov	ax,word [last_displayed] |  | ||||||
| 	cmp	ax,0A0Dh |  | ||||||
| 	je	line_break_ok |  | ||||||
| 	cmp	ax,0D0Ah |  | ||||||
| 	je	line_break_ok |  | ||||||
|       make_line_break: |  | ||||||
| 	mov	word [buffer],0A0Dh |  | ||||||
| 	push	[con_handle] |  | ||||||
| 	call	[GetStdHandle] |  | ||||||
| 	push	0 |  | ||||||
| 	push	bytes_count |  | ||||||
| 	push	2 |  | ||||||
| 	push	buffer |  | ||||||
| 	push	eax |  | ||||||
| 	call	[WriteFile] |  | ||||||
|       line_break_ok: |  | ||||||
| 	ret |  | ||||||
| display_block: |  | ||||||
| 	add	[displayed_count],ecx |  | ||||||
| 	cmp	ecx,1 |  | ||||||
| 	ja	take_last_two_characters |  | ||||||
| 	jb	block_displayed |  | ||||||
| 	mov	al,[last_displayed+1] |  | ||||||
| 	mov	ah,[esi] |  | ||||||
| 	mov	word [last_displayed],ax |  | ||||||
| 	jmp	block_ok |  | ||||||
|       take_last_two_characters: |  | ||||||
| 	mov	ax,[esi+ecx-2] |  | ||||||
| 	mov	word [last_displayed],ax |  | ||||||
|       block_ok: |  | ||||||
| 	push	ecx |  | ||||||
| 	push	[con_handle] |  | ||||||
| 	call	[GetStdHandle] |  | ||||||
| 	pop	ecx |  | ||||||
| 	push	0 |  | ||||||
| 	push	bytes_count |  | ||||||
| 	push	ecx |  | ||||||
| 	push	esi |  | ||||||
| 	push	eax |  | ||||||
| 	call	[WriteFile] |  | ||||||
|       block_displayed: |  | ||||||
| 	ret |  | ||||||
|  |  | ||||||
| fatal_error: |  | ||||||
| 	mov	[con_handle],STD_ERROR_HANDLE |  | ||||||
| 	mov	esi,error_prefix |  | ||||||
| 	call	display_string |  | ||||||
| 	pop	esi |  | ||||||
| 	call	display_string |  | ||||||
| 	mov	esi,error_suffix |  | ||||||
| 	call	display_string |  | ||||||
| 	mov	al,0FFh |  | ||||||
| 	jmp	exit_program |  | ||||||
| assembler_error: |  | ||||||
| 	mov	[con_handle],STD_ERROR_HANDLE |  | ||||||
| 	call	display_user_messages |  | ||||||
| 	push	dword 0 |  | ||||||
| 	mov	ebx,[current_line] |  | ||||||
|       get_error_lines: |  | ||||||
| 	mov	eax,[ebx] |  | ||||||
| 	cmp	byte [eax],0 |  | ||||||
| 	je	get_next_error_line |  | ||||||
| 	push	ebx |  | ||||||
| 	test	byte [ebx+7],80h |  | ||||||
| 	jz	display_error_line |  | ||||||
| 	mov	edx,ebx |  | ||||||
|       find_definition_origin: |  | ||||||
| 	mov	edx,[edx+12] |  | ||||||
| 	test	byte [edx+7],80h |  | ||||||
| 	jnz	find_definition_origin |  | ||||||
| 	push	edx |  | ||||||
|       get_next_error_line: |  | ||||||
| 	mov	ebx,[ebx+8] |  | ||||||
| 	jmp	get_error_lines |  | ||||||
|       display_error_line: |  | ||||||
| 	mov	esi,[ebx] |  | ||||||
| 	call	display_string |  | ||||||
| 	mov	esi,line_number_start |  | ||||||
| 	call	display_string |  | ||||||
| 	mov	eax,[ebx+4] |  | ||||||
| 	and	eax,7FFFFFFFh |  | ||||||
| 	call	display_number |  | ||||||
| 	mov	dl,']' |  | ||||||
| 	call	display_character |  | ||||||
| 	pop	esi |  | ||||||
| 	cmp	ebx,esi |  | ||||||
| 	je	line_number_ok |  | ||||||
| 	mov	dl,20h |  | ||||||
| 	call	display_character |  | ||||||
| 	push	esi |  | ||||||
| 	mov	esi,[esi] |  | ||||||
| 	movzx	ecx,byte [esi] |  | ||||||
| 	inc	esi |  | ||||||
| 	call	display_block |  | ||||||
| 	mov	esi,line_number_start |  | ||||||
| 	call	display_string |  | ||||||
| 	pop	esi |  | ||||||
| 	mov	eax,[esi+4] |  | ||||||
| 	and	eax,7FFFFFFFh |  | ||||||
| 	call	display_number |  | ||||||
| 	mov	dl,']' |  | ||||||
| 	call	display_character |  | ||||||
|       line_number_ok: |  | ||||||
| 	mov	esi,line_data_start |  | ||||||
| 	call	display_string |  | ||||||
| 	mov	esi,ebx |  | ||||||
| 	mov	edx,[esi] |  | ||||||
| 	call	open |  | ||||||
| 	mov	al,2 |  | ||||||
| 	xor	edx,edx |  | ||||||
| 	call	lseek |  | ||||||
| 	mov	edx,[esi+8] |  | ||||||
| 	sub	eax,edx |  | ||||||
| 	jz	line_data_displayed |  | ||||||
| 	push	eax |  | ||||||
| 	xor	al,al |  | ||||||
| 	call	lseek |  | ||||||
| 	mov	ecx,[esp] |  | ||||||
| 	mov	edx,[additional_memory] |  | ||||||
| 	lea	eax,[edx+ecx] |  | ||||||
| 	cmp	eax,[additional_memory_end] |  | ||||||
| 	ja	out_of_memory |  | ||||||
| 	call	read |  | ||||||
| 	call	close |  | ||||||
| 	pop	ecx |  | ||||||
| 	mov	esi,[additional_memory] |  | ||||||
|       get_line_data: |  | ||||||
| 	mov	al,[esi] |  | ||||||
| 	cmp	al,0Ah |  | ||||||
| 	je	display_line_data |  | ||||||
| 	cmp	al,0Dh |  | ||||||
| 	je	display_line_data |  | ||||||
| 	cmp	al,1Ah |  | ||||||
| 	je	display_line_data |  | ||||||
| 	or	al,al |  | ||||||
| 	jz	display_line_data |  | ||||||
| 	inc	esi |  | ||||||
| 	loop	get_line_data |  | ||||||
|       display_line_data: |  | ||||||
| 	mov	ecx,esi |  | ||||||
| 	mov	esi,[additional_memory] |  | ||||||
| 	sub	ecx,esi |  | ||||||
| 	call	display_block |  | ||||||
|       line_data_displayed: |  | ||||||
| 	mov	esi,cr_lf |  | ||||||
| 	call	display_string |  | ||||||
| 	pop	ebx |  | ||||||
| 	or	ebx,ebx |  | ||||||
| 	jnz	display_error_line |  | ||||||
| 	mov	esi,error_prefix |  | ||||||
| 	call	display_string |  | ||||||
| 	pop	esi |  | ||||||
| 	call	display_string |  | ||||||
| 	mov	esi,error_suffix |  | ||||||
| 	call	display_string |  | ||||||
| 	mov	al,2 |  | ||||||
| 	jmp	exit_program |  | ||||||
|  |  | ||||||
| make_timestamp: |  | ||||||
| 	push	buffer |  | ||||||
| 	call	[GetSystemTime] |  | ||||||
| 	movzx	ecx,word [buffer] |  | ||||||
| 	mov	eax,ecx |  | ||||||
| 	sub	eax,1970 |  | ||||||
| 	mov	ebx,365 |  | ||||||
| 	mul	ebx |  | ||||||
| 	mov	ebp,eax |  | ||||||
| 	mov	eax,ecx |  | ||||||
| 	sub	eax,1969 |  | ||||||
| 	shr	eax,2 |  | ||||||
| 	add	ebp,eax |  | ||||||
| 	mov	eax,ecx |  | ||||||
| 	sub	eax,1901 |  | ||||||
| 	mov	ebx,100 |  | ||||||
| 	div	ebx |  | ||||||
| 	sub	ebp,eax |  | ||||||
| 	mov	eax,ecx |  | ||||||
| 	xor	edx,edx |  | ||||||
| 	sub	eax,1601 |  | ||||||
| 	mov	ebx,400 |  | ||||||
| 	div	ebx |  | ||||||
| 	add	ebp,eax |  | ||||||
| 	movzx	ecx,word [buffer+2] |  | ||||||
| 	mov	eax,ecx |  | ||||||
| 	dec	eax |  | ||||||
| 	mov	ebx,30 |  | ||||||
| 	mul	ebx |  | ||||||
| 	add	ebp,eax |  | ||||||
| 	cmp	ecx,8 |  | ||||||
| 	jbe	months_correction |  | ||||||
| 	mov	eax,ecx |  | ||||||
| 	sub	eax,7 |  | ||||||
| 	shr	eax,1 |  | ||||||
| 	add	ebp,eax |  | ||||||
| 	mov	ecx,8 |  | ||||||
|       months_correction: |  | ||||||
| 	mov	eax,ecx |  | ||||||
| 	shr	eax,1 |  | ||||||
| 	add	ebp,eax |  | ||||||
| 	cmp	ecx,2 |  | ||||||
| 	jbe	day_correction_ok |  | ||||||
| 	sub	ebp,2 |  | ||||||
| 	movzx	ecx,word [buffer] |  | ||||||
| 	test	ecx,11b |  | ||||||
| 	jnz	day_correction_ok |  | ||||||
| 	xor	edx,edx |  | ||||||
| 	mov	eax,ecx |  | ||||||
| 	mov	ebx,100 |  | ||||||
| 	div	ebx |  | ||||||
| 	or	edx,edx |  | ||||||
| 	jnz	day_correction |  | ||||||
| 	mov	eax,ecx |  | ||||||
| 	mov	ebx,400 |  | ||||||
| 	div	ebx |  | ||||||
| 	or	edx,edx |  | ||||||
| 	jnz	day_correction_ok |  | ||||||
|       day_correction: |  | ||||||
| 	inc	ebp |  | ||||||
|       day_correction_ok: |  | ||||||
| 	movzx	eax,word [buffer+6] |  | ||||||
| 	dec	eax |  | ||||||
| 	add	eax,ebp |  | ||||||
| 	mov	ebx,24 |  | ||||||
| 	mul	ebx |  | ||||||
| 	movzx	ecx,word [buffer+8] |  | ||||||
| 	add	eax,ecx |  | ||||||
| 	mov	ebx,60 |  | ||||||
| 	mul	ebx |  | ||||||
| 	movzx	ecx,word [buffer+10] |  | ||||||
| 	add	eax,ecx |  | ||||||
| 	mov	ebx,60 |  | ||||||
| 	mul	ebx |  | ||||||
| 	movzx	ecx,word [buffer+12] |  | ||||||
| 	add	eax,ecx |  | ||||||
| 	adc	edx,0 |  | ||||||
| 	ret |  | ||||||
|  |  | ||||||
| error_prefix db 'error: ',0 |  | ||||||
| error_suffix db '.' |  | ||||||
| cr_lf db 0Dh,0Ah,0 |  | ||||||
| line_number_start db ' [',0 |  | ||||||
| line_data_start db ':',0Dh,0Ah,0 |  | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,13 +1,13 @@ | |||||||
| doc "Test function for Ceylon" | "Test function for Ceylon" | ||||||
| by  "Enrique" | by ("Enrique") | ||||||
| shared void test() { | shared void test() { | ||||||
|   print("test"); |     print("test"); | ||||||
| } | } | ||||||
|  |  | ||||||
| doc "Test class for Ceylon" | "Test class for Ceylon" | ||||||
| shared class Test(name) satisfies Comparable<Test> { | shared class Test(name) satisfies Comparable<Test> { | ||||||
|     shared String name; |     shared String name; | ||||||
|     shared actual String string = "Test " name "."; |     shared actual String string = "Test ``name``."; | ||||||
|  |  | ||||||
|     shared actual Comparison compare(Test other) { |     shared actual Comparison compare(Test other) { | ||||||
|         return name<=>other.name; |         return name<=>other.name; | ||||||
|   | |||||||
							
								
								
									
										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); | ||||||
|  | } | ||||||
							
								
								
									
										11
									
								
								samples/Clean/GenHylo.dcl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								samples/Clean/GenHylo.dcl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | definition module GenHylo | ||||||
|  |  | ||||||
|  | import StdGeneric, GenMap | ||||||
|  |  | ||||||
|  | :: Fix f = In (f .(Fix f)) | ||||||
|  | Out :: !u:(Fix v:a) -> v:(a w:(Fix v:a)), [u <= w] | ||||||
|  |  | ||||||
|  | hylo :: ((.f .b) -> .b) (.a -> (.f .a)) -> (.a -> .b) | gMap{|*->*|} f | ||||||
|  | cata :: (u:(f .a) -> .a) -> (Fix u:f) -> .a | gMap{|*->*|} f | ||||||
|  | ana :: (.a -> u:(f .a)) -> .a -> (Fix u:f) | gMap{|*->*|} f | ||||||
|  |  | ||||||
							
								
								
									
										9
									
								
								samples/Clean/GenMap.dcl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								samples/Clean/GenMap.dcl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | |||||||
|  | definition module GenMap | ||||||
|  |  | ||||||
|  | import StdGeneric | ||||||
|  |  | ||||||
|  | generic gMap a b :: .a -> .b | ||||||
|  | derive gMap c, UNIT, PAIR, EITHER, CONS, FIELD, OBJECT, {}, {!}  | ||||||
|  |  | ||||||
|  | derive gMap [], (,), (,,),  (,,,), (,,,,), (,,,,,), (,,,,,,), (,,,,,,,) | ||||||
|  |  | ||||||
							
								
								
									
										19
									
								
								samples/Clean/GenMap.icl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								samples/Clean/GenMap.icl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | |||||||
|  | implementation module GenMap | ||||||
|  |  | ||||||
|  | import StdClass, StdArray, StdInt, StdFunc | ||||||
|  | import StdGeneric, _Array | ||||||
|  |  | ||||||
|  | generic gMap a b :: .a -> .b | ||||||
|  | gMap{|c|} x 					= x | ||||||
|  | gMap{|UNIT|} x 					= x | ||||||
|  | gMap{|PAIR|} fx fy (PAIR x y) 	= PAIR (fx x) (fy y)  | ||||||
|  | gMap{|EITHER|} fl fr (LEFT x) 	= LEFT (fl x) | ||||||
|  | gMap{|EITHER|} fl fr (RIGHT x) 	= RIGHT (fr x) | ||||||
|  | gMap{|CONS|} f (CONS x) 		= CONS (f x) | ||||||
|  | gMap{|FIELD|} f (FIELD x) 		= FIELD (f x) | ||||||
|  | gMap{|OBJECT|} f (OBJECT x) 	= OBJECT (f x) | ||||||
|  | gMap{|{}|} f xs 				= mapArray f xs | ||||||
|  | gMap{|{!}|} f xs				= mapArray f xs | ||||||
|  |  | ||||||
|  | derive gMap [], (,), (,,),  (,,,), (,,,,), (,,,,,), (,,,,,,), (,,,,,,,) | ||||||
|  |  | ||||||
							
								
								
									
										54
									
								
								samples/Clean/fsieve.icl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								samples/Clean/fsieve.icl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | |||||||
|  | module fsieve | ||||||
|  |  | ||||||
|  | /* | ||||||
|  | The Fast Sieve of Eratosthenes. | ||||||
|  |  | ||||||
|  | A sequential and optimized version of the sieve of Eratosthenes. | ||||||
|  | The program calculates a list of the first NrOfPrime primes. | ||||||
|  | The result of the program is the NrOfPrimes'th prime. | ||||||
|  |  | ||||||
|  | Strictness annotations have been added because the strictness analyser | ||||||
|  | is not able to deduce all strictness information. Removal of these !'s | ||||||
|  | will make the program about 20% slower. | ||||||
|  |  | ||||||
|  | On a machine without a math coprocessor the execution of this | ||||||
|  | program might take a (very) long time. Set NrOfPrimes to a smaller value. | ||||||
|  | */ | ||||||
|  |  | ||||||
|  | import StdClass; // RWS | ||||||
|  | import StdInt, StdReal | ||||||
|  |       | ||||||
|  | NrOfPrimes :== 3000  | ||||||
|  | 	 | ||||||
|  | //	The sieve algorithm: generate an infinite list of all primes. | ||||||
|  |  | ||||||
|  | Primes::[Int] | ||||||
|  | Primes = pr where pr = [5 : Sieve 7 4 pr] | ||||||
|  |  | ||||||
|  | Sieve::Int !Int [Int] -> [Int] | ||||||
|  | Sieve g i prs | ||||||
|  | 	| IsPrime prs g (toInt (sqrt (toReal g)))	=  [g : Sieve` g i prs] | ||||||
|  | 												=  Sieve (g + i) (6 - i) prs | ||||||
|  |  | ||||||
|  | Sieve`::Int Int [Int] -> [Int] | ||||||
|  | Sieve` g i prs =  Sieve (g + i) (6 - i) prs | ||||||
|  |  | ||||||
|  | IsPrime::[Int] !Int Int -> Bool | ||||||
|  | IsPrime [f:r] pr bd | f>bd 			=  True | ||||||
|  | 					| pr rem f==0	=  False | ||||||
|  | 									=  IsPrime r pr bd | ||||||
|  | 								   | ||||||
|  | //	Select is used to get the NrOfPrimes'th prime from the infinite list. | ||||||
|  |  | ||||||
|  | Select::[x] Int -> x | ||||||
|  | Select [f:r] 1 =  f | ||||||
|  | Select [f:r] n =  Select r (n - 1) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /*	The Start rule: Select the NrOfPrimes'th prime from the list of primes | ||||||
|  | 	generated by Primes. | ||||||
|  | */ | ||||||
|  |  | ||||||
|  | Start::Int | ||||||
|  | Start = Select [2, 3 : Primes] NrOfPrimes | ||||||
|  |  | ||||||
							
								
								
									
										99
									
								
								samples/Clean/sem.icl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								samples/Clean/sem.icl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,99 @@ | |||||||
|  | module monadicSemantics | ||||||
|  |  | ||||||
|  | import StdEnv, StdGeneric, GenMap, GenHylo | ||||||
|  |  | ||||||
|  | /* For fun I implemented the recursive datastructre Exp and Stm as fixpoints | ||||||
|  |    This helps us define recursive functions on them (only a little bit though) | ||||||
|  |    However deriving gMap for Fix did not works out of the box | ||||||
|  |    I had to remove some uniqueness typing in GenMap and GenHylo */ | ||||||
|  | :: Op      = Plus | Minus | Times | Rem | Equal | LessThan | ||||||
|  | :: Var     :== String | ||||||
|  |  | ||||||
|  | :: ExpP a  = Int Int | Var Var | Op Op a a | ||||||
|  | :: Exp     :== Fix ExpP | ||||||
|  |  | ||||||
|  | :: StmP a  = Assign Var Exp | If Exp a a | While Exp a | Seq a a | Cont | ||||||
|  | :: Stm     :== Fix StmP | ||||||
|  |  | ||||||
|  | derive gMap ExpP, StmP, Fix | ||||||
|  |  | ||||||
|  | // Environment. Semantics is basically Env -> Env | ||||||
|  | :: Env :== Var -> Int | ||||||
|  | :: Sem :== Env -> (Int, Env) | ||||||
|  | empty = \v . 0 | ||||||
|  |  | ||||||
|  | // return | ||||||
|  | rtn :: Int -> Sem | ||||||
|  | rtn i = \e. (i, e) | ||||||
|  |  | ||||||
|  | // the usual bind | ||||||
|  | (>>=) infixl 1 :: Sem (Int->Sem) -> Sem | ||||||
|  | (>>=) x y = \e. (\(i,e2).y i e2) (x e) | ||||||
|  | (>>|) infixl 1 :: Sem Sem -> Sem | ||||||
|  | (>>|) x y = x >>= \_. y | ||||||
|  |  | ||||||
|  | // read variable from environment | ||||||
|  | read :: Var -> Sem | ||||||
|  | read v = \e. (e v, e) | ||||||
|  |  | ||||||
|  | // assign value to give variable in environment | ||||||
|  | write :: Var Int -> Sem | ||||||
|  | write v i = \e. (i, \w. if (w==v) i (e w)) | ||||||
|  |  | ||||||
|  | // semantics | ||||||
|  | class sem a :: a -> Sem | ||||||
|  |  | ||||||
|  | operator :: Op -> Int -> Int -> Int | ||||||
|  | operator Plus     = (+) | ||||||
|  | operator Minus    = (-) | ||||||
|  | operator Times    = (*) | ||||||
|  | operator Rem      = rem | ||||||
|  | operator Equal    = \x y . if (x==y) 1 0 | ||||||
|  | operator LessThan = \x y . if (x< y)  1 0 | ||||||
|  |  | ||||||
|  | // semantics of expressions | ||||||
|  | instance sem Exp where | ||||||
|  | 	sem x = cata phi x where | ||||||
|  | 		phi (Int n)     = rtn n | ||||||
|  | 		phi (Var v)     = read v | ||||||
|  | 		phi (Op op x y) = x >>= \v1. y >>= return o (operator op v1) | ||||||
|  |  | ||||||
|  | // semantics of statments | ||||||
|  | // NOTE: while will always return 0, as it might not even be executed | ||||||
|  | instance sem Stm where | ||||||
|  | 	sem x = cata phi x where | ||||||
|  | 		phi (Assign v e)     = sem e >>= write v | ||||||
|  | 		phi (If e s1 s2)     = sem e >>= \b . if (b<>0) s1 s2 | ||||||
|  | 		phi stm=:(While e s) = sem e >>= \b . if (b<>0) (s >>| phi stm) (phi Cont) | ||||||
|  | 		phi (Seq s1 s2)      = s1 >>| s2    // Here the cata *finally* pays off :D | ||||||
|  | 		phi Cont             = rtn 0 | ||||||
|  |  | ||||||
|  | // convenience functions | ||||||
|  | int    = In o Int | ||||||
|  | var    = In o Var | ||||||
|  | op o   = In o2 (Op o) | ||||||
|  | assign = In o2 Assign | ||||||
|  | ifte e = In o2 (If e) | ||||||
|  | while  = In o2 While | ||||||
|  | seq    = In o2 Seq | ||||||
|  | cont   = In Cont | ||||||
|  |  | ||||||
|  | // test case, also testing the new operator < | ||||||
|  | pEuclides = | ||||||
|  | 	while (op LessThan (int 0) (var "b"))( | ||||||
|  | 		seq (assign "r" (op Rem (var "a") (var "b"))) | ||||||
|  | 		(seq (assign "a" (var "b")) | ||||||
|  | 		( (assign "b" (var "r"))) | ||||||
|  | 		) | ||||||
|  | 	) | ||||||
|  |  | ||||||
|  | Start = fst (program start) where | ||||||
|  | 	program = sem pEuclides >>| read "a" | ||||||
|  | 	start "a" = 9 | ||||||
|  | 	start "b" = 12 | ||||||
|  | 	start _ = 0 | ||||||
|  |  | ||||||
|  | // Helper | ||||||
|  | (o2) infixr 9 | ||||||
|  | (o2) f g x :== f o (g x) | ||||||
|  |  | ||||||
							
								
								
									
										14
									
								
								samples/Clean/stack.dcl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								samples/Clean/stack.dcl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | definition module stack | ||||||
|  |  | ||||||
|  | :: Stack a | ||||||
|  |  | ||||||
|  | newStack :: (Stack a) | ||||||
|  | push :: a (Stack a) -> Stack a | ||||||
|  | pushes :: [a] (Stack a) -> Stack a | ||||||
|  | pop :: (Stack a) -> Stack a | ||||||
|  | popn :: Int (Stack a) -> Stack a | ||||||
|  | top :: (Stack a) -> a | ||||||
|  | topn :: Int (Stack a) -> [a] | ||||||
|  | elements :: (Stack a) -> [a] | ||||||
|  | count :: (Stack a) -> Int | ||||||
|  |  | ||||||
							
								
								
									
										33
									
								
								samples/Clean/stack.icl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								samples/Clean/stack.icl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | implementation module stack | ||||||
|  | import StdEnv | ||||||
|  |  | ||||||
|  | :: Stack a :== [a] | ||||||
|  |  | ||||||
|  | newStack :: (Stack a) | ||||||
|  | newStack = [] | ||||||
|  |  | ||||||
|  | push :: a (Stack a) -> Stack a | ||||||
|  | push x s = [x:s] | ||||||
|  |  | ||||||
|  | pushes :: [a] (Stack a) -> Stack a | ||||||
|  | pushes x s = x ++ s | ||||||
|  |  | ||||||
|  | pop :: (Stack a) -> Stack a | ||||||
|  | pop [] = abort "Cannot use pop on an empty stack" | ||||||
|  | pop [e:s] = s | ||||||
|  |  | ||||||
|  | popn :: Int (Stack a) -> Stack a | ||||||
|  | popn n s  = drop n s | ||||||
|  |  | ||||||
|  | top :: (Stack a) -> a | ||||||
|  | top [] = abort "Cannot use top on an empty stack" | ||||||
|  | top [e:s] = e | ||||||
|  |  | ||||||
|  | topn :: Int (Stack a) -> [a] | ||||||
|  | topn n s = take n s | ||||||
|  | elements :: (Stack a) -> [a] | ||||||
|  | elements s = s | ||||||
|  |  | ||||||
|  | count :: (Stack a) -> Int | ||||||
|  | count s = length s | ||||||
|  |  | ||||||
							
								
								
									
										16
									
								
								samples/Clean/streams.dcl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								samples/Clean/streams.dcl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | definition module streams | ||||||
|  |  | ||||||
|  | import StdEnv | ||||||
|  |  | ||||||
|  | instance zero [Real] | ||||||
|  | instance one [Real] | ||||||
|  | instance + [Real]         | ||||||
|  | instance - [Real] | ||||||
|  | instance * [Real] | ||||||
|  | instance / [Real] | ||||||
|  |  | ||||||
|  | X :: [Real] | ||||||
|  | invert :: [Real] -> [Real] | ||||||
|  | pow :: [Real] Int -> [Real] | ||||||
|  | (shuffle) infixl 7 :: [Real] [Real] -> [Real] | ||||||
|  |  | ||||||
							
								
								
									
										49
									
								
								samples/Clean/streams.icl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								samples/Clean/streams.icl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | |||||||
|  | implementation module streams | ||||||
|  |  | ||||||
|  | import StdEnv | ||||||
|  |  | ||||||
|  | instance zero [Real] | ||||||
|  | where | ||||||
|  |         zero = [] //Infinite row of zeroes represented as empty list to ease computation | ||||||
|  |  | ||||||
|  | instance one [Real] | ||||||
|  | where | ||||||
|  |         one = [1.0:zero] | ||||||
|  |  | ||||||
|  | instance + [Real] | ||||||
|  | where | ||||||
|  |         (+) [s:s`] [t:t`] = [s+t:s`+t`] | ||||||
|  |         (+) [s:s`] [] = [s:s`] | ||||||
|  |         (+) [] [t:t`] = [t:t`] | ||||||
|  |         (+) [] [] = [] | ||||||
|  |          | ||||||
|  | instance - [Real] | ||||||
|  | where | ||||||
|  |         (-) [s:s`] [t:t`] = [s-t:s`-t`] | ||||||
|  |         (-) [s:s`] [] = [s:s`] | ||||||
|  |         (-) [] [t:t`] = [-1.0] * [t:t`] | ||||||
|  |         (-) [] [] = [] | ||||||
|  |  | ||||||
|  | instance * [Real] | ||||||
|  | where | ||||||
|  |         (*) [s:s`] [t:t`] = [s*t:s`*[t:t`]+[s]*t`] | ||||||
|  |         (*) _ _ = [] | ||||||
|  |  | ||||||
|  | instance / [Real] | ||||||
|  | where | ||||||
|  |         (/) s t = s * (invert t) | ||||||
|  |  | ||||||
|  | X :: [Real] | ||||||
|  | X = [0.0:one] | ||||||
|  |  | ||||||
|  | invert :: [Real] -> [Real] | ||||||
|  | invert [s:s`] = [1.0/s:(invert [s:s`]) * s` * [-1.0/s]] | ||||||
|  |  | ||||||
|  | pow :: [Real] Int -> [Real] | ||||||
|  | pow s 0 = one | ||||||
|  | pow s n = s * pow s (n-1) | ||||||
|  |  | ||||||
|  | (shuffle) infixl 7 :: [Real] [Real] -> [Real] | ||||||
|  | (shuffle) [s:s`] [t:t`] = [s*t:s` shuffle [t:t`] + [s:s`] shuffle t`] | ||||||
|  | (shuffle) _ _ = [] | ||||||
|  |  | ||||||
							
								
								
									
										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 | ||||||
|  |  | ||||||
							
								
								
									
										8
									
								
								samples/Forth/bitmap.frt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								samples/Forth/bitmap.frt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | \ Bit arrays. | ||||||
|  | : bits ( u1 -- u2 ) 7 + 3 rshift ; | ||||||
|  | : bitmap ( u "name" -- ) create bits here over erase allot | ||||||
|  |    does> ( u -- a x ) over 3 rshift +  1 rot 7 and lshift ; | ||||||
|  | : bit@ ( a x -- f ) swap c@ and ; | ||||||
|  | : 1bit ( a x -- ) over c@ or swap c! ; | ||||||
|  | : 0bit ( a x -- ) invert over c@ and swap c! ; | ||||||
|  | : bit! ( f a x -- ) rot if 1bit else 0bit then ; | ||||||
							
								
								
									
										7
									
								
								samples/Forth/enum.frt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								samples/Forth/enum.frt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | \ Implements ENUM. | ||||||
|  |  | ||||||
|  | \ Double DOES>! | ||||||
|  | : enum   create 0 ,  does> create dup @ 1 rot +! ,  does> @ ; | ||||||
|  |  | ||||||
|  | \ But this is simpler. | ||||||
|  | : enum   create 0 ,  does> dup @ constant 1 swap +! ; | ||||||
							
								
								
									
										8
									
								
								samples/Forth/macros.frt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								samples/Forth/macros.frt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | \ Simplifies compiling words. | ||||||
|  |  | ||||||
|  | : [[     ; immediate | ||||||
|  | : '<>    >in @ ' swap >in ! <> ; | ||||||
|  | : (]])   begin dup '<> while postpone postpone repeat drop ; | ||||||
|  | : ]]     ['] [[ (]]) ; immediate | ||||||
|  |  | ||||||
|  | ( Usage:   : foo ]] dup * [[ ; immediate   : bar 42 foo . ; ) | ||||||
							
								
								
									
										57
									
								
								samples/G-code/duettest.g
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								samples/G-code/duettest.g
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | |||||||
|  | ; RepRapPro Ormerod | ||||||
|  | ; Board test GCodes | ||||||
|  | M111 S1; Debug on | ||||||
|  | G21 ; mm | ||||||
|  | G90 ; Absolute positioning | ||||||
|  | M83 ; Extrusion relative | ||||||
|  | M906 X800 Y800 Z800 E800 ; Motor currents (mA) | ||||||
|  | T0 ; Extruder 0 | ||||||
|  | G1 X50 F500 | ||||||
|  | G1 X0 | ||||||
|  | G4 P500 | ||||||
|  | G1 Y50 F500 | ||||||
|  | G1 Y0 | ||||||
|  | G4 P500 | ||||||
|  | G1 Z20 F200 | ||||||
|  | G1 Z0 | ||||||
|  | G4 P500 | ||||||
|  | G1 E20 F200 | ||||||
|  | G1 E-20 | ||||||
|  | G4 P500 | ||||||
|  | M106 S255 | ||||||
|  | G4 P500 | ||||||
|  | M106 S0 | ||||||
|  | G4 P500 | ||||||
|  | M105 | ||||||
|  | G10 P0 S100 | ||||||
|  | T0 | ||||||
|  | M140 S100 | ||||||
|  | G4 P5000 | ||||||
|  | M105 | ||||||
|  | G4 P5000 | ||||||
|  | M105 | ||||||
|  | G4 P5000 | ||||||
|  | M105 | ||||||
|  | G4 P5000 | ||||||
|  | M105 | ||||||
|  | G4 P5000 | ||||||
|  | M105 | ||||||
|  | G4 P5000 | ||||||
|  | M105 | ||||||
|  | G4 P5000 | ||||||
|  | M105 | ||||||
|  | G4 P5000 | ||||||
|  | M105 | ||||||
|  | G4 P5000 | ||||||
|  | M105 | ||||||
|  | G4 P5000 | ||||||
|  | M105 | ||||||
|  | G4 P5000 | ||||||
|  | M105 | ||||||
|  | G4 P5000 | ||||||
|  | M105 | ||||||
|  | M0 | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										25912
									
								
								samples/G-code/lm.g
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25912
									
								
								samples/G-code/lm.g
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										29735
									
								
								samples/G-code/rm.g
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29735
									
								
								samples/G-code/rm.g
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										13
									
								
								samples/G-code/square.g
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								samples/G-code/square.g
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | G28 X0 Y0 | ||||||
|  | G1 X55 Y5 F2000 | ||||||
|  | G1 Y180 | ||||||
|  | G1 X180 | ||||||
|  | G1 Y5 | ||||||
|  | G1 X55 | ||||||
|  | G1 Y180 | ||||||
|  | G1 X180 | ||||||
|  | G1 Y5 | ||||||
|  | G1 X55 | ||||||
|  | M0 | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										57
									
								
								samples/GDScript/example.gd
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								samples/GDScript/example.gd
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | |||||||
|  | # Taken from https://github.com/okamstudio/godot/wiki/gdscript | ||||||
|  | # a file is a class! | ||||||
|  |  | ||||||
|  | # inheritance | ||||||
|  |  | ||||||
|  | extends BaseClass | ||||||
|  |  | ||||||
|  | # member variables | ||||||
|  |  | ||||||
|  | var a = 5  | ||||||
|  | var s = "Hello" | ||||||
|  | var arr = [1, 2, 3] | ||||||
|  | var dict = {"key":"value", 2:3} | ||||||
|  |  | ||||||
|  | # constants | ||||||
|  |  | ||||||
|  | const answer = 42 | ||||||
|  | const thename = "Charly" | ||||||
|  |  | ||||||
|  | # built-in vector types | ||||||
|  |  | ||||||
|  | var v2 = Vector2(1, 2) | ||||||
|  | var v3 = Vector3(1, 2, 3) | ||||||
|  |  | ||||||
|  | # function | ||||||
|  |  | ||||||
|  | func some_function(param1, param2): | ||||||
|  |     var local_var = 5 | ||||||
|  |  | ||||||
|  |     if param1 < local_var: | ||||||
|  |         print(param1) | ||||||
|  |     elif param2 > 5: | ||||||
|  |         print(param2) | ||||||
|  |     else: | ||||||
|  |         print("fail!") | ||||||
|  |  | ||||||
|  |     for i in range(20): | ||||||
|  |         print(i) | ||||||
|  |  | ||||||
|  |     while(param2 != 0): | ||||||
|  |         param2 -= 1 | ||||||
|  |  | ||||||
|  |     var local_var2 = param1+3 | ||||||
|  |     return local_var2 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # subclass | ||||||
|  |  | ||||||
|  | class Something: | ||||||
|  |     var a = 10 | ||||||
|  |  | ||||||
|  | # constructor | ||||||
|  |  | ||||||
|  | func _init(): | ||||||
|  |     print("constructed!") | ||||||
|  |     var lv = Something.new() | ||||||
|  |     print(lv.a) | ||||||
							
								
								
									
										216
									
								
								samples/GDScript/grid.gd
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										216
									
								
								samples/GDScript/grid.gd
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,216 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
|  | extends Control | ||||||
|  |  | ||||||
|  | # Simple Tetris-like demo, (c) 2012 Juan Linietsky | ||||||
|  | # Implemented by using a regular Control and drawing on it during the _draw() callback. | ||||||
|  | # The drawing surface is updated only when changes happen (by calling update()) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | var score = 0 | ||||||
|  | var score_label=null | ||||||
|  |  | ||||||
|  | const MAX_SHAPES = 7 | ||||||
|  |  | ||||||
|  | var block = preload("block.png") | ||||||
|  |  | ||||||
|  | var block_colors=[ | ||||||
|  | 	Color(1,0.5,0.5), | ||||||
|  | 	Color(0.5,1,0.5), | ||||||
|  | 	Color(0.5,0.5,1), | ||||||
|  | 	Color(0.8,0.4,0.8), | ||||||
|  | 	Color(0.8,0.8,0.4), | ||||||
|  | 	Color(0.4,0.8,0.8), | ||||||
|  | 	Color(0.7,0.7,0.7)] | ||||||
|  |  | ||||||
|  | var	block_shapes=[ | ||||||
|  | 	[ Vector2(0,-1),Vector2(0,0),Vector2(0,1),Vector2(0,2) ], # I | ||||||
|  | 	[ Vector2(0,0),Vector2(1,0),Vector2(1,1),Vector2(0,1) ], # O | ||||||
|  | 	[ Vector2(-1,1),Vector2(0,1),Vector2(0,0),Vector2(1,0) ], # S | ||||||
|  | 	[ Vector2(1,1),Vector2(0,1),Vector2(0,0),Vector2(-1,0) ], # Z | ||||||
|  | 	[ Vector2(-1,1),Vector2(-1,0),Vector2(0,0),Vector2(1,0) ], # L | ||||||
|  | 	[ Vector2(1,1),Vector2(1,0),Vector2(0,0),Vector2(-1,0) ], # J | ||||||
|  | 	[ Vector2(0,1),Vector2(1,0),Vector2(0,0),Vector2(-1,0) ]] # T | ||||||
|  | 	 | ||||||
|  |  | ||||||
|  | var block_rotations=[ | ||||||
|  | 	Matrix32( Vector2(1,0),Vector2(0,1), Vector2() ), | ||||||
|  | 	Matrix32( Vector2(0,1),Vector2(-1,0), Vector2() ), | ||||||
|  | 	Matrix32( Vector2(-1,0),Vector2(0,-1), Vector2() ), | ||||||
|  | 	Matrix32( Vector2(0,-1),Vector2(1,0), Vector2() ) | ||||||
|  | ] | ||||||
|  | 	 | ||||||
|  |  | ||||||
|  | var width=0 | ||||||
|  | var height=0 | ||||||
|  |  | ||||||
|  | var cells={} | ||||||
|  |  | ||||||
|  | var piece_active=false | ||||||
|  | var piece_shape=0 | ||||||
|  | var piece_pos=Vector2() | ||||||
|  | var piece_rot=0 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | func piece_cell_xform(p,er=0): | ||||||
|  | 	var r = (4+er+piece_rot)%4 | ||||||
|  | 	return piece_pos+block_rotations[r].xform(p) | ||||||
|  |  | ||||||
|  | func _draw(): | ||||||
|  |  | ||||||
|  | 	var sb = get_stylebox("bg","Tree") # use line edit bg | ||||||
|  | 	draw_style_box(sb,Rect2(Vector2(),get_size()).grow(3)) | ||||||
|  | 	 | ||||||
|  | 	var bs = block.get_size() | ||||||
|  | 	for y in range(height): | ||||||
|  | 		for x in range(width): | ||||||
|  | 			if (Vector2(x,y) in cells): | ||||||
|  | 				draw_texture_rect(block,Rect2(Vector2(x,y)*bs,bs),false,block_colors[cells[Vector2(x,y)]]) | ||||||
|  | 				 | ||||||
|  | 	if (piece_active): | ||||||
|  | 		 | ||||||
|  | 		for c in block_shapes[piece_shape]: | ||||||
|  | 			draw_texture_rect(block,Rect2(piece_cell_xform(c)*bs,bs),false,block_colors[piece_shape]) | ||||||
|  | 			 | ||||||
|  |  | ||||||
|  | func piece_check_fit(ofs,er=0): | ||||||
|  |  | ||||||
|  | 	for c in block_shapes[piece_shape]: | ||||||
|  | 		var pos = piece_cell_xform(c,er)+ofs | ||||||
|  | 		if (pos.x < 0): | ||||||
|  | 			return false | ||||||
|  | 		if (pos.y < 0): | ||||||
|  | 			return false | ||||||
|  | 		if (pos.x >= width): | ||||||
|  | 			return false | ||||||
|  | 		if (pos.y >= height): | ||||||
|  | 			return false | ||||||
|  | 		if (pos in cells): | ||||||
|  | 			return false | ||||||
|  | 	 | ||||||
|  | 	return true	 | ||||||
|  |  | ||||||
|  | func new_piece(): | ||||||
|  |  | ||||||
|  | 	piece_shape = randi() % MAX_SHAPES	 | ||||||
|  | 	piece_pos = Vector2(width/2,0) | ||||||
|  | 	piece_active=true | ||||||
|  | 	piece_rot=0 | ||||||
|  | 	if (piece_shape==0): | ||||||
|  | 		piece_pos.y+=1 | ||||||
|  | 		 | ||||||
|  | 	if (not piece_check_fit(Vector2())): | ||||||
|  | 		#game over | ||||||
|  | 		#print("GAME OVER!") | ||||||
|  | 		game_over() | ||||||
|  | 		 | ||||||
|  | 	update() | ||||||
|  | 		 | ||||||
|  | 	 | ||||||
|  | func test_collapse_rows(): | ||||||
|  | 	var accum_down=0 | ||||||
|  | 	for i in range(height): | ||||||
|  | 		var y = height - i - 1 | ||||||
|  | 		var collapse = true | ||||||
|  | 		for x in range(width): | ||||||
|  | 			if (Vector2(x,y) in cells): | ||||||
|  | 				if (accum_down): | ||||||
|  | 					cells[ Vector2(x,y+accum_down) ] = cells[Vector2(x,y)] | ||||||
|  | 			else: | ||||||
|  | 				collapse=false | ||||||
|  | 				if (accum_down): | ||||||
|  | 					cells.erase( Vector2(x,y+accum_down) ) | ||||||
|  | 						 | ||||||
|  | 		if (collapse): | ||||||
|  | 			accum_down+=1 | ||||||
|  | 		 | ||||||
|  | 			 | ||||||
|  | 	score+=accum_down*100 | ||||||
|  | 	score_label.set_text(str(score)) | ||||||
|  | 			 | ||||||
|  | 		 | ||||||
|  | func game_over(): | ||||||
|  |  | ||||||
|  | 		piece_active=false | ||||||
|  | 		get_node("gameover").set_text("Game Over")		 | ||||||
|  | 		update() | ||||||
|  | 				 | ||||||
|  | 		 | ||||||
|  | func restart_pressed(): | ||||||
|  |  | ||||||
|  | 		score=0 | ||||||
|  | 		score_label.set_text("0") | ||||||
|  | 		cells.clear() | ||||||
|  | 		get_node("gameover").set_text("")		 | ||||||
|  | 		piece_active=true | ||||||
|  | 		update() | ||||||
|  | 		 | ||||||
|  | 		 | ||||||
|  |  | ||||||
|  | func piece_move_down(): | ||||||
|  |  | ||||||
|  | 	if (!piece_active): | ||||||
|  | 		return | ||||||
|  | 	if (piece_check_fit(Vector2(0,1))): | ||||||
|  | 		piece_pos.y+=1 | ||||||
|  | 		update()		 | ||||||
|  | 	else: | ||||||
|  |  | ||||||
|  | 		for c in block_shapes[piece_shape]: | ||||||
|  | 			var pos = piece_cell_xform(c) | ||||||
|  | 			cells[pos]=piece_shape | ||||||
|  | 		test_collapse_rows() | ||||||
|  | 		new_piece() | ||||||
|  | 		 | ||||||
|  |  | ||||||
|  | func piece_rotate(): | ||||||
|  |  | ||||||
|  | 	var adv = 1 | ||||||
|  | 	if (not piece_check_fit(Vector2(),1)): | ||||||
|  | 		return | ||||||
|  | 	piece_rot = (piece_rot + adv) % 4 | ||||||
|  | 	update() | ||||||
|  | 	 | ||||||
|  | 	 | ||||||
|  |  | ||||||
|  | func _input(ie): | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	if (not piece_active): | ||||||
|  | 		return | ||||||
|  | 	if (!ie.is_pressed()): | ||||||
|  | 		return | ||||||
|  |  | ||||||
|  | 	if (ie.is_action("move_left")): | ||||||
|  | 		if (piece_check_fit(Vector2(-1,0))): | ||||||
|  | 			piece_pos.x-=1 | ||||||
|  | 			update() | ||||||
|  | 	elif (ie.is_action("move_right")): | ||||||
|  | 		if (piece_check_fit(Vector2(1,0))): | ||||||
|  | 			piece_pos.x+=1 | ||||||
|  | 			update() | ||||||
|  | 	elif (ie.is_action("move_down")): | ||||||
|  | 		piece_move_down() | ||||||
|  | 	elif (ie.is_action("rotate")): | ||||||
|  | 		piece_rotate() | ||||||
|  | 		 | ||||||
|  | 		 | ||||||
|  | func setup(w,h): | ||||||
|  | 	width=w | ||||||
|  | 	height=h | ||||||
|  | 	set_size( Vector2(w,h)*block.get_size() ) | ||||||
|  | 	new_piece() | ||||||
|  | 	get_node("timer").start() | ||||||
|  | 	 | ||||||
|  |  | ||||||
|  | func _ready(): | ||||||
|  | 	# Initalization here | ||||||
|  |  | ||||||
|  | 	setup(10,20) | ||||||
|  | 	score_label = get_node("../score") | ||||||
|  |  | ||||||
|  | 	set_process_input(true) | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										243
									
								
								samples/GDScript/player.gd
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										243
									
								
								samples/GDScript/player.gd
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,243 @@ | |||||||
|  |  | ||||||
|  | extends RigidBody | ||||||
|  |  | ||||||
|  | # member variables here, example: | ||||||
|  | # var a=2 | ||||||
|  | # var b="textvar" | ||||||
|  |  | ||||||
|  | #var dir=Vector3() | ||||||
|  |  | ||||||
|  | const ANIM_FLOOR = 0 | ||||||
|  | const ANIM_AIR_UP = 1 | ||||||
|  | const ANIM_AIR_DOWN = 2 | ||||||
|  |  | ||||||
|  | const SHOOT_TIME = 1.5 | ||||||
|  | const SHOOT_SCALE = 2 | ||||||
|  |  | ||||||
|  | const CHAR_SCALE = Vector3(0.3,0.3,0.3) | ||||||
|  |  | ||||||
|  | var facing_dir = Vector3(1, 0, 0) | ||||||
|  | var movement_dir = Vector3() | ||||||
|  |  | ||||||
|  | var jumping=false | ||||||
|  |  | ||||||
|  | var turn_speed=40 | ||||||
|  | var keep_jump_inertia = true | ||||||
|  | var air_idle_deaccel = false | ||||||
|  | var accel=19.0 | ||||||
|  | var deaccel=14.0 | ||||||
|  | var sharp_turn_threshhold = 140 | ||||||
|  |  | ||||||
|  | var max_speed=3.1 | ||||||
|  | var on_floor = false | ||||||
|  |  | ||||||
|  | var prev_shoot = false | ||||||
|  |  | ||||||
|  | var last_floor_velocity = Vector3() | ||||||
|  |  | ||||||
|  | var shoot_blend = 0 | ||||||
|  |  | ||||||
|  | func adjust_facing(p_facing, p_target,p_step, p_adjust_rate,current_gn): | ||||||
|  |  | ||||||
|  | 	var n = p_target # normal | ||||||
|  | 	var t = n.cross(current_gn).normalized() | ||||||
|  | 	 | ||||||
|  | 	var x = n.dot(p_facing) | ||||||
|  | 	var y = t.dot(p_facing) | ||||||
|  | 	 | ||||||
|  | 	var ang = atan2(y,x) | ||||||
|  | 	 | ||||||
|  | 	if (abs(ang)<0.001): # too small | ||||||
|  | 		return p_facing | ||||||
|  | 	 | ||||||
|  | 	var s = sign(ang) | ||||||
|  | 	ang = ang * s | ||||||
|  | 	var turn = ang * p_adjust_rate * p_step | ||||||
|  | 	var a | ||||||
|  | 	if (ang<turn): | ||||||
|  | 		a=ang | ||||||
|  | 	else: | ||||||
|  | 		a=turn | ||||||
|  | 	ang = (ang - a) * s | ||||||
|  | 	 | ||||||
|  | 	return ((n * cos(ang)) + (t * sin(ang))) * p_facing.length() | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | func _integrate_forces( state ): | ||||||
|  |  | ||||||
|  | 	var lv = state.get_linear_velocity() # linear velocity | ||||||
|  | 	var g = state.get_total_gravity() | ||||||
|  | 	var delta = state.get_step() | ||||||
|  | 	var d = 1.0 - delta*state.get_total_density() | ||||||
|  | 	if (d<0): | ||||||
|  | 		d=0 | ||||||
|  | 	lv += g * delta #apply gravity | ||||||
|  |  | ||||||
|  | 	var anim = ANIM_FLOOR | ||||||
|  |  | ||||||
|  | 	var up = -g.normalized() # (up is against gravity) | ||||||
|  | 	var vv = up.dot(lv) # vertical velocity | ||||||
|  | 	var hv = lv - (up*vv) # horizontal velocity | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	var hdir = hv.normalized() # horizontal direction | ||||||
|  | 	var hspeed = hv.length()	#horizontal speed | ||||||
|  |  | ||||||
|  | 	var floor_velocity | ||||||
|  | 	var onfloor = false | ||||||
|  |  | ||||||
|  | 	if (state.get_contact_count() == 0): | ||||||
|  | 		floor_velocity = last_floor_velocity | ||||||
|  | 	else: | ||||||
|  | 		for i in range(state.get_contact_count()): | ||||||
|  | 			if (state.get_contact_local_shape(i) != 1): | ||||||
|  | 				continue | ||||||
|  | 			 | ||||||
|  | 			onfloor = true | ||||||
|  | 			floor_velocity = state.get_contact_collider_velocity_at_pos(i) | ||||||
|  | 			break | ||||||
|  | 		 | ||||||
|  |  | ||||||
|  | 	var dir = Vector3() #where does the player intend to walk to | ||||||
|  | 	var cam_xform = get_node("target/camera").get_global_transform() | ||||||
|  | 	 | ||||||
|  | 	if (Input.is_action_pressed("move_forward")): | ||||||
|  | 		dir+=-cam_xform.basis[2]  | ||||||
|  | 	if (Input.is_action_pressed("move_backwards")): | ||||||
|  | 		dir+=cam_xform.basis[2]  | ||||||
|  | 	if (Input.is_action_pressed("move_left")): | ||||||
|  | 		dir+=-cam_xform.basis[0]  | ||||||
|  | 	if (Input.is_action_pressed("move_right")): | ||||||
|  | 		dir+=cam_xform.basis[0]  | ||||||
|  | 		 | ||||||
|  | 	var jump_attempt = Input.is_action_pressed("jump") | ||||||
|  | 	var shoot_attempt = Input.is_action_pressed("shoot") | ||||||
|  | 		 | ||||||
|  | 	var target_dir = (dir - up*dir.dot(up)).normalized() | ||||||
|  | 	 | ||||||
|  | 	if (onfloor): | ||||||
|  |  | ||||||
|  | 		var sharp_turn = hspeed > 0.1 and rad2deg(acos(target_dir.dot(hdir))) > sharp_turn_threshhold | ||||||
|  |  | ||||||
|  | 		if (dir.length()>0.1 and !sharp_turn) : | ||||||
|  | 			if (hspeed > 0.001) : | ||||||
|  |  | ||||||
|  | 				#linear_dir = linear_h_velocity/linear_vel | ||||||
|  | 				#if (linear_vel > brake_velocity_limit and linear_dir.dot(ctarget_dir)<-cos(Math::deg2rad(brake_angular_limit))) | ||||||
|  | 				#	brake=true | ||||||
|  | 				#else | ||||||
|  | 				hdir = adjust_facing(hdir,target_dir,delta,1.0/hspeed*turn_speed,up) | ||||||
|  | 				facing_dir = hdir | ||||||
|  | 			else: | ||||||
|  |  | ||||||
|  | 				hdir = target_dir | ||||||
|  | 			 | ||||||
|  | 			if (hspeed<max_speed): | ||||||
|  | 				hspeed+=accel*delta | ||||||
|  |  | ||||||
|  | 		else: | ||||||
|  | 			hspeed-=deaccel*delta | ||||||
|  | 			if (hspeed<0): | ||||||
|  | 				hspeed=0 | ||||||
|  | 		 | ||||||
|  | 		hv = hdir*hspeed | ||||||
|  | 		 | ||||||
|  | 		var mesh_xform = get_node("Armature").get_transform()  | ||||||
|  | 		var facing_mesh=-mesh_xform.basis[0].normalized() | ||||||
|  | 		facing_mesh = (facing_mesh - up*facing_mesh.dot(up)).normalized() | ||||||
|  | 		facing_mesh = adjust_facing(facing_mesh,target_dir,delta,1.0/hspeed*turn_speed,up) | ||||||
|  | 		var m3 = Matrix3(-facing_mesh,up,-facing_mesh.cross(up).normalized()).scaled( CHAR_SCALE ) | ||||||
|  | 		 | ||||||
|  | 		get_node("Armature").set_transform(Transform(m3,mesh_xform.origin)) | ||||||
|  | 				 | ||||||
|  | 		if (not jumping and jump_attempt): | ||||||
|  | 			vv = 7.0 | ||||||
|  | 			jumping = true		 | ||||||
|  | 			get_node("sfx").play("jump") | ||||||
|  | 	else: | ||||||
|  |  | ||||||
|  | 		if (vv>0): | ||||||
|  | 			anim=ANIM_AIR_UP | ||||||
|  | 		else: | ||||||
|  | 			anim=ANIM_AIR_DOWN | ||||||
|  | 			 | ||||||
|  | 		var hs | ||||||
|  | 		if (dir.length()>0.1): | ||||||
|  |  | ||||||
|  | 			hv += target_dir * (accel * 0.2) * delta | ||||||
|  | 			if (hv.length() > max_speed): | ||||||
|  | 				hv = hv.normalized() * max_speed | ||||||
|  |  | ||||||
|  | 		else: | ||||||
|  |  | ||||||
|  | 			if (air_idle_deaccel): | ||||||
|  | 				hspeed = hspeed - (deaccel * 0.2) * delta | ||||||
|  | 				if (hspeed<0): | ||||||
|  | 					hspeed=0 | ||||||
|  |  | ||||||
|  | 				hv = hdir*hspeed | ||||||
|  | 			 | ||||||
|  | 		 | ||||||
|  | 	if (jumping and vv < 0): | ||||||
|  | 		jumping=false | ||||||
|  |  | ||||||
|  | 	lv = hv+up*vv | ||||||
|  | 	 | ||||||
|  | 	 | ||||||
|  |  | ||||||
|  | 	if (onfloor): | ||||||
|  |  | ||||||
|  | 		movement_dir = lv | ||||||
|  | 		#lv += floor_velocity | ||||||
|  | 		last_floor_velocity = floor_velocity | ||||||
|  | 	else: | ||||||
|  |  | ||||||
|  | 		if (on_floor) : | ||||||
|  |  | ||||||
|  | 			#if (keep_jump_inertia): | ||||||
|  | 			#	lv += last_floor_velocity | ||||||
|  | 			pass | ||||||
|  | 		 | ||||||
|  | 		last_floor_velocity = Vector3() | ||||||
|  | 		movement_dir = lv | ||||||
|  | 	 | ||||||
|  | 	on_floor = onfloor | ||||||
|  |  | ||||||
|  | 	state.set_linear_velocity(lv) | ||||||
|  | 	 | ||||||
|  | 	if (shoot_blend>0): | ||||||
|  | 		shoot_blend -= delta * SHOOT_SCALE | ||||||
|  | 		if (shoot_blend<0): | ||||||
|  | 			shoot_blend=0 | ||||||
|  | 	 | ||||||
|  | 	if (shoot_attempt and not prev_shoot): | ||||||
|  | 		shoot_blend = SHOOT_TIME		 | ||||||
|  | 		var bullet = preload("res://bullet.scn").instance() | ||||||
|  | 		bullet.set_transform( get_node("Armature/bullet").get_global_transform().orthonormalized() ) | ||||||
|  | 		get_parent().add_child( bullet ) | ||||||
|  | 		bullet.set_linear_velocity( get_node("Armature/bullet").get_global_transform().basis[2].normalized() * 20 ) | ||||||
|  | 		PS.body_add_collision_exception( bullet.get_rid(), get_rid() ) #add it to bullet | ||||||
|  | 		get_node("sfx").play("shoot") | ||||||
|  | 		 | ||||||
|  | 	prev_shoot = shoot_attempt | ||||||
|  | 	 | ||||||
|  | 	if (onfloor): | ||||||
|  | 		get_node("AnimationTreePlayer").blend2_node_set_amount("walk",hspeed / max_speed) | ||||||
|  | 		 | ||||||
|  | 	get_node("AnimationTreePlayer").transition_node_set_current("state",anim) | ||||||
|  | 	get_node("AnimationTreePlayer").blend2_node_set_amount("gun",min(shoot_blend,1.0)) | ||||||
|  | #	state.set_angular_velocity(Vector3())	 | ||||||
|  | 	 | ||||||
|  | 	 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | func _ready(): | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	# Initalization here | ||||||
|  | 	get_node("AnimationTreePlayer").set_active(true) | ||||||
|  | 	pass | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										73
									
								
								samples/GDScript/pong.gd
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								samples/GDScript/pong.gd
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,73 @@ | |||||||
|  |  | ||||||
|  | extends Node2D | ||||||
|  |  | ||||||
|  | # member variables here, example: | ||||||
|  | # var a=2 | ||||||
|  | # var b="textvar" | ||||||
|  | const INITIAL_BALL_SPEED = 80 | ||||||
|  | var ball_speed = INITIAL_BALL_SPEED | ||||||
|  | var screen_size = Vector2(640,400) | ||||||
|  | #default ball direction | ||||||
|  | var direction = Vector2(-1,0) | ||||||
|  | var pad_size = Vector2(8,32) | ||||||
|  | const PAD_SPEED = 150 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | func _process(delta): | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	# get ball positio and pad rectangles | ||||||
|  | 	var ball_pos = get_node("ball").get_pos() | ||||||
|  | 	var left_rect = Rect2( get_node("left").get_pos() - pad_size*0.5, pad_size ) | ||||||
|  | 	var right_rect = Rect2( get_node("right").get_pos() - pad_size*0.5, pad_size ) | ||||||
|  | 	 | ||||||
|  | 	#integrate new ball postion | ||||||
|  | 	ball_pos+=direction*ball_speed*delta | ||||||
|  | 	 | ||||||
|  | 	#flip when touching roof or floor | ||||||
|  | 	if ( (ball_pos.y<0 and direction.y <0) or (ball_pos.y>screen_size.y and direction.y>0)): | ||||||
|  | 		direction.y = -direction.y | ||||||
|  | 		 | ||||||
|  | 	#flip, change direction and increase speed when touching pads	 | ||||||
|  | 	if ( (left_rect.has_point(ball_pos) and direction.x < 0) or (right_rect.has_point(ball_pos) and direction.x > 0)): | ||||||
|  | 		direction.x=-direction.x | ||||||
|  | 		ball_speed*=1.1 | ||||||
|  | 		direction.y=randf()*2.0-1 | ||||||
|  | 		direction = direction.normalized() | ||||||
|  |  | ||||||
|  | 	#check gameover | ||||||
|  | 	if (ball_pos.x<0 or ball_pos.x>screen_size.x): | ||||||
|  | 		ball_pos=screen_size*0.5 | ||||||
|  | 		ball_speed=INITIAL_BALL_SPEED | ||||||
|  | 		direction=Vector2(-1,0) | ||||||
|  | 			 | ||||||
|  | 						 | ||||||
|  | 	get_node("ball").set_pos(ball_pos) | ||||||
|  |  | ||||||
|  | 	#move left pad	 | ||||||
|  | 	var left_pos = get_node("left").get_pos() | ||||||
|  | 	 | ||||||
|  | 	if (left_pos.y > 0 and Input.is_action_pressed("left_move_up")): | ||||||
|  | 		left_pos.y+=-PAD_SPEED*delta | ||||||
|  | 	if (left_pos.y < screen_size.y and Input.is_action_pressed("left_move_down")): | ||||||
|  | 		left_pos.y+=PAD_SPEED*delta | ||||||
|  | 		 | ||||||
|  | 	get_node("left").set_pos(left_pos) | ||||||
|  | 		 | ||||||
|  | 	#move right pad	 | ||||||
|  | 	var right_pos = get_node("right").get_pos() | ||||||
|  | 	 | ||||||
|  | 	if (right_pos.y > 0 and Input.is_action_pressed("right_move_up")): | ||||||
|  | 		right_pos.y+=-PAD_SPEED*delta | ||||||
|  | 	if (right_pos.y < screen_size.y and Input.is_action_pressed("right_move_down")): | ||||||
|  | 		right_pos.y+=PAD_SPEED*delta | ||||||
|  | 		 | ||||||
|  | 	get_node("right").set_pos(right_pos) | ||||||
|  | 	 | ||||||
|  | 	  | ||||||
|  |  | ||||||
|  | func _ready(): | ||||||
|  | 	screen_size = get_viewport_rect().size # get actual size | ||||||
|  | 	pad_size = get_node("left").get_texture().get_size() | ||||||
|  | 	set_process(true) | ||||||
|  |  | ||||||
							
								
								
									
										21
									
								
								samples/Graph Modeling Language/sample.gml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								samples/Graph Modeling Language/sample.gml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | graph | ||||||
|  | [ | ||||||
|  |   directed 0 | ||||||
|  |   node | ||||||
|  |   [ | ||||||
|  |     id 0 | ||||||
|  |     label "Node 1" | ||||||
|  |     value 100 | ||||||
|  |   ] | ||||||
|  |   node | ||||||
|  |   [ | ||||||
|  |     id 1 | ||||||
|  |     label "Node 2" | ||||||
|  |     value 200 | ||||||
|  |   ] | ||||||
|  |   edge | ||||||
|  |   [ | ||||||
|  |     source 1 | ||||||
|  |     target 0 | ||||||
|  |   ] | ||||||
|  | ] | ||||||
							
								
								
									
										13
									
								
								samples/Groff/sample.4
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								samples/Groff/sample.4
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | .TH FOO 1 | ||||||
|  | .SH NAME | ||||||
|  | foo \- bar | ||||||
|  | .SH SYNOPSIS | ||||||
|  | .B foo | ||||||
|  | .I bar | ||||||
|  | .SH DESCRIPTION | ||||||
|  | Foo bar | ||||||
|  | .BR baz | ||||||
|  | quux. | ||||||
|  | .PP | ||||||
|  | .B Foo | ||||||
|  | bar baz. | ||||||
							
								
								
									
										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 | ||||||
							
								
								
									
										12
									
								
								samples/JavaScript/jsbuild.jsb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								samples/JavaScript/jsbuild.jsb
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | jsb.library('mylibrary', jsb.STATIC_LIBRARY, function(libObject) { | ||||||
|  |     libObject.outputName = 'mylibrary'; | ||||||
|  |     libObject.cflags = [ '-Wall' ]; | ||||||
|  |     libObject.ldflags = [ '-pthread' ]; | ||||||
|  |     libObject.includePaths = [ 'src/include' ]; | ||||||
|  |     libObject.sources = [  | ||||||
|  |         'src/main.cpp', | ||||||
|  |         'src/app.cpp' | ||||||
|  |     ]; | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | jsb.build(); | ||||||
							
								
								
									
										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(),  | ||||||
|  | 		""  | ||||||
|  | 	), | ||||||
|  |  | ||||||
|  | ); | ||||||
|  | ?> | ||||||
							
								
								
									
										193
									
								
								samples/Pascal/custforms.pp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										193
									
								
								samples/Pascal/custforms.pp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,193 @@ | |||||||
|  | unit custforms; | ||||||
|  |  | ||||||
|  | {$mode objfpc}{$H+} | ||||||
|  |  | ||||||
|  | interface | ||||||
|  |  | ||||||
|  | uses | ||||||
|  |   Classes, SysUtils, Forms; | ||||||
|  |  | ||||||
|  | Type | ||||||
|  |  | ||||||
|  |   { TCustomFormDescr } | ||||||
|  |  | ||||||
|  |   TCustomFormDescr = Class | ||||||
|  |   private | ||||||
|  |     FAuthor: String; | ||||||
|  |     FCaption: String; | ||||||
|  |     FCategory: String; | ||||||
|  |     FDescription: String; | ||||||
|  |     FFormClass: TFormClass; | ||||||
|  |     FLazPackage: String; | ||||||
|  |     FUnitName: String; | ||||||
|  |   public | ||||||
|  |     Constructor Create(AFormClass : TFormClass; const APackage: string); | ||||||
|  |     Constructor Create(AFormClass : TFormClass; Const ACaption,ADescription,AUnit,APackage : String); | ||||||
|  |     Property FormClass : TFormClass Read FFormClass Write FFormClass; | ||||||
|  |     Property Caption : String Read FCaption Write FCaption; | ||||||
|  |     Property Description : String Read FDescription Write FDescription; | ||||||
|  |     Property UnitName : String Read FUnitName Write FUnitName; | ||||||
|  |     Property Category : String Read FCategory Write FCategory; | ||||||
|  |     Property Author : String Read FAuthor Write FAuthor; | ||||||
|  |     Property LazPackage : String Read FLazPackage Write FLazPackage; | ||||||
|  |   end; | ||||||
|  |  | ||||||
|  | Procedure RegisterCustomForm(Descr : TCustomFormDescr); | ||||||
|  | Procedure RegisterCustomForm(AFormClass : TFormClass; const APackage: string); | ||||||
|  | Procedure RegisterCustomForm(AFormClass : TFormClass; Const AUnitName, APackage : String); | ||||||
|  |  | ||||||
|  | Procedure Register; | ||||||
|  |  | ||||||
|  | implementation | ||||||
|  |  | ||||||
|  | uses ProjectIntf,NewItemIntf,contnrs; | ||||||
|  |  | ||||||
|  | Const | ||||||
|  |   SAppFrameWork = 'Custom forms'; | ||||||
|  |   SInstanceOf   = 'Create a new instance of %s'; | ||||||
|  |  | ||||||
|  | { TCustomFormDescr } | ||||||
|  |  | ||||||
|  | constructor TCustomFormDescr.Create(AFormClass: TFormClass; | ||||||
|  |   const APackage: string); | ||||||
|  |  | ||||||
|  | Var | ||||||
|  |   N,U : String; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |   N:=AFormClass.ClassName; | ||||||
|  |   U:=N; | ||||||
|  |   If (Upcase(U[1])='T') then | ||||||
|  |     Delete(U,1,1); | ||||||
|  |   Create(AFormClass,N,Format(SInstanceOf,[N]),U,APackage); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | constructor TCustomFormDescr.Create(AFormClass: TFormClass; | ||||||
|  |   const ACaption, ADescription, AUnit, APackage: String); | ||||||
|  | begin | ||||||
|  |   FFormClass:=AFormClass; | ||||||
|  |   FCaption:=ACaption; | ||||||
|  |   FDescription:=ADescription; | ||||||
|  |   FUnitName:=AUnit; | ||||||
|  |   FCategory:=SAppFrameWork; | ||||||
|  |   FLazPackage:=APackage; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | // Registration code. | ||||||
|  |  | ||||||
|  | Type | ||||||
|  |   { TCustomFormFileDescriptor } | ||||||
|  |   TCustomFormFileDescriptor = Class(TFileDescPascalUnitWithResource) | ||||||
|  |   private | ||||||
|  |     FFormDescr: TCustomFormDescr; | ||||||
|  |   Public | ||||||
|  |     Constructor Create(ADescr : TCustomFormDescr); | ||||||
|  |     Property FormDescr : TCustomFormDescr Read FFormDescr; | ||||||
|  |     Function GetLocalizedName : String; override; | ||||||
|  |     Function GetLocalizedDescription : String; override; | ||||||
|  |     Function GetInterfaceUsesSection : String; override; | ||||||
|  |   end; | ||||||
|  |  | ||||||
|  | { TCustomFormFileDescriptor } | ||||||
|  |  | ||||||
|  | constructor TCustomFormFileDescriptor.Create(ADescr: TCustomFormDescr); | ||||||
|  | begin | ||||||
|  |   Inherited Create; | ||||||
|  |   FFormDescr:=ADescr; | ||||||
|  |   ResourceClass:=FFormDescr.FFormClass; | ||||||
|  |   Name:=FFormDescr.Caption; | ||||||
|  |   RequiredPackages:=ADescr.LazPackage; | ||||||
|  |   //Writeln('TCustomFormFileDescriptor.Create RequiredPackages=',RequiredPackages); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | function TCustomFormFileDescriptor.GetLocalizedName: String; | ||||||
|  | begin | ||||||
|  |   Result:=FFormDescr.Caption; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | function TCustomFormFileDescriptor.GetLocalizedDescription: String; | ||||||
|  | begin | ||||||
|  |   Result:=FFormDescr.Description; | ||||||
|  |   If (FFormDescr.Author<>'') then | ||||||
|  |     Result:=Result+LineEnding+'By '+FFormDescr.Author; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | function TCustomFormFileDescriptor.GetInterfaceUsesSection: String; | ||||||
|  | begin | ||||||
|  |   Result:=inherited GetInterfaceUsesSection; | ||||||
|  |   Result:=Result+',Forms,'+FFormDescr.UnitName; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | Var | ||||||
|  |   CustomFormList : TObjectList; | ||||||
|  |  | ||||||
|  | Procedure RegisterCustomForm(Descr : TCustomFormDescr); | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |   CustomFormList.Add(Descr); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | Procedure RegisterCustomForm(AFormClass : TFormClass; const APackage: string); | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |   RegisterCustomForm(TCustomFormDescr.Create(AFormClass,APackage)); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | Procedure RegisterCustomForm(AFormClass : TFormClass; Const AUnitName, APackage : String); | ||||||
|  |  | ||||||
|  | Var | ||||||
|  |   D : TCustomFormDescr; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |   D:=TCustomFormDescr.Create(AFormClass,APackage); | ||||||
|  |   D.UnitName:=AUnitName; | ||||||
|  |   RegisterCustomForm(D); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Procedure Register; | ||||||
|  |  | ||||||
|  | Var | ||||||
|  |   L : TStringList; | ||||||
|  |   I : Integer; | ||||||
|  |   D : TCustomFormDescr; | ||||||
|  |    | ||||||
|  | begin | ||||||
|  |   L:=TStringList.Create; | ||||||
|  |   Try | ||||||
|  |     L.Sorted:=True; | ||||||
|  |     L.Duplicates:=dupIgnore; | ||||||
|  |     For I:=0 to CustomFormList.Count-1 do | ||||||
|  |       L.Add(TCustomFormDescr(CustomFormList[i]).Category); | ||||||
|  |     For I:=0 to L.Count-1 do | ||||||
|  |     begin | ||||||
|  |       RegisterNewItemCategory(TNewIDEItemCategory.Create(L[i])); | ||||||
|  |     end; | ||||||
|  |   Finally | ||||||
|  |     L.Free; | ||||||
|  |   end; | ||||||
|  |   For I:=0 to CustomFormList.Count-1 do | ||||||
|  |     begin | ||||||
|  |     D:=TCustomFormDescr(CustomFormList[i]); | ||||||
|  |     RegisterProjectFileDescriptor(TCustomFormFileDescriptor.Create(D),D.Category); | ||||||
|  |     end; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | Procedure InitCustomForms; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |   CustomFormList:=TObjectList.Create; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | Procedure DoneCustomForms; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |   FreeAndNil(CustomFormList); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | Initialization | ||||||
|  |   InitCustomForms; | ||||||
|  | Finalization | ||||||
|  |   DoneCustomForms; | ||||||
|  | end. | ||||||
|  |  | ||||||
							
								
								
									
										51
									
								
								samples/Pascal/gtkextra.pp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								samples/Pascal/gtkextra.pp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | |||||||
|  | { $Id$ } | ||||||
|  | { | ||||||
|  |  --------------------------------------------------------------------------- | ||||||
|  |  gtkextra.pp  -  GTK(2) widgetset - additional gdk/gtk functions | ||||||
|  |  --------------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  |  This unit contains missing gdk/gtk functions and defines for certain  | ||||||
|  |  versions of gtk or fpc. | ||||||
|  |  | ||||||
|  |  --------------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  |  @created(Sun Jan 28th WET 2006) | ||||||
|  |  @lastmod($Date$) | ||||||
|  |  @author(Marc Weustink <marc@@dommelstein.nl>) | ||||||
|  |  | ||||||
|  |  ***************************************************************************** | ||||||
|  |   This file is part of the Lazarus Component Library (LCL) | ||||||
|  |  | ||||||
|  |   See the file COPYING.modifiedLGPL.txt, included in this distribution, | ||||||
|  |   for details about the license. | ||||||
|  |  ***************************************************************************** | ||||||
|  |  } | ||||||
|  |  | ||||||
|  | unit GtkExtra; | ||||||
|  |  | ||||||
|  | {$mode objfpc}{$H+} | ||||||
|  |  | ||||||
|  | interface | ||||||
|  |  | ||||||
|  | {$I gtkdefines.inc} | ||||||
|  |  | ||||||
|  | {$ifdef gtk1} | ||||||
|  | {$I gtk1extrah.inc} | ||||||
|  | {$endif} | ||||||
|  |  | ||||||
|  | {$ifdef gtk2} | ||||||
|  | {$I gtk2extrah.inc} | ||||||
|  | {$endif} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | implementation | ||||||
|  |  | ||||||
|  | {$ifdef gtk1} | ||||||
|  | {$I gtk1extra.inc} | ||||||
|  | {$endif} | ||||||
|  |  | ||||||
|  | {$ifdef gtk2} | ||||||
|  | {$I gtk2extra.inc} | ||||||
|  | {$endif} | ||||||
|  |  | ||||||
|  | end. | ||||||
							
								
								
									
										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
											
										
									
								
							
							
								
								
									
										11
									
								
								samples/Prolog/dleak-report.script!
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								samples/Prolog/dleak-report.script!
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | #!/usr/bin/env swipl | ||||||
|  |  | ||||||
|  | :- set_prolog_flag(verbose, silent). | ||||||
|  | :- use_module(dleak). | ||||||
|  |  | ||||||
|  | :- initialization | ||||||
|  | 	main, halt. | ||||||
|  |  | ||||||
|  | main :- | ||||||
|  | 	current_prolog_flag(argv, [File]), | ||||||
|  | 	dleak(File). | ||||||
							
								
								
									
										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). | ||||||
							
								
								
									
										26
									
								
								samples/Puppet/expiringhost.pp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								samples/Puppet/expiringhost.pp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | |||||||
|  | define example::expiringhost($ip, $timestamp) { | ||||||
|  |  | ||||||
|  |   # Calculate the age of this resource by comparing 'now' against $timestamp | ||||||
|  |   $age = inline_template("<%= require 'time'; Time.now - Time.parse(timestamp) %>") | ||||||
|  |  | ||||||
|  |   # Max age, in seconds. | ||||||
|  |   $maxage = 60 | ||||||
|  |  | ||||||
|  |   if $age > $maxage { | ||||||
|  |     $expired = true | ||||||
|  |     notice("Expiring resource $class[$name] due to age > $maxage (actual: $age)") | ||||||
|  |   } else { | ||||||
|  |     $expired = false | ||||||
|  |     notice("Found recently-active $class[$name] (age: $age)") | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   # I set target to a /tmp path so you can run this example as non-root. | ||||||
|  |   # In production, you probabyl won't set target as it defaults to /etc/hosts | ||||||
|  |   # (or wherever puppet thinks your platform wants it) | ||||||
|  |   host { | ||||||
|  |     $name: | ||||||
|  |       ip => $ip, | ||||||
|  |       target => "/tmp/expiring-hosts-example-output", | ||||||
|  |       ensure => $expired ? { true => absent, false => present }; | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										26
									
								
								samples/Puppet/stages-example.pp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								samples/Puppet/stages-example.pp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | |||||||
|  | class foo { | ||||||
|  |   notify { | ||||||
|  |     "foo": ; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | class bar { | ||||||
|  |   notify { | ||||||
|  |     "bar": ; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | node default { | ||||||
|  |   stage { | ||||||
|  |     "one": ; | ||||||
|  |     "two": ; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   class { | ||||||
|  |     "foo": stage => "one"; | ||||||
|  |     "bar": stage => "two"; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   Stage["one"] -> Stage["two"] | ||||||
|  | } | ||||||
							
								
								
									
										22
									
								
								samples/Puppet/unmanaged-notify-puppet25.pp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								samples/Puppet/unmanaged-notify-puppet25.pp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | # Manually manage /tmp/original | ||||||
|  | # Each puppet run will copy it to /tmp/flag if there's a change and notify | ||||||
|  | # the exec when it changes. | ||||||
|  | #  | ||||||
|  | # The idea here is you might need (in some case) to manually manage a file outside | ||||||
|  | # of puppet (in this case, "/tmp/original"). Using this example, you can make puppet | ||||||
|  | # signal other parts of your catalog based on changes to that file. | ||||||
|  |  | ||||||
|  | file { | ||||||
|  |   # This will, when different, copy /tmp/original to /tmp/flag and notify our | ||||||
|  |   # exec. | ||||||
|  |   "/tmp/flag": | ||||||
|  |     source => "file:///tmp/original", | ||||||
|  |     notify => Exec["hello world"]; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | exec { | ||||||
|  |   "hello world": | ||||||
|  |     command => "/bin/echo hello world", | ||||||
|  |     refreshonly => true; | ||||||
|  | } | ||||||
|  |  | ||||||
							
								
								
									
										82
									
								
								samples/Python/action.cgi
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										82
									
								
								samples/Python/action.cgi
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,82 @@ | |||||||
|  | #!/usr/bin/python | ||||||
|  |  | ||||||
|  | from model import Feed | ||||||
|  | import session | ||||||
|  | import datetime | ||||||
|  | import sys | ||||||
|  |  | ||||||
|  | argv = session.argv() | ||||||
|  |  | ||||||
|  | feed = Feed.get(guid=argv[1]) | ||||||
|  | action = argv[2] | ||||||
|  |  | ||||||
|  | if action == 'done': | ||||||
|  |     when = feed.notify_interval * feed.notify_unit | ||||||
|  | elif action == 'snooze': | ||||||
|  |     if len(argv) > 3: | ||||||
|  |         when = int(argv[3]) | ||||||
|  |     else: | ||||||
|  |         when = 3600 | ||||||
|  | else: | ||||||
|  |     print '''Status: 400 Bad request | ||||||
|  | Content-type: text/html | ||||||
|  |  | ||||||
|  | Unknown action %s''' % action | ||||||
|  |     sys.exit(1) | ||||||
|  |  | ||||||
|  | feed.notify_next = datetime.datetime.utcnow() + datetime.timedelta(seconds=when) | ||||||
|  | feed.save() | ||||||
|  |  | ||||||
|  | response = '''Content-type: text/html | ||||||
|  |  | ||||||
|  | <html><head><title>Alarm reset</title> | ||||||
|  | <link rel="stylesheet" href="{base_url}/style.css"> | ||||||
|  | </head> | ||||||
|  | <body> | ||||||
|  |  | ||||||
|  | <div class="container"> | ||||||
|  | <h1>Alarm reset</h1> | ||||||
|  | <div> | ||||||
|  | <p id="reset">Alarm "<span class="name">{name}</span>" has been reset. You won't be notified for another <span class="duration">{duration}</span>.</p> | ||||||
|  |  | ||||||
|  | <p>Actions:</p> | ||||||
|  | <ul> | ||||||
|  | <li><a href="{edit_url}?feed={guid}">Edit this reminder</a></li> | ||||||
|  | <li><a href="{edit_url}">Create another reminder</a></li> | ||||||
|  | <li><a href="{base_url}">Visit the Reminder Me site</a></li> | ||||||
|  | </ul> | ||||||
|  | </div> | ||||||
|  | </div> | ||||||
|  |  | ||||||
|  | <p class="back"><a href=".">Reminder Me</a></p> | ||||||
|  |  | ||||||
|  | </body></html>''' | ||||||
|  |  | ||||||
|  | when_left = when | ||||||
|  | duration_list = [] | ||||||
|  | for (label,period) in [('month',86400*365/12), | ||||||
|  |                        ('week',86400*7), | ||||||
|  |                        ('day',86400), | ||||||
|  |                        ('hour',3600), | ||||||
|  |                        ('minute',60), | ||||||
|  |                        ('second',1)]: | ||||||
|  |     if when == period: | ||||||
|  |         duration_list = [label] | ||||||
|  |         break | ||||||
|  |      | ||||||
|  |     val = when_left/period | ||||||
|  |     if val: | ||||||
|  |         duration_list.append("%d %s%s" % ( | ||||||
|  |             val, | ||||||
|  |             label, | ||||||
|  |             val > 1 and 's' or '')) | ||||||
|  |         when_left -= val*period | ||||||
|  |  | ||||||
|  | basedir=session.request_script_dir() | ||||||
|  |  | ||||||
|  | print response.format(guid=feed.guid, | ||||||
|  |                       name=feed.name, | ||||||
|  |                       edit_url="%s/edit.cgi" % basedir, | ||||||
|  |                       base_url=basedir, | ||||||
|  |                       duration=', '.join(duration_list)) | ||||||
|  |                        | ||||||
							
								
								
									
										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" \ | ||||||
|  | ] | ||||||
							
								
								
									
										27
									
								
								samples/Shell/settime.cgi
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								samples/Shell/settime.cgi
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | #!/bin/bash | ||||||
|  | echo "Content-type: text/html" | ||||||
|  | day=`echo "$QUERY_STRING" | sed -n 's/^.*day=\([^&]*\).*$/\1/p' | sed "s/%20/ /g"` | ||||||
|  | month=`echo "$QUERY_STRING" | sed -n 's/^.*month=\([^&]*\).*$/\1/p' | sed "s/%20/ /g"` | ||||||
|  | year=`echo "$QUERY_STRING" | sed -n 's/^.*year=\([^&]*\).*$/\1/p' | sed "s/%20/ /g"` | ||||||
|  | hour=`echo "$QUERY_STRING" | sed -n 's/^.*hour=\([^&]*\).*$/\1/p' | sed "s/%20/ /g"` | ||||||
|  | minute=`echo "$QUERY_STRING" | sed -n 's/^.*minute=\([^&]*\).*$/\1/p' | sed "s/%20/ /g"` | ||||||
|  | second=`echo "$QUERY_STRING" | sed -n 's/^.*second=\([^&]*\).*$/\1/p' | sed "s/%20/ /g"` | ||||||
|  | echo "" | ||||||
|  | echo "<html><body>" | ||||||
|  |  | ||||||
|  | echo "<pre> $(killall ems) </pre>" | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | echo "<pre> $(date $month$day$hour$minute$year.$second) </pre>" | ||||||
|  |  | ||||||
|  | echo "<pre> $(/sbin/hwclock -w>/dev/null & /sbin/reboot) </pre>" | ||||||
|  |  | ||||||
|  | echo "<pre> $(/sbin/reboot) </pre>" | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | echo "</body></html>" | ||||||
							
								
								
									
										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? |     assert !blob("Perl/script.pl").binary? | ||||||
|   end |   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 |   def test_text | ||||||
|     assert blob("Text/README").text? |     assert blob("Text/README").text? | ||||||
|     assert blob("Text/dump.sql").text? |     assert blob("Text/dump.sql").text? | ||||||
| @@ -185,9 +192,9 @@ class TestBlob < Test::Unit::TestCase | |||||||
|     assert !blob("Text/README").generated? |     assert !blob("Text/README").generated? | ||||||
|  |  | ||||||
|     # Xcode project files |     # Xcode project files | ||||||
|     assert blob("XML/MainMenu.xib").generated? |     assert !blob("XML/MainMenu.xib").generated? | ||||||
|     assert blob("Binary/MainMenu.nib").generated? |     assert blob("Binary/MainMenu.nib").generated? | ||||||
|     assert blob("XML/project.pbxproj").generated? |     assert !blob("XML/project.pbxproj").generated? | ||||||
|  |  | ||||||
|     # Gemfile.locks |     # Gemfile.locks | ||||||
|     assert blob("Gemfile.lock").generated? |     assert blob("Gemfile.lock").generated? | ||||||
| @@ -255,6 +262,10 @@ class TestBlob < Test::Unit::TestCase | |||||||
|  |  | ||||||
|  |  | ||||||
|     assert Linguist::Generated.generated?("node_modules/grunt/lib/grunt.js", nil) |     assert Linguist::Generated.generated?("node_modules/grunt/lib/grunt.js", nil) | ||||||
|  |  | ||||||
|  |     # Godep saved dependencies | ||||||
|  |     assert blob("Godeps/Godeps.json").generated? | ||||||
|  |     assert blob("Godeps/_workspace/src/github.com/kr/s3/sign.go").generated? | ||||||
|   end |   end | ||||||
|  |  | ||||||
|   def test_vendored |   def test_vendored | ||||||
| @@ -272,12 +283,16 @@ class TestBlob < Test::Unit::TestCase | |||||||
|     assert blob("app/bower_components/custom/custom.js").vendored? |     assert blob("app/bower_components/custom/custom.js").vendored? | ||||||
|     assert blob("vendor/assets/bower_components/custom/custom.js").vendored? |     assert blob("vendor/assets/bower_components/custom/custom.js").vendored? | ||||||
|  |  | ||||||
|  |     # Go dependencies | ||||||
|  |     assert !blob("Godeps/Godeps.json").vendored? | ||||||
|  |     assert blob("Godeps/_workspace/src/github.com/kr/s3/sign.go").vendored? | ||||||
|  |  | ||||||
|     # Rails vendor/ |     # Rails vendor/ | ||||||
|     assert blob("vendor/plugins/will_paginate/lib/will_paginate.rb").vendored? |     assert blob("vendor/plugins/will_paginate/lib/will_paginate.rb").vendored? | ||||||
|  |  | ||||||
|     # 'thirdparty' directory |     # 'thirdparty' directory | ||||||
|     assert blob("thirdparty/lib/main.c").vendored? |     assert blob("thirdparty/lib/main.c").vendored? | ||||||
|      |  | ||||||
|     # 'extern(al)' directory |     # 'extern(al)' directory | ||||||
|     assert blob("extern/util/__init__.py").vendored? |     assert blob("extern/util/__init__.py").vendored? | ||||||
|     assert blob("external/jquery.min.js").vendored? |     assert blob("external/jquery.min.js").vendored? | ||||||
| @@ -386,6 +401,16 @@ class TestBlob < Test::Unit::TestCase | |||||||
|     # NuGet Packages |     # NuGet Packages | ||||||
|     assert blob("packages/Modernizr.2.0.6/Content/Scripts/modernizr-2.0.6-development-only.js").vendored? |     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? | ||||||
|  |  | ||||||
|  |     # Cocoapods | ||||||
|  |     assert blob('Pods/blah').vendored? | ||||||
|  |  | ||||||
|     # Html5shiv |     # Html5shiv | ||||||
|     assert blob("Scripts/html5shiv.js").vendored? |     assert blob("Scripts/html5shiv.js").vendored? | ||||||
|     assert blob("Scripts/html5shiv.min.js").vendored? |     assert blob("Scripts/html5shiv.min.js").vendored? | ||||||
| @@ -400,6 +425,11 @@ class TestBlob < Test::Unit::TestCase | |||||||
|     assert blob("cordova-2.1.0.js").vendored? |     assert blob("cordova-2.1.0.js").vendored? | ||||||
|     assert blob("cordova-2.1.0.min.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 |     # Vagrant | ||||||
|     assert blob("Vagrantfile").vendored? |     assert blob("Vagrantfile").vendored? | ||||||
|  |  | ||||||
| @@ -415,6 +445,12 @@ class TestBlob < Test::Unit::TestCase | |||||||
|     assert blob("octicons.css").vendored? |     assert blob("octicons.css").vendored? | ||||||
|     assert blob("public/octicons.min.css").vendored? |     assert blob("public/octicons.min.css").vendored? | ||||||
|     assert blob("public/octicons/sprockets-octicons.scss").vendored? |     assert blob("public/octicons/sprockets-octicons.scss").vendored? | ||||||
|  |  | ||||||
|  |     # Typesafe Activator | ||||||
|  |     assert blob("activator").vendored? | ||||||
|  |     assert blob("activator.bat").vendored? | ||||||
|  |     assert blob("subproject/activator").vendored? | ||||||
|  |     assert blob("subproject/activator.bat").vendored? | ||||||
|   end |   end | ||||||
|  |  | ||||||
|   def test_language |   def test_language | ||||||
|   | |||||||
| @@ -44,12 +44,12 @@ class TestClassifier < Test::Unit::TestCase | |||||||
|   end |   end | ||||||
|  |  | ||||||
|   def test_instance_classify_empty |   def test_instance_classify_empty | ||||||
|     results = Classifier.classify(Samples::DATA, "") |     results = Classifier.classify(Samples.cache, "") | ||||||
|     assert results.first[1] < 0.5, results.first.inspect |     assert results.first[1] < 0.5, results.first.inspect | ||||||
|   end |   end | ||||||
|  |  | ||||||
|   def test_instance_classify_nil |   def test_instance_classify_nil | ||||||
|     assert_equal [], Classifier.classify(Samples::DATA, nil) |     assert_equal [], Classifier.classify(Samples.cache, nil) | ||||||
|   end |   end | ||||||
|  |  | ||||||
|   def test_classify_ambiguous_languages |   def test_classify_ambiguous_languages | ||||||
| @@ -58,7 +58,7 @@ class TestClassifier < Test::Unit::TestCase | |||||||
|       languages = Language.find_by_filename(sample[:path]).map(&:name) |       languages = Language.find_by_filename(sample[:path]).map(&:name) | ||||||
|       next unless languages.length > 1 |       next unless languages.length > 1 | ||||||
|  |  | ||||||
|       results = Classifier.classify(Samples::DATA, File.read(sample[:path]), languages) |       results = Classifier.classify(Samples.cache, File.read(sample[:path]), languages) | ||||||
|       assert_equal language.name, results.first[0], "#{sample[:path]}\n#{results.inspect}" |       assert_equal language.name, results.first[0], "#{sample[:path]}\n#{results.inspect}" | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
|   | |||||||
| @@ -17,6 +17,7 @@ class TestLanguage < Test::Unit::TestCase | |||||||
|     assert_equal Lexer['C'], Language['OpenCL'].lexer |     assert_equal Lexer['C'], Language['OpenCL'].lexer | ||||||
|     assert_equal Lexer['C'], Language['XS'].lexer |     assert_equal Lexer['C'], Language['XS'].lexer | ||||||
|     assert_equal Lexer['C++'], Language['C++'].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['Coldfusion HTML'], Language['ColdFusion'].lexer | ||||||
|     assert_equal Lexer['Coq'], Language['Coq'].lexer |     assert_equal Lexer['Coq'], Language['Coq'].lexer | ||||||
|     assert_equal Lexer['FSharp'], Language['F#'].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['ChucK'].lexer | ||||||
|     assert_equal Lexer['Java'], Language['Java'].lexer |     assert_equal Lexer['Java'], Language['Java'].lexer | ||||||
|     assert_equal Lexer['JavaScript'], Language['JavaScript'].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['MOOCode'], Language['Moocode'].lexer | ||||||
|     assert_equal Lexer['MuPAD'], Language['mupad'].lexer |     assert_equal Lexer['MuPAD'], Language['mupad'].lexer | ||||||
|     assert_equal Lexer['NASM'], Language['Assembly'].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['Mirah'].lexer | ||||||
|     assert_equal Lexer['Ruby'], Language['Ruby'].lexer |     assert_equal Lexer['Ruby'], Language['Ruby'].lexer | ||||||
|     assert_equal Lexer['S'], Language['R'].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['Scheme'], Language['Nu'].lexer | ||||||
|     assert_equal Lexer['Racket'], Language['Racket'].lexer |     assert_equal Lexer['Racket'], Language['Racket'].lexer | ||||||
|     assert_equal Lexer['Scheme'], Language['Scheme'].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('c++') |     assert_equal Language['C++'], Language.find_by_alias('c++') | ||||||
|     assert_equal Language['C++'], Language.find_by_alias('cpp') |     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') | ||||||
|     assert_equal Language['CoffeeScript'], Language.find_by_alias('coffee-script') |     assert_equal Language['CoffeeScript'], Language.find_by_alias('coffee-script') | ||||||
|     assert_equal Language['ColdFusion'], Language.find_by_alias('cfm') |     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 'pot',           Language['Gettext Catalog'].search_term | ||||||
|     assert_equal 'irc',           Language['IRC log'].search_term |     assert_equal 'irc',           Language['IRC log'].search_term | ||||||
|     assert_equal 'lhs',           Language['Literate Haskell'].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 'raw',           Language['Raw token data'].search_term | ||||||
|     assert_equal 'bash',          Language['Shell'].search_term |     assert_equal 'bash',          Language['Shell'].search_term | ||||||
|     assert_equal 'vim',           Language['VimL'].search_term |     assert_equal 'vim',           Language['VimL'].search_term | ||||||
| @@ -185,6 +187,7 @@ class TestLanguage < Test::Unit::TestCase | |||||||
|  |  | ||||||
|   def test_programming |   def test_programming | ||||||
|     assert_equal :programming, Language['JavaScript'].type |     assert_equal :programming, Language['JavaScript'].type | ||||||
|  |     assert_equal :programming, Language['LSL'].type | ||||||
|     assert_equal :programming, Language['Perl'].type |     assert_equal :programming, Language['Perl'].type | ||||||
|     assert_equal :programming, Language['PowerShell'].type |     assert_equal :programming, Language['PowerShell'].type | ||||||
|     assert_equal :programming, Language['Python'].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 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 ['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('.rb') |     assert_equal [], Language.find_by_filename('.null') | ||||||
|     assert_equal [], Language.find_by_filename('.nkt') |  | ||||||
|     assert_equal [Language['Shell']], Language.find_by_filename('.bashrc') |     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('bash_profile') | ||||||
|     assert_equal [Language['Shell']], Language.find_by_filename('.zshrc') |     assert_equal [Language['Shell']], Language.find_by_filename('.zshrc') | ||||||
|     assert_equal [Language['Clojure']], Language.find_by_filename('riemann.config') |     assert_equal [Language['Clojure']], Language.find_by_filename('riemann.config') | ||||||
|     assert_equal [Language['HTML+Django']], Language.find_by_filename('index.jinja') |     assert_equal [Language['HTML+Django']], Language.find_by_filename('index.jinja') | ||||||
|  |     assert_equal [Language['Chapel']], Language.find_by_filename('examples/hello.chpl') | ||||||
|   end |   end | ||||||
|  |  | ||||||
|   def test_find_by_shebang |   def test_find_by_shebang | ||||||
| @@ -325,6 +328,7 @@ class TestLanguage < Test::Unit::TestCase | |||||||
|     assert_equal '#3581ba', Language['Python'].color |     assert_equal '#3581ba', Language['Python'].color | ||||||
|     assert_equal '#f1e05a', Language['JavaScript'].color |     assert_equal '#f1e05a', Language['JavaScript'].color | ||||||
|     assert_equal '#31859c', Language['TypeScript'].color |     assert_equal '#31859c', Language['TypeScript'].color | ||||||
|  |     assert_equal '#3d9970', Language['LSL'].color | ||||||
|   end |   end | ||||||
|  |  | ||||||
|   def test_colors |   def test_colors | ||||||
| @@ -337,6 +341,7 @@ class TestLanguage < Test::Unit::TestCase | |||||||
|     assert_equal 'coffee', Language['CoffeeScript'].ace_mode |     assert_equal 'coffee', Language['CoffeeScript'].ace_mode | ||||||
|     assert_equal 'csharp', Language['C#'].ace_mode |     assert_equal 'csharp', Language['C#'].ace_mode | ||||||
|     assert_equal 'css', Language['CSS'].ace_mode |     assert_equal 'css', Language['CSS'].ace_mode | ||||||
|  |     assert_equal 'lsl', Language['LSL'].ace_mode | ||||||
|     assert_equal 'javascript', Language['JavaScript'].ace_mode |     assert_equal 'javascript', Language['JavaScript'].ace_mode | ||||||
|   end |   end | ||||||
|  |  | ||||||
| @@ -351,6 +356,7 @@ class TestLanguage < Test::Unit::TestCase | |||||||
|   end |   end | ||||||
|  |  | ||||||
|   def test_extensions |   def test_extensions | ||||||
|  |     assert Language['LSL'].extensions.include?('.lsl') | ||||||
|     assert Language['Perl'].extensions.include?('.pl') |     assert Language['Perl'].extensions.include?('.pl') | ||||||
|     assert Language['Python'].extensions.include?('.py') |     assert Language['Python'].extensions.include?('.py') | ||||||
|     assert Language['Ruby'].extensions.include?('.rb') |     assert Language['Ruby'].extensions.include?('.rb') | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| require 'linguist/repository' | require 'linguist/repository' | ||||||
|  | require 'linguist/lazy_blob' | ||||||
| require 'test/unit' | require 'test/unit' | ||||||
|  |  | ||||||
| class TestRepository < Test::Unit::TestCase | class TestRepository < Test::Unit::TestCase | ||||||
| @@ -47,4 +47,45 @@ class TestRepository < Test::Unit::TestCase | |||||||
|  |  | ||||||
|     assert_equal linguist_repo.cache, new_repo.cache |     assert_equal linguist_repo.cache, new_repo.cache | ||||||
|   end |   end | ||||||
|  |  | ||||||
|  |   def test_repo_git_attributes | ||||||
|  |     # See https://github.com/github/linguist/blob/351c1cc8fd57340839bdb400d7812332af80e9bd/.gitattributes | ||||||
|  |     # | ||||||
|  |     # It looks like this: | ||||||
|  |     # Gemfile linguist-vendored=true | ||||||
|  |     # lib/linguist.rb linguist-language=Java | ||||||
|  |     # test/*.rb linguist-language=Java | ||||||
|  |     # Rakefile linguist-generated | ||||||
|  |     # test/fixtures/* linguist-vendored=false | ||||||
|  |  | ||||||
|  |     attr_commit = '351c1cc8fd57340839bdb400d7812332af80e9bd' | ||||||
|  |     repo = linguist_repo(attr_commit) | ||||||
|  |  | ||||||
|  |     assert repo.breakdown_by_file.has_key?("Java") | ||||||
|  |     assert repo.breakdown_by_file["Java"].include?("lib/linguist.rb") | ||||||
|  |  | ||||||
|  |     assert repo.breakdown_by_file.has_key?("Ruby") | ||||||
|  |     assert !repo.breakdown_by_file["Ruby"].empty? | ||||||
|  |   end | ||||||
|  |  | ||||||
|  |   def test_linguist_override_vendored? | ||||||
|  |     attr_commit = '351c1cc8fd57340839bdb400d7812332af80e9bd' | ||||||
|  |     repo = linguist_repo(attr_commit).read_index | ||||||
|  |  | ||||||
|  |     override_vendored = Linguist::LazyBlob.new(rugged_repository, attr_commit, 'Gemfile') | ||||||
|  |  | ||||||
|  |     # overridden .gitattributes | ||||||
|  |     assert override_vendored.vendored? | ||||||
|  |   end | ||||||
|  |  | ||||||
|  |   def test_linguist_override_unvendored? | ||||||
|  |     attr_commit = '351c1cc8fd57340839bdb400d7812332af80e9bd' | ||||||
|  |     repo = linguist_repo(attr_commit).read_index | ||||||
|  |  | ||||||
|  |     # lib/linguist/vendor.yml defines this as vendored. | ||||||
|  |     override_unvendored = Linguist::LazyBlob.new(rugged_repository, attr_commit, 'test/fixtures/foo.rb') | ||||||
|  |  | ||||||
|  |     # overridden .gitattributes | ||||||
|  |     assert !override_unvendored.vendored? | ||||||
|  |   end | ||||||
| end | end | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ class TestSamples < Test::Unit::TestCase | |||||||
|   include Linguist |   include Linguist | ||||||
|  |  | ||||||
|   def test_up_to_date |   def test_up_to_date | ||||||
|     assert serialized = Samples::DATA |     assert serialized = Samples.cache | ||||||
|     assert latest = Samples.data |     assert latest = Samples.data | ||||||
|  |  | ||||||
|     # Just warn, it shouldn't scare people off by breaking the build. |     # Just warn, it shouldn't scare people off by breaking the build. | ||||||
| @@ -29,21 +29,39 @@ class TestSamples < Test::Unit::TestCase | |||||||
|   end |   end | ||||||
|  |  | ||||||
|   def test_verify |   def test_verify | ||||||
|     assert data = Samples::DATA |     assert data = Samples.cache | ||||||
|  |  | ||||||
|     assert_equal data['languages_total'], data['languages'].inject(0) { |n, (_, c)| n += c } |     assert_equal data['languages_total'], data['languages'].inject(0) { |n, (_, c)| n += c } | ||||||
|     assert_equal data['tokens_total'], data['language_tokens'].inject(0) { |n, (_, c)| n += c } |     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 } } |     assert_equal data['tokens_total'], data['tokens'].inject(0) { |n, (_, ts)| n += ts.inject(0) { |m, (_, c)| m += c } } | ||||||
|   end |   end | ||||||
|    |  | ||||||
|  |   # Check that there aren't samples with extensions that aren't explicitly defined in languages.yml | ||||||
|  |   def test_parity | ||||||
|  |     extensions = Samples.cache['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 |   # If a language extension isn't globally unique then make sure there are samples | ||||||
|   def test_presence |   def test_presence | ||||||
|     Linguist::Language.all.each do |language| |     Linguist::Language.all.each do |language| | ||||||
|       language.all_extensions.each do |extension| |       language.all_extensions.each do |extension| | ||||||
|         language_matches = Language.find_by_filename("foo#{extension}") |         language_matches = Language.find_by_filename("foo#{extension}") | ||||||
|          |  | ||||||
|         # If there is more than one language match for a given 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 |         if language_matches.length > 1 | ||||||
|           language_matches.each do |language| |           language_matches.each do |language| | ||||||
|             assert File.directory?("samples/#{language.name}"), "#{language.name} is missing a samples directory" |             assert File.directory?("samples/#{language.name}"), "#{language.name} is missing a samples directory" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user