Class: Albacore::NugetModel::Package

Inherits:
Object
  • Object
show all
Extended by:
Logging
Includes:
Logging
Defined in:
lib/albacore/nuget_model.rb

Overview

the nuget package element writer

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods included from Logging

debug, err, error, fatal, info, puts, trace, warn

Constructor Details

#initialize(metadata = nil, files = nil) ⇒ Package

creates a new nuspec package instance



231
232
233
234
# File 'lib/albacore/nuget_model.rb', line 231

def initialize  = nil, files = nil
  @metadata =  || Metadata.new
  @files = files || []
end

Instance Attribute Details

#filesObject

the files is something enumerable that corresponds to the file elements inside ‘//package/files’.



228
229
230
# File 'lib/albacore/nuget_model.rb', line 228

def files
  @files
end

#metadataObject

the metadata corresponds to the metadata element of the nuspec



224
225
226
# File 'lib/albacore/nuget_model.rb', line 224

def 
  @metadata
end

Class Method Details

.from_xml(xml) ⇒ Object

read the nuget specification from a nuspec file



310
311
312
313
314
315
316
317
318
319
320
# File 'lib/albacore/nuget_model.rb', line 310

def self.from_xml xml
  ns = { ng: 'http://schemas.microsoft.com/packaging/2010/07/nuspec.xsd' }
  parser = Nokogiri::XML(xml)
  meta = Metadata.from_xml(parser.xpath('.//ng:metadata', ns))
  files = parser.
    xpath('.//ng:files', ns).
    children.
    reject { |n| n.text? or n['src'].nil? }.
    collect { |n| FileItem.new n['src'], n['target'], n['exclude'] }
  Package.new meta, files
end

.from_xxproj(proj, *opts) ⇒ Object

Read the nuget specification from a xxproj instance (e.g. csproj, fsproj) Options:

- symbols
- dotnet_version
 Specifies the version to use for constructing the nuspec's lib folder
- known_projects
- configuration
- project_dependencies
 Specifies whether to follow the project dependencies. See nuget_model_spec.rb
 for examples of usage of this property.
- nuget_dependencies


339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
# File 'lib/albacore/nuget_model.rb', line 339

