Share via


SPContentType.ResourceFolder property

Gets the content type's resource folder.

Namespace:  Microsoft.SharePoint
Assembly:  Microsoft.SharePoint (in Microsoft.SharePoint.dll)

Syntax

'Declaration
Public ReadOnly Property ResourceFolder As SPFolder
    Get
'Usage
Dim instance As SPContentType
Dim value As SPFolder

value = instance.ResourceFolder
public SPFolder ResourceFolder { get; }

Property value

Type: Microsoft.SharePoint.SPFolder
The resource folder.

Remarks

The resource folder is the storage location for any file, such as a document template, that is used by the content type.

Examples

The following example is a console application that displays information about the resource folder for every content type on every list in a Web site. As it iterates through the lists and their content types, the application collects the total size of files in each resource folder and prints an accumulated total to the console at the end of the run.

Imports System
Imports Microsoft.SharePoint

Module Test
   Sub Main()
      Using site As SPSite = New SPSite("https://localhost")
         Using web As SPWeb = site.OpenWeb()
            Dim resourceSize As Long = 0
            For Each list As SPList In web.Lists
               For Each ct As SPContentType In list.ContentTypes
                  resourceSize += ResourceFolderInfo(list, ct)
               Next ct
            Next list
            Console.WriteLine(vbCrLf + "Total size of files in all resource folders = {0} bytes", resourceSize.ToString())
         End Using
      End Using
      Console.Write(vbCrLf + "Press ENTER to continue...")
      Console.ReadLine()
   End Sub

   Private Function ResourceFolderInfo(ByRef list As SPList, ByRef ct As SPContentType) As Long
      If list Is Nothing OrElse ct Is Nothing Then
         Throw New ArgumentException()
      End If

      Dim fldr As SPFolder = ct.ResourceFolder
      Dim total As Long = 0

      Console.WriteLine(vbCrLf + "Content type name: {0}", ct.Name)
      Console.WriteLine("Relative path to resource folder: {0}", fldr.ServerRelativeUrl)

      Console.Write("Files in folder:")
      For Each file As SPFile In fldr.Files
         Console.WriteLine(" {0}", file.Name)
         total += file.Length
      Next file

      Console.WriteLine()
      Return total
   End Function

End Module
using System;
using Microsoft.SharePoint;

namespace Test
{
   class ConsoleApp
   {
      static void Main(string[] args)
      {
         using (SPSite site = new SPSite("https://localhost"))
         {
            using (SPWeb web = site.OpenWeb())
            {
               long resourceSize = 0;
               foreach (SPList list in web.Lists)
               {
                  foreach (SPContentType ct in list.ContentTypes)
                  {
                    resourceSize += ResourceFolderInfo(list, ct);
                  }
               }
               Console.WriteLine("\nTotal size of files in all resource folders = {0} bytes", resourceSize.ToString());
            }
         }
         Console.Write("\nPress ENTER to continue...");
         Console.ReadLine();
      }

      private static long ResourceFolderInfo(SPList list, SPContentType ct)
      {
         if (list == null || ct == null)
            throw new ArgumentException();

         SPFolder fldr = ct.ResourceFolder;
         long total = 0;

         Console.WriteLine("\nContent type name: {0}", ct.Name);
         Console.WriteLine("Relative path to resource folder: {0}", fldr.ServerRelativeUrl);
         
         Console.Write("Files in folder:");
         foreach (SPFile file in fldr.Files)
         {
            Console.WriteLine(" {0}", file.Name);
            total += file.Length;
         }

         Console.WriteLine();
         return total;
      }
   }
}

See also

Reference

SPContentType class

SPContentType members

Microsoft.SharePoint namespace

DocumentTemplateUrl

Other resources

Introduction to Content Types

Site and List Content Types

Base Content Type Hierarchy