def self.from_xxproj proj, *opts
  opts = Map.options(opts || {}).
    apply({
      symbols:              false,
      dotnet_version:       'net40',
      known_projects:       Set.new,
      configuration:        'Debug',
      project_dependencies: true,
      verify_files:         false,
      nuget_dependencies:   true })

  trace { "#from_xxproj proj: #{proj} opts: #{opts} [nuget model: package]" }

  version = opts.get :version
  package = Package.new
  package..id = proj.name if proj.name
  package..version = version if version
  package..authors = proj.authors if proj.authors

  if opts.get :nuget_dependencies
    # add declared packages as dependencies
    proj.declared_packages.each do |p|
      package..add_dependency p.id, p.version
    end
  end

  if opts.get :project_dependencies
    # add declared projects as dependencies
    proj.
      declared_projects.
      keep_if { |p| opts.get(:known_projects).include? p.name }.
      each do |p|
      debug "adding project dependency: #{proj.name} => #{p.name} at #{version} [nuget model: package]"
      package..add_dependency p.name, version
    end
  end

  output = get_output_path proj, opts
  target_lib = %W[lib #{opts.get(:dotnet_version)}].join(Albacore::Paths.separator)

  if opts.get :symbols 
    compile_files = proj.included_files.keep_if { |f| f.item_name == "compile" }

    debug "add compiled files: #{compile_files} [nuget model: package]"
    compile_files.each do |f|
      target = %W[src #{Albacore::Paths.normalise_slashes(f.include)}].join(Albacore::Paths.separator)
      package.add_file f.include, target
    end 

    debug "add dll and pdb files [nuget model: package]"
    package.add_file(Albacore::Paths.normalise_slashes(output + proj.asmname + '.pdb'), target_lib)
    package.add_file(Albacore::Paths.normalise_slashes(output + proj.asmname + '.dll'), target_lib)
  else
    # add *.{dll,xml,config}
    %w[dll xml config].each do |ext|
      file = %W{#{output} #{proj.asmname}.#{ext}}.
        map { |f| f.gsub /\\$/, '' }.
        map { |f| Albacore::Paths.normalise_slashes f }.
        join(Albacore::Paths.separator)
      debug "adding binary file #{file} [nuget model: package]"
      package.add_file file, target_lib
    end
  end

  if opts.get :verify_files
    package.files.each do |file|
      file_path = File.expand_path file.src, proj.proj_path_base
      unless File.exists? file_path
        info "while building nuspec for proj: #{proj.name}, file: #{file_path} => #{file.target} not found, removing from nuspec [nuget model: package]"
        package.remove_file file.src
        trace { "files: #{package.files.map { |f| f.src }.inspect} [nuget model: package]" }
      end
    end
  end

  package
end

.from_xxproj_file(file, *opts) ⇒ Object

read the nuget specification from a xxproj file (e.g. csproj, fsproj)



323
324
325
326
# File 'lib/albacore/nuget_model.rb', line 323

def self.from_xxproj_file file, *opts
  proj = Albacore::Project.new file
  from_xxproj proj, *opts
end

.get_output_path(proj, opts) ⇒ Object



416
417
418
419
420
421
# File 'lib/albacore/nuget_model.rb', line 416

def self.get_output_path proj, opts
  try = proj.try_output_path(opts.get(:configuration))
  return try if try
  warn 'using fallback output path'
  proj.fallback_output_path
end

Instance Method Details

#add_file(src, target, exclude = nil) ⇒ Object

add a file to the instance



237
238
239
240
# File 'lib/albacore/nuget_model.rb', line 237

def add_file src, target, exclude = nil
  @files << FileItem.new(src, target, exclude)
  self
end

#merge_with(other) ⇒ Object

creates a new Package/Metadata by overriding data in this instance with data from passed instance



286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
# File 'lib/albacore/nuget_model.rb', line 286

def merge_with other
  m_next = @metadata.merge_with other.
  files_res = {}

  # my files
  @files.each { |f| files_res[f.src] = f }

  # overrides
  other.files.each { |f| files_res[f.src] = f }

  # result
  f_next = files_res.collect { |k, v| v }

  Package.new m_next, f_next
end

#remove_file(src) ⇒ Object

remove the file denoted by src



243
244
245
246
247
# File 'lib/albacore/nuget_model.rb', line 243

def remove_file src
  src = src.src if src.respond_to? :src # if passed an OpenStruct e.g.
  trace { "remove_file: removing file '#{src}' [nuget model: package]" }
  @files = @files.reject { |f| f.src == src }
end

#to_sObject



302
303
304
# File 'lib/albacore/nuget_model.rb', line 302

def to_s
  "NugetModel::Package(files: #{@files.map(&:to_s)}, metadata: #{ @metadata.to_s })"
end

#to_xmlObject

gets the current package as a xml node



280
281
282
# File 'lib/albacore/nuget_model.rb', line 280

def to_xml
  to_xml_builder.to_xml
end

#to_xml_builderObject

gets the current package as a xml builder



257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
# File 'lib/albacore/nuget_model.rb', line 257

def to_xml_builder
  md = Nokogiri::XML(@metadata.to_xml).at_css('metadata').to_xml
  Nokogiri::XML::Builder.new(encoding: 'utf-8') do |x|
    x.package(xmlns: 'http://schemas.microsoft.com/packaging/2010/07/nuspec.xsd') {
      x << md
      #x.__send__ :insert, md.at_css("metadata")
#           x << md.at_css("metadata").to_xml(indent: 4)
      unless @files.empty?
        x.files {
          @files.each do |f|
            if f.exclude
              x.file src: f.src, target: f.target, exclude: f.exclude
            else
              x.file src: f.src, target: f.target
            end
          end
        }
      end
    }
  end
end

#with_metadata {|@metadata| ... } ⇒ Object

do something with the metadata. returns the #self Package instance

Yields:



251
252
253
254
# File 'lib/albacore/nuget_model.rb', line 251

def  &block
  yield @metadata if block_given?
  self
